Update Primayan Medicare report search and layout
This commit is contained in:
@@ -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,
|
||||
]
|
||||
]);
|
||||
|
||||
|
||||
@@ -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}
|
||||
>
|
||||
|
||||
Reference in New Issue
Block a user