675 lines
21 KiB
PHP
675 lines
21 KiB
PHP
<?php
|
|
class Testcalculationnew extends MY_Controller
|
|
{
|
|
var $db_onedev;
|
|
public function index()
|
|
{
|
|
echo "Test Calculation API";
|
|
}
|
|
|
|
public function __construct()
|
|
{
|
|
parent::__construct();
|
|
$this->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_TestCalculationNat_SexID,
|
|
Nat_SexID,
|
|
IF(T_TestCalculationNat_SexID = 0,'',Nat_SexName) as Nat_SexName
|
|
FROM t_testcalculation
|
|
JOIN nat_test ON T_TestCalculationNat_TestID = Nat_TestID
|
|
LEFT JOIN nat_sex ON T_TestCalculationNat_SexID = Nat_SexID
|
|
$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){
|
|
$x = $this->db_onedev->query("select concat( '[', group_concat( json_object('id', T_TestCalculationDetailID, 'testname', CONCAT(T_TestCalculationDetailCode,' | ', Nat_TestName)) separator ',' ), ']' )
|
|
as n from t_testcalculation_detail
|
|
JOIN nat_test ON T_TestCalculationDetailNat_TestID = Nat_TestID
|
|
WHERE T_TestCalculationDetailT_TestCalculationID = '{$v['T_TestCalculationID']}' AND T_TestCalculationDetailIsActive = 'Y'")->row();
|
|
$rows[$k]['tesx'] = 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 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 nat_sex
|
|
WHERE
|
|
Nat_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 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 'AY'
|
|
WHEN S_NumberingCounter = 26 THEN 'AZ'
|
|
WHEN S_NumberingCounter = 27 THEN 'BA'
|
|
WHEN S_NumberingCounter = 28 THEN 'BB'
|
|
WHEN S_NumberingCounter = 29 THEN 'BC'
|
|
WHEN S_NumberingCounter = 30 THEN 'BD'
|
|
WHEN S_NumberingCounter = 31 THEN 'BE'
|
|
WHEN S_NumberingCounter = 32 THEN 'BF'
|
|
WHEN S_NumberingCounter = 33 THEN 'BG'
|
|
WHEN S_NumberingCounter = 34 THEN 'BH'
|
|
WHEN S_NumberingCounter = 35 THEN 'BI'
|
|
WHEN S_NumberingCounter = 36 THEN 'BJ'
|
|
WHEN S_NumberingCounter = 37 THEN 'BK'
|
|
WHEN S_NumberingCounter = 38 THEN 'BL'
|
|
WHEN S_NumberingCounter = 39 THEN 'BM'
|
|
WHEN S_NumberingCounter = 40 THEN 'BN'
|
|
WHEN S_NumberingCounter = 41 THEN 'BO'
|
|
WHEN S_NumberingCounter = 42 THEN 'BP'
|
|
WHEN S_NumberingCounter = 43 THEN 'BQ'
|
|
WHEN S_NumberingCounter = 44 THEN 'BR'
|
|
WHEN S_NumberingCounter = 45 THEN 'BS'
|
|
WHEN S_NumberingCounter = 46 THEN 'BT'
|
|
WHEN S_NumberingCounter = 47 THEN 'BU'
|
|
WHEN S_NumberingCounter = 48 THEN 'BV'
|
|
WHEN S_NumberingCounter = 49 THEN 'BW'
|
|
WHEN S_NumberingCounter = 50 THEN 'BX'
|
|
WHEN S_NumberingCounter = 51 THEN 'BY'
|
|
WHEN S_NumberingCounter = 52 THEN 'BZ'
|
|
ELSE 'CA'
|
|
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'
|
|
WHEN S_NumberingCounter = 27 THEN 'BA'
|
|
WHEN S_NumberingCounter = 28 THEN 'BB'
|
|
WHEN S_NumberingCounter = 29 THEN 'BC'
|
|
WHEN S_NumberingCounter = 30 THEN 'BD'
|
|
WHEN S_NumberingCounter = 31 THEN 'BE'
|
|
WHEN S_NumberingCounter = 32 THEN 'BF'
|
|
WHEN S_NumberingCounter = 33 THEN 'BG'
|
|
WHEN S_NumberingCounter = 34 THEN 'BH'
|
|
WHEN S_NumberingCounter = 35 THEN 'BI'
|
|
WHEN S_NumberingCounter = 36 THEN 'BJ'
|
|
WHEN S_NumberingCounter = 37 THEN 'BK'
|
|
WHEN S_NumberingCounter = 38 THEN 'BL'
|
|
WHEN S_NumberingCounter = 39 THEN 'BM'
|
|
WHEN S_NumberingCounter = 40 THEN 'BN'
|
|
WHEN S_NumberingCounter = 41 THEN 'BO'
|
|
WHEN S_NumberingCounter = 42 THEN 'BP'
|
|
WHEN S_NumberingCounter = 43 THEN 'BQ'
|
|
WHEN S_NumberingCounter = 44 THEN 'BR'
|
|
WHEN S_NumberingCounter = 45 THEN 'BS'
|
|
WHEN S_NumberingCounter = 46 THEN 'BT'
|
|
WHEN S_NumberingCounter = 47 THEN 'BU'
|
|
WHEN S_NumberingCounter = 48 THEN 'BV'
|
|
WHEN S_NumberingCounter = 49 THEN 'BW'
|
|
WHEN S_NumberingCounter = 50 THEN 'BX'
|
|
WHEN S_NumberingCounter = 51 THEN 'BY'
|
|
WHEN S_NumberingCounter = 52 THEN 'BZ'
|
|
ELSE 'CA'
|
|
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_TestCalculationNat_SexID,
|
|
T_TestCalculationUserID,
|
|
T_TestCalculationCreatedDateTime,
|
|
T_TestCalculationLastUpdated
|
|
)
|
|
VALUES(
|
|
'{$prm['T_TestCalculationName']}',
|
|
'{$prm['T_TestCalculationNat_TestID']}',
|
|
'{$prm['T_TestCalculationFormula']}',
|
|
'{$prm['T_TestCalculationNat_SexID']}',
|
|
'{$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_TestCalculationNat_SexID = '{$prm['T_TestCalculationNat_SexID']}',
|
|
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;
|
|
}
|
|
}
|
|
|
|
} |