Files
BE_IBL/application/controllers/regonline/Booking.php
2026-04-15 15:23:57 +07:00

371 lines
11 KiB
PHP

<?php
class Booking extends MY_Controller
{
var $db_onedev;
public function index()
{
echo "Schedule API";
}
public function __construct()
{
parent::__construct();
$this->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'] = '<v-icon color="error" @click="deleteAddress(props.item)">delete</v-icon>';
$rows[$k]['action'] .= '<v-icon color="primary" @click="deleteAddress(props.item)">edit</v-icon>';
}
}
$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;
}
}
}