[New Feature] Export Excel Request LOG
This commit is contained in:
@@ -4,6 +4,7 @@ namespace Modules\Internal\Http\Controllers\Api;
|
||||
|
||||
use App\Helpers\Helper;
|
||||
use App\Models\RequestLog;
|
||||
use App\Models\RequestLogBenefit;
|
||||
use App\Models\Organization;
|
||||
use App\Models\Icd;
|
||||
use App\Services\ClaimService;
|
||||
@@ -149,11 +150,27 @@ class ReportLogController extends Controller
|
||||
// Membuat penulis entitas Spout
|
||||
$writer = WriterEntityFactory::createXLSXWriter();
|
||||
// Membuka penulis untuk menulis ke file
|
||||
$writer->openToFile(public_path('files/Data Request LOG.xlsx'));
|
||||
|
||||
$writer->openToFile(public_path('files/Report-Request-Final-LOG.xlsx'));
|
||||
$headerArray = [
|
||||
'Code',
|
||||
'Member',
|
||||
'GL Create Time',
|
||||
'GL Submit Time',
|
||||
'GL Create By',
|
||||
'FGL Create Time',
|
||||
'FGL Submit Time',
|
||||
'FGL Created By',
|
||||
'Service',
|
||||
'Provider',
|
||||
'Document Qty',
|
||||
'Duration GL',
|
||||
'Duration FGL',
|
||||
'Status GL',
|
||||
'Status Final GL'
|
||||
];
|
||||
// Sheet 1
|
||||
$writer->getCurrentSheet()->setName('Data');
|
||||
$headers_map_to_table_fields = RequestLog::$listing_data_doc_headers;
|
||||
$headers_map_to_table_fields = $headerArray;
|
||||
$headerRow = WriterEntityFactory::createRowFromArray($headers_map_to_table_fields);
|
||||
$writer->addRow($headerRow);
|
||||
|
||||
@@ -165,18 +182,44 @@ class ReportLogController extends Controller
|
||||
->orderBy('id', 'desc')
|
||||
->get()->toArray();
|
||||
|
||||
// dd($dataRequestLog);
|
||||
foreach ($dataRequestLog as $index => $row){
|
||||
$serviceType = $this->getServiceName($row['service_code']);
|
||||
|
||||
$serviceName = Helper::serviceName($row['service_code']);
|
||||
$provider = Organization::where('id', $row['organization_id'])->first();
|
||||
$documentQty = File::where(['fileable_type' => 'App\Models\RequestLog', 'fileable_id' => $row['id']])->get()->toArray();
|
||||
$parsedDateTime = Carbon::parse($row['created_at']);
|
||||
$formattedDateTime = $parsedDateTime->format('Y-m-d H:i:s');
|
||||
|
||||
$timeInsertBenefit = RequestLogBenefit::where('request_log_id', $row['id'])->first();
|
||||
|
||||
if ($timeInsertBenefit){
|
||||
$created_final_at = Carbon::parse($timeInsertBenefit->created_at);
|
||||
$created_final_at = $created_final_at->format('Y-m-d H:i:s');
|
||||
|
||||
$durationFinalGl = Helper::differenceTime($timeInsertBenefit->created_at, $row['approved_final_log_at']);
|
||||
} else {
|
||||
$durationFinalGl = 0;
|
||||
$created_final_at = false;
|
||||
}
|
||||
|
||||
$durationGl = Helper::differenceTime($formattedDateTime, $row['submission_date']);
|
||||
|
||||
|
||||
$rowData = [
|
||||
$row['id'], // id
|
||||
$row['code'], // code
|
||||
$row['member']['name'], // name
|
||||
$row['member'] ? $row['member']['name'] : '', // name
|
||||
$formattedDateTime ? $formattedDateTime : "-" , // created at
|
||||
$row['submission_date'], // submission date
|
||||
$serviceType, // service type
|
||||
$row['payment_type_name'], // service type
|
||||
$row['status'], // service type
|
||||
Helper::userName($row['approved_by']), // created by
|
||||
$created_final_at ? $created_final_at : "-", // fgl create time
|
||||
$row['approved_final_log_at'] ? $row['approved_final_log_at'] : "", // fgl submit time
|
||||
$row['final_log'] == 1 ? Helper::userName($row['approved_final_log_by']) : '-', // fgl create by
|
||||
$serviceName, // service
|
||||
$provider ? $provider->name : '-', // provider
|
||||
count($documentQty), // dokument qty
|
||||
$durationGl, // duration gl
|
||||
$row['final_log'] == 1 ? $durationFinalGl : '-', // duration fgl
|
||||
$row['status'] ?? '-', // status gl
|
||||
$row['status_final_log'] ?? '-', // status fgl
|
||||
];
|
||||
$row = WriterEntityFactory::createRowFromArray($rowData);
|
||||
$writer->addRow($row);
|
||||
@@ -185,7 +228,7 @@ class ReportLogController extends Controller
|
||||
|
||||
return Helper::responseJson([
|
||||
'file_name' => "Data Request Log " . date('Y-m-d h:i:s'),
|
||||
"file_url" => url('files/Data Request LOG.xlsx')
|
||||
"file_url" => url('files/Report-Request-Final-LOG.xlsx')
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
Reference in New Issue
Block a user