Merge remote-tracking branch 'origin/staging' into origin/production

This commit is contained in:
Linksehat Staging Server
2024-01-31 11:55:54 +07:00
5 changed files with 62 additions and 20 deletions

View File

@@ -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')
]);
}

View File

@@ -322,6 +322,7 @@ Route::prefix('internal')->group(function () {
Route::prefix('report')->group(function () {
Route::prefix('/logs')->group(function () {
Route::get('/', [ReportLogController::class, 'index']);
Route::get('/export', [ReportLogController::class, 'generateDataRequestLogExcel']);
});
});

View File

@@ -50,7 +50,7 @@ class ReportLogResource extends JsonResource
'submission_date' => $this->submission_date,
'approved_by' => Helper::userName($this->approved_by),
'approved_final_log_at' => $this->approved_final_log_at,
'approved_final_log_by' => Helper::userName($this->approved_final_log_by),
'approved_final_log_by' => $this->final_log == 1 ? Helper::userName($this->approved_final_log_by) : '-',
'service_name' => $this->service ? $this->service->name : '',
'provider' => $provider ? $provider->name : '-',
'document_qty' => count($documentQty),

View File

@@ -14,8 +14,8 @@ return new class extends Migration
public function up()
{
Schema::table('request_logs', function (Blueprint $table) {
$table->dateTime('created_final_at');
$table->bigInteger('created_final_by');
$table->dateTime('created_final_at')->default(null);
$table->bigInteger('created_final_by')->default(null);
});
}

View File

@@ -170,7 +170,7 @@ export default function List() {
}
const handleGetData = (type :string) => {
axios.get(`customer-service/request/data`)
axios.get(`report/logs/export`)
.then((response) => {
const link = document.createElement('a');
link.href = response.data.data.file_url;
@@ -200,7 +200,7 @@ export default function List() {
sx={{ p: 1.8 }}
onClick={handleClick}
>
Import
Export
</Button>
<Menu
id="import-button"
@@ -211,9 +211,7 @@ export default function List() {
'aria-labelledby': 'basic-button',
}}
>
<MenuItem onClick={handleImportButton}>Import</MenuItem>
<MenuItem onClick={() => {handleGetTemplate('template-request-log')}}>Download Template</MenuItem>
<MenuItem onClick={() => {handleGetData('data-request-log')}}>Download Request LOG</MenuItem>
<MenuItem onClick={() => {handleGetData('')}}>Download Excel</MenuItem>
</Menu>
</Stack>
)}