Files
BE_IBL/application/controllers/mockup/couriercominghome/Done.php
2026-04-15 15:24:12 +07:00

367 lines
12 KiB
PHP

<?php
class Done extends MY_Controller
{
var $db_onedev;
public function index()
{
echo "SampleStorage 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;
}
$spk = $prm['spk'];
$sql = "SELECT T_OrderHeaderID as order_id,
Result_CourierSPKDetailResult_CourierSPKID as spk_id,
IFNULL(Result_CourierComingHomeConfirmed,'X') as status_confirmed,
IFNULL(Result_CourierComingHomeID,0) as header_id,
IFNULL(Result_CourierComingHomeDetailsID,0) as detail_id,
Result_CourierSPKDetailID as spk_detail_id,
DATE_FORMAT(T_OrderPromiseDateTime,'%d-%m-%Y %H:%i') as date_promise,
CONCAT(IFNULL(M_TitleName,''),' ',M_PatientName) as patient_fullname,
M_CompanyName,
'' as selected_receive,
M_MouIsBill as flag_bill,
IFNULL(Result_CourierComingHomeDetailsM_CourierStatusReceiveID,0) as received_id,
IFNULL(M_CourierStatusReceiveCode,'XXX') as received_code,
IFNULL(M_CourierStatusReceiveStatus,'') as received_status,
IFNULL(M_CourierStatusReceiveName,'Pilih status') as received_name,
IFNULL(Result_CourierComingHomeDetailsReceiver,'') as receiver_name,
IFNULL(DATE_FORMAT(Result_CourierComingHomeDetailsReceivedDateTime,'%d%m%Y%H%i'),'000000000000') as received_datetime,
DATE_FORMAT(Result_CourierComingHomeDetailsReceivedDateTime,'%d-%m-%Y %H:%i') as received_datetime_ina,
IFNULL(Result_CourierComingHomeDetailsPayment,0) as payment,
Result_CourierSPKDetailForceDone as force_done,
Last_StatusPaymentBillTotal as bill_total,
Last_StatusPaymentPaid as paid,
T_OrderHeaderLabNumberExt as no_reg,
courier_staff.M_StaffName as staff_name,
IFNULL(Result_CourierComingHomeConfirmed,'X') as status,
IFNULL(confirmed_staff.M_StaffName,'Belum dikonfirmasi') as confirmed_by,
Last_StatusPaymentIsLunas as status_payment,
Last_StatusPaymentUnpaid as unpaid
FROM result_courierspk_detail
JOIN result_courierspk ON Result_CourierSPKID = Result_CourierSPKDetailResult_CourierSPKID
JOIN t_orderpromise ON Result_CourierSPKDetailT_OrderPromiseID = T_OrderPromiseID AND T_OrderPromiseIsActive = 'Y'
JOIN t_orderdelivery ON Result_CourierSPKDetailT_OrderDeliveryID = T_OrderDeliveryID AND T_OrderDeliveryIsActive = 'Y'
JOIN t_orderheader ON T_OrderDeliveryT_OrderHeaderID = T_OrderHeaderID
JOIN m_mou ON T_OrderHeaderM_MouID = M_MouID
JOIN last_statuspayment ON Last_StatusPaymentT_OrderHeaderID = T_OrderHeaderID
JOIN m_company ON T_OrderHeaderM_CompanyID = M_CompanyID
JOIN m_courier ON Result_CourierSPKM_CourierID = M_CourierID
JOIN m_staff courier_staff ON M_CourierM_StaffID = courier_staff.M_StaffID
JOIN m_patient ON T_OrderHeaderM_PatientID = M_PatientID
LEFT JOIN m_title ON M_PatientM_TitleID = M_TitleID
LEFT JOIN result_couriercominghome_details ON
Result_CourierComingHomeDetailsResult_CourierSPKDetailID = Result_CourierSPKDetailID
LEFT JOIN result_couriercominghome ON Result_CourierComingHomeDetailsResult_CourierComingHomeID = Result_CourierComingHomeID
LEFT JOIN m_user ON Result_CourierComingHomeConfirmBy = M_UserID
LEFT JOIN m_staff confirmed_staff ON M_UserM_StaffID = confirmed_staff.M_StaffID
LEFT JOIN m_courierstatusreceive ON Result_CourierComingHomeDetailsM_CourierStatusReceiveID = M_CourierStatusReceiveID
WHERE
Result_CourierSPKDetailResult_CourierSPKID = {$spk} AND
Result_CourierSPKStatus <> 'S' AND
( Result_CourierSPKDetailStatus = 'S' OR Result_CourierSPKDetailStatus = 'D' ) AND
Result_CourierSPKDetailIsActive = 'Y'
GROUP BY spk_detail_id
ORDER BY T_OrderPromiseDateTime ASC, T_OrderHeaderID ASC";
//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]['chex'] = false;
$rows[$k]['selected_receive'] = array("id"=>$v['received_id'],"code"=>$v['received_code'],"name"=>$v['received_name'],"status"=>$v["received_status"]);
}
}
$result = array("total" => $tot_page, "records" => $rows, "sql"=> '');
$this->sys_ok($result);
exit;
}
function getkerajaan(){
if (! $this->isLogin) {
$this->sys_error("Invalid Token");
exit;
}
//$rst = array(array('id'=>0,'name'=>'Semua'));
$sql = "SELECT 0 as id, 'Semua' as name UNION SELECT Nat_GroupID as id, Nat_GroupName as name FROM nat_group WHERE Nat_GroupIsActive = 'Y'";
$rst_db = $this->db_onedev->query($sql)->result_array();
//$c = array_combine($rst,$rst_db);
$result = array(
"total" => 1 ,
"records" => $rst_db
);
$this->sys_ok($result);
exit;
}
function dosend(){
if (! $this->isLogin) {
$this->sys_error("Invalid Token");
exit;
}
$prm = $this->sys_input;
$userid = $this->sys_user['M_UserID'];
$selected = $prm['selected'];
foreach($selected as $k => $v){
$sql = "UPDATE result_frontoffice SET Result_FrontOfficeStatus = 'R' WHERE Result_FrontOfficeID = {$v['xid']}";
$this->db_onedev->query($sql);
}
$result = array(
"total" => 1 ,
"records" => array('status'=>'OK'),
);
$this->sys_ok($result);
exit;
}
function savereport(){
if (! $this->isLogin) {
$this->sys_error("Invalid Token");
exit;
}
$prm = $this->sys_input;
$userid = $this->sys_user['M_UserID'];
$data = $prm['data'];
$spk_id = $data[0]['spk_id'];
$header_id = intval($data[0]['header_id']);
$last_id = $header_id;
if($header_id == 0){
$sql = "INSERT INTO result_couriercominghome(
Result_CourierComingHomeResultCourierSpkID,
Result_CourierComingHomeDateTime,
Result_CourierComingHomeCreated,
Result_CourierComingHomeUserID
)
VALUES(
{$spk_id},
NOW(),
NOW(),
{$userid}
)";
$this->db_onedev->query($sql);
$last_id = $this->db_onedev->insert_id();
}
foreach($data as $k => $v){
$detail_id = intval($v['detail_id']);
$xdatetime = $v['received_datetime'];
//echo substr($xdatetime,0,2)."-".substr($xdatetime,2,2)."-".substr($xdatetime,4,4)." ".substr($xdatetime,9,2).":".substr($xdatetime,11,2);
$xdatetime = date("Y-m-d H:i:s", strtotime(substr($xdatetime,0,2)."-".substr($xdatetime,2,2)."-".substr($xdatetime,4,4)." ".substr($xdatetime,8,2).":".substr($xdatetime,10,2)));
//echo $xdatetime;
if($detail_id == 0){
$sql = "INSERT INTO result_couriercominghome_details(
Result_CourierComingHomeDetailsResult_CourierComingHomeID,
Result_CourierComingHomeDetailsResult_CourierSPKDetailID,
Result_CourierComingHomeDetailsM_CourierStatusReceiveID,
Result_CourierComingHomeDetailsReceiver,
Result_CourierComingHomeDetailsPayment,
Result_CourierComingHomeDetailsReceivedDateTime,
Result_CourierComingHomeDetailsUserID,
Result_CourierComingHomeDetailsCreated
)
VALUES(
{$last_id},
{$v['spk_detail_id']},
{$v['received_id']},
'{$v['receiver_name']}',
{$v['payment']},
'{$xdatetime}',
{$userid},
NOW()
)";
}
else{
$sql = "UPDATE result_couriercominghome_details SET
Result_CourierComingHomeDetailsResult_CourierComingHomeID = {$last_id},
Result_CourierComingHomeDetailsResult_CourierSPKDetailID = {$v['spk_detail_id']},
Result_CourierComingHomeDetailsM_CourierStatusReceiveID = {$v['received_id']},
Result_CourierComingHomeDetailsReceiver = '{$v['receiver_name']}',
Result_CourierComingHomeDetailsPayment = {$v['payment']},
Result_CourierComingHomeDetailsReceivedDateTime = '{$xdatetime}',
Result_CourierComingHomeDetailsUserID = {$userid}
WHERE
Result_CourierComingHomeDetailsID = {$detail_id}
";
}
$this->db_onedev->query($sql);
}
$result = array(
"total" => 1 ,
"records" => array('status'=>'OK'),
);
$this->sys_ok($result);
exit;
}
function confirmreport(){
if (! $this->isLogin) {
$this->sys_error("Invalid Token");
exit;
}
$prm = $this->sys_input;
$userid = $this->sys_user['M_UserID'];
$data = $prm['data'];
$spk_id = $data[0]['spk_id'];
$header_id = intval($data[0]['header_id']);
$last_id = $header_id;
$sql = "UPDATE result_couriercominghome SET
Result_CourierComingHomeConfirmed = 'Y',
Result_CourierComingHomeConfirmBy = {$userid},
Result_CourierComingHomeConfirmDateTime = NOW(),
Result_CourierComingHomeUserID = {$userid}
WHERE
Result_CourierComingHomeID = {$header_id}
";
$this->db_onedev->query($sql);
foreach($data as $k => $v){
$detail_id = intval($v['detail_id']);
$sql = "UPDATE result_couriercominghome_details SET
Result_CourierComingHomeDetailsFlagConfirmed = 'Y',
Result_CourierComingHomeDetailsUserID = {$userid}
WHERE
Result_CourierComingHomeDetailsID = {$detail_id}
";
$this->db_onedev->query($sql);
//echo $sql;
}
$result = array(
"total" => 1 ,
"records" => array('status'=>'OK'),
);
$this->sys_ok($result);
exit;
}
public function getspk()
{
$prm = $this->sys_input;
if (! $this->isLogin) {
$this->sys_error("Invalid Token");
exit;
}
$sql = "SELECT Result_CourierSPKID as id,
CONCAT(Result_CourierSPKNumbering,' ',M_StaffName) as name
FROM result_courierspk
JOIN m_courier ON Result_CourierSPKM_CourierID = M_CourierID
JOIN m_staff ON M_CourierM_StaffID = M_StaffID
WHERE
Result_CourierSPKDate = '{$prm['startdate']}' AND
Result_CourierSPKIsActive = 'Y'
ORDER BY Result_CourierSPKNumbering ASC";
$query = $this->db_onedev->query($sql);
$rows = $query->result_array();
$result = array("total" => count($rows), "records" => $rows, "sql"=> '');
$this->sys_ok($result);
exit;
}
function sendemail(){
try {
//# cek token valid
if (! $this->isLogin) {
$this->sys_error("Invalid Token");
exit;
}
$prm = $this->sys_input;
$userid = $this->sys_user['M_UserID'];
$rows = array();
$ids = "(".$prm['ids'].")";
$sql = "UPDATE result_sendemail SET Result_SendEmailStatus = 'S', Result_SendEmailUserID = {$userid} WHERE Result_SendEmailID IN {$ids}";
//echo $sql;
$this->db_onedev->query($sql);
$sql = "SELECT * FROM result_sendemail WHERE Result_SendEmailID IN {$ids}";
$dt_rst = $this->db_onedev->query($sql)->result_array();
foreach($dt_rst as $k => $v){
$dt_log = json_encode($v);
$sql = "INSERT INTO one_log.log_resultsendemail (
Log_ResultSendEmailDatetime,
Log_ResultSendEmailJson,
Log_ResultSendEmailUserID
)
VALUES(
NOW(),
'{$dt_log}',
{$userid}
)";
$this->db_onedev->query($sql);
}
$result = array ("total" => 0, "records" => $rows);
$this->sys_ok($result);
} catch(Exception $exc) {
$message = $exc->getMessage();
$this->sys_error($message);
}
}
function updateemail(){
try {
//# cek token valid
if (! $this->isLogin) {
$this->sys_error("Invalid Token");
exit;
}
$prm = $this->sys_input;
$userid = $this->sys_user['M_UserID'];
$rows = array();
$id = $prm['id'];
$sql = "UPDATE t_orderdelivery SET T_OrderDeliveryDestination = '{$prm['edited_email']}', T_OrderDeliveryUserID = {$userid} WHERE T_OrderDeliveryID = {$id}";
//echo $sql;
$this->db_onedev->query($sql);
$result = array ("total" => 0, "records" => array());
$this->sys_ok($result);
} catch(Exception $exc) {
$message = $exc->getMessage();
$this->sys_error($message);
}
}
}