Update Primayan Medicare report search and layout

This commit is contained in:
Iqbal
2026-05-11 11:36:13 +07:00
parent 21a909aacb
commit d96e439b2a
2 changed files with 66 additions and 38 deletions

View File

@@ -7,11 +7,9 @@ use App\Models\Corporate;
use Illuminate\Http\Request;
use Illuminate\Routing\Controller;
use Illuminate\Support\Facades\DB;
use Box\Spout\Writer\Common\Creator\WriterEntityFactory;
use Illuminate\Support\Facades\Storage;
use PhpOffice\PhpSpreadsheet\Spreadsheet;
use PhpOffice\PhpSpreadsheet\Writer\Xlsx;
use PhpOffice\PhpSpreadsheet\Style\NumberFormat;
use PhpOffice\PhpSpreadsheet\Style\Alignment;
use PhpOffice\PhpSpreadsheet\Style\Border;
use PhpOffice\PhpSpreadsheet\Style\Fill;
@@ -62,6 +60,8 @@ class PrimayanMedicareController extends Controller
$query->orWhere('members.name', 'like', "%" . $search . "%")
->orWhere('members.member_id', 'like', "%" . $search . "%")
->orWhere('claim_requests.code', 'like', "%" . $search . "%")
->orWhere('request_logs.code', 'like', "%" . $search . "%")
->orWhere('claims.code', 'like', "%" . $search . "%")
->orWhere('corporate_employees.nik', 'like', "%" . $search . "%");
});
})
@@ -173,6 +173,8 @@ class PrimayanMedicareController extends Controller
$query->orWhere('members.name', 'like', "%" . $search . "%")
->orWhere('members.member_id', 'like', "%" . $search . "%")
->orWhere('claim_requests.code', 'like', "%" . $search . "%")
->orWhere('request_logs.code', 'like', "%" . $search . "%")
->orWhere('claims.code', 'like', "%" . $search . "%")
->orWhere('corporate_employees.nik', 'like', "%" . $search . "%");
});
})
@@ -226,8 +228,8 @@ class PrimayanMedicareController extends Controller
mkdir(storage_path('app/public/temp'), 0755, true);
}
$writer = WriterEntityFactory::createXLSXWriter();
$writer->openToFile($filePath);
$spreadsheet = new Spreadsheet();
$sheet = $spreadsheet->getActiveSheet();
$serviceCodeMap = [
'OP' => 'Outpatient',
@@ -258,40 +260,55 @@ class PrimayanMedicareController extends Controller
'Excess Paid',
'Status',
];
$headerRow = WriterEntityFactory::createRowFromArray($headers);
$writer->addRow($headerRow);
$sheet->fromArray($headers, null, 'A1');
$sheet->getStyle('A1:Q1')->applyFromArray([
'font' => [
'bold' => true,
],
'alignment' => [
'horizontal' => Alignment::HORIZONTAL_CENTER,
]
]);
$rowIndex = 2;
$no = 1;
foreach ($results as $row) {
$serviceCode = $row->service_code ?? '-';
foreach ($results as $item) {
$serviceCode = $item->service_code ?? '-';
$serviceName = $serviceCodeMap[$serviceCode] ?? $serviceCode;
$rowData = [
$no++,
($row->claim_code && $row->log_code)
? $row->claim_code . ' / ' . $row->log_code
: ($row->claim_code ?? $row->log_code ?? $row->request_code ?? '-'),
$row->member_name ?? '-',
$row->member_number ?? '-',
$row->nik ?? '-',
$row->birth_date ?? '-',
$row->gender ?? '-',
$row->plan_code ?? '-',
$row->benefit_name ?? $row->benefit_desc ?? '-',
($item->claim_code && $item->log_code)
? $item->claim_code . ' / ' . $item->log_code
: ($item->claim_code ?? $item->log_code ?? $item->request_code ?? '-'),
$item->member_name ?? '-',
$item->member_number ?? '-',
$item->nik ?? '-',
$item->birth_date ?? '-',
$item->gender ?? '-',
$item->plan_code ?? '-',
$item->benefit_name ?? $item->benefit_desc ?? '-',
$serviceName,
$row->provider_name ?? '-',
$row->request_date ?? '-',
$row->amount_incurred ?? 0,
$row->amount_approved ?? 0,
$row->amount_not_approved ?? 0,
$row->excess_paid ?? 0,
$row->status ?? '-',
$item->provider_name ?? '-',
$item->request_date ?? '-',
$item->amount_incurred ?? 0,
$item->amount_approved ?? 0,
$item->amount_not_approved ?? 0,
$item->excess_paid ?? 0,
$item->status ?? '-',
];
$dataRow = WriterEntityFactory::createRowFromArray($rowData);
$writer->addRow($dataRow);
$sheet->fromArray($rowData, null, 'A' . $rowIndex);
$rowIndex++;
}
$writer->close();
foreach (range('A', 'Q') as $col) {
$sheet->getColumnDimension($col)->setAutoSize(true);
}
$writer = new Xlsx($spreadsheet);
$writer->save($filePath);
return Helper::responseJson([
'file_name' => 'Primayan Medicare List ' . now()->format('Y-m-d H:i:s'),
@@ -333,8 +350,15 @@ class PrimayanMedicareController extends Controller
// Header Date Range (Row 1)
$dateRange = now()->startOfMonth()->format('j F') . ' - ' . now()->format('j F Y');
$sheet->setCellValue('A1', strtoupper($dateRange));
$sheet->mergeCells('A1:G1');
$sheet->getStyle('A1')->getAlignment()->setHorizontal(Alignment::HORIZONTAL_CENTER);
$sheet->mergeCells('A1:B1');
$sheet->getStyle('A1')->applyFromArray([
'font' => [
'bold' => true,
],
'alignment' => [
'horizontal' => Alignment::HORIZONTAL_CENTER,
]
]);
// Table Headers (Row 3)
$headers = ['Code RS', 'Branch Code', 'Total Benefit', 'Deposit 10%', 'Pemakaian Benefit Obat & Rujukan', 'Pemakaian Telekonsultasi', 'Sisa Deposit'];
@@ -353,6 +377,9 @@ class PrimayanMedicareController extends Controller
'allBorders' => [
'borderStyle' => Border::BORDER_THIN,
]
],
'alignment' => [
'horizontal' => Alignment::HORIZONTAL_CENTER,
]
]);

