db_onedev = $this->load->database("onedev", true); } function add_verifications_label($orderid,$type){ $query = " SELECT Result_VerificationsID as id, IFNULL(Result_VerificationsValueID,0) as xid, IFNULL(Result_VerificationsValueCheck,'N') as chex, IF(ISNULL(Result_VerificationsValueID),'',Result_VerificationsValueNote) as note, Result_VerificationsLabel as label FROM result_verifications LEFT JOIN result_verifications_value ON Result_VerificationsValueT_OrderHeaderID = {$orderid} AND Result_VerificationsValueType = '{$type}' WHERE Result_VerificationIsActive = 'Y' GROUP BY Result_VerificationsID "; //echo $query; $rows = $this->db_onedev->query($query)->result_array(); foreach($rows as $k => $v){ if($v['chex'] == 'N') $rows[$k]['chex'] = false; else $rows[$k]['chex'] = true; } return $rows; } public function search() { $prm = $this->sys_input; if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $nolab = $prm["nolab"]; $nama = $prm["name"]; //$startdate = $prm["startdate"]; //$enddate = $prm["enddate"]; $groupid = 3; $subgroupid = $prm["subgroupid"]; $join_group = ''; if($groupid != 0){ $join_group = "JOIN nat_group ON T_TestNat_GroupID = Nat_GroupID AND Nat_GroupID = {$groupid}"; } $join_subgroup = ''; if($subgroupid != 0){ $join_group = "JOIN nat_subgroup ON T_TestNat_SubgroupID = Nat_SubgroupID AND Nat_SubgroupID = {$subgroupid}"; } if(!isset($prm['current_page'])) $prm['current_page'] = 1; $sql_where = "WHERE So_ResultEntryValidation1 = 'Y' AND So_ResultEntryValidation2 = 'N' AND So_ResultEntryIsActive = 'Y'"; $number_limit = 10; $number_offset = ($prm['current_page'] - 1) * $number_limit ; //$sql_param = array(); if ($nolab != "") { if ($sql_where != "") { $sql_where .=" and "; } $sql_where .= " T_OrderHeaderLabNumber like '%$nolab%' "; } if ($nama != "") { if ($sql_where != "") { $sql_where .=" and "; } $sql_where .= " M_PatientName like '%$nama%' "; } $sql = "SELECT T_OrderHeaderID as orderid, GROUP_CONCAT(T_OrderDetailID separator ',') as ids, fn_result_so_check_verification_status(T_OrderHeaderID,'xray') as status, T_OrderHeaderLabNumber as ordernumber, UPPER(CONCAT(M_TitleName,' ',M_PatientName)) as patient_fullname, UPPER(M_SexName) as sexname, DATE_FORMAT(T_OrderHeaderDate,'%d-%m-%Y') as orderdate, DATE_FORMAT(M_PatientDOB,'%d-%m-%Y') as dob, UPPER(T_OrderHeaderM_PatientAge) as umur, M_LangName as languange_name, GROUP_CONCAT(T_TestName separator ',') as test_name, '' as details, '' as verifications, T_OrderHeaderIsCito as iscito, 'xray' as type FROM so_resultentry JOIN t_orderdetail ON So_ResultEntryT_OrderDetailID = T_OrderDetailID AND T_OrderDetailIsActive = 'Y' JOIN t_test ON T_OrderDetailT_TestID = T_TestID AND T_TestNat_SubgroupID IN (17,18,19) JOIN t_orderheader ON So_ResultEntryT_OrderHeaderID = T_OrderHeaderID JOIN m_company ON T_OrderHeaderM_CompanyID = M_CompanyID JOIN m_patient ON T_OrderHeaderM_PatientID = M_PatientID JOIN m_sex ON M_PatientM_SexID = M_SexID LEFT JOIN m_title ON M_PatientM_TitleID = M_TitleID JOIN m_lang ON So_ResultEntryM_LangID = M_LangID $join_group $join_subgroup $sql_where GROUP BY T_OrderHeaderID HAVING fn_result_verification_check_ready_xray(T_OrderHeaderID) = 'Y' UNION SELECT T_OrderHeaderID as orderid, GROUP_CONCAT(T_OrderDetailID separator ',') as ids, fn_result_so_check_verification_status(T_OrderHeaderID,'usg') as status, T_OrderHeaderLabNumber as ordernumber, UPPER(CONCAT(M_TitleName,' ',M_PatientName)) as patient_fullname, UPPER(M_SexName) as sexname, DATE_FORMAT(T_OrderHeaderDate,'%d-%m-%Y') as orderdate, DATE_FORMAT(M_PatientDOB,'%d-%m-%Y') as dob, UPPER(T_OrderHeaderM_PatientAge) as umur, M_LangName as languange_name, GROUP_CONCAT(T_TestName separator ',') as test_name, '' as details, '' as verifications, T_OrderHeaderIsCito as iscito, 'usg' as type FROM so_resultentry JOIN t_orderdetail ON So_ResultEntryT_OrderDetailID = T_OrderDetailID AND T_OrderDetailIsActive = 'Y' JOIN t_test ON T_OrderDetailT_TestID = T_TestID AND T_TestNat_SubgroupID = 22 JOIN t_orderheader ON So_ResultEntryT_OrderHeaderID = T_OrderHeaderID JOIN m_company ON T_OrderHeaderM_CompanyID = M_CompanyID JOIN m_patient ON T_OrderHeaderM_PatientID = M_PatientID JOIN m_sex ON M_PatientM_SexID = M_SexID LEFT JOIN m_title ON M_PatientM_TitleID = M_TitleID JOIN m_lang ON So_ResultEntryM_LangID = M_LangID $join_group $join_subgroup $sql_where GROUP BY T_OrderHeaderID HAVING fn_result_verification_check_ready_usg(T_OrderHeaderID) = 'Y' UNION SELECT T_OrderHeaderID as orderid, GROUP_CONCAT(T_OrderDetailID separator ',') as ids, fn_result_so_check_verification_status(T_OrderHeaderID,'bdm') as status, T_OrderHeaderLabNumber as ordernumber, UPPER(CONCAT(M_TitleName,' ',M_PatientName)) as patient_fullname, UPPER(M_SexName) as sexname, DATE_FORMAT(T_OrderHeaderDate,'%d-%m-%Y') as orderdate, DATE_FORMAT(M_PatientDOB,'%d-%m-%Y') as dob, UPPER(T_OrderHeaderM_PatientAge) as umur, M_LangName as languange_name, GROUP_CONCAT(T_TestName separator ',') as test_name, '' as details, '' as verifications, T_OrderHeaderIsCito as iscito, 'bdm' as type FROM so_resultentry JOIN t_orderdetail ON So_ResultEntryT_OrderDetailID = T_OrderDetailID AND T_OrderDetailIsActive = 'Y' JOIN t_test ON T_OrderDetailT_TestID = T_TestID AND T_TestNat_SubgroupID = 20 JOIN t_orderheader ON So_ResultEntryT_OrderHeaderID = T_OrderHeaderID JOIN m_company ON T_OrderHeaderM_CompanyID = M_CompanyID JOIN m_patient ON T_OrderHeaderM_PatientID = M_PatientID JOIN m_sex ON M_PatientM_SexID = M_SexID LEFT JOIN m_title ON M_PatientM_TitleID = M_TitleID JOIN m_lang ON So_ResultEntryM_LangID = M_LangID $join_group $join_subgroup $sql_where GROUP BY T_OrderHeaderID HAVING fn_result_verification_check_ready_bdm(T_OrderHeaderID) = 'Y' UNION SELECT T_OrderHeaderID as orderid, GROUP_CONCAT(T_OrderDetailID separator ',') as ids, fn_result_so_check_verification_status(T_OrderHeaderID,'scan') as status, T_OrderHeaderLabNumber as ordernumber, UPPER(CONCAT(M_TitleName,' ',M_PatientName)) as patient_fullname, UPPER(M_SexName) as sexname, DATE_FORMAT(T_OrderHeaderDate,'%d-%m-%Y') as orderdate, DATE_FORMAT(M_PatientDOB,'%d-%m-%Y') as dob, UPPER(T_OrderHeaderM_PatientAge) as umur, M_LangName as languange_name, GROUP_CONCAT(T_TestName separator ',') as test_name, '' as details, '' as verifications, T_OrderHeaderIsCito as iscito, 'scan' as type FROM so_resultentry JOIN t_orderdetail ON So_ResultEntryT_OrderDetailID = T_OrderDetailID AND T_OrderDetailIsActive = 'Y' JOIN t_test ON T_OrderDetailT_TestID = T_TestID AND T_TestNat_SubgroupID IN (21,23) JOIN t_orderheader ON So_ResultEntryT_OrderHeaderID = T_OrderHeaderID JOIN m_company ON T_OrderHeaderM_CompanyID = M_CompanyID JOIN m_patient ON T_OrderHeaderM_PatientID = M_PatientID JOIN m_sex ON M_PatientM_SexID = M_SexID LEFT JOIN m_title ON M_PatientM_TitleID = M_TitleID JOIN m_lang ON So_ResultEntryM_LangID = M_LangID $join_group $join_subgroup $sql_where GROUP BY T_OrderHeaderID HAVING fn_result_verification_check_ready_scan(T_OrderHeaderID) = 'Y' "; //echo $sql; $query = $this->db_onedev->query($sql); $rows = $query->result_array(); //echo $this->db_onedev->last_query(); if($rows){ foreach($rows as $k => $v){ $rows[$k]['verifications'] = $this->add_verifications_label($v['orderid'],$v['type']); } } $result = array("total" => count($rst), "records" => $rows, "sql"=> ''); $this->sys_ok($result); exit; } function verify(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $userid = $this->sys_user["M_UserID"]; $xstatus = $prm['act']; $ids = '['.$prm['ids'].']'; if($xstatus == 'Y'){ $msg = "Berhasil melakukan verifikasi"; $query =" INSERT INTO result_verifications_value ( Result_VerificationsValueT_OrderHeaderID, Result_VerificationsValueType, Result_VerificationsValueIds, Result_VerificationsValueCheck, Result_VerificationsValueNote, Result_VerificationsValueUserID, Result_VerificationsValueCreated ) SELECT {$prm['orderid']}, '{$prm['type']}', '{$ids}', 'Y', '', {$userid}, NOW() FROM result_verifications WHERE Result_VerificationIsActive = 'Y' ON DUPLICATE KEY UPDATE Result_VerificationsValueCheck = 'Y', Result_VerificationsValueNote = '', Result_VerificationsValueUserID = {$userid}, Result_VerificationsValueLastUpdated = NOW() "; //echo $query; $this->db_onedev->query($query); $sql = " INSERT INTO result_frontoffice( Result_FrontOfficeT_OrderHeaderID, Result_FrontOfficeIds, Result_FrontOfficeStatus, Result_FrontOfficeType, Result_FrontOfficeTestName, Result_FrontOfficeCreated, Result_FrontOfficeUserID ) VALUES( {$prm['orderid']}, '{$ids}', 'P', '{$prm['type']}', '{$prm['test_name']}', NOW(), {$userid} ) ON DUPLICATE KEY UPDATE Result_FrontOfficeStatus = 'P', Result_FrontOfficeType = '{$prm['type']}', Result_FrontOfficeUserID = {$userid} "; //echo $sql; $this->db_onedev->query($sql); $sql = "UPDATE so_resultentry SET So_ResultEntryStatus = 'VAL2' , So_ResultEntryValidation2 = 'Y' WHERE JSON_CONTAINS('{$ids}',So_ResultEntryT_OrderDetailID) "; //echo $sql; $this->db_onedev->query($sql); } else{ $msg = "Tolak untuk perbaikan"; $verifications = $prm['verifications']; foreach($verifications as $k => $v){ $chx = $v['chex'] == true ?'Y':'N'; $query =" INSERT INTO result_verifications_value ( Result_VerificationsValueT_OrderHeaderID, Result_VerificationsValueType, Result_VerificationsValueIds, Result_VerificationsValueResult_VerificationsID, Result_VerificationsValueCheck, Result_VerificationsValueNote, Result_VerificationsValueUserID, Result_VerificationsValueCreated ) values( {$prm['orderid']}, '{$prm['type']}', '{$ids}', {$v['id']}, '{$chx}', '{$v['note']}', {$userid}, NOW() ) ON DUPLICATE KEY UPDATE Result_VerificationsValueCheck = '{$chx}', Result_VerificationsValueNote = '{$v['note']}', Result_VerificationsValueUserID = {$userid}, Result_VerificationsValueLastUpdated = NOW() "; //echo $query; $this->db_onedev->query($query); } } $result = array ("total" => 0, "records" => array('status'=>'OK','message'=>$msg)); $this->sys_ok($result); } }