db_onedev = $this->load->database("onedev", true); } public function search() { $prm = $this->sys_input; if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $nama = $prm["nama"]; //echo $companyid; $sql_where = "WHERE T_TestCalculationIsActive = 'Y'"; $sql_param = array(); if ($nama != "") { if ($sql_where != "") { $sql_where .=" and "; } $sql_where .= " Nat_TestName like ? OR T_TestCalculationName like ?"; $sql_param[] = "%$nama%"; $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 t_testcalculation JOIN nat_test ON T_TestCalculationNat_TestID = Nat_TestID $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_testcalculation count", $this->db_onedev); exit; } $sql = "SELECT T_TestCalculationID, T_TestCalculationName, T_TestCalculationNat_TestID, Nat_TestName, Nat_TestCode, T_TestCalculationFormula, T_TestCalculationIsAge, T_TestCalculationIsSex FROM t_testcalculation JOIN nat_test ON T_TestCalculationNat_TestID = Nat_TestID $sql_where ORDER BY T_TestCalculationID DESC limit 0,$tot_count"; //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 getsexreg(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $sexid = $prm['sexid']; $rows = []; $query =" SELECT * FROM m_title JOIN m_sex ON M_TitleM_SexID = M_SexID WHERE M_TitleIsActive = 'Y' "; //echo $query; $rows['titles'] = $this->db_onedev->query($query)->result_array(); $query =" SELECT * FROM m_sex WHERE ($sexid = 0 or ($sexid > 0 and M_SexID = $sexid)) "; //echo $query; $rows['sexes'] = $this->db_onedev->query($query)->result_array(); $result = array( "total" => count($rows) , "records" => $rows, ); $this->sys_ok($result); exit; } function getdetail(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $query =" SELECT t_testcalculation_detail.*, Nat_TestID, Nat_TestName, '' as tes, 'xxx' as tests, '' as action FROM t_testcalculation LEFT JOIN t_testcalculation_detail ON T_TestCalculationID = T_TestCalculationDetailT_TestCalculationID AND T_TestCalculationDetailIsActive = 'Y' JOIN nat_test ON T_TestCalculationDetailNat_TestID = Nat_TestID WHERE T_TestCalculationIsActive = 'Y' AND T_TestCalculationID = ? "; //echo $query; $rows = $this->db_onedev->query($query,array($prm['id']))->result_array(); if($rows){ foreach($rows as $k => $v){ $rows[$k]['tests'] = $this->add_test($v['T_TestCalculationDetailT_TestCalculationID']); } } $result = array( "total" => count($rows) , "records" => $rows ); $this->sys_ok($result); exit; } function add_test($orderid){ $query =" SELECT t_testcalculation_detail.*, 'Y' as editable, T_TestCalculationDetailID as xid, Nat_TestID, CONCAT('[',T_TestCalculationDetailCode,'] ',Nat_TestName) as Nat_TestName FROM t_testcalculation_detail JOIN nat_test ON T_TestCalculationDetailNat_TestID = Nat_TestID WHERE T_TestCalculationDetailT_TestCalculationID = {$orderid} AND T_TestCalculationDetailIsActive = 'Y' GROUP BY T_TestCalculationDetailID"; //echo $query; $rows = $this->db_onedev->query($query)->result_array(); if(!$rows) $rows = array(); return $rows; } public function getnumber() { $prm = $this->sys_input; if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $testid = $prm['Nat_TestID']; $testname = $prm['Nat_TestName']; $numbering = $this->db_onedev->query("SELECT fn_numbering('CALC') as numbering")->row()->numbering; $sql = $this->db_onedev->query("SELECT CASE WHEN S_NumberingCounter = 1 THEN 'AA' WHEN S_NumberingCounter = 2 THEN 'AB' WHEN S_NumberingCounter = 3 THEN 'AC' WHEN S_NumberingCounter = 4 THEN 'AD' WHEN S_NumberingCounter = 5 THEN 'AE' WHEN S_NumberingCounter = 6 THEN 'AF' WHEN S_NumberingCounter = 7 THEN 'AG' WHEN S_NumberingCounter = 8 THEN 'AH' WHEN S_NumberingCounter = 9 THEN 'AI' WHEN S_NumberingCounter = 10 THEN 'AJ' WHEN S_NumberingCounter = 11 THEN 'AK' WHEN S_NumberingCounter = 12 THEN 'AL' WHEN S_NumberingCounter = 13 THEN 'AM' WHEN S_NumberingCounter = 14 THEN 'AN' WHEN S_NumberingCounter = 15 THEN 'AO' WHEN S_NumberingCounter = 16 THEN 'AP' WHEN S_NumberingCounter = 17 THEN 'AQ' WHEN S_NumberingCounter = 18 THEN 'AR' WHEN S_NumberingCounter = 19 THEN 'AS' WHEN S_NumberingCounter = 20 THEN 'AT' WHEN S_NumberingCounter = 21 THEN 'AU' WHEN S_NumberingCounter = 22 THEN 'AV' WHEN S_NumberingCounter = 23 THEN 'AW' WHEN S_NumberingCounter = 24 THEN 'AX' WHEN S_NumberingCounter = 25 THEN 'AX' WHEN S_NumberingCounter = 26 THEN 'AZ' ELSE 'BA' END as getnumbering FROM s_numbering WHERE S_NumberingType = 'CALC'")->row(); $getnumbering = $sql->getnumbering; $query ="SELECT *, CONCAT('[',T_TestCalculationDetailCode,'] ','{$testname}') as Nat_TestName, T_TestCalculationDetailCode FROM (SELECT 'Y' as editable, '{$testid}' as Nat_TestID, '{$testname}' as Nat_TestName, CASE WHEN S_NumberingCounter = 1 THEN 'AA' WHEN S_NumberingCounter = 2 THEN 'AB' WHEN S_NumberingCounter = 3 THEN 'AC' WHEN S_NumberingCounter = 4 THEN 'AD' WHEN S_NumberingCounter = 5 THEN 'AE' WHEN S_NumberingCounter = 6 THEN 'AF' WHEN S_NumberingCounter = 7 THEN 'AG' WHEN S_NumberingCounter = 8 THEN 'AH' WHEN S_NumberingCounter = 9 THEN 'AI' WHEN S_NumberingCounter = 10 THEN 'AJ' WHEN S_NumberingCounter = 11 THEN 'AK' WHEN S_NumberingCounter = 12 THEN 'AL' WHEN S_NumberingCounter = 13 THEN 'AM' WHEN S_NumberingCounter = 14 THEN 'AN' WHEN S_NumberingCounter = 15 THEN 'AO' WHEN S_NumberingCounter = 16 THEN 'AP' WHEN S_NumberingCounter = 17 THEN 'AQ' WHEN S_NumberingCounter = 18 THEN 'AR' WHEN S_NumberingCounter = 19 THEN 'AS' WHEN S_NumberingCounter = 20 THEN 'AT' WHEN S_NumberingCounter = 21 THEN 'AU' WHEN S_NumberingCounter = 22 THEN 'AV' WHEN S_NumberingCounter = 23 THEN 'AW' WHEN S_NumberingCounter = 24 THEN 'AX' WHEN S_NumberingCounter = 25 THEN 'AX' WHEN S_NumberingCounter = 26 THEN 'AZ' ELSE 'BA' END as T_TestCalculationDetailCode FROM s_numbering WHERE S_NumberingType = 'CALC') a "; //echo $query; $rows = $this->db_onedev->query($query)->result_array(); //$this->_add_address($rows); $result = array("records" => $rows,"number" => $getnumbering); $this->sys_ok($result); exit; } function deletenumber(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $userid = $this->sys_user["M_UserID"]; $query ="UPDATE s_numbering SET S_NumberingCounter = S_NumberingCounter - 1 WHERE S_NumberingType = 'CALC' "; //echo $query; $rows = $this->db_onedev->query($query); $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function savenewdetail(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $userid = $this->sys_user["M_UserID"]; $query ="INSERT INTO t_testcalculation( T_TestCalculationName, T_TestCalculationNat_TestID, T_TestCalculationFormula, T_TestCalculationIsAge, T_TestCalculationIsSex, T_TestCalculationUserID, T_TestCalculationCreatedDateTime, T_TestCalculationLastUpdated ) VALUES( '{$prm['T_TestCalculationName']}', '{$prm['T_TestCalculationNat_TestID']}', '{$prm['T_TestCalculationFormula']}', '{$prm['T_TestCalculationIsAge']}', '{$prm['T_TestCalculationIsSex']}', '{$userid}', NOW(), NOW() ) "; //echo $query; $rows = $this->db_onedev->query($query); $orderdetail_id = $this->db_onedev->insert_id(); foreach($prm['ordertests'] as $k=>$v){ $query = "INSERT INTO t_testcalculation_detail ( T_TestCalculationDetailT_TestCalculationID, T_TestCalculationDetailNat_TestID, T_TestCalculationDetailCode, T_TestCalculationDetailUserID, T_TestCalculationDetailCreatedDateTime, T_TestCalculationDetailLastUpdated ) VALUE( ?,?,?,?,now(),now() )"; $insert_new_test = $this->db_onedev->query($query,array( $orderdetail_id, $v['Nat_TestID'], $v['T_TestCalculationDetailCode'], $userid )); } $result = array( "total" => 1 , "records" => array('status'=>'OK'), "id" => $orderdetail_id ); $this->sys_ok($result); exit; } function saveeditdetail(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $order_id = $prm['T_TestCalculationID']; $userid = $this->sys_user["M_UserID"]; $query ="UPDATE t_testcalculation SET T_TestCalculationName = '{$prm['T_TestCalculationName']}', T_TestCalculationNat_TestID = '{$prm['T_TestCalculationNat_TestID']}', T_TestCalculationFormula = '{$prm['T_TestCalculationFormula']}', T_TestCalculationIsAge = '{$prm['T_TestCalculationIsAge']}', T_TestCalculationIsSex = '{$prm['T_TestCalculationIsSex']}', T_TestCalculationUserID = '{$userid}' WHERE T_TestCalculationID = '{$prm['T_TestCalculationID']}' "; //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_testcalculation_detail ( T_TestCalculationDetailT_TestCalculationID, T_TestCalculationDetailNat_TestID, T_TestCalculationDetailCode, T_TestCalculationDetailUserID, T_TestCalculationDetailCreatedDateTime, T_TestCalculationDetailLastUpdated ) VALUE( ?,?,?,?,now(),now() )"; $insert_new_test = $this->db_onedev->query($query,array( $order_id, $v['Nat_TestID'], $v['T_TestCalculationDetailCode'], $userid )); } } if(isset($prm['deleted_ordertests'])){ foreach($prm['deleted_ordertests'] as $i=>$del){ $query = "UPDATE t_testcalculation_detail SET T_TestCalculationDetailIsActive = 'N', T_TestCalculationDetailUserID = '{$userid}', T_TestCalculationDetailLastUpdated = now() WHERE T_TestCalculationDetailID = ? "; $delete_exist_test = $this->db_onedev->query($query,array($del['T_TestCalculationDetailID'],)); } } $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function delete(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $userid = $this->sys_user["M_UserID"]; $query ="UPDATE t_testcalculation SET T_TestCalculationIsActive = 'N', T_TestCalculationUserID = '{$userid}' WHERE T_TestCalculationID = '{$prm['T_TestCalculationID']}' "; //echo $query; $rows = $this->db_onedev->query($query); $query ="UPDATE t_testcalculation_detail SET T_TestCalculationDetailIsActive = 'N', T_TestCalculationDetailUserID = '{$userid}' WHERE T_TestCalculationDetailT_TestCalculationID = '{$prm['T_TestCalculationID']}' "; //echo $query; $rows = $this->db_onedev->query($query); //echo $query; $rows = $this->db_onedev->query($query); $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function deletedetail(){ if (! $this->isLogin) { $this->sys_error("Invalid Token"); exit; } $prm = $this->sys_input; $userid = $this->sys_user["M_UserID"]; $query ="UPDATE t_testcalculation SET T_TestCalculationIsActive = 'N', T_TestCalculationUserID = '{$userid}' WHERE T_TestCalculationID = '{$prm['T_TestCalculationID']}' "; //echo $query; $rows = $this->db_onedev->query($query); $query ="UPDATE t_testcalculation_detail SET T_TestCalculationDetailIsActive = 'N', T_TestCalculationDetailUserID = '{$userid}' WHERE T_TestCalculationDetailT_TestCalculationID = '{$prm['T_TestCalculationID']}' AND T_TestCalculationDetailIsActive = 'Y' "; //echo $query; $rows = $this->db_onedev->query($query); $result = array( "total" => 1 , "records" => array('status'=>'OK') ); $this->sys_ok($result); exit; } function searchtestheader(){ $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 nat_test WHERE Nat_TestName like ? AND Nat_TestIsActive = 'Y' AND Nat_TestIsResult = 'Y' ORDER BY Nat_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 Nat_TestID, Nat_TestName FROM nat_test WHERE Nat_TestName like ? AND Nat_TestIsActive = 'Y' AND Nat_TestIsResult = 'Y' ORDER BY Nat_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; } } function searchtest(){ $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 nat_test WHERE Nat_TestName like ? AND Nat_TestIsActive = 'Y' AND Nat_TestIsResult = 'Y' ORDER BY Nat_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, Nat_TestID, Nat_TestName FROM nat_test WHERE Nat_TestName like ? AND Nat_TestIsActive = 'Y' AND Nat_TestIsResult = 'Y' ORDER BY Nat_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; } } function searchtestfavorit(){ $prm = $this->sys_input; $max_rst = 12; $tot_count = 0; $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}' JOIN t_favorite ON T_TestID = T_FavoriteT_TestID AND T_FavoriteIsActive = 'Y' WHERE T_TestIsActive = 'Y' ORDER BY T_TestName ASC"; $query = $this->db_onedev->query($sql); //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, Nat_TestID,'N' as Nat_TestIsBill, 0 as Nat_TestMinDP 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.nat_test ON M_MouNat_TestID = Nat_TestID JOIN t_favorite ON T_TestID = T_FavoriteT_TestID AND T_FavoriteIsActive = 'Y' WHERE T_TestIsActive = 'Y' ORDER BY T_TestName ASC LIMIT 0,20 "; $query = $this->db_onedev->query($sql); 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; } } }