db_onedev = $this->load->database("onedev", true); } function getschedule(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $tanggal = $prm['tanggal']; $query =" SELECT M_BranchID, M_BranchName, M_BranchCode, 'xxx' as regtimes, '' as action FROM m_reg_kuota_branch JOIN m_branch ON M_BranchCode = M_RegKuotaM_BranchCode AND M_BranchIsActive = 'Y' LEFT JOIN t_reg_booking ON T_RegBookingM_BranchID = M_BranchID AND T_RegBookingDate = '{$tanggal}' AND T_RegBookingIsActive = 'Y' WHERE M_RegKuotaIsActive = 'Y' AND M_RegKuotaIsWork = 'Y' GROUP BY M_BranchID ORDER BY M_BranchS_RegionalID ASC, M_BranchID ASC "; //echo $query; $rows = $this->db_onedev->query($query)->result_array(); if($rows){ foreach($rows as $k => $v){ $x = $this->db_onedev->query("select concat( '[', group_concat( json_object('id',IFNULL(T_RegBookingID,M_RegKuotaID), 'tipe', tipe,'jumlah', jumlah) separator ',' ), ']' ) as n FROM (SELECT T_RegBookingID, 'CITO' as tipe, 20 as jumlah, M_RegKuotaID FROM m_reg_kuota_branch JOIN m_branch ON M_BranchCode = M_RegKuotaM_BranchCode AND M_BranchIsActive = 'Y' JOIN t_reg_booking ON T_RegBookingM_BranchID = M_BranchID AND T_RegBookingDate = '{$tanggal}' AND T_RegBookingIsActive = 'Y' WHERE M_RegKuotaIsActive = 'Y' AND M_RegKuotaIsWork = 'Y' GROUP BY M_BranchID UNION SELECT T_RegBookingID,'REGULER' as tipe, 30 as jumlah,M_RegKuotaID FROM m_reg_kuota_branch JOIN m_branch ON M_BranchCode = M_RegKuotaM_BranchCode AND M_BranchIsActive = 'Y' JOIN t_reg_booking ON T_RegBookingM_BranchID = M_BranchID AND T_RegBookingDate = '{$tanggal}' AND T_RegBookingIsActive = 'Y' WHERE M_RegKuotaIsActive = 'Y' AND M_RegKuotaIsWork = 'Y' GROUP BY M_BranchID) a")->row(); $rows[$k]['regtimex'] = json_decode($x->n); $rows[$k]['regtimes'] = $this->add_regtime($tanggal,$v['M_BranchID']); $rows[$k]['action'] = 'delete'; $rows[$k]['action'] .= 'edit'; } } $result = array( "total" => count($rows) , "records" => $rows, ); $this->sys_ok($result); exit; } function getbooking(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $tanggal = $prm['tanggal']; $query =" SELECT t_reg_booking.*, M_BranchID, M_BranchName, M_BranchCode, M_StaffID, M_StaffName, 'xxx' as regtimes, '' as action FROM t_reg_booking JOIN m_branch ON T_RegBookingM_BranchID = M_BranchID LEFT JOIN m_user ON M_UserID = T_RegBookingUserID LEFT JOIN m_staff ON M_StaffID = M_UserM_StaffID WHERE T_RegBookingDate = '{$tanggal}' AND T_RegBookingIsActive = 'Y' GROUP BY T_RegBookingID ORDER BY T_RegBookingID DESC "; //echo $query; $rows = $this->db_onedev->query($query)->result_array(); if($rows){ } $result = array( "total" => count($rows) , "records" => $rows, ); $this->sys_ok($result); exit; } function add_regtime($tanggal, $branchid){ $query =" SELECT t_reg_booking.*, M_BranchID, M_BranchName, M_BranchCode, 20 as jumlah, 'CITO' as tipe FROM m_reg_kuota_branch LEFT JOIN m_branch ON M_BranchCode = M_RegKuotaM_BranchCode AND M_BranchIsActive = 'Y' LEFT JOIN t_reg_booking ON T_RegBookingM_BranchID = M_BranchID AND T_RegBookingDate = '{$tanggal}' AND T_RegBookingIsActive = 'Y' WHERE M_RegKuotaIsActive = 'Y' AND M_RegKuotaIsWork = 'Y' AND M_RegKuotaM_BranchID = '{$branchid}' GROUP BY M_BranchID UNION SELECT t_reg_booking.*, M_BranchID, M_BranchName, M_BranchCode, 30 as jumlah, 'REGULER' as tipe FROM m_reg_kuota_branch LEFT JOIN m_branch ON M_BranchCode = M_RegKuotaM_BranchCode AND M_BranchIsActive = 'Y' LEFT JOIN t_reg_booking ON T_RegBookingM_BranchID = M_BranchID AND T_RegBookingDate = '{$tanggal}' AND T_RegBookingIsActive = 'Y' WHERE M_RegKuotaIsActive = 'Y' AND M_RegKuotaIsWork = 'Y' AND M_RegKuotaM_BranchID = '{$branchid}' GROUP BY M_BranchID"; //echo $query; $rows = $this->db_onedev->query($query)->result_array(); if(!$rows) $rows = array(); return $rows; } function getday(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $rows = []; $query =" SELECT * FROM m_reg_day WHERE M_RegDayIsActive = 'Y' "; //echo $query; $rows['days'] = $this->db_onedev->query($query)->result_array(); $result = array( "total" => count($rows) , "records" => $rows, ); $this->sys_ok($result); exit; } function getsubcategory(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $rows = []; $query =" SELECT * FROM t_subcategory JOIN t_category ON T_CategoryID = T_SubCategoryT_CategoryID AND T_CategoryName LIKE '%covid%' WHERE T_SubCategoryIsActive = 'Y' "; //echo $query; $rows['subcategorys'] = $this->db_onedev->query($query)->result_array(); $result = array( "total" => count($rows) , "records" => $rows, ); $this->sys_ok($result); exit; } 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 savenewbooking(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $T_RegBookingDate = $prm['T_RegBookingDate']; $T_RegBookingM_BranchID = $prm['T_RegBookingM_BranchID']; $T_RegBookingM_BranchCode = $prm['T_RegBookingM_BranchCode']; $T_RegBookingType = $prm['T_RegBookingType']; $T_RegBookingTotal = $prm['T_RegBookingTotal']; $T_RegBookingNote = $prm['T_RegBookingNote']; $userid = $this->sys_user["M_UserID"]; $query = "INSERT INTO t_reg_booking( T_RegBookingDate, T_RegBookingM_BranchID, T_RegBookingM_BranchCode, T_RegBookingType, T_RegBookingTotal, T_RegBookingNote, T_RegBookingStatus, T_RegBookingUserID, T_RegBookingCreated, T_RegBookingLastUpdated ) VALUES(?,?,?,?,?,?,?,?,now(),now())"; $insert_header = $this->db_onedev->query($query,array($T_RegBookingDate, $T_RegBookingM_BranchID, $T_RegBookingM_BranchCode, $T_RegBookingType, $T_RegBookingTotal, $T_RegBookingNote, 'Y', $userid)); $last_id = $this->db_onedev->insert_id(); $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function savecancelbooking(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $id = $prm['xid']; $T_RegBookingCancelNote = $prm['T_RegBookingCancelNote']; $userid = $this->sys_user["M_UserID"]; $sql = "UPDATE t_reg_booking SET T_RegBookingStatus = 'X', T_RegBookingCancelNote = ?, T_RegBookingCancelUserID = ?, T_RegBookingCancelDateTime = now() WHERE T_RegBookingID = ?"; $query = $this->db_onedev->query($sql, array($T_RegBookingCancelNote, $userid, $id ) ); $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; } } }