367 lines
12 KiB
PHP
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);
|
|
}
|
|
}
|
|
|
|
} |