db_onedev = $this->load->database("onedev", true); } public function search() { $prm = $this->sys_input; if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $code = $prm["code"]; $nama = $prm["nama"]; // echo $norm; $sql_where = "WHERE Nat_TestIsActive = 'Y'"; $sql_param = array(); if ($code != "") { if ($sql_where != "") { $sql_where .=" and "; } $sql_where .= " Nat_TestCode like ? "; $sql_param[] = "%$code%"; } if ($nama != "") { if ($sql_where != "") { $sql_where .=" and "; } $sql_where .= " Nat_TestName like ? "; $sql_param[] = "%$nama%"; } //if ($sql_where != "") $sql_where .= " and "; // Order masih dalam status registrasi //$sql_where .= " M_PatientIsActive = 'Y' "; $sql = " SELECT count(*) as total FROM nat_test $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("nat_test count", $this->db_onedev); exit; } $sql = "SELECT * FROM nat_test JOIN m_instrumentmethode ON M_InstrumentMethodeNat_TestID = Nat_TestID $sql_where GROUP BY Nat_TestID ORDER BY Nat_TestCode ASC"; //echo $sql; $query = $this->db_onedev->query($sql, $sql_param); $rows = $query->result_array(); if($rows){ foreach($rows as $k => $v){ } } //$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 getmethodereg(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $rows = []; $query =" SELECT * FROM nat_methode WHERE Nat_MethodeIsActive = 'Y' "; //echo $query; $rows['methodees'] = $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 nat_test ( Nat_TestM_CompanyID, Nat_TestM_MouID, Nat_TestDate, Nat_TestNote, Nat_TestUserID, Nat_TestCreated ) 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_ReceiveReferenceHeaderStatusLogNat_TestID, 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 nat_test SET Nat_TestIsSent = 'Y', Nat_TestSentDate = now(), Nat_TestUserID = '{$userid}' WHERE Nat_TestID = '{$prm['Nat_TestID']}' "; //echo $query; $rows = $this->db_onedev->query($query); $rows = $this->db_onedev->query($query); $querylog ="INSERT INTO g_receivereferenceheaderstatuslog ( G_ReceiveReferenceHeaderStatusLogDate, G_ReceiveReferenceHeaderStatusLogNat_TestID, G_ReceiveReferenceHeaderStatusLogM_StatusReferenceID, G_ReceiveReferenceHeaderStatusLogM_UserID, G_ReceiveReferenceHeaderStatusLogUserID, G_ReceiveReferenceHeaderStatusLogCreated, G_ReceiveReferenceHeaderStatusLogLastUpdated ) VALUES( NOW(), '{$prm['Nat_TestID']}', '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 getmethode(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $query =" SELECT Nat_MethodeID, Nat_MethodeName, Nat_TestName, IFNULL(GROUP_CONCAT(DISTINCT M_DayOfWeekName ORDER BY M_DayOfWeekID ASC SEPARATOR ', '),'No Local Setting') as M_DayOfWeekName, GROUP_CONCAT(DISTINCT Nat_InstrumentName SEPARATOR ', ') as Nat_InstrumentName, M_MethodePriorityNumber, 'xxx' as days, '' as action FROM nat_test JOIN nat_normalvalue ON Nat_TestID = Nat_NormalValueNat_TestID JOIN nat_methode ON Nat_NormalValueNat_MethodeID = Nat_MethodeID JOIN m_instrumentmethode ON M_InstrumentMethodeNat_TestID = Nat_TestID AND M_InstrumentMethodeNat_MethodeID = Nat_MethodeID AND M_InstrumentMethodeIsActive = 'Y' JOIN nat_instrument ON M_InstrumentMethodeNat_InstrumentID = Nat_InstrumentID LEFT JOIN m_methode_priority ON M_MethodePriorityNat_TestID = Nat_TestID AND M_MethodePriorityNat_MethodeID = Nat_MethodeID AND M_MethodePriorityIsActive = 'Y' LEFT JOIN m_dayofweek ON M_MethodePriorityM_DayOfWeekID = M_DayOfWeekID WHERE Nat_TestID = ? GROUP BY Nat_MethodeID ORDER BY Nat_MethodeID ASC "; //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',IFNULL(M_MethodePriorityID,M_DayOfWeekID), 'dayname', M_DayOfWeekName,'prioritas', M_MethodePriorityNumber ,'status', IF(IFNULL(M_MethodePriorityNumber,0) = 0, 'N','Y')) separator ',' ), ']' ) as n FROM (SELECT M_MethodePriorityID,M_DayOfWeekID,M_DayOfWeekName,IFNULL(M_MethodePriorityNumber,0) as M_MethodePriorityNumber FROM m_dayofweek JOIN nat_test ON Nat_TestID = '{$prm['id']}' JOIN nat_normalvalue ON Nat_TestID = Nat_NormalValueNat_TestID AND Nat_NormalValueNat_MethodeID = '{$v['Nat_MethodeID']}' JOIN nat_methode ON Nat_NormalValueNat_MethodeID = Nat_MethodeID LEFT JOIN m_methode_priority ON Nat_TestID = M_MethodePriorityNat_TestID AND Nat_MethodeID = M_MethodePriorityNat_MethodeID AND M_DayOfWeekID = M_MethodePriorityM_DayOfWeekID AND M_MethodePriorityIsActive = 'Y' GROUP BY M_DayOfWeekID) a")->row(); $rows[$k]['dayx'] = json_decode($x->n); $rows[$k]['days'] = $this->add_day($prm['id'],$v['Nat_MethodeID']); $rows[$k]['action'] = 'delete'; $rows[$k]['action'] .= 'edit'; } } $result = array( "total" => count($rows) , "records" => $rows, ); $this->sys_ok($result); exit; } function add_day($testid,$methodeid){ $query =" SELECT m_methode_priority.*,IFNULL(M_MethodePriorityNumber,0) as M_MethodePriorityNumber, m_dayofweek.*,IF(M_MethodePriorityID IS NULL,'N','Y') as isday, IFNULL(M_MethodePriorityNat_MethodeID,0) as xid FROM m_dayofweek JOIN nat_test ON Nat_TestID = '{$testid}' JOIN nat_normalvalue ON Nat_TestID = Nat_NormalValueNat_TestID AND Nat_NormalValueNat_MethodeID = '{$methodeid}' JOIN nat_methode ON Nat_NormalValueNat_MethodeID = Nat_MethodeID LEFT JOIN m_methode_priority ON Nat_TestID = M_MethodePriorityNat_TestID AND Nat_MethodeID = M_MethodePriorityNat_MethodeID AND M_DayOfWeekID = M_MethodePriorityM_DayOfWeekID AND M_MethodePriorityIsActive = 'Y' GROUP BY M_DayOfWeekID"; //echo $query; $rows = $this->db_onedev->query($query)->result_array(); if(!$rows) $rows = array(); return $rows; } function savenewmethode(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $userid = $this->sys_user["M_UserID"]; foreach($prm['orderdays'] as $k=>$v){ $query = "INSERT INTO m_methode_priority ( M_MethodePriorityM_MethodePriorityID, M_MethodePriorityT_TestID, M_MethodePriorityT_TestCode, M_MethodePriorityT_TestName, M_MethodePriorityT_TestPrice, M_MethodePriorityT_TestDisc, M_MethodePriorityT_TestDiscRp, M_MethodePriorityT_TestTotal, M_MethodePriorityUserID, M_MethodePriorityCreated, M_MethodePriorityLastUpdated ) 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 saveeditmethode(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $test_id = $prm['M_MethodePriorityNat_TestID']; $methode_id = $prm['M_MethodePriorityNat_MethodeID']; $priority = $prm['M_MethodePriorityNumber']; $userid = $this->sys_user["M_UserID"]; foreach($prm['orderdays'] as $k=>$v){ if(($v['xid'] == 0 || $v['xid'] == '0') && ($v['isday'] === 'Y')){ $query = "INSERT INTO m_methode_priority( M_MethodePriorityNat_TestID, M_MethodePriorityNat_MethodeID, M_MethodePriorityM_DayOfWeekID, M_MethodePriorityNumber, M_MethodePriorityUserID, M_MethodePriorityCreated, M_MethodePriorityLastUpdated ) VALUE( ?,?,?,?,?,now(),now() )"; $insert_methode = $this->db_onedev->query($query,array( $test_id, $methode_id, $v['M_DayOfWeekID'], $priority, $userid )); }elseif($v['xid'] > 0 && $v['isday'] === 'N'){ $queryupdate ="UPDATE m_methode_priority SET M_MethodePriorityIsActive = 'N', M_MethodePriorityUserID = '{$userid}', M_MethodePriorityLastUpdated = now() WHERE M_MethodePriorityID = ? "; // echo $queryupdate; $update_methode = $this->db_onedev->query($queryupdate,array($v['M_MethodePriorityID'],)); // echo $update_methode; }else{ $queryupdate ="UPDATE m_methode_priority SET M_MethodePriorityNumber = '{$priority}', M_MethodePriorityUserID = '{$userid}', M_MethodePriorityLastUpdated = now() WHERE M_MethodePriorityID = ? "; // echo $queryupdate; $update_methode = $this->db_onedev->query($queryupdate,array($v['M_MethodePriorityID'],)); } } $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 M_MethodePriorityIsActive = 'N', M_MethodePriorityUserID = '{$userid}' WHERE M_MethodePriorityID = '{$prm['M_MethodePriorityID']}' "; //echo $query; $rows = $this->db_onedev->query($query); $query ="UPDATE m_methode_priority SET M_MethodePriorityIsActive = 'N', M_MethodePriorityUserID = '{$userid}' WHERE M_MethodePriorityM_MethodePriorityID = '{$prm['M_MethodePriorityID']}' AND M_MethodePriorityIsActive = '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,'N' as M_CompanyIsBill, 0 as M_CompanyMinDP FROM one_lis_dev.t_test JOIN one_lis_dev.t_price ON T_PriceT_TestID = T_TestID AND T_PriceIsCito = 'N' AND T_PriceM_MouID = '{$mou_id}' JOIN one_lis_dev.m_mou ON M_MouID = '{$mou_id}' JOIN one_lis_dev.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; } } }