View File

@@ -90,8 +90,8 @@ export default function List() {
return (
<form style={{ width: '100%' }}>
<Grid container spacing={2} sx={{ justifyContent: 'space-between', alignItems: 'center' }}>
<Grid item md={2}>
<Grid container spacing={2} sx={{ alignItems: 'center' }}>
<Grid item xs={12} md={2.4}>
<TextField
id="search-input"
ref={searchInput}
@@ -118,7 +118,7 @@ export default function List() {
/>
</Grid>
<Grid item md={2}>
<Grid item xs={12} md={2}>
<FormControl fullWidth>
<InputLabel>Status</InputLabel>
<Select
@@ -146,7 +146,7 @@ export default function List() {
</FormControl>
</Grid>
<Grid item md={2}>
<Grid item xs={12} md={2}>
<FormControl fullWidth>
<InputLabel>Provider</InputLabel>
<Select
@@ -172,7 +172,7 @@ export default function List() {
</FormControl>
</Grid>
<Grid item md={2}>
<Grid item xs={12} md={2}>
<LocalizationProvider dateAdapter={AdapterDateFns}>
<DesktopDatePicker
value={searchParams.get('start_date') || null}
@@ -196,7 +196,7 @@ export default function List() {
</LocalizationProvider>
</Grid>
<Grid item md={2}>
<Grid item xs={12} md={2}>
<LocalizationProvider dateAdapter={AdapterDateFns}>
<DesktopDatePicker
value={searchParams.get('end_date') || null}
@@ -220,11 +220,12 @@ export default function List() {
</LocalizationProvider>
</Grid>
<Grid item md={1}>
<Grid item xs={12} md={1.6}>
<LoadingButton
variant="outlined"
startIcon={<UploadIcon />}
sx={{ p: 1.8 }}
fullWidth
sx={{ height: '56px' }}
onClick={handleExportClick}
loading={exportLoading}
>