Files
BE_IBL/application/controllers/mockup/fo/mergeemailv1/Done.php
2026-05-29 14:21:47 +07:00

282 lines
7.2 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);
$this->load->library('Ibl_merge_report_gateway');
}
public function search()
{
$prm = $this->sys_input;
if (!$this->isLogin) {
$this->sys_error("Invalid Token");
exit;
}
$nolab = $prm["nolab"];
$groupid = $prm["groupid"];
//$subgroupid = $prm["subgroupid"];
$join_group = '';
if ($groupid != '0') {
$join_group = "JOIN nat_group ON T_TestNat_GroupID = Nat_GroupID AND Nat_GroupID = {$groupid}";
}
/*$join_subgroup = '';
if($subgroupid != 0){
$join_group = "JOIN nat_subgroup ON T_TestNat_SubgroupID = Nat_SubgroupID AND Nat_SubgroupID = {$subgroupid}";
}*/
if (!isset($prm['current_page']))
$prm['current_page'] = 1;
$sql_where = "WHERE Result_FrontOfficeStatus = 'S' AND JSON_CONTAINS(Result_FrontOfficeIds,T_OrderDetailID)";
$number_limit = 10;
$number_offset = ($prm['current_page'] - 1) * $number_limit;
//$sql_param = array();
if ($nolab != "") {
if ($sql_where != "") {
$sql_where .= " and ";
}
$sql_where .= " ( T_OrderHeaderLabNumber like '%$nolab%' OR M_PatientName like '%$nolab%' )";
}
$sql = "SELECT Result_FrontOfficeID as xid,
T_OrderHeaderID as orderid,
T_OrderHeaderLabNumber as ordernumber,
UPPER(CONCAT(M_TitleName,' ',M_PatientName)) as patient_fullname,
Result_FrontOfficeTestName as test_name,
'N' as chex
FROM result_frontoffice
join t_orderheader ON Result_FrontOfficeT_OrderHeaderID = T_OrderHeaderID
JOIN t_orderdetail ON T_OrderDetailT_OrderHeaderID = T_OrderHeaderID
JOIN t_test ON T_OrderDetailT_TestID = T_TestID AND JSON_CONTAINS(Result_FrontOfficeIds, T_OrderDetailID)
$join_group
JOIN m_patient ON T_OrderHeaderM_PatientID = M_PatientID
JOIN m_sex ON M_PatientM_SexID = M_SexID
LEFT JOIN m_title ON M_PatientM_TitleID = M_TitleID
$sql_where
GROUP BY Result_FrontOfficeID
";
$query = $this->db_onedev->query($sql);
$rows = $query->result_array();
foreach ($rows as $k => $v) {
if ($v['chex'] == 'N')
$rows[$k]['chex'] = false;
else
$rows[$k]['chex'] = true;
}
$result = array("total" => count($rst), "records" => $rows, "sql" => $this->db_onedev->last_query());
$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 mergereport()
{
if (!$this->isLogin) {
$this->sys_error("Invalid Token");
exit;
}
$prm = $this->sys_input;
$userid = $this->sys_user['M_UserID'];
$labNumber = isset($prm['T_OrderHeaderLabNumber']) ? trim($prm['T_OrderHeaderLabNumber']) : '';
if ($labNumber === '' && isset($prm['nolab'])) {
$labNumber = trim($prm['nolab']);
}
$name = isset($prm['name']) ? trim($prm['name']) : '';
if ($labNumber === '') {
$this->sys_error("LAB_NUMBER_REQUIRED - T_OrderHeaderLabNumber wajib diisi");
exit;
}
$resultMerge = $this->ibl_merge_report_gateway->create_merge_request_from_lab_number(
$labNumber,
$userid,
$name
);
if ($resultMerge['status'] !== 'OK') {
$this->sys_error($resultMerge['code'] . " - " . $resultMerge['message']);
exit;
}
$record = [
"last_id" => $resultMerge['data']['mergeRequestID'],
"url" => $resultMerge['data']['previewUrl'],
"T_OrderHeaderID" => $resultMerge['data']['T_OrderHeaderID'],
"T_OrderHeaderLabNumber" => $resultMerge['data']['T_OrderHeaderLabNumber'],
"snapshot" => $resultMerge['data']['snapshot'],
"go_payload_preview" => $resultMerge['data']['goPayloadPreview'],
];
$result = array(
"total" => 1,
"records" => array('status' => 'OK', 'records' => $record),
);
$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 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();
$sql = "INSERT INTO result_handoveremail (
Result_HandOverEmailSendDateTime,
Result_HandOverEmailT_OrderHeaderID,
Result_HandOverEmailT_OrderPromiseID,
Result_HandOverEmailT_OrderDeliveryID,
Result_HandOverEmailOfficer,
Result_HandOverEmailCreated,
Result_HandOverEmailUserID
)VALUES(
NOW(),
{$prm['order_id']},
{$prm['order_promise_id']},
{$prm['delivery_id']},
{$userid},
NOW(),
{$userid}
)
";
//echo $sql;
$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 resendemail()
{
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();
$sql = "UPDATE result_handoveremail SET
Result_HandOverEmailSendDateTime = NOW(),
Result_HandOverEmailOfficer = {$userid},
Result_HandOverEmailStatus = 'S',
Result_HandOverEmailRetry = 0,
Result_HandOverEmailUserID = {$userid}
WHERE
Result_HandOverEmailID = {$prm['xid']}
";
//echo $sql;
$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);
}
}
}