first commit

This commit is contained in:
2024-04-19 14:04:41 +07:00
commit 014283036f
7282 changed files with 1324127 additions and 0 deletions

View File

@@ -0,0 +1,10 @@
<?php
namespace App\Http\Controllers;
use Laravel\Lumen\Routing\Controller as BaseController;
class Controller extends BaseController
{
//
}

View File

@@ -0,0 +1,18 @@
<?php
namespace App\Http\Controllers;
class ExampleController extends Controller
{
/**
* Create a new controller instance.
*
* @return void
*/
public function __construct()
{
//
}
//
}

View File

@@ -0,0 +1,479 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use Auth;
class IcdController extends Controller
{
public function __construct(Request $request)
{
// $this->middleware('auth:api');
if(null == $request->header('x-token'))
{
return response()->json(['error' => 'Unauthorized'], 401);
}
$user = DB::table('webservice')->where('token',$request->header('x-token'))->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
}
public function rajalDiagFiltered($tgl_awal,$tgl_akhir,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
// $tgl_awal = urldecode($tgl_awal);
// $tgl_akhir = urldecode($tgl_akhir);
$incovit = DB::table('m_ruang')->select('no')->where([
['kelompok','=','IGD'],
['st_aktif','=',1]
])->get();
$arr_incovit = [];
foreach ($incovit as $row) {
$arr_incovit[] = $row->no;
}
if(null == $tgl_awal || null == $tgl_akhir)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
$result = DB::table('t_icd')
->join('icd','t_icd.icd','=','icd.icd_code')
->join('m_dokter','m_dokter.kddokter','=','t_icd.kddokter')
->join('t_pendaftaran','t_icd.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->select(DB::raw('t_icd.tanggal,m_ruang.nama as namaruang,icd.icd_code, icd.jenis_penyakit,m_dokter.namadokter,count(*) as jml'))
->where([
['status_rajal','=',1],
])
->whereNotIn('t_pendaftaran.kdpoly',$arr_incovit)
->whereBetween('t_icd.tanggal',[$tgl_awal,$tgl_akhir])
->groupBy('t_icd.tanggal','icd.icd_code','m_dokter.namadokter','m_ruang.nama')
->get();
// return $result;
$arr_result = [];
$i = 0;
foreach($result->all() as $key => $detil)
{
$row_detil = DB::table('t_icd')
->join('icd','t_icd.icd','=','icd.icd_code')
->join('m_dokter','m_dokter.kddokter','=','t_icd.kddokter')
->join('t_pendaftaran','t_icd.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->join('m_pasien','m_pasien.nomr','=','t_pendaftaran.nomr')
->leftJoin('m_statuskeluar','t_pendaftaran.status','=','m_statuskeluar.status')
->select(DB::raw('m_pasien.jeniskelamin,age(m_pasien.tgllahir) as usia,m_statuskeluar.keterangan as status_keluar'))
->where([
['status_rajal','=',1],
['m_ruang.nama','=',$detil->namaruang],
['icd.icd_code','=',$detil->icd_code],
['m_dokter.namadokter','=',$detil->namadokter],
['t_icd.tanggal','=',$detil->tanggal],
])
->whereNotIn('t_pendaftaran.kdpoly',$arr_incovit)
->get();
$set_result = collect($result[$key]);
// $set_result->pull('jml');
$set_result['pasien'] = $row_detil->all();
$arr_result[] = $set_result->all();
$result->forget($key);
$i++;
}
return response()->json($arr_result);
}
public function igdDiagFiltered($tgl_awal,$tgl_akhir,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
// $tgl_awal = urldecode($tgl_awal);
// $tgl_akhir = urldecode($tgl_akhir);
$incovit = DB::table('m_ruang')->select('no')->where([
['kelompok','=','IGD'],
['st_aktif','=',1]
])->get();
$arr_incovit = [];
foreach ($incovit as $row) {
$arr_incovit[] = $row->no;
}
if(null == $tgl_awal || null == $tgl_akhir)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
$result = DB::table('t_icd')
->join('icd','t_icd.icd','=','icd.icd_code')
->join('m_dokter','m_dokter.kddokter','=','t_icd.kddokter')
->join('t_pendaftaran','t_icd.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->select(DB::raw('t_icd.tanggal,icd.icd_code, m_ruang.nama as namaruang,icd.jenis_penyakit,m_dokter.namadokter,count(*) as jml'))
->where([
['status_rajal','=',1],
])
->whereIn('t_pendaftaran.kdpoly',$arr_incovit)
->whereBetween('t_icd.tanggal',[$tgl_awal,$tgl_akhir])
->groupBy('t_icd.tanggal','icd.icd_code','m_ruang.nama','m_dokter.namadokter')
->get();
// return $result;
$arr_result = [];
$i = 0;
foreach($result->all() as $key => $detil)
{
$row_detil = DB::table('t_icd')
->join('icd','t_icd.icd','=','icd.icd_code')
->join('m_dokter','m_dokter.kddokter','=','t_icd.kddokter')
->join('t_pendaftaran','t_icd.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->join('m_pasien','m_pasien.nomr','=','t_pendaftaran.nomr')
->leftJoin('m_statuskeluar','t_pendaftaran.status','=','m_statuskeluar.status')
->select(DB::raw('m_pasien.jeniskelamin,age(m_pasien.tgllahir) as usia,m_statuskeluar.keterangan as status_keluar'))
->where([
['status_rajal','=',1],
['m_ruang.nama','=',$detil->namaruang],
['icd.icd_code','=',$detil->icd_code],
['m_dokter.namadokter','=',$detil->namadokter],
['t_icd.tanggal','=',$detil->tanggal],
])
->whereIn('t_pendaftaran.kdpoly',$arr_incovit)
->get();
$set_result = collect($result[$key]);
// $set_result->pull('jml');
$set_result['pasien'] = $row_detil->all();
$arr_result[] = $set_result->all();
$result->forget($key);
$i++;
}
return response()->json($arr_result);
}
public function ranapDiagFiltered($tgl_awal,$tgl_akhir,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
// $tgl_awal = urldecode($tgl_awal);
// $tgl_akhir = urldecode($tgl_akhir);
if(null == $tgl_awal || null == $tgl_akhir)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
$result = DB::table('t_icd')
->join('icd','t_icd.icd','=','icd.icd_code')
->join('m_dokter','m_dokter.kddokter','=','t_icd.kddokter')
->join('t_admission','t_icd.idxdaftar','=','t_admission.id_admission')
->join('m_ruang','m_ruang.no','=','t_admission.noruang')
->select(DB::raw('t_icd.tanggal,m_ruang.kelompok,m_ruang.nama as namaruang,icd.icd_code, icd.jenis_penyakit,m_dokter.namadokter,count(*) as jml'))
->where([
['status_rajal','=',0],
])
->whereBetween('t_icd.tanggal',[$tgl_awal,$tgl_akhir])
->groupBy('t_icd.tanggal','icd.icd_code','m_dokter.namadokter','m_ruang.kelompok','m_ruang.nama')
->get();
// return $result;
$arr_result = [];
$i = 0;
foreach($result->all() as $key => $detil)
{
$row_detil = DB::table('t_icd')
->join('icd','t_icd.icd','=','icd.icd_code')
->join('m_dokter','m_dokter.kddokter','=','t_icd.kddokter')
->join('t_admission','t_icd.idxdaftar','=','t_admission.id_admission')
->join('m_ruang','m_ruang.no','=','t_admission.noruang')
->join('m_pasien','m_pasien.nomr','=','t_admission.nomr')
->leftJoin('t_resumepulang','t_resumepulang.idadmission','=','t_admission.id_admission')
->leftJoin('m_statuskeluarranap','m_statuskeluarranap.kode','=','t_resumepulang.statuspulang')
->select(DB::raw('m_pasien.jeniskelamin,age(m_pasien.tgllahir) as usia,m_statuskeluarranap.nama as status_keluar'))
->where([
['status_rajal','=',0],
['m_ruang.nama','=',$detil->namaruang],
['icd.icd_code','=',$detil->icd_code],
['m_dokter.namadokter','=',$detil->namadokter],
['t_icd.tanggal','=',$detil->tanggal],
])
->get();
$set_result = collect($result[$key]);
// $set_result->pull('jml');
$set_result['pasien'] = $row_detil->all();
$arr_result[] = $set_result->all();
$result->forget($key);
$i++;
}
return response()->json($arr_result);
}
public function rajalTindakanFiltered($tgl_awal,$tgl_akhir,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
// $tgl_awal = urldecode($tgl_awal);
// $tgl_akhir = urldecode($tgl_akhir);
$incovit = DB::table('m_ruang')->select('no')->where([
['kelompok','=','IGD'],
['st_aktif','=',1]
])->get();
$arr_incovit = [];
foreach ($incovit as $row) {
$arr_incovit[] = $row->no;
}
if(null == $tgl_awal || null == $tgl_akhir)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
$result = DB::table('t_icd_cm')
->join('icd_cm','t_icd_cm.icd','=','icd_cm.kode')
->join('m_dokter','m_dokter.kddokter','=','t_icd_cm.kddokter')
->join('t_pendaftaran','t_icd_cm.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->select(DB::raw('t_icd_cm.tanggal,m_ruang.nama as namaruang,icd_cm.kode, icd_cm.keterangan,m_dokter.namadokter,count(*) as jml'))
->where([
['status_rajal','=',1],
])
->whereNotIn('t_pendaftaran.kdpoly',$arr_incovit)
->whereBetween('t_icd_cm.tanggal',[$tgl_awal,$tgl_akhir])
->groupBy('t_icd_cm.tanggal','icd_cm.kode','m_dokter.namadokter','m_ruang.nama')
->get();
// return $result;
$arr_result = [];
$i = 0;
foreach($result->all() as $key => $detil)
{
$row_detil = DB::table('t_icd_cm')
->join('icd_cm','t_icd_cm.icd','=','icd_cm.kode')
->join('m_dokter','m_dokter.kddokter','=','t_icd_cm.kddokter')
->join('t_pendaftaran','t_icd_cm.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->join('m_pasien','m_pasien.nomr','=','t_pendaftaran.nomr')
->leftJoin('m_statuskeluar','t_pendaftaran.status','=','m_statuskeluar.status')
->select(DB::raw('m_pasien.jeniskelamin,age(m_pasien.tgllahir) as usia,m_statuskeluar.keterangan as status_keluar'))
->where([
['status_rajal','=',1],
['m_ruang.nama','=',$detil->namaruang],
['icd_cm.kode','=',$detil->kode],
['m_dokter.namadokter','=',$detil->namadokter],
['t_icd_cm.tanggal','=',$detil->tanggal],
])
->whereNotIn('t_pendaftaran.kdpoly',$arr_incovit)
->get();
$set_result = collect($result[$key]);
// $set_result->pull('jml');
$set_result['pasien'] = $row_detil->all();
$arr_result[] = $set_result->all();
$result->forget($key);
$i++;
}
return response()->json($arr_result);
}
public function igdTindakanFiltered($tgl_awal,$tgl_akhir,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
// $tgl_awal = urldecode($tgl_awal);
// $tgl_akhir = urldecode($tgl_akhir);
$incovit = DB::table('m_ruang')->select('no')->where([
['kelompok','=','IGD'],
['st_aktif','=',1]
])->get();
$arr_incovit = [];
foreach ($incovit as $row) {
$arr_incovit[] = $row->no;
}
if(null == $tgl_awal || null == $tgl_akhir)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
$result = DB::table('t_icd_cm')
->join('icd_cm','t_icd_cm.icd','=','icd_cm.kode')
->join('m_dokter','m_dokter.kddokter','=','t_icd_cm.kddokter')
->join('t_pendaftaran','t_icd_cm.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->select(DB::raw('t_icd_cm.tanggal,icd_cm.kode, m_ruang.nama as namaruang,icd_cm.keterangan,m_dokter.namadokter,count(*) as jml'))
->where([
['status_rajal','=',1],
])
->whereIn('t_pendaftaran.kdpoly',$arr_incovit)
->whereBetween('t_icd_cm.tanggal',[$tgl_awal,$tgl_akhir])
->groupBy('t_icd_cm.tanggal','icd_cm.kode','m_ruang.nama','m_dokter.namadokter')
->get();
// return $result;
$arr_result = [];
$i = 0;
foreach($result->all() as $key => $detil)
{
$row_detil = DB::table('t_icd_cm')
->join('icd_cm','t_icd_cm.icd','=','icd_cm.kode')
->join('m_dokter','m_dokter.kddokter','=','t_icd_cm.kddokter')
->join('t_pendaftaran','t_icd_cm.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->join('m_pasien','m_pasien.nomr','=','t_pendaftaran.nomr')
->leftJoin('m_statuskeluar','t_pendaftaran.status','=','m_statuskeluar.status')
->select(DB::raw('m_pasien.jeniskelamin,age(m_pasien.tgllahir) as usia,m_statuskeluar.keterangan as status_keluar'))
->where([
['status_rajal','=',1],
['m_ruang.nama','=',$detil->namaruang],
['icd_cm.kode','=',$detil->kode],
['m_dokter.namadokter','=',$detil->namadokter],
['t_icd_cm.tanggal','=',$detil->tanggal],
])
->whereIn('t_pendaftaran.kdpoly',$arr_incovit)
->get();
$set_result = collect($result[$key]);
// $set_result->pull('jml');
$set_result['pasien'] = $row_detil->all();
$arr_result[] = $set_result->all();
$result->forget($key);
$i++;
}
return response()->json($arr_result);
}
public function ranapTindakanFiltered($tgl_awal,$tgl_akhir,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
// $tgl_awal = urldecode($tgl_awal);
// $tgl_akhir = urldecode($tgl_akhir);
if(null == $tgl_awal || null == $tgl_akhir)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
$result = DB::table('t_icd_cm')
->leftJoin('icd_cm as cm1','t_icd_cm.icd','=','cm1.kode')
->leftJoin('icd_cm as cm2','t_icd_cm.icd_verified','=','cm2.kode')
->join('m_dokter','m_dokter.kddokter','=','t_icd_cm.kddokter')
->join('t_admission','t_icd_cm.idxdaftar','=','t_admission.id_admission')
->join('m_ruang','m_ruang.no','=','t_admission.noruang')
->select(DB::raw('t_icd_cm.tanggal,m_ruang.kelompok,m_ruang.nama as namaruang,case when cm1.kode is null then cm2.kode end as kode, case when cm1.keterangan is null then cm2.keterangan end as keterangan,m_dokter.namadokter,count(*) as jml'))
->where([
['status_rajal','=',0],
])
->whereBetween('t_icd_cm.tanggal',[$tgl_awal,$tgl_akhir])
->groupBy('t_icd_cm.tanggal','cm1.kode','cm2.kode','m_dokter.namadokter','m_ruang.kelompok','m_ruang.nama')
->get();
// return $result;
$arr_result = [];
$i = 0;
foreach($result->all() as $key => $detil)
{
$row_detil = DB::table('t_icd_cm')
->leftJoin('icd_cm as cm1','t_icd_cm.icd','=','cm1.kode')
->leftJoin('icd_cm as cm2','t_icd_cm.icd_verified','=','cm2.kode')
->join('m_dokter','m_dokter.kddokter','=','t_icd_cm.kddokter')
->join('t_admission','t_icd_cm.idxdaftar','=','t_admission.id_admission')
->join('m_ruang','m_ruang.no','=','t_admission.noruang')
->join('m_pasien','m_pasien.nomr','=','t_admission.nomr')
->leftJoin('t_resumepulang','t_resumepulang.idadmission','=','t_admission.id_admission')
->leftJoin('m_statuskeluarranap','m_statuskeluarranap.kode','=','t_resumepulang.statuspulang')
->select(DB::raw('m_pasien.jeniskelamin,age(m_pasien.tgllahir) as usia,m_statuskeluarranap.nama as status_keluar'))
->where([
['status_rajal','=',0],
['m_ruang.nama','=',$detil->namaruang],
['m_dokter.namadokter','=',$detil->namadokter],
['t_icd_cm.tanggal','=',$detil->tanggal],
])
->where(function($query) use ($detil) {
$query->where('cm1.kode','=',$detil->kode)
->orWhere('cm2.kode','=',$detil->kode);
})
// ->whereNotIn('t_pendaftaran.kdpoly',$arr_incovit)
->get();
$set_result = collect($result[$key]);
// $set_result->pull('jml');
$set_result['pasien'] = $row_detil->all();
$arr_result[] = $set_result->all();
$result->forget($key);
$i++;
}
return response()->json($arr_result);
}
}

View File

@@ -0,0 +1,390 @@
<?php
namespace App\Http\Controllers;
use Illuminate\Support\Facades\DB;
use Illuminate\Support\Facades\Http;
use Illuminate\Http\Request;
use Illuminate\Http\Response;
use Auth;
class PasienController extends Controller
{
public function __construct(Request $request)
{
// $this->middleware('auth:api');
if(null == $request->header('x-token'))
{
return response()->json(['error' => 'Unauthorized'], 401);
}
$user = DB::table('webservice')->where('token',$request->header('x-token'))->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
}
public function pasienFilter($nomr,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
if(null == $nomr)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
elseif(strlen($nomr) < 8)
{
return response()->json(['error' => 'Parameter less than 8 digit!'],400);
}
elseif(strlen($nomr) > 8)
{
return response()->json(['error' => 'Parameter more than 8 digit!'],400);
}
$result = DB::table('m_pasien')
->leftJoin('m_agama_pasien','m_agama_pasien.id_agama','=','m_pasien.agama')
->leftJoin('m_status_pasien','m_status_pasien.id_status','=','m_pasien.status')
->leftJoin('m_pendidikan_pasien','m_pendidikan_pasien.id_pendidikan','=','m_pasien.pendidikan')
->select('nomr','nama','tgllahir','alamat','noktp','jeniskelamin','notelp','tgldaftar','no_kartu','txt_kelurahan','txt_kecamatan','txt_kota','txt_provinsi',DB::raw('case when m_status_pasien.nama_status is null then txt_status else m_status_pasien.nama_status end as txt_status,case when m_agama_pasien.nama_agama is null then txt_agama else m_agama_pasien.nama_agama end as txt_agama,case when m_pendidikan_pasien.nama_pendidikan is null then txt_pendidikan else m_pendidikan_pasien.nama_pendidikan end as txt_pendidikan'))
->where('nomr',$nomr)
->get();
// return $result;
$arr_result = [];
$i = 0;
foreach($result->all() as $key => $detil)
{
// $row_detil = DB::table('t_icd')
// ->join('icd','t_icd.icd','=','icd.icd_code')
// ->join('m_dokter','m_dokter.kddokter','=','t_icd.kddokter')
// ->join('t_pendaftaran','t_icd.idxdaftar','=','t_pendaftaran.idxdaftar')
// ->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
// ->join('m_pasien','m_pasien.nomr','=','t_pendaftaran.nomr')
// ->leftJoin('m_statuskeluar','t_pendaftaran.status','=','m_statuskeluar.status')
// ->select(DB::raw('m_pasien.jeniskelamin,age(m_pasien.tgllahir) as usia,m_statuskeluar.keterangan as status_keluar'))
// ->where([
// ['status_rajal','=',1],
// ['m_ruang.nama','=',$detil->namaruang],
// ['icd.icd_code','=',$detil->icd_code],
// ['m_dokter.namadokter','=',$detil->namadokter],
// ['t_icd.tanggal','=',$detil->tanggal],
// ])
// ->whereNotIn('t_pendaftaran.kdpoly',$arr_incovit)
// ->get();
$set_result = collect($result[$key]);
// $set_result->pull('jml');
// $set_result['pasien'] = $row_detil->all();
$arr_result[] = $set_result->all();
$result->forget($key);
$i++;
}
return response()->json($arr_result);
}
public function labsentralFilter($nomr,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
if(null == $nomr)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
elseif(strlen($nomr) < 8)
{
return response()->json(['error' => 'Parameter less than 8 digit!'],400);
}
elseif(strlen($nomr) > 8)
{
return response()->json(['error' => 'Parameter more than 8 digit!'],400);
}
$response = Http::get('http://192.168.2.9/viewer/api.php?get=1&nomr='.$nomr);
$jsonData = $response->json();
return $jsonData;
}
public function labmikroFilter($nomr,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
if(null == $nomr)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
elseif(strlen($nomr) < 8)
{
return response()->json(['error' => 'Parameter less than 8 digit!'],400);
}
elseif(strlen($nomr) > 8)
{
return response()->json(['error' => 'Parameter more than 8 digit!'],400);
}
$result = DB::table('t_orderlabmikro_main')
->join('t_orderlabmikro','t_orderlabmikro.nolab','=','t_orderlabmikro_main.nolab')
->select('no_lokal','tgl_hasil','jenis_hasil','idxordermikro')
->where('t_orderlabmikro_main.nomr',$nomr)
->where('t_orderlabmikro.status_final',1)
->get();
$arr_result = [];
$i = 0;
foreach($result->all() as $key => $detil)
{
$set_result = collect($result[$key]);
$set_result['nama'] = $detil->jenis_hasil.' - '.$detil->tgl_hasil.' - '.$detil->no_lokal;
$set_result['url'] = env('SIMRS_APP_URL').'lab/detil_hasil_labmikro.php?preview=1&no='.$detil->idxordermikro;
$set_result->pull('idxordermikro');
$set_result->pull('jenis_hasil');
$set_result->pull('tgl_hasil');
$set_result->pull('no_lokal');
$arr_result[] = $set_result->all();
$result->forget($key);
$i++;
}
$message = ($i > 0) ? 'Ditemukan beberapa hasil lab mikrobiologi.' : 'Tidak ditemukan hasil lab mikrobiologi.';
return response()->json(['message'=>$message,'data'=>$arr_result]);
}
public function labpatologiFilter($nomr,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
if(null == $nomr)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
elseif(strlen($nomr) < 8)
{
return response()->json(['error' => 'Parameter less than 8 digit!'],400);
}
elseif(strlen($nomr) > 8)
{
return response()->json(['error' => 'Parameter more than 8 digit!'],400);
}
$result = DB::table('t_orderlabpa_main')
->select('no_reg_pa','tgljawab_lab as tgl_hasil','lokalisasi','noreglab','idxdaftar')
->where('nomr',$nomr)
->whereNotNull('tgljawab_lab')
->get();
$arr_result = [];
$i = 0;
foreach($result->all() as $key => $detil)
{
$set_result = collect($result[$key]);
$set_result['nama'] = $detil->lokalisasi.' - '.$detil->tgl_hasil.' - '.$detil->no_reg_pa;
$set_result['url'] = env('SIMRS_APP_URL').'lab/detil_hasil_labpa.php?preview=1&idx='.$detil->idxdaftar.'&nomr='.$nomr.'&nolab='.$detil->noreglab;
$set_result->pull('no_reg_pa');
$set_result->pull('tgl_hasil');
$set_result->pull('lokalisasi');
$set_result->pull('noreglab');
$set_result->pull('idxdaftar');
$arr_result[] = $set_result->all();
$result->forget($key);
$i++;
}
$message = ($i > 0) ? 'Ditemukan beberapa hasil lab patologi anatomi.' : 'Tidak ditemukan hasil lab patologi anatomi.';
return response()->json(['message'=>$message,'data'=>$arr_result]);
}
public function resumeFilter($nomr,Request $request)
{
$token = $request->header('x-token');
$user = DB::table('webservice')->where('token',$token)->first();
if(!$user || empty($user)){
return response()->json(['error' => 'Unauthorized'], 401);
}
if(null == $nomr)
{
return response()->json(['error' => 'Invalid Parameter!'],400);
}
elseif(strlen($nomr) < 8)
{
return response()->json(['error' => 'Parameter less than 8 digit!'],400);
}
elseif(strlen($nomr) > 8)
{
return response()->json(['error' => 'Parameter more than 8 digit!'],400);
}
// SELECT * from t_resumemedis a join m_dokter d on a.dpjp = d.kddokter
// get resume
$resume = DB::table('t_resumemedis')
->join('m_dokter','t_resumemedis.dpjp','=','m_dokter.kddokter')
->where([
['nomr','=',$nomr]
])
->orderBy('idx','desc')
->get();
$arr_result['resume'] = [];
$i = 0;
foreach($resume->all() as $key => $detil_resume)
{
$idx = ($detil_resume->idxrajal != 0) ? $detil_resume->idxrajal : $detil_resume->idxranap;
$status_rajal = ($detil_resume->idxrajal != 0) ? 1 : 0;
$arr_result['resume'][$idx] = [
'tanggal_mrs' => $detil_resume->tanggalmasuk,
'diagnosa_utama' => $detil_resume->diagnosa_utama,
'diagnosa_klinis' => $detil_resume->keluhan_utama,
'icd_diagnosa' => [],
'icd_tindakan' => [],
'nama_ruang' => '',
'url_resume' => env('SIMRS_APP_URL').'include/master.php?load_resume_pdf=1&idx='.$idx.'&rajal_status='.$status_rajal.'&jenis_resume=dpjp&attach=1'
];
if($status_rajal == 1) {
$icd_diagnosa_rajal = DB::table('t_icd')
->join('icd','t_icd.icd','=','icd.icd_code')
->join('t_pendaftaran','t_icd.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->select('m_ruang.nama as namaruang','icd.icd_code as icd', 'icd.jenis_penyakit as keterangan')
->where([
['t_icd.idxdaftar','=',$idx],
['t_icd.status_rajal','=',1]
])
->whereNull('t_icd.icd_verified')
->get();
foreach($icd_diagnosa_rajal->all() as $key => $detil)
{
$set_result = collect($icd_diagnosa_rajal[$key]);
if(array_key_exists($idx,$arr_result['resume'])){
$arr_result['resume'][$idx]['icd_diagnosa'][] = $set_result->all();
}
$icd_diagnosa_rajal->forget($key);
}
$icd_tindakan_rajal = DB::table('t_icd_cm')
->join('icd_cm','t_icd_cm.icd','=','icd_cm.kode')
->join('m_dokter','m_dokter.kddokter','=','t_icd_cm.kddokter')
->join('t_pendaftaran','t_icd_cm.idxdaftar','=','t_pendaftaran.idxdaftar')
->join('m_ruang','m_ruang.no','=','t_pendaftaran.kdpoly')
->select('m_ruang.nama as namaruang','icd_cm.kode as icd', 'icd_cm.keterangan')
->where([
['t_icd_cm.idxdaftar','=',$idx],
['t_icd_cm.status_rajal','=',1]
])
->whereNull('t_icd_cm.icd_verified')
->get();
foreach($icd_tindakan_rajal->all() as $key => $detil)
{
$set_result = collect($icd_tindakan_rajal[$key]);
if(array_key_exists($idx,$arr_result['resume'])){
$arr_result['resume'][$idx]['icd_tindakan'][] = $set_result->all();
}
$icd_tindakan_rajal->forget($key);
}
}
else {
$icd_diagnosa_ranap = DB::table('t_icd')
->join('icd','t_icd.icd','=','icd.icd_code')
->join('t_admission','t_icd.idxdaftar','=','t_admission.id_admission')
->join('m_ruang','m_ruang.no','=','t_admission.noruang')
->select('m_ruang.nama as namaruang','icd.icd_code as icd', 'icd.jenis_penyakit as keterangan')
->where([
['t_icd.idxdaftar','=',$idx],
['t_icd.status_rajal','=',0]
])
->whereNull('t_icd.icd_verified')
->get();
foreach($icd_diagnosa_ranap->all() as $key => $detil)
{
$set_result = collect($icd_diagnosa_ranap[$key]);
if(array_key_exists($idx,$arr_result['resume'])){
$arr_result['resume'][$idx]['icd_diagnosa'][] = $set_result->all();
}
$icd_diagnosa_ranap->forget($key);
}
$icd_tindakan_ranap = DB::table('t_icd_cm')
->join('icd_cm','t_icd_cm.icd','=','icd_cm.kode')
->join('m_dokter','m_dokter.kddokter','=','t_icd_cm.kddokter')
->join('t_admission','t_icd_cm.idxdaftar','=','t_admission.id_admission')
->join('m_ruang','m_ruang.no','=','t_admission.noruang')
->select('m_ruang.nama as namaruang','icd_cm.kode as icd', 'icd_cm.keterangan')
->where([
['t_icd_cm.idxdaftar','=',$idx],
['t_icd_cm.status_rajal','=',0]
])
->whereNull('t_icd_cm.icd_verified')
->get();
$arr_result['icd_tindakan'] = [];
foreach($icd_tindakan_ranap->all() as $key => $detil)
{
$set_result = collect($icd_tindakan_ranap[$key]);
if(array_key_exists($idx,$arr_result['resume'])){
$arr_result['resume'][$idx]['icd_tindakan'][] = $set_result->all();
}
$icd_tindakan_ranap->forget($key);
}
}
$i++;
}
$message = ($i > 0) ? 'Ditemukan beberapa hasil resume.' : 'Tidak ditemukan hasil resume.';
return response()->json(['message'=>$message,'data'=>$arr_result]);
}
}

View File

@@ -0,0 +1,44 @@
<?php
namespace App\Http\Controllers;
use App\Http\Controllers\Controller;
use Illuminate\Support\Facades\Hash;
use Illuminate\Support\Str;
use Illuminate\Http\Request;
use App\Models\User;
class UserController extends Controller
{
public function __construct()
{
// $this->middleware('auth:api');
}
/**
* Display a listing of the resource.
*
* @return \Illuminate\Http\Response
*/
public function authenticate(Request $request)
{
$this->validate($request, [
'email' => 'required',
'password' => 'required'
]);
$user = User::where('email', $request->input('email'))->first();
if($user != NULL && Hash::check($request->input('password'), $user->password)){
$apikey = base64_encode(Str::random(40));
$time = date('Y-m-d H:i:s');
User::where('email', $request->input('email'))->update(['token' => "$apikey"]);;
return response()->json(['status' => 'success','token' => $apikey,'updated_at' => $time]);
}else{
return response()->json(['status' => 'fail'],401);
}
}
}
?>