db_onedev = $this->load->database("onedev", true); } public function search() { $prm = $this->sys_input; if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $norm = $prm["snorm"]; $nama = $prm["nama"]; // echo $norm; $sql_where = "WHERE T_ReceiveReferenceHeaderIsActive = 'Y' "; $sql_param = array(); if ($nama != "") { if ($sql_where != "") { $sql_where .=" and "; } $sql_where .= " M_CompanyName like ? "; $sql_param[] = "%$nama%"; } if ($norm != "") { if ($sql_where != "") { $sql_where .=" and "; } $sql_where .= " T_ReceiveReferenceHeaderNumber like ? "; $sql_param[] = "%$norm%"; } //if ($sql_where != "") $sql_where .= " and "; // Order masih dalam status registrasi //$sql_where .= " M_PatientIsActive = 'Y' "; $sql = " SELECT count(*) as total FROM t_receivereferenceheader JOIN m_company ON T_ReceiveReferenceHeaderM_CompanyID = M_CompanyID LEFT JOIN m_mou ON T_ReceiveReferenceHeaderM_MouID = M_MouID $sql_where "; //echo $sql; $query = $this->db_onedev->query($sql, $sql_param); $tot_count = 0; if ($query) { $tot_count = $query->result_array()[0]["total"]; } else { $this->sys_error_db("t_receivereferenceheader count", $this->db_onedev); exit; } $sql = "SELECT T_ReceiveReferenceHeaderID, T_ReceiveReferenceHeaderM_CompanyID, M_CompanyName, T_ReceiveReferenceHeaderM_MouID, M_MouName, DATE_FORMAT(T_ReceiveReferenceHeaderDate,'%d-%m-%Y') as T_ReceiveReferenceHeaderDate, T_ReceiveReferenceHeaderNumber, T_ReceiveReferenceHeaderNote, T_ReceiveReferenceHeaderIsSent, T_ReceiveReferenceHeaderSentDate, T_ReceiveReferenceHeaderIsConfirm, T_ReceiveReferenceHeaderConfirmDate, (SELECT `fn_receivereference_get_status`(T_ReceiveReferenceHeaderID)) as aksi FROM t_receivereferenceheader JOIN m_company ON T_ReceiveReferenceHeaderM_CompanyID = M_CompanyID LEFT JOIN m_mou ON T_ReceiveReferenceHeaderM_MouID = M_MouID $sql_where ORDER BY T_ReceiveReferenceHeaderNumber DESC limit 0,$tot_count"; $query = $this->db_onedev->query($sql, $sql_param); $rows = $query->result_array(); if($rows){ foreach($rows as $k => $v){ $x = $this->db_onedev->query("select concat( '[', group_concat( json_object('id', G_ReceiveReferenceHeaderStatusLogID, 'status', M_StatusReferenceDisplayName, 'waktu', DATE_FORMAT(G_ReceiveReferenceHeaderStatusLogCreated,'%d-%m-%Y %H:%i'), 'user' , M_UserUsername) separator ',' ), ']' ) as n from g_receivereferenceheaderstatuslog LEFT JOIN m_statusreference ON G_ReceiveReferenceHeaderStatusLogM_StatusReferenceID = M_StatusReferenceID LEFT JOIN m_user ON G_ReceiveReferenceHeaderStatusLogM_UserID = M_UserID LEFT JOIN m_staff ON M_UserM_StaffID = M_StaffID WHERE G_ReceiveReferenceHeaderStatusLogT_ReceiveReferenceHeaderID = '{$v['T_ReceiveReferenceHeaderID']}' AND G_ReceiveReferenceHeaderStatusLogIsActive = 'Y'")->row(); $rows[$k]['statuss'] = json_decode($x->n); } } //$this->_add_address($rows); $result = array("total" => $tot_count, "records" => $rows, "sql"=> $this->db_onedev->last_query()); $this->sys_ok($result); exit; } function searchcompany(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $max_rst = 12; $tot_count =0; $q = [ 'search' => '%' ]; if ($prm['search'] != '') { $q['search'] = "%{$prm['search']}%"; } // QUERY TOTAL $sql = "SELECT count(*) as total FROM m_company WHERE M_CompanyName like ? AND M_CompanyIsActive = 'Y' AND M_CompanyIsLabFrom = 'Y'"; $query = $this->db_onedev->query($sql,$q['search']); //echo $query; if ($query) { $tot_count = $query->result_array()[0]["total"]; } else { $this->sys_error_db("m_company count",$this->db_onedev); exit; } $sql = " SELECT * FROM m_company WHERE M_CompanyName like ? AND M_CompanyIsActive = 'Y' AND M_CompanyIsLabFrom = 'Y' ORDER BY M_CompanyName DESC "; $query = $this->db_onedev->query($sql, array($q['search'])); if ($query) { $rows = $query->result_array(); //echo $this->db_onedev->last_query(); $result = array("total" => $tot_count, "records" => $rows, "total_display" => sizeof($rows)); $this->sys_ok($result); } else { $this->sys_error_db("m_company rows",$this->db_onedev); exit; } } function getmou(){ $prm = $this->sys_input; $query =" SELECT * FROM m_mou WHERE M_MouIsActive = 'Y' AND M_MouM_CompanyID = ? "; //echo $query; $rows = $this->db_onedev->query($query,array($prm['id']))->result_array(); $result = array( "total" => count($rows) , "records" => $rows, ); $this->sys_ok($result); exit; } function getsexreg(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $rows = []; $query =" SELECT * FROM m_sex WHERE M_SexIsActive = 'Y' "; //echo $query; $rows['sexes'] = $this->db_onedev->query($query)->result_array(); $result = array( "total" => count($rows) , "records" => $rows, ); $this->sys_ok($result); exit; } function save(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $pdob = date('Y-m-d',strtotime($prm['M_PatientDOB'])); $query ="UPDATE m_patient SET M_PatientM_TitleID = '{$prm['M_PatientM_TitleID']}', M_PatientName = '{$prm['M_PatientName']}', M_PatientDOB = '{$pdob}', M_PatientM_SexID = '{$prm['M_PatientM_SexID']}', M_PatientM_ReligionID = '{$prm['M_PatientM_ReligionID']}', M_PatientEmail = '{$prm['M_PatientEmail']}', M_PatientHP = '{$prm['M_PatientHP']}', M_PatientPhone = '{$prm['M_PatientPhone']}', M_PatientM_IdTypeID = '{$prm['M_PatientM_IdTypeID']}', M_PatientIDNumber = '{$prm['M_PatientIDNumber']}', M_PatientNote = '{$prm['M_PatientNote']}' WHERE M_PatientID = '{$prm['M_PatientID']}' "; //echo $query; $rows = $this->db_onedev->query($query); $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function newreceivereference(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $pdate = date('Y-m-d',strtotime($prm['sdate'])); $userid = $this->sys_user["M_UserID"]; $query ="INSERT INTO t_receivereferenceheader ( T_ReceiveReferenceHeaderM_CompanyID, T_ReceiveReferenceHeaderM_MouID, T_ReceiveReferenceHeaderDate, T_ReceiveReferenceHeaderNote, T_ReceiveReferenceHeaderUserID, T_ReceiveReferenceHeaderCreated ) VALUES( '{$prm['companyid']}', '{$prm['mouid']}', '{$pdate}', '{$prm['note']}', '{$userid}', NOW() ) "; // echo $query; $rows = $this->db_onedev->query($query); $last_id = $this->db_onedev->insert_id(); $querylog ="INSERT INTO g_receivereferenceheaderstatuslog ( G_ReceiveReferenceHeaderStatusLogDate, G_ReceiveReferenceHeaderStatusLogT_ReceiveReferenceHeaderID, G_ReceiveReferenceHeaderStatusLogM_StatusReferenceID, G_ReceiveReferenceHeaderStatusLogM_UserID, G_ReceiveReferenceHeaderStatusLogUserID, G_ReceiveReferenceHeaderStatusLogCreated, G_ReceiveReferenceHeaderStatusLogLastUpdated ) VALUES( NOW(), '{$last_id}', '1', '{$userid}', '{$userid}', NOW(), NOW() )"; //echo $querylog; $insert_new_log = $this->db_onedev->query($querylog); $result = array( "total" => 1 , "records" => array('status'=>'OK'), "id" => $last_id ); $this->sys_ok($result); exit; } function sendorder(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $userid = $this->sys_user["M_UserID"]; $query ="UPDATE t_receivereferenceheader SET T_ReceiveReferenceHeaderIsSent = 'Y', T_ReceiveReferenceHeaderSentDate = now(), T_ReceiveReferenceHeaderUserID = '{$userid}' WHERE T_ReceiveReferenceHeaderID = '{$prm['T_ReceiveReferenceHeaderID']}' "; //echo $query; $rows = $this->db_onedev->query($query); $rows = $this->db_onedev->query($query); $querylog ="INSERT INTO g_receivereferenceheaderstatuslog ( G_ReceiveReferenceHeaderStatusLogDate, G_ReceiveReferenceHeaderStatusLogT_ReceiveReferenceHeaderID, G_ReceiveReferenceHeaderStatusLogM_StatusReferenceID, G_ReceiveReferenceHeaderStatusLogM_UserID, G_ReceiveReferenceHeaderStatusLogUserID, G_ReceiveReferenceHeaderStatusLogCreated, G_ReceiveReferenceHeaderStatusLogLastUpdated ) VALUES( NOW(), '{$prm['T_ReceiveReferenceHeaderID']}', '2', '{$userid}', '{$userid}', NOW(), NOW() )"; //echo $querylog; $insert_new_log = $this->db_onedev->query($querylog); $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function getpatient(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $query =" SELECT t_receivereferencepatient.*, CONCAT(T_ReceiveReferencePatientName, ' (', IF(M_SexCode = 'F','P','L'), ')') as pasienname, IF(T_ReceiveReferencePatientDPAmount > 0, CONCAT(FORMAT(T_ReceiveReferencePatientTotal,0),' (DP: ',FORMAT(T_ReceiveReferencePatientDPAmount,0),')'),FORMAT(T_ReceiveReferencePatientTotal,0)) as total, DATE_FORMAT(T_ReceiveReferencePatientDOB,'%d-%m-%Y') as T_ReceiveReferencePatientDOB, M_SexName, '' as tes, 'xxx' as tests, '' as action, T_ReceiveReferenceHeaderIsSent, 'N' as show_detail, T_OrderHeaderLabNumber FROM t_receivereferencepatient JOIN m_sex ON T_ReceiveReferencePatientM_SexID = M_SexID JOIN t_receivereferenceheader ON T_ReceiveReferencePatientT_ReceiveReferenceHeaderID = T_ReceiveReferenceHeaderID LEFT JOIN t_orderheader ON T_ReceiveReferencePatientT_OrderHeaderID = T_OrderHeaderID WHERE T_ReceiveReferencePatientIsActive = 'Y' AND T_ReceiveReferencePatientT_ReceiveReferenceHeaderID = ? GROUP BY T_ReceiveReferencePatientID "; //echo $query; $rows = $this->db_onedev->query($query,array($prm['id']))->result_array(); if($rows){ foreach($rows as $k => $v){ $x = $this->db_onedev->query("select concat( '[', group_concat( json_object('id', T_ReceiveReferenceTestID, 'testname', T_ReceiveReferenceTestT_TestName, 'status', T_ReceiveReferenceTestStatus) separator ',' ), ']' ) as n from t_receivereferencetest WHERE T_ReceiveReferenceTestT_ReceiveReferencePatientID = '{$v['T_ReceiveReferencePatientID']}' AND T_ReceiveReferenceTestIsActive = 'Y'")->row(); $rows[$k]['tesx'] = json_decode($x->n); $rows[$k]['tests'] = $this->add_test($v['T_ReceiveReferencePatientID']); $rows[$k]['action'] = 'delete'; $rows[$k]['action'] .= 'edit'; } } $result = array( "total" => count($rows) , "records" => $rows, ); $this->sys_ok($result); exit; } function add_test($orderid){ $query =" SELECT t_receivereferencetest.*, t_test.*,'Y' as editable, T_ReceiveReferenceTestT_TestID as xid, T_ReceiveReferenceTestT_TestPrice as T_PriceAmount, T_ReceiveReferenceTestT_TestDisc as T_PriceDisc, T_ReceiveReferenceTestT_TestDiscRp as T_PriceDiscRp, T_ReceiveReferenceTestT_TestTotal as total, T_ReceiveReferenceTestID as idx, T_OrderDetailResult, T_OrderDetailNote FROM t_receivereferencetest JOIN t_receivereferencepatient ON T_ReceiveReferenceTestT_ReceiveReferencePatientID = T_ReceiveReferencePatientID JOIN t_receivereferenceheader ON T_ReceiveReferencePatientT_ReceiveReferenceHeaderID = T_ReceiveReferenceHeaderID LEFT JOIN t_orderheader ON T_ReceiveReferencePatientT_OrderHeaderID = T_OrderHeaderID LEFT JOIN t_orderdetail ON T_OrderHeaderID = T_OrderDetailT_OrderHeaderID JOIN t_test ON T_ReceiveReferenceTestT_TestID = T_TestID WHERE T_ReceiveReferenceTestT_ReceiveReferencePatientID = {$orderid} AND T_ReceiveReferenceTestIsActive = 'Y' GROUP BY T_ReceiveReferenceTestID"; //echo $query; $rows = $this->db_onedev->query($query)->result_array(); if(!$rows) $rows = array(); return $rows; } function savenewpatient(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $pdob = date('Y-m-d',strtotime($prm['T_ReceiveReferencePatientDOB'])); $userid = $this->sys_user["M_UserID"]; $query ="INSERT INTO t_receivereferencepatient ( T_ReceiveReferencePatientT_ReceiveReferenceHeaderID, T_ReceiveReferencePatientNoRef, T_ReceiveReferencePatientName, T_ReceiveReferencePatientDOB, T_ReceiveReferencePatientM_SexID, T_ReceiveReferencePatientUserID, T_ReceiveReferencePatientTotal, T_ReceiveReferencePatientDPPercent, T_ReceiveReferencePatientDPAmount, T_ReceiveReferencePatientCreated ) VALUES( '{$prm['T_ReceiveReferencePatientT_ReceiveReferenceHeaderID']}', '{$prm['T_ReceiveReferencePatientNoRef']}', '{$prm['T_ReceiveReferencePatientName']}', '{$pdob}', '{$prm['T_ReceiveReferencePatientM_SexID']}', '{$userid}', '{$prm['T_ReceiveReferencePatientTotal']}', '{$prm['T_ReceiveReferencePatientDPPercent']}', '{$prm['T_ReceiveReferencePatientDPAmount']}', NOW() ) "; //echo $query; $rows = $this->db_onedev->query($query); $orderpatient_id = $this->db_onedev->insert_id(); foreach($prm['ordertests'] as $k=>$v){ $query = "INSERT INTO t_receivereferencetest ( T_ReceiveReferenceTestT_ReceiveReferencePatientID, T_ReceiveReferenceTestT_TestID, T_ReceiveReferenceTestT_TestCode, T_ReceiveReferenceTestT_TestName, T_ReceiveReferenceTestT_TestPrice, T_ReceiveReferenceTestT_TestDisc, T_ReceiveReferenceTestT_TestDiscRp, T_ReceiveReferenceTestT_TestTotal, T_ReceiveReferenceTestUserID, T_ReceiveReferenceTestCreated, T_ReceiveReferenceTestLastUpdated ) VALUE( ?,?,?,?,?,?,?,?,?, now(),now() )"; $insert_new_test = $this->db_onedev->query($query,array( $orderpatient_id, $v['T_TestID'], $v['T_TestCode'], $v['T_TestName'], $v['T_PriceAmount'], $v['T_PriceDisc'], $v['T_PriceDiscRp'], $v['total'], $userid )); } $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function saveeditpatient(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $order_id = $prm['T_ReceiveReferencePatientID']; $pdob = date('Y-m-d',strtotime($prm['T_ReceiveReferencePatientDOB'])); $userid = $this->sys_user["M_UserID"]; $query ="UPDATE t_receivereferencepatient SET T_ReceiveReferencePatientT_ReceiveReferenceHeaderID = '{$prm['T_ReceiveReferencePatientT_ReceiveReferenceHeaderID']}', T_ReceiveReferencePatientNoRef = '{$prm['T_ReceiveReferencePatientNoRef']}', T_ReceiveReferencePatientName = '{$prm['T_ReceiveReferencePatientName']}', T_ReceiveReferencePatientDOB = '{$pdob}', T_ReceiveReferencePatientM_SexID = '{$prm['T_ReceiveReferencePatientM_SexID']}', T_ReceiveReferencePatientTotal = '{$prm['T_ReceiveReferencePatientTotal']}', T_ReceiveReferencePatientDPPercent = '{$prm['T_ReceiveReferencePatientDPPercent']}', T_ReceiveReferencePatientDPAmount = '{$prm['T_ReceiveReferencePatientDPAmount']}', T_ReceiveReferencePatientUserID = '{$userid}' WHERE T_ReceiveReferencePatientID = '{$prm['T_ReceiveReferencePatientID']}' "; //echo $query; $rows = $this->db_onedev->query($query); foreach($prm['ordertests'] as $k=>$v){ if($v['xid'] == 0 || $v['xid'] == '0'){ $query = "INSERT INTO t_receivereferencetest ( T_ReceiveReferenceTestT_ReceiveReferencePatientID, T_ReceiveReferenceTestT_TestID, T_ReceiveReferenceTestT_TestCode, T_ReceiveReferenceTestT_TestName, T_ReceiveReferenceTestT_TestPrice, T_ReceiveReferenceTestUserID, T_ReceiveReferenceTestCreated, T_ReceiveReferenceTestLastUpdated ) VALUE( ?,?,?,?,?,?,now(),now() )"; $insert_new_test = $this->db_onedev->query($query,array( $order_id, $v['T_TestID'], $v['T_TestCode'], $v['T_TestName'], $v['total'], $userid )); } } if(isset($prm['deleted_ordertests'])){ foreach($prm['deleted_ordertests'] as $i=>$del){ $query = "UPDATE t_receivereferencetest SET T_ReceiveReferenceTestIsActive = 'N', T_ReceiveReferenceTestUserID = '{$userid}', T_ReceiveReferenceTestLastUpdated = now() WHERE T_ReceiveReferenceTestID = ? "; $delete_exist_test = $this->db_onedev->query($query,array($del['T_ReceiveReferenceTestID'],)); } } $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function deletepatient(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $userid = $this->sys_user["M_UserID"]; $query ="UPDATE t_receivereferencepatient SET T_ReceiveReferencePatientIsActive = 'N', T_ReceiveReferencePatientUserID = '{$userid}' WHERE T_ReceiveReferencePatientID = '{$prm['T_ReceiveReferencePatientID']}' "; //echo $query; $rows = $this->db_onedev->query($query); $query ="UPDATE t_receivereferencetest SET T_ReceiveReferenceTestIsActive = 'N', T_ReceiveReferenceTestUserID = '{$userid}' WHERE T_ReceiveReferenceTestT_ReceiveReferencePatientID = '{$prm['T_ReceiveReferencePatientID']}' AND T_ReceiveReferenceTestIsActive = 'Y' "; //echo $query; $rows = $this->db_onedev->query($query); $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function searchtest(){ $prm = $this->sys_input; $max_rst = 12; $tot_count = 0; $q = [ 'search' => '%' ]; if ($prm['search'] != '') { $q['search'] = "%{$prm['search']}%"; } $mou_id = $prm['mouid']; // QUERY TOTAL $sql = "SELECT count(*) as total FROM t_test JOIN t_price ON T_PriceT_TestID = T_TestID AND T_PriceIsCito = 'N' AND T_PriceM_MouID = '{$mou_id}' WHERE T_TestName like ? AND T_TestIsActive = 'Y' ORDER BY T_TestName ASC"; $query = $this->db_onedev->query($sql,$q['search']); //echo $query; if ($query) { $tot_count = $query->result_array()[0]["total"]; } else { $this->sys_error_db("test count",$this->db_onedev); exit; } $sql = " SELECT 'Y' as editable, 0 as xid, T_TestID, T_TestCode, T_TestName, T_PriceAmount, T_PriceDisc, T_PriceDiscRp, T_PriceAmount - ((T_PriceDisc/100) * T_PriceAmount) - T_PriceDiscRp as total, M_CompanyID, M_CompanyIsBill, M_CompanyMinDP FROM one.t_test JOIN one.t_price ON T_PriceT_TestID = T_TestID AND T_PriceIsCito = 'N' AND T_PriceM_MouID = '{$mou_id}' JOIN one.m_mou ON M_MouID = '{$mou_id}' JOIN one.m_company ON M_MouM_CompanyID = M_CompanyID WHERE T_TestName like ? AND T_TestIsActive = 'Y' ORDER BY T_TestName ASC "; $query = $this->db_onedev->query($sql, array($q['search'])); if ($query) { $rows = $query->result_array(); //echo $this->db_onedev->last_query(); $result = array("total" => $tot_count, "records" => $rows, "total_display" => sizeof($rows)); $this->sys_ok($result); } else { $this->sys_error_db("test rows",$this->db_onedev); exit; } } }