Merge remote-tracking branch 'origin/staging' into origin/production
This commit is contained in:
@@ -275,6 +275,7 @@ class ClaimController extends Controller
|
||||
'No',
|
||||
'Code',
|
||||
'Date Submission',
|
||||
'Date Admission',
|
||||
'Date Discharge',
|
||||
'Provider',
|
||||
'Member ID (BN)',
|
||||
@@ -320,6 +321,7 @@ class ClaimController extends Controller
|
||||
->select(
|
||||
DB::raw('1 AS no'),
|
||||
'request_logs.submission_date',
|
||||
'request_logs.created_at',
|
||||
'request_logs.discharge_date',
|
||||
'request_logs.organization_id',
|
||||
'request_logs.id',
|
||||
@@ -328,10 +330,15 @@ class ClaimController extends Controller
|
||||
'request_logs.code',
|
||||
'request_logs.diagnosis',
|
||||
'request_logs.keterangan',
|
||||
'request_logs.catatan'
|
||||
'request_logs.catatan',
|
||||
DB::raw('
|
||||
(Select SUM(request_log_benefits.amount_approved) as tot_bill FROM request_log_benefits
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id LIMIT 1) AS tot_bill
|
||||
')
|
||||
)
|
||||
->groupBy(
|
||||
'request_logs.submission_date',
|
||||
'request_logs.created_at',
|
||||
'request_logs.discharge_date',
|
||||
'request_logs.organization_id',
|
||||
'request_logs.id',
|
||||
@@ -340,7 +347,8 @@ class ClaimController extends Controller
|
||||
'request_logs.code',
|
||||
'request_logs.diagnosis',
|
||||
'request_logs.keterangan',
|
||||
'request_logs.catatan'
|
||||
'request_logs.catatan',
|
||||
'tot_bill'
|
||||
)
|
||||
->orderBy('request_logs.submission_date')
|
||||
->get();
|
||||
@@ -455,6 +463,7 @@ class ClaimController extends Controller
|
||||
}
|
||||
$total_billing = 0;
|
||||
$lastIndex = count($dataClaimLog) - 1;
|
||||
$firtIndex = 0;
|
||||
if (isset($dataClaimLog) && count($dataClaimLog) > 0)
|
||||
{
|
||||
foreach ($dataClaimLog as $index => $item_benefit)
|
||||
@@ -463,6 +472,7 @@ class ClaimController extends Controller
|
||||
$rowData = [
|
||||
$check_first_id != $item->id ? $no : $no,
|
||||
!empty($item->code) ? $item->code : '',
|
||||
!empty($item->created_at) ? $item->created_at : '',
|
||||
!empty($item->submission_date) ? $item->submission_date : '',
|
||||
!empty($item->discharge_date) ? $item->discharge_date : '',
|
||||
!empty($dataRumahSakit->nama_rumahsakit) ? $dataRumahSakit->nama_rumahsakit : '',
|
||||
@@ -473,7 +483,7 @@ class ClaimController extends Controller
|
||||
'LinkSehat',
|
||||
!empty($dataMember->nama_perusahaan) ? $dataMember->nama_perusahaan : '',
|
||||
!empty($dataMember->no_polis) ? $dataMember->no_polis : '',
|
||||
($lastIndex == $index ? $total_billing : ''),
|
||||
($firtIndex == $index ? $item->tot_bill : ''),
|
||||
!empty($item_benefit->code) ? $item_benefit->code : '',
|
||||
!empty($item_benefit->benfit) ? $item_benefit->benfit : '',
|
||||
!empty($item_benefit->amount_incurred) ? $item_benefit->amount_incurred : '',
|
||||
@@ -495,6 +505,7 @@ class ClaimController extends Controller
|
||||
$rowData = [
|
||||
$check_first_id != $item->id ? $no : '',
|
||||
!empty($item->code) ? $item->code : '',
|
||||
!empty($item->created_at) ? $item->created_at : '',
|
||||
!empty($item->submission_date) ? $item->submission_date : '',
|
||||
!empty($item->discharge_date) ? $item->discharge_date : '',
|
||||
!empty($dataRumahSakit->nama_rumahsakit) ? $dataRumahSakit->nama_rumahsakit : '',
|
||||
@@ -531,9 +542,9 @@ class ClaimController extends Controller
|
||||
->build();
|
||||
$grand_total_billing = 0;
|
||||
foreach ($dataRow as $rowData) {
|
||||
if (is_numeric($rowData[12])) {
|
||||
if (is_numeric($rowData[13])) {
|
||||
// Jumlahkan nilai angka ke total
|
||||
$grand_total_billing += $rowData[12];
|
||||
$grand_total_billing += $rowData[13];
|
||||
}
|
||||
$row = WriterEntityFactory::createRowFromArray($rowData, $style);
|
||||
$writer->addRow($row);
|
||||
@@ -552,6 +563,7 @@ class ClaimController extends Controller
|
||||
'',
|
||||
'',
|
||||
'',
|
||||
'',
|
||||
$grand_total_billing,
|
||||
'',
|
||||
'',
|
||||
|
||||
@@ -39,6 +39,13 @@ class DataServiceMonitoring extends JsonResource
|
||||
'diagnosis' => $filesFinalLogDiagnosis,
|
||||
'kondisi' => $filesFinalLogKondisi,
|
||||
|
||||
];
|
||||
} else {
|
||||
$files = [
|
||||
'result' => [],
|
||||
'diagnosis' => [],
|
||||
'kondisi' => [],
|
||||
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
@@ -224,6 +224,7 @@ class DailyMonitoringController extends Controller
|
||||
$validator = Validator::make($request->all(),[
|
||||
'request_code' => 'required|exists:request_logs,code',
|
||||
'subject' => 'required',
|
||||
'submission_date' => 'required',
|
||||
'body_temperature' => 'required|numeric',
|
||||
'sistole' => 'required|numeric',
|
||||
'diastole' => 'required|numeric',
|
||||
@@ -251,6 +252,7 @@ class DailyMonitoringController extends Controller
|
||||
// insert claim daily monitoring
|
||||
$db_response = RequestDailyMonitoring::create([
|
||||
'request_log_id' => $request_log->id,
|
||||
'submission_date' => $request->submission_date,
|
||||
'subject' => $request->subject,
|
||||
'sistole' => $request->sistole,
|
||||
'diastole' => $request->diastole,
|
||||
|
||||
@@ -15,6 +15,7 @@ class RequestDailyMonitoring extends Model
|
||||
protected $fillable = [
|
||||
'request_log_id',
|
||||
'subject',
|
||||
'submission_date',
|
||||
'body_temperature',
|
||||
'respiration_rate',
|
||||
'sistole',
|
||||
|
||||
@@ -20,6 +20,11 @@ class RequestLogDailyMonitoring extends Model
|
||||
return $this->hasMany(RequestLogMedicalPlan::class);
|
||||
}
|
||||
|
||||
public function files()
|
||||
{
|
||||
return $this->morphMany(File::class, 'fileable');
|
||||
}
|
||||
|
||||
/* -------------------------------------------------------------------------- */
|
||||
|
||||
protected function code(): Attribute
|
||||
@@ -28,4 +33,6 @@ class RequestLogDailyMonitoring extends Model
|
||||
get: fn ($value, $attributes) => 'RE-' . str_pad($attributes['id'], 3, '0', STR_PAD_LEFT),
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
}
|
||||
|
||||
@@ -0,0 +1,32 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Database\Migrations\Migration;
|
||||
use Illuminate\Database\Schema\Blueprint;
|
||||
use Illuminate\Support\Facades\Schema;
|
||||
|
||||
return new class extends Migration
|
||||
{
|
||||
/**
|
||||
* Run the migrations.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function up()
|
||||
{
|
||||
Schema::table('request_log_daily_monitorings', function (Blueprint $table) {
|
||||
$table->dateTime('submission_date')->after('request_log_id')->nullable()->default(null);
|
||||
});
|
||||
}
|
||||
|
||||
/**
|
||||
* Reverse the migrations.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function down()
|
||||
{
|
||||
Schema::table('request_log_daily_monitorings', function (Blueprint $table) {
|
||||
$table->dropColumn('submission_date');
|
||||
});
|
||||
}
|
||||
};
|
||||
@@ -1029,23 +1029,56 @@ export default function ServiceMonitoring() {
|
||||
</Stack>
|
||||
<Stack spacing={1}>
|
||||
<Typography variant="h6" sx={{ paddingTop: 2 }}>
|
||||
Perencanaan
|
||||
Medical Plan :
|
||||
</Typography>
|
||||
</Stack>
|
||||
<Stack direction={'row'} spacing={2}>
|
||||
<Grid item xs={12} lg={12} md={12}>
|
||||
<Stack marginLeft={5}>
|
||||
{data.dailyMonitorings ? (
|
||||
<ul style={{ listStyleType: 'disc' }}>
|
||||
{dailyMonitoring.plans.length > 0 &&
|
||||
dailyMonitoring.plans.map((plan, planIndex) => (
|
||||
<Stack marginLeft={5}>
|
||||
{data.dailyMonitorings ? (
|
||||
<ul style={{ listStyleType: 'disc' }}>
|
||||
{dailyMonitoring.plans.length > 0 ? (
|
||||
dailyMonitoring.plans.map((plan, planIndex) =>
|
||||
plan.type === 1 ? (
|
||||
<li key={planIndex}>{plan.plan}</li>
|
||||
))}
|
||||
</ul>
|
||||
) : (
|
||||
'-'
|
||||
)}
|
||||
</Stack>
|
||||
) : null
|
||||
)
|
||||
) : (
|
||||
<li>No plans available</li>
|
||||
)}
|
||||
</ul>
|
||||
) : (
|
||||
'-'
|
||||
)}
|
||||
</Stack>
|
||||
|
||||
</Grid>
|
||||
</Stack>
|
||||
<Stack spacing={1}>
|
||||
<Typography variant="h6" sx={{ paddingTop: 2 }}>
|
||||
Non Medikamentosa Plan :
|
||||
</Typography>
|
||||
</Stack>
|
||||
<Stack direction={'row'} spacing={2}>
|
||||
<Grid item xs={12} lg={12} md={12}>
|
||||
<Stack marginLeft={5}>
|
||||
{data.dailyMonitorings ? (
|
||||
<ul style={{ listStyleType: 'disc' }}>
|
||||
{dailyMonitoring.plans.length > 0 ? (
|
||||
dailyMonitoring.plans.map((plan, planIndex) =>
|
||||
plan.type === 2 ? (
|
||||
<li key={planIndex}>{plan.plan}</li>
|
||||
) : null
|
||||
)
|
||||
) : (
|
||||
<li>No plans available</li>
|
||||
)}
|
||||
</ul>
|
||||
) : (
|
||||
'-'
|
||||
)}
|
||||
</Stack>
|
||||
|
||||
</Grid>
|
||||
</Stack>
|
||||
</Grid>
|
||||
|
||||
@@ -80,7 +80,7 @@ const navConfig = [
|
||||
title: 'CASE MANAGEMENT',
|
||||
children: [
|
||||
{ title: 'Daily Monitoring', path: '/case_management/daily_monitoring' },
|
||||
{ title: 'Laboratorium Result', path: '/case_management/laboratorium_result' },
|
||||
// { title: 'Laboratorium Result', path: '/case_management/laboratorium_result' },
|
||||
{ title: 'Inpatient Monitoring', path: '/case_management/inpatient_monitoring' },
|
||||
],
|
||||
},
|
||||
|
||||
@@ -123,6 +123,10 @@ export default function ClaimListRow ({ ...props }: Props) {
|
||||
<Visibility />
|
||||
View
|
||||
</MenuItem>
|
||||
<MenuItem onClick={() => navigate(`/case_management/daily_monitoring/${props.row.member_id}/claims/${props.row.code}/add_monitoring`)}>
|
||||
<AddIcon />
|
||||
Daily Monitoring
|
||||
</MenuItem>
|
||||
</>
|
||||
} />
|
||||
)
|
||||
|
||||
@@ -50,6 +50,7 @@ export default function DetailMonitoringList() {
|
||||
claim_code : '',
|
||||
claim_id : '',
|
||||
subject : '',
|
||||
submission_date : '',
|
||||
body_temperature: '',
|
||||
sistole : '',
|
||||
diastole : '',
|
||||
@@ -183,6 +184,24 @@ export default function DetailMonitoringList() {
|
||||
<FormProvider methods={methods} onSubmit={handleSubmit(submitHandler)}>
|
||||
<Card sx={{ padding: '24px' }}>
|
||||
<Grid container spacing={6}>
|
||||
{/* Date */}
|
||||
<Grid item xs={12}>
|
||||
<Grid container spacing={3}>
|
||||
<Grid item xs={12}>
|
||||
<Typography variant="body1" component="div">
|
||||
Date* :
|
||||
</Typography>
|
||||
</Grid>
|
||||
<Grid item xs={12} sx={{display: 'flex', gap: 1}}>
|
||||
<RHFDatePickerV2
|
||||
label='Date'
|
||||
name="submission_date"
|
||||
dateFormat='dd MMM yyyy'
|
||||
fullWidth
|
||||
/>
|
||||
</Grid>
|
||||
</Grid>
|
||||
</Grid>
|
||||
{/* Subject */}
|
||||
<Grid item xs={12}>
|
||||
<Grid container spacing={3}>
|
||||
@@ -421,7 +440,7 @@ export default function DetailMonitoringList() {
|
||||
<Grid container spacing={3}>
|
||||
<Grid item xs={12}>
|
||||
<Typography variant="body1" component="div">
|
||||
Confirmation Medical Letter*
|
||||
Confirmation Medical Letter
|
||||
</Typography>
|
||||
</Grid>
|
||||
<Grid item xs={12}>
|
||||
@@ -477,7 +496,7 @@ export default function DetailMonitoringList() {
|
||||
<Grid container spacing={3}>
|
||||
<Grid item xs={12}>
|
||||
<Typography variant="body1" component="div">
|
||||
Medical Action Letter*
|
||||
Medical Action Letter
|
||||
</Typography>
|
||||
</Grid>
|
||||
<Grid item xs={12}>
|
||||
@@ -534,7 +553,7 @@ export default function DetailMonitoringList() {
|
||||
<Grid container spacing={3}>
|
||||
<Grid item xs={12}>
|
||||
<Typography variant="body1" component="div">
|
||||
Laboratorium Result*
|
||||
Laboratorium Result
|
||||
</Typography>
|
||||
</Grid>
|
||||
<Grid item xs={6}>
|
||||
@@ -579,7 +598,7 @@ export default function DetailMonitoringList() {
|
||||
</Grid>
|
||||
<Grid item xs={12}>
|
||||
<Typography variant="body1" component="div">
|
||||
Laboratorium Result*
|
||||
Laboratorium Result
|
||||
</Typography>
|
||||
</Grid>
|
||||
<Grid item xs={12}>
|
||||
|
||||
@@ -85,7 +85,7 @@ export default function DetailMonitoringList() {
|
||||
variant="ghost"
|
||||
color="default"
|
||||
>
|
||||
{row.created_at ? fDate(row.created_at) : '-'}
|
||||
{row.submission_date ? fDate(row.submission_date) : '-'}
|
||||
</Label>
|
||||
|
||||
{row.discharge_date.discharge_date ?
|
||||
@@ -264,7 +264,7 @@ export default function DetailMonitoringList() {
|
||||
</Grid>
|
||||
<Grid item xs={6}>
|
||||
<Typography variant="body2" color={"GrayText"}>
|
||||
{row.provider}
|
||||
{row.provider != null ? row.provider : '-' }
|
||||
</Typography>
|
||||
</Grid>
|
||||
</Grid>
|
||||
@@ -276,7 +276,7 @@ export default function DetailMonitoringList() {
|
||||
</Grid>
|
||||
<Grid item xs={6}>
|
||||
<Typography variant="body2" color={"GrayText"}>
|
||||
{row.examination}
|
||||
{row.examination != null ? row.examination : '-' }
|
||||
</Typography>
|
||||
</Grid>
|
||||
</Grid>
|
||||
|
||||
@@ -47,6 +47,7 @@ export const getClaimList = async ( member_id: string ): Promise<ResponseListing
|
||||
*/
|
||||
export const AddMonitoringDetail = async ( claim_code: string,data: DetailMonitoringListType ): Promise<boolean> => {
|
||||
data.lab_date = data.lab_date != '' && data.lab_date != null ? fDateOnly(data.lab_date) : '';
|
||||
data.submission_date = data.submission_date != '' && data.submission_date != null ? fDateOnly(data.submission_date) : '';
|
||||
|
||||
const formData = makeFormData({...data});
|
||||
|
||||
|
||||
@@ -57,6 +57,7 @@ export type DetailMonitoringListType = {
|
||||
diastole : string
|
||||
analysis : string,
|
||||
complaints : string,
|
||||
submission_date : string,
|
||||
lab_date : string,
|
||||
provider : string,
|
||||
examination : string,
|
||||
|
||||
Reference in New Issue
Block a user