update listing dan edit claim management
This commit is contained in:
@@ -12,9 +12,13 @@ use App\Services\ClaimService;
|
|||||||
use Illuminate\Contracts\Support\Renderable;
|
use Illuminate\Contracts\Support\Renderable;
|
||||||
use Illuminate\Http\Request;
|
use Illuminate\Http\Request;
|
||||||
use Illuminate\Routing\Controller;
|
use Illuminate\Routing\Controller;
|
||||||
|
use Modules\HospitalPortal\Helpers\ApiResponse;
|
||||||
|
use Illuminate\Support\Facades\Validator;
|
||||||
use Modules\Internal\Transformers\ClaimShowResource;
|
use Modules\Internal\Transformers\ClaimShowResource;
|
||||||
|
use Modules\Internal\Transformers\ClaimEditResource;
|
||||||
use Box\Spout\Reader\Common\Creator\ReaderEntityFactory;
|
use Box\Spout\Reader\Common\Creator\ReaderEntityFactory;
|
||||||
use Box\Spout\Writer\Common\Creator\WriterEntityFactory;
|
use Box\Spout\Writer\Common\Creator\WriterEntityFactory;
|
||||||
|
|
||||||
use PDF;
|
use PDF;
|
||||||
|
|
||||||
class ClaimController extends Controller
|
class ClaimController extends Controller
|
||||||
@@ -23,22 +27,35 @@ class ClaimController extends Controller
|
|||||||
* Display a listing of the resource.
|
* Display a listing of the resource.
|
||||||
* @return Renderable
|
* @return Renderable
|
||||||
*/
|
*/
|
||||||
public function index()
|
public function index(Request $request)
|
||||||
{
|
{
|
||||||
$claims = Claim::with([
|
$claims = Claim::with([
|
||||||
'member',
|
'member',
|
||||||
'diagnoses' => function ($diagnosis) {
|
'member.currentCorporate',
|
||||||
return $diagnosis->where('type', 'primary');
|
'member.currentCorporate.currentPolicy',
|
||||||
},
|
'member.currentPlan',
|
||||||
'diagnoses.icd',
|
'diagnoses' => function ($diagnosis) {
|
||||||
'plan',
|
$diagnosis->where('type', 'primary');
|
||||||
'benefit',
|
},
|
||||||
'claimRequest',
|
'diagnoses.icd',
|
||||||
'claimRequest.service'
|
'benefit',
|
||||||
])
|
'claimRequest',
|
||||||
->where('status', '!=', 'requested') // penjagaan agar approve baru masuk ke claim management
|
'claimRequest.service',
|
||||||
->latest()
|
])
|
||||||
->paginate(10);
|
->when($request->search, function ($q, $search) {
|
||||||
|
$q->where(function ($subQuery) use ($search) {
|
||||||
|
$subQuery->whereHas('claimRequest', function ($claimRequest) use ($search) {
|
||||||
|
$claimRequest->where('code', 'LIKE', "%" . $search . "%");
|
||||||
|
})
|
||||||
|
->orWhereHas('member', function ($member) use ($search) {
|
||||||
|
$member->where('name', 'LIKE', "%" . $search . "%");
|
||||||
|
});
|
||||||
|
});
|
||||||
|
})
|
||||||
|
->where('status', '!=', 'requested') // Penjagaan agar approve baru masuk ke claim management
|
||||||
|
->latest()
|
||||||
|
->paginate(10);
|
||||||
|
|
||||||
|
|
||||||
return response()->json($claims);
|
return response()->json($claims);
|
||||||
}
|
}
|
||||||
@@ -129,7 +146,32 @@ class ClaimController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function edit($id)
|
public function edit($id)
|
||||||
{
|
{
|
||||||
return view('internal::edit');
|
$claim = Claim::query()
|
||||||
|
->with([
|
||||||
|
'member',
|
||||||
|
'plan',
|
||||||
|
'member.currentPlan',
|
||||||
|
'member.currentPlan.benefits',
|
||||||
|
'member.currentCorporate',
|
||||||
|
'member.currentPolicy',
|
||||||
|
// 'diagnosis',
|
||||||
|
'diagnoses',
|
||||||
|
'diagnoses.icd',
|
||||||
|
'benefit',
|
||||||
|
'files',
|
||||||
|
'claimRequest',
|
||||||
|
'claimRequest.files',
|
||||||
|
'items',
|
||||||
|
'items.claim_itemable',
|
||||||
|
'encounters',
|
||||||
|
'encounters.doctors',
|
||||||
|
'encounters.primaryDiagnoses',
|
||||||
|
'encounters.primaryDiagnoses.diagnosis',
|
||||||
|
'encounters.healthcare'
|
||||||
|
])
|
||||||
|
->findOrFail($id);
|
||||||
|
|
||||||
|
return Helper::responseJson(ClaimEditResource::make($claim));
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -140,7 +182,42 @@ class ClaimController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function update(Request $request, $id)
|
public function update(Request $request, $id)
|
||||||
{
|
{
|
||||||
//
|
$customMessages = [
|
||||||
|
'required' => 'Kolom :attribute wajib diisi.',
|
||||||
|
'numeric' => 'Kolom :attribute harus berupa angka.',
|
||||||
|
];
|
||||||
|
|
||||||
|
$data = [
|
||||||
|
'benefit_desc' => $request->benefit_desc,
|
||||||
|
'amount_incurred' => $request->amount_incurred,
|
||||||
|
'amount_approved' => $request->amount_approved,
|
||||||
|
'amount_not_approved' => $request->amount_not_approved,
|
||||||
|
'excess_paid' => $request->excess_paid,
|
||||||
|
];
|
||||||
|
|
||||||
|
$validator = Validator::make($request->all(), [
|
||||||
|
'benefit_desc' => 'required',
|
||||||
|
'amount_incurred' => 'required|numeric',
|
||||||
|
'amount_approved' => 'required|numeric',
|
||||||
|
'amount_not_approved' => 'required|numeric',
|
||||||
|
'excess_paid' => 'required|numeric',
|
||||||
|
], $customMessages);
|
||||||
|
|
||||||
|
if ($validator->fails()) {
|
||||||
|
return ApiResponse::apiResponse('Bad Request', $data, $validator->errors(), 400);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Validasi berhasil, lanjutkan dengan pembaruan data
|
||||||
|
$claim = Claim::findOrFail($id);
|
||||||
|
$claim->fill([
|
||||||
|
'benefit_desc' => $request->benefit_desc,
|
||||||
|
'amount_incurred' => $request->amount_incurred,
|
||||||
|
'amount_approved' => $request->amount_approved,
|
||||||
|
'amount_not_approved' => $request->amount_not_approved,
|
||||||
|
'excess_paid' => $request->excess_paid,
|
||||||
|
])->save();
|
||||||
|
|
||||||
|
return $claim;
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|||||||
@@ -15,6 +15,8 @@ use Modules\Internal\Transformers\ClaimRequestShowResource;
|
|||||||
use Illuminate\Support\Facades\Storage;
|
use Illuminate\Support\Facades\Storage;
|
||||||
use App\Services\ClaimRequestService;
|
use App\Services\ClaimRequestService;
|
||||||
use App\Exceptions\ImportRowException;
|
use App\Exceptions\ImportRowException;
|
||||||
|
use App\Events\ClaimRequested;
|
||||||
|
|
||||||
|
|
||||||
use App\Models\File;
|
use App\Models\File;
|
||||||
use App\Models\FilesMcu;
|
use App\Models\FilesMcu;
|
||||||
@@ -85,7 +87,7 @@ class ClaimRequestController extends Controller
|
|||||||
'files',
|
'files',
|
||||||
'member',
|
'member',
|
||||||
'claim',
|
'claim',
|
||||||
'claim.organization',
|
'organization',
|
||||||
]);
|
]);
|
||||||
|
|
||||||
return Helper::responseJson(data: ClaimRequestShowResource::make($claimRequest));
|
return Helper::responseJson(data: ClaimRequestShowResource::make($claimRequest));
|
||||||
@@ -109,30 +111,38 @@ class ClaimRequestController extends Controller
|
|||||||
*/
|
*/
|
||||||
public function update(Request $request, $id)
|
public function update(Request $request, $id)
|
||||||
{
|
{
|
||||||
$claim_id = ClaimRequest::find($id)->claim_id;
|
$claimRequest = ClaimRequest::findOrFail($id);
|
||||||
$organization_id = Organization::where('code', $request->provider_code)->first();
|
$claimRequest->load([
|
||||||
if (!$organization_id) {
|
'histories' => function ($history) {
|
||||||
|
$history->latest();
|
||||||
|
},
|
||||||
|
'files',
|
||||||
|
'member',
|
||||||
|
'claim',
|
||||||
|
'organization',
|
||||||
|
]);
|
||||||
|
$organization = Organization::where('code', $request->provider_code)->first();
|
||||||
|
if (!$organization) {
|
||||||
return response()->json(['error' => true, 'message' => 'Data tidak ditemukan'], 404);
|
return response()->json(['error' => true, 'message' => 'Data tidak ditemukan'], 404);
|
||||||
}
|
}
|
||||||
|
|
||||||
$newClaimRequest = ClaimRequestService::updateClaimRequest(code: $code, member: $member, paymentType: 'reimbursement', serviceCode: $request->service_code);
|
$updateClaimRequest = ClaimRequestService::updateClaimRequest(organization_id: $organization->id, claim_request_id: $id);
|
||||||
|
|
||||||
ClaimRequested::dispatch($newClaimRequest);
|
ClaimRequested::dispatch($updateClaimRequest);
|
||||||
|
|
||||||
// Log History
|
// Log History
|
||||||
$newClaimRequest->histories()->create([
|
$updateClaimRequest->histories()->create([
|
||||||
'title' => 'Update Claim Requested',
|
'title' => 'Update Claim Requested',
|
||||||
'description' => "Update Claim Requested for Member : {$member->member_id} - ({$member->full_name})",
|
'description' => "Update Claim Requested for Member : {$claimRequest->member->member_id} - ({$claimRequest->member->full_name})",
|
||||||
'type' => 'info',
|
'type' => 'update',
|
||||||
'system_origin' => 'hospital-portal'
|
'system_origin' => 'prime-center'
|
||||||
]);
|
]);
|
||||||
|
|
||||||
if ($request->hasFile('result_files')) {
|
if ($request->hasFile('result_files')) {
|
||||||
foreach ($request->result_files as $file) {
|
foreach ($request->result_files as $file) {
|
||||||
$pathFile = File::storeFile('claim-result', $newClaimRequest->id, $file);
|
$pathFile = File::storeFile('claim-result', $id, $file);
|
||||||
$newClaimRequest->files()->updateOrCreate([
|
$updateClaimRequest->files()->updateOrCreate([
|
||||||
'type' => 'claim-result',
|
'type' => 'claim-result',
|
||||||
'name' => File::getFileName('claim-result', $newClaimRequest->id, $file),
|
'name' => File::getFileName('claim-result', $id, $file),
|
||||||
'original_name' => $file->getClientOriginalName(),
|
'original_name' => $file->getClientOriginalName(),
|
||||||
'extension' => $file->getClientOriginalExtension(),
|
'extension' => $file->getClientOriginalExtension(),
|
||||||
'path' => $pathFile,
|
'path' => $pathFile,
|
||||||
@@ -144,10 +154,10 @@ class ClaimRequestController extends Controller
|
|||||||
|
|
||||||
if ($request->hasFile('diagnosa_files')) {
|
if ($request->hasFile('diagnosa_files')) {
|
||||||
foreach ($request->diagnosa_files as $file) {
|
foreach ($request->diagnosa_files as $file) {
|
||||||
$pathFile = File::storeFile('claim-diagnosis', $newClaimRequest->id, $file);
|
$pathFile = File::storeFile('claim-diagnosis', $id, $file);
|
||||||
$newClaimRequest->files()->updateOrCreate([
|
$updateClaimRequest->files()->updateOrCreate([
|
||||||
'type' => 'claim-diagnosis',
|
'type' => 'claim-diagnosis',
|
||||||
'name' => File::getFileName('claim-diagnosis', $newClaimRequest->id, $file),
|
'name' => File::getFileName('claim-diagnosis', $id, $file),
|
||||||
'original_name' => $file->getClientOriginalName(),
|
'original_name' => $file->getClientOriginalName(),
|
||||||
'extension' => $file->getClientOriginalExtension(),
|
'extension' => $file->getClientOriginalExtension(),
|
||||||
'path' => $pathFile,
|
'path' => $pathFile,
|
||||||
@@ -159,10 +169,10 @@ class ClaimRequestController extends Controller
|
|||||||
|
|
||||||
if ($request->hasFile('kondisi_files')) {
|
if ($request->hasFile('kondisi_files')) {
|
||||||
foreach ($request->kondisi_files as $file) {
|
foreach ($request->kondisi_files as $file) {
|
||||||
$pathFile = File::storeFile('claim-kondisi', $newClaimRequest->id, $file);
|
$pathFile = File::storeFile('claim-kondisi', $id, $file);
|
||||||
$newClaimRequest->files()->updateOrCreate([
|
$updateClaimRequest->files()->updateOrCreate([
|
||||||
'type' => 'claim-kondisi',
|
'type' => 'claim-kondisi',
|
||||||
'name' => File::getFileName('claim-kondisi', $newClaimRequest->id, $file),
|
'name' => File::getFileName('claim-kondisi', $id, $file),
|
||||||
'original_name' => $file->getClientOriginalName(),
|
'original_name' => $file->getClientOriginalName(),
|
||||||
'extension' => $file->getClientOriginalExtension(),
|
'extension' => $file->getClientOriginalExtension(),
|
||||||
'path' => $pathFile,
|
'path' => $pathFile,
|
||||||
@@ -171,6 +181,13 @@ class ClaimRequestController extends Controller
|
|||||||
]);
|
]);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
return response()->json([
|
||||||
|
'error' => false,
|
||||||
|
'message' => 'Update succses',
|
||||||
|
'data' => $updateClaimRequest],
|
||||||
|
200);
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
@@ -308,17 +325,18 @@ class ClaimRequestController extends Controller
|
|||||||
'Ingest Code' => $e->getCode(),
|
'Ingest Code' => $e->getCode(),
|
||||||
'Ingest Note' => $e->getMessage(),
|
'Ingest Note' => $e->getMessage(),
|
||||||
]), $sheet->getName());
|
]), $sheet->getName());
|
||||||
} catch (\Exception $e) {
|
}
|
||||||
// throw new \Exception($e);
|
// catch (\Exception $e) {
|
||||||
// Write Server Error to File
|
// // throw new \Exception($e);
|
||||||
// $import->read($fileRead);
|
// // Write Server Error to File
|
||||||
// $import->write($fileWrite, 'xsls');
|
// // $import->read($fileRead);
|
||||||
dd($e);
|
// // $import->write($fileWrite, 'xsls');
|
||||||
$import->addArrayToRow(array_merge($row_data, [
|
// dd( $e->getMessage());
|
||||||
'Ingest Code' => 500,
|
// $import->addArrayToRow(array_merge($row_data, [
|
||||||
'Ingest Note' => env('APP_DEBUG') ? $e->getMessage() : 'Server Error',
|
// 'Ingest Code' => 500,
|
||||||
]), $sheet->getName());
|
// 'Ingest Note' => env('APP_DEBUG') ? $e->getMessage() : 'Server Error',
|
||||||
}
|
// ]), $sheet->getName());
|
||||||
|
// }
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -129,7 +129,7 @@ Route::prefix('internal')->group(function () {
|
|||||||
|
|
||||||
Route::get('corporates/{corporate_id}/formulariums', [CorporateFormulariumController::class, 'index']);
|
Route::get('corporates/{corporate_id}/formulariums', [CorporateFormulariumController::class, 'index']);
|
||||||
Route::get('corporates/{corporate_id}/formulariums/{formularium_id}', [CorporateFormulariumController::class, 'show']);
|
Route::get('corporates/{corporate_id}/formulariums/{formularium_id}', [CorporateFormulariumController::class, 'show']);
|
||||||
Route::get('corporates/{corporate_id}/formulariums/create', [CorporateFormulariumController::class, 'create']);
|
Route::get('corporates/{corporate_id}/formulariums-create', [CorporateFormulariumController::class, 'create']);
|
||||||
Route::post('corporates/{corporate_id}/formulariums', [CorporateFormulariumController::class, 'store']);
|
Route::post('corporates/{corporate_id}/formulariums', [CorporateFormulariumController::class, 'store']);
|
||||||
Route::get('corporates/{corporate_id}/formulariums/list', [CorporateFormulariumController::class, 'generateFormulariumList']);
|
Route::get('corporates/{corporate_id}/formulariums/list', [CorporateFormulariumController::class, 'generateFormulariumList']);
|
||||||
Route::post('corporates/{corporate_id}/formulariums/import', [CorporateFormulariumController::class, 'import']);
|
Route::post('corporates/{corporate_id}/formulariums/import', [CorporateFormulariumController::class, 'import']);
|
||||||
@@ -193,6 +193,8 @@ Route::prefix('internal')->group(function () {
|
|||||||
Route::post('claims/{id}/re-open', [ClaimController::class, 'reOpen'])->name('claim.re-open');
|
Route::post('claims/{id}/re-open', [ClaimController::class, 'reOpen'])->name('claim.re-open');
|
||||||
Route::post('claims', [ClaimController::class, 'store']);
|
Route::post('claims', [ClaimController::class, 'store']);
|
||||||
Route::get('claims/{id}', [ClaimController::class, 'show']);
|
Route::get('claims/{id}', [ClaimController::class, 'show']);
|
||||||
|
Route::put('claims/{id}', [ClaimController::class, 'update']);
|
||||||
|
Route::get('claims/{id}/edit', [ClaimController::class, 'edit']);
|
||||||
Route::post('check-limit', [ClaimController::class, 'checkLimit']);
|
Route::post('check-limit', [ClaimController::class, 'checkLimit']);
|
||||||
Route::get('claims/1/data-claim', [ClaimController::class, 'dataClaimReport']);
|
Route::get('claims/1/data-claim', [ClaimController::class, 'dataClaimReport']);
|
||||||
|
|
||||||
|
|||||||
36
Modules/Internal/Transformers/ClaimEditResource.php
Normal file
36
Modules/Internal/Transformers/ClaimEditResource.php
Normal file
@@ -0,0 +1,36 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
namespace Modules\Internal\Transformers;
|
||||||
|
|
||||||
|
use App\Models\Benefit;
|
||||||
|
use Illuminate\Http\Resources\Json\JsonResource;
|
||||||
|
|
||||||
|
class ClaimEditResource extends JsonResource
|
||||||
|
{
|
||||||
|
/**
|
||||||
|
* Transform the resource into an array.
|
||||||
|
*
|
||||||
|
* @param \Illuminate\Http\Request
|
||||||
|
* @return array
|
||||||
|
*/
|
||||||
|
public function toArray($request)
|
||||||
|
{
|
||||||
|
$value = parent::toArray($request);
|
||||||
|
$data['id'] = $value['id'];
|
||||||
|
$data['plan_id'] = $value['plan'] ? $value['plan']['code'] : '-';
|
||||||
|
$data['payor_id'] = $value['member'] ? $value['member']['current_corporate']['payor_id'] : '-';
|
||||||
|
$data['corporate_id'] = $value['member'] ? $value['member']['current_corporate']['code'] : '-';
|
||||||
|
$data['policy_number'] = $value['member'] ? $value['member']['current_policy']['code'] : '-';
|
||||||
|
$data['member_id'] = $value['member'] ? $value['member']['member_id'] : '-';
|
||||||
|
// $data['benefit_code'] = $value['benefit'] ? $value['benefit']['code'] : '-';
|
||||||
|
// $data['benefit_desc'] = $value['benefit'] ? $value['benefit']['description'] : '-';
|
||||||
|
$data['benefit_code'] = $value['benefit_code'];
|
||||||
|
$data['benefit_desc'] = $value['benefit_desc'];
|
||||||
|
$data['amount_incurred'] = $value['amount_incurred'];
|
||||||
|
$data['amount_approved'] = $value['amount_approved'];
|
||||||
|
$data['amount_not_approved'] = $value['amount_not_approved'];
|
||||||
|
$data['excess_paid'] = $value['excess_paid'];
|
||||||
|
|
||||||
|
return $data;
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -31,7 +31,13 @@ class Claim extends Model
|
|||||||
'benefit_id',
|
'benefit_id',
|
||||||
'organization_id',
|
'organization_id',
|
||||||
'status',
|
'status',
|
||||||
'service_code'
|
'service_code',
|
||||||
|
'benefit_code',
|
||||||
|
'benefit_desc',
|
||||||
|
'amount_incurred',
|
||||||
|
'amount_approved',
|
||||||
|
'amount_not_approved',
|
||||||
|
'excess_paid',
|
||||||
];
|
];
|
||||||
|
|
||||||
protected $hidden = [
|
protected $hidden = [
|
||||||
|
|||||||
@@ -26,6 +26,7 @@ class ClaimRequest extends Model
|
|||||||
'policy_id',
|
'policy_id',
|
||||||
'status',
|
'status',
|
||||||
'claim_id',
|
'claim_id',
|
||||||
|
'organization_id',
|
||||||
'code'
|
'code'
|
||||||
];
|
];
|
||||||
|
|
||||||
@@ -45,6 +46,8 @@ class ClaimRequest extends Model
|
|||||||
"MEMBER ID" => "member_id",
|
"MEMBER ID" => "member_id",
|
||||||
"MEMBER NAME" => "member_name",
|
"MEMBER NAME" => "member_name",
|
||||||
"RECORD TYPE (P/D)" => "record_type",
|
"RECORD TYPE (P/D)" => "record_type",
|
||||||
|
"BENEFIT CODE" => "benefit_code",
|
||||||
|
"BENEFIT DESC" => "benefit_desc",
|
||||||
"CLAIM TYPE" => "claim_type",
|
"CLAIM TYPE" => "claim_type",
|
||||||
"CLAIM PROCESS STATUS" => "status",
|
"CLAIM PROCESS STATUS" => "status",
|
||||||
"CLIENT CLAIM ID" => "client_claim_id",
|
"CLIENT CLAIM ID" => "client_claim_id",
|
||||||
@@ -63,7 +66,7 @@ class ClaimRequest extends Model
|
|||||||
"TOT AMT NOT APPROVED" => "tot_amt_not_approved",
|
"TOT AMT NOT APPROVED" => "tot_amt_not_approved",
|
||||||
"TOT EXCESS PAID" => "tot_excess_paid",
|
"TOT EXCESS PAID" => "tot_excess_paid",
|
||||||
"REMARKS" => "remarks",
|
"REMARKS" => "remarks",
|
||||||
"SECONDARY DIAGNOSIS CODE" => "secondary_diagnosis_code",
|
"SECONDARY DIAGNOSIS CODE" => "secondary_diagnosis",
|
||||||
"APPROVED DATE" => "approved_date",
|
"APPROVED DATE" => "approved_date",
|
||||||
"APPROVED BY" => "approved_by",
|
"APPROVED BY" => "approved_by",
|
||||||
"DATE RECEIVED" => "data_received",
|
"DATE RECEIVED" => "data_received",
|
||||||
@@ -233,6 +236,11 @@ class ClaimRequest extends Model
|
|||||||
return $this->morphMany(ClaimHistory::class, 'historiable');
|
return $this->morphMany(ClaimHistory::class, 'historiable');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
public function organization()
|
||||||
|
{
|
||||||
|
return $this->belongsTo(Organization::class, 'organization_id');
|
||||||
|
}
|
||||||
|
|
||||||
public function member()
|
public function member()
|
||||||
{
|
{
|
||||||
return $this->belongsTo(Member::class, 'member_id', 'id');
|
return $this->belongsTo(Member::class, 'member_id', 'id');
|
||||||
|
|||||||
@@ -103,4 +103,8 @@ class Organization extends Model
|
|||||||
{
|
{
|
||||||
return $this->hasMany(Claim::class, 'organization_id', 'id');
|
return $this->hasMany(Claim::class, 'organization_id', 'id');
|
||||||
}
|
}
|
||||||
|
public function claim_request()
|
||||||
|
{
|
||||||
|
return $this->hasMany(ClaimRequest::class, 'organization_id', 'id');
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -11,7 +11,6 @@ use App\Helpers\Helper;
|
|||||||
use App\Models\Icd;
|
use App\Models\Icd;
|
||||||
use App\Models\Member;
|
use App\Models\Member;
|
||||||
use Carbon\Carbon;
|
use Carbon\Carbon;
|
||||||
|
|
||||||
use App\Exceptions\ImportRowException;
|
use App\Exceptions\ImportRowException;
|
||||||
use Box\Spout\Writer\Common\Creator\WriterEntityFactory;
|
use Box\Spout\Writer\Common\Creator\WriterEntityFactory;
|
||||||
|
|
||||||
@@ -21,9 +20,20 @@ use Str;
|
|||||||
|
|
||||||
class ClaimRequestService{
|
class ClaimRequestService{
|
||||||
|
|
||||||
public static function storeClaimRequest($code, $member, $paymentType, $serviceCode, $submissionDate = null, $status = 'requested')
|
public static function storeClaimRequest($row, $code, $member, $paymentType, $serviceCode, $submissionDate = null, $status = 'requested', $organization_code = null)
|
||||||
{
|
{
|
||||||
try {
|
// try {
|
||||||
|
|
||||||
|
if($organization_code){
|
||||||
|
$organization = Organization::where('code', $organization_code)->first();
|
||||||
|
if (!$organization){
|
||||||
|
throw new ImportRowException(__('Code Provider Tidak ditemukan', [
|
||||||
|
'attribute' => 'provider_code',
|
||||||
|
'code' => $row['provider_code']
|
||||||
|
]), 403, null, $row);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
DB::beginTransaction();
|
DB::beginTransaction();
|
||||||
|
|
||||||
$claimRequestData = [
|
$claimRequestData = [
|
||||||
@@ -34,6 +44,7 @@ class ClaimRequestService{
|
|||||||
'payment_type' => $paymentType,
|
'payment_type' => $paymentType,
|
||||||
'service_code' => $serviceCode,
|
'service_code' => $serviceCode,
|
||||||
'policy_id' => $member->currentPolicy->id ?? null,
|
'policy_id' => $member->currentPolicy->id ?? null,
|
||||||
|
'organization_id' => $organization ? $organization->id : 0,
|
||||||
];
|
];
|
||||||
|
|
||||||
$claimRequest = ClaimRequest::create($claimRequestData);
|
$claimRequest = ClaimRequest::create($claimRequestData);
|
||||||
@@ -41,11 +52,11 @@ class ClaimRequestService{
|
|||||||
DB::commit();
|
DB::commit();
|
||||||
|
|
||||||
return $claimRequest;
|
return $claimRequest;
|
||||||
} catch (\Exception $error) {
|
// } catch (\Exception $error) {
|
||||||
DB::rollBack();
|
// DB::rollBack();
|
||||||
|
|
||||||
throw new \Exception($error);
|
// throw new \Exception($error);
|
||||||
}
|
// }
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function storeClaimManagement($row, $member, $claim_request_id){
|
public static function storeClaimManagement($row, $member, $claim_request_id){
|
||||||
@@ -66,6 +77,12 @@ class ClaimRequestService{
|
|||||||
'currency' => 'IDR',
|
'currency' => 'IDR',
|
||||||
'plan_id' => $member->currentPlan->id,
|
'plan_id' => $member->currentPlan->id,
|
||||||
'total_claim' => $row['tot_amt_insurred'],
|
'total_claim' => $row['tot_amt_insurred'],
|
||||||
|
'benefit_code' => $row['benefit_code'],
|
||||||
|
'benefit_desc' => $row['benefit_desc'],
|
||||||
|
'amount_incurred' => $row['tot_amt_insurred'],
|
||||||
|
'amount_approved' => $row['tot_amt_approved'],
|
||||||
|
'amount_not_approved' => $row['tot_amt_not_approved'],
|
||||||
|
'excess_paid' => $row['tot_excess_paid'],
|
||||||
'claim_request_id' => $claim_request_id,
|
'claim_request_id' => $claim_request_id,
|
||||||
'organization_id' => $organization ? $organization->id : NULL,
|
'organization_id' => $organization ? $organization->id : NULL,
|
||||||
'status' => 'requested'
|
'status' => 'requested'
|
||||||
@@ -90,17 +107,14 @@ class ClaimRequestService{
|
|||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
public static function updateClaimRequest(){
|
public static function updateClaimRequest($organization_id, $claim_request_id){
|
||||||
try {
|
try {
|
||||||
$data = [
|
$data = [
|
||||||
'member_id' => $member->id,
|
'organization_id' => $organization_id
|
||||||
'currency' => 'IDR',
|
|
||||||
'plan_id' => $member->currentPlan->id,
|
|
||||||
'total_claim' => $row['tot_amt_insurred'],
|
|
||||||
'claim_request_id' => $claim_request_id,
|
|
||||||
'organization_id' => $organization ? $organization->id : NULL,
|
|
||||||
'status' => 'requested'
|
|
||||||
];
|
];
|
||||||
|
DB::commit();
|
||||||
|
$update = ClaimRequest::where('id', $claim_request_id)->update($data);
|
||||||
|
return ClaimRequest::find($claim_request_id);
|
||||||
|
|
||||||
} catch (\Exception $error) {
|
} catch (\Exception $error) {
|
||||||
DB::rollBack();
|
DB::rollBack();
|
||||||
@@ -124,12 +138,22 @@ class ClaimRequestService{
|
|||||||
throw new ImportRowException(__('Member Tidak ditemukan'), 0, null, $row);
|
throw new ImportRowException(__('Member Tidak ditemukan'), 0, null, $row);
|
||||||
};
|
};
|
||||||
$code = $row['client_claim_id'];
|
$code = $row['client_claim_id'];
|
||||||
|
$organization_id = $row['provider_code'];
|
||||||
$submissionDate = Helper::formatDateDB($row['admission_date']);
|
$submissionDate = Helper::formatDateDB($row['admission_date']);
|
||||||
$paymentType = $row['claim_type'];
|
$paymentType = $row['claim_type'];
|
||||||
$status = $row['status'];
|
$status = $row['status'];
|
||||||
$serviceCode = $row['coverage_type'];
|
$serviceCode = $row['coverage_type'];
|
||||||
|
|
||||||
$newClaimRequest = $this->storeClaimRequest(code: $code, member: $member, paymentType: $paymentType, serviceCode: $serviceCode, submissionDate: $submissionDate, status: $status);
|
$newClaimRequest = $this->storeClaimRequest(
|
||||||
|
row: $row,
|
||||||
|
code: $code,
|
||||||
|
member: $member,
|
||||||
|
paymentType: $paymentType,
|
||||||
|
serviceCode: $serviceCode,
|
||||||
|
submissionDate: $submissionDate,
|
||||||
|
status: $status,
|
||||||
|
organization_code: $organization_id
|
||||||
|
);
|
||||||
|
|
||||||
$newlyCreatedID = $newClaimRequest->id;
|
$newlyCreatedID = $newClaimRequest->id;
|
||||||
|
|
||||||
@@ -145,6 +169,7 @@ class ClaimRequestService{
|
|||||||
|
|
||||||
$claim_request_data = $row;
|
$claim_request_data = $row;
|
||||||
|
|
||||||
|
dd($row);
|
||||||
// dd($claim_request_data['admission_date']);
|
// dd($claim_request_data['admission_date']);
|
||||||
|
|
||||||
$this->validatePlanRow($claim_request_data);
|
$this->validatePlanRow($claim_request_data);
|
||||||
|
|||||||
@@ -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('claim_requests', function (Blueprint $table) {
|
||||||
|
$table->integer('organization_id')->after('claim_id');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function down()
|
||||||
|
{
|
||||||
|
Schema::table('claim_request', function (Blueprint $table) {
|
||||||
|
$table->dropColumn('organization_id');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
@@ -0,0 +1,42 @@
|
|||||||
|
<?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('claims', function (Blueprint $table) {
|
||||||
|
$table->string('benefit_code')->after('organization_id');
|
||||||
|
$table->string('benefit_desc')->after('benefit_code');
|
||||||
|
$table->integer('amount_incurred')->after('benefit_desc');
|
||||||
|
$table->integer('amount_approved')->after('amount_incurred');
|
||||||
|
$table->integer('amount_not_approved')->after('amount_approved');
|
||||||
|
$table->integer('excess_paid')->after('amount_not_approved');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
/**
|
||||||
|
* Reverse the migrations.
|
||||||
|
*
|
||||||
|
* @return void
|
||||||
|
*/
|
||||||
|
public function down()
|
||||||
|
{
|
||||||
|
Schema::table('claims', function (Blueprint $table) {
|
||||||
|
$table->dropColumn('benefit_code');
|
||||||
|
$table->dropColumn('benefit_desc');
|
||||||
|
$table->dropColumn('amount_incurred');
|
||||||
|
$table->dropColumn('amount_approved');
|
||||||
|
$table->dropColumn('amount_not_approved');
|
||||||
|
$table->dropColumn('excess_paid');
|
||||||
|
});
|
||||||
|
}
|
||||||
|
};
|
||||||
2356
frontend/dashboard/pnpm-lock.yaml
generated
2356
frontend/dashboard/pnpm-lock.yaml
generated
File diff suppressed because it is too large
Load Diff
@@ -1,3 +1,4 @@
|
|||||||
|
import { Benefit } from "./corporates";
|
||||||
import { Member } from "./member";
|
import { Member } from "./member";
|
||||||
|
|
||||||
export type ClaimRequest = {
|
export type ClaimRequest = {
|
||||||
@@ -17,12 +18,45 @@ export type ClaimRequest = {
|
|||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export type Claims = {
|
||||||
|
id: number;
|
||||||
|
code: string;
|
||||||
|
plan: Plan;
|
||||||
|
payor_id: string;
|
||||||
|
corporate_id: string;
|
||||||
|
policy_number: string;
|
||||||
|
member: Member;
|
||||||
|
benefit: Benefit | boolean;
|
||||||
|
status: string;
|
||||||
|
claim_request: ClaimRequest;
|
||||||
|
};
|
||||||
|
|
||||||
|
export type ClaimsEdit = {
|
||||||
|
id: number;
|
||||||
|
plan_id: string;
|
||||||
|
payor_id: string;
|
||||||
|
corporate_id: string;
|
||||||
|
policy_number: string;
|
||||||
|
member_id: string;
|
||||||
|
benefit_code: string;
|
||||||
|
benefit_desc: string;
|
||||||
|
amount_incurred: number;
|
||||||
|
amount_approved: number;
|
||||||
|
amount_not_approved: number;
|
||||||
|
excess_paid: number;
|
||||||
|
}
|
||||||
|
|
||||||
export type Files = {
|
export type Files = {
|
||||||
name: string;
|
name: string;
|
||||||
url: string;
|
url: string;
|
||||||
path: string;
|
path: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export type Plan = {
|
||||||
|
code: string;
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
export type Organizations = {
|
export type Organizations = {
|
||||||
id: number;
|
id: number;
|
||||||
code: string;
|
code: string;
|
||||||
@@ -46,4 +80,11 @@ export type Organizations = {
|
|||||||
merchant_key: string;
|
merchant_key: string;
|
||||||
image_url: string;
|
image_url: string;
|
||||||
region_groups: string;
|
region_groups: string;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
export type Import = {
|
||||||
|
result_file: {
|
||||||
|
url: string,
|
||||||
|
name: string,
|
||||||
|
}
|
||||||
|
}
|
||||||
@@ -6,6 +6,8 @@ import { Controller, useForm } from 'react-hook-form';
|
|||||||
import React, { useRef, useEffect, useMemo, useState } from 'react';
|
import React, { useRef, useEffect, useMemo, useState } from 'react';
|
||||||
import axios from '../../utils/axios';
|
import axios from '../../utils/axios';
|
||||||
import { FormProvider, RHFTextField } from '../../components/hook-form';
|
import { FormProvider, RHFTextField } from '../../components/hook-form';
|
||||||
|
|
||||||
|
import { makeFormData } from '@/utils/jsonToFormData';
|
||||||
import {
|
import {
|
||||||
Autocomplete,
|
Autocomplete,
|
||||||
Button,
|
Button,
|
||||||
@@ -55,7 +57,7 @@ export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
|||||||
const { enqueueSnackbar } = useSnackbar();
|
const { enqueueSnackbar } = useSnackbar();
|
||||||
|
|
||||||
const EditClaimSchema = Yup.object().shape({
|
const EditClaimSchema = Yup.object().shape({
|
||||||
organization_id: Yup.string().required('Name is required'),
|
organization_id: Yup.string().required('Code Provider is required'),
|
||||||
});
|
});
|
||||||
|
|
||||||
const defaultValues = useMemo(
|
const defaultValues = useMemo(
|
||||||
@@ -66,19 +68,21 @@ export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
|||||||
date: currentClaim?.submission_date ? fDateTimesecond(currentClaim?.submission_date) : '-',
|
date: currentClaim?.submission_date ? fDateTimesecond(currentClaim?.submission_date) : '-',
|
||||||
claim_method: currentClaim?.payment_type || '-',
|
claim_method: currentClaim?.payment_type || '-',
|
||||||
service_type: currentClaim?.service_code || '-',
|
service_type: currentClaim?.service_code || '-',
|
||||||
organization_id: currentClaim?.claim?.organization?.code || '-',
|
organization_id: currentClaim?.organization?.code || '-',
|
||||||
}),
|
}),
|
||||||
[currentClaim]
|
[currentClaim]
|
||||||
);
|
);
|
||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
console.log(currentClaim, 'er')
|
|
||||||
if (isEdit && currentClaim) {
|
if (isEdit && currentClaim) {
|
||||||
reset(defaultValues);
|
reset(defaultValues);
|
||||||
}
|
}
|
||||||
if (!isEdit) {
|
if (!isEdit) {
|
||||||
reset(defaultValues);
|
reset(defaultValues);
|
||||||
}
|
}
|
||||||
|
// setFileKondisis(currentClaim?.files_by_type?.claim_diagnosis);
|
||||||
|
// setFileDiagnosas(currentClaim?.files_by_type?.claim_diagnosis);
|
||||||
|
setFileHasilPenunjangCurrent(currentClaim?.files_by_type?.claim_result);
|
||||||
}, [isEdit, currentClaim]);
|
}, [isEdit, currentClaim]);
|
||||||
|
|
||||||
|
|
||||||
@@ -150,6 +154,7 @@ export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
|||||||
// Files Result Hasil Penunjang
|
// Files Result Hasil Penunjang
|
||||||
const fileHasilPenunjangInput = useRef<HTMLInputElement>(null);
|
const fileHasilPenunjangInput = useRef<HTMLInputElement>(null);
|
||||||
const [fileHasilPenunjangs, setFileHasilPenunjangs] = useState([]);
|
const [fileHasilPenunjangs, setFileHasilPenunjangs] = useState([]);
|
||||||
|
const [fileHasilPenunjangsCurrent, setFileHasilPenunjangCurrent] = useState([]);
|
||||||
|
|
||||||
const handleResultInputChange = (event) => {
|
const handleResultInputChange = (event) => {
|
||||||
if (event.target.files[0]) {
|
if (event.target.files[0]) {
|
||||||
@@ -169,12 +174,19 @@ export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
|||||||
|
|
||||||
const onSubmit = async (data: FormValuesProps) => {
|
const onSubmit = async (data: FormValuesProps) => {
|
||||||
try {
|
try {
|
||||||
const formData = new FormData();
|
// const formData = new FormData();
|
||||||
formData.append('result_files', fileHasilPenunjangs);
|
// formData.append('result_files', fileHasilPenunjangs);
|
||||||
formData.append('diagnosa_files', fileDiagnosaInput);
|
// formData.append('diagnosa_files', fileDiagnosaInput);
|
||||||
formData.append('kondisi_files', fileKondisiInput);
|
// formData.append('kondisi_files', fileKondisiInput);
|
||||||
formData.append('provider_code', data.organization_id);
|
// formData.append('provider_code', data.organization_id);
|
||||||
formData.append('_method', 'PUT');
|
// formData.append('_method', 'PUT');
|
||||||
|
const formData = makeFormData({
|
||||||
|
result_files: fileHasilPenunjangs,
|
||||||
|
diagnosa_files: fileDiagnosas,
|
||||||
|
kondisi_files: fileKondisis,
|
||||||
|
provider_code: data.organization_id,
|
||||||
|
_method: 'PUT'
|
||||||
|
});
|
||||||
|
|
||||||
const response = await axios.post(`/claim-requests/${data.id}`, formData);
|
const response = await axios.post(`/claim-requests/${data.id}`, formData);
|
||||||
|
|
||||||
|
|||||||
@@ -47,12 +47,13 @@ import { fDateTimesecond } from '@/utils/formatTime';
|
|||||||
import { capitalizeFirstLetter } from '@/utils/formatString';
|
import { capitalizeFirstLetter } from '@/utils/formatString';
|
||||||
import Label from '@/components/Label';
|
import Label from '@/components/Label';
|
||||||
import TableMoreMenu from '@/components/table/TableMoreMenu';
|
import TableMoreMenu from '@/components/table/TableMoreMenu';
|
||||||
|
import { Import } from '@/@types/claims';
|
||||||
// import LoadingButton from '@/theme/overrides/LoadingButton';
|
// import LoadingButton from '@/theme/overrides/LoadingButton';
|
||||||
|
|
||||||
export default function List() {
|
export default function List() {
|
||||||
const { themeColorPresets } = useSettings();
|
const { themeColorPresets } = useSettings();
|
||||||
const [searchParams, setSearchParams] = useSearchParams();
|
const [searchParams, setSearchParams] = useSearchParams();
|
||||||
const [importResult, setImportResult] = useState(null);
|
const [importResult, setImportResult] = useState<Import>(null);
|
||||||
|
|
||||||
const navigate = useNavigate()
|
const navigate = useNavigate()
|
||||||
|
|
||||||
@@ -213,7 +214,7 @@ export default function List() {
|
|||||||
}}
|
}}
|
||||||
>
|
>
|
||||||
<MenuItem onClick={handleImportButton}>Import</MenuItem>
|
<MenuItem onClick={handleImportButton}>Import</MenuItem>
|
||||||
<MenuItem onClick={() => {handleGetTemplate('claim-request')}}>Download Template test</MenuItem>
|
<MenuItem onClick={() => {handleGetTemplate('claim-request')}}>Download Template</MenuItem>
|
||||||
<MenuItem onClick={() => {handleGetData('data-plan-benefit')}}>Download Claim Request</MenuItem>
|
<MenuItem onClick={() => {handleGetData('data-plan-benefit')}}>Download Claim Request</MenuItem>
|
||||||
</Menu>
|
</Menu>
|
||||||
<Button
|
<Button
|
||||||
@@ -257,6 +258,16 @@ export default function List() {
|
|||||||
</LoadingButton>
|
</LoadingButton>
|
||||||
</Stack>
|
</Stack>
|
||||||
)}
|
)}
|
||||||
|
{importResult && (
|
||||||
|
<Stack direction={'row'} sx={{ px: 2, pb: 2 }}>
|
||||||
|
<Box sx={{ color: 'text.secondary' }}>
|
||||||
|
Last Import Result Report :{' '}
|
||||||
|
<a href={importResult.result_file?.url ?? '#'}>
|
||||||
|
{importResult.result_file?.name ?? '-'}
|
||||||
|
</a>
|
||||||
|
</Box>
|
||||||
|
</Stack>
|
||||||
|
)}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -28,31 +28,26 @@ export default function ClaimsCreateUpdate() {
|
|||||||
|
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
if (isEdit) {
|
if (isEdit) {
|
||||||
axios.get('/claims/' + id).then((res) => {
|
axios.get(`/claims/${id}/edit`).then((res) => {
|
||||||
// console.log('Yeet', res.data);
|
console.log('Yeet', res.data.data);
|
||||||
setCurrentClaim(res.data);
|
setCurrentClaim(res.data.data);
|
||||||
});
|
});;
|
||||||
|
|
||||||
}
|
}
|
||||||
}, [id]);
|
}, [id]);
|
||||||
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Page title={isEdit ? `Edit Claim : ${currentClaim?.id}` : "Create New Claim"}>
|
<Page title={'Edit Claim Management'}>
|
||||||
<Container maxWidth={themeStretch ? false : 'xl'}>
|
<Container maxWidth={themeStretch ? false : 'xl'}>
|
||||||
<Stack direction="row" alignItems="center">
|
<Stack direction="row" alignItems="center">
|
||||||
<HeaderBreadcrumbs
|
<HeaderBreadcrumbs
|
||||||
heading={
|
heading={`Edit Claim Management`}
|
||||||
!isEdit
|
|
||||||
? 'Create New Claim'
|
|
||||||
: `Edit Claim : ${currentClaim?.code}`
|
|
||||||
}
|
|
||||||
links={[
|
links={[
|
||||||
{ name: 'Dashboard', href: '/dashboard' },
|
{ name: 'Dashboard', href: '/dashboard' },
|
||||||
{
|
{
|
||||||
name: 'Claim',
|
name: 'Claim Management',
|
||||||
href: '/claims',
|
|
||||||
},
|
},
|
||||||
{ name: !isEdit ? 'Create' : currentClaim?.id ?? '' },
|
|
||||||
]}
|
]}
|
||||||
/>
|
/>
|
||||||
</Stack>
|
</Stack>
|
||||||
|
|||||||
@@ -24,16 +24,18 @@ import {
|
|||||||
ListItemAvatar,
|
ListItemAvatar,
|
||||||
Avatar,
|
Avatar,
|
||||||
ListItemText,
|
ListItemText,
|
||||||
|
Card,
|
||||||
} from '@mui/material';
|
} from '@mui/material';
|
||||||
import Iconify from '../../components/Iconify';
|
import Iconify from '../../components/Iconify';
|
||||||
import { LoadingButton } from '@mui/lab';
|
import { LoadingButton } from '@mui/lab';
|
||||||
import { fCurrency } from '../../utils/formatNumber';
|
import { fCurrency } from '../../utils/formatNumber';
|
||||||
import MemberSelectDialog from '../../components/dialogs/MemberSelectDialog';
|
import MemberSelectDialog from '../../components/dialogs/MemberSelectDialog';
|
||||||
import { Add, DeleteOutline } from '@mui/icons-material';
|
import { Add, DeleteOutline } from '@mui/icons-material';
|
||||||
|
import { ClaimsEdit } from '@/@types/claims';
|
||||||
|
|
||||||
type Props = {
|
type Props = {
|
||||||
isEdit: boolean;
|
isEdit: boolean;
|
||||||
currentClaim?: any;
|
currentClaim?: ClaimsEdit;
|
||||||
};
|
};
|
||||||
|
|
||||||
export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
||||||
@@ -42,18 +44,27 @@ export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
|||||||
const { enqueueSnackbar } = useSnackbar();
|
const { enqueueSnackbar } = useSnackbar();
|
||||||
|
|
||||||
const NewCorporateSchema = Yup.object().shape({
|
const NewCorporateSchema = Yup.object().shape({
|
||||||
name: Yup.string().required('Name is required'),
|
benefit_desc: Yup.string().required('Benefit Desc is required'),
|
||||||
code: Yup.string().required('Corporate Code is required'),
|
amount_incurred: Yup.string().required('Amount Incurred is required'),
|
||||||
active: Yup.boolean().required('Corporate Status is required'),
|
amount_approved: Yup.number().required('Amount Approved is required'),
|
||||||
|
amount_not_approved: Yup.number().required('Amount Not Approved is required'),
|
||||||
|
excess_paid: Yup.number().required('Excess Paid is required'),
|
||||||
// file: Yup.boolean().required('Corporate Status is required'),
|
// file: Yup.boolean().required('Corporate Status is required'),
|
||||||
});
|
});
|
||||||
|
|
||||||
const defaultValues = useMemo(
|
const defaultValues = useMemo(
|
||||||
() => ({
|
() => ({
|
||||||
member: currentClaim?.member || {},
|
plan_id: currentClaim?.plan_id || null,
|
||||||
|
payor_id: currentClaim?.payor_id || null,
|
||||||
|
corporate_id: currentClaim?.corporate_id || null,
|
||||||
|
policy_number: currentClaim?.policy_number || null,
|
||||||
member_id: currentClaim?.member_id || null,
|
member_id: currentClaim?.member_id || null,
|
||||||
diagnosis_id: currentClaim?.diagnosis_id || null,
|
benefit_code: currentClaim?.benefit_code || '-',
|
||||||
total_claim: currentClaim?.total_claim || 0,
|
benefit_desc: currentClaim?.benefit_desc || '-',
|
||||||
|
amount_incurred: currentClaim?.amount_incurred || 0,
|
||||||
|
amount_approved: currentClaim?.amount_approved || 0,
|
||||||
|
amount_not_approved: currentClaim?.amount_not_approved || 0,
|
||||||
|
excess_paid: currentClaim?.excess_paid || 0,
|
||||||
}),
|
}),
|
||||||
// eslint-disable-next-line react-hooks/exhaustive-deps
|
// eslint-disable-next-line react-hooks/exhaustive-deps
|
||||||
[currentClaim]
|
[currentClaim]
|
||||||
@@ -88,11 +99,11 @@ export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
|||||||
console.log('defaultValues', defaultValues);
|
console.log('defaultValues', defaultValues);
|
||||||
if (isEdit && currentClaim) {
|
if (isEdit && currentClaim) {
|
||||||
reset(defaultValues);
|
reset(defaultValues);
|
||||||
setMember(defaultValues.member)
|
// setMember(defaultValues.member)
|
||||||
}
|
}
|
||||||
if (!isEdit) {
|
if (!isEdit) {
|
||||||
reset(defaultValues);
|
reset(defaultValues);
|
||||||
setMember(defaultValues.member)
|
// setMember(defaultValues.member)
|
||||||
}
|
}
|
||||||
}, [isEdit, currentClaim]);
|
}, [isEdit, currentClaim]);
|
||||||
|
|
||||||
@@ -105,13 +116,13 @@ export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
|||||||
console.log('currentFiles', getValues('uploaded_files'));
|
console.log('currentFiles', getValues('uploaded_files'));
|
||||||
};
|
};
|
||||||
|
|
||||||
const memberSelected = (member) => {
|
// const memberSelected = (member) => {
|
||||||
setMember(member)
|
// setMember(member)
|
||||||
};
|
// };
|
||||||
|
|
||||||
const checkLimit = async () => {
|
// const checkLimit = async () => {
|
||||||
console.log('CHECKING LIMIT');
|
// console.log('CHECKING LIMIT');
|
||||||
};
|
// };
|
||||||
|
|
||||||
const onSubmit = async (data: any) => {
|
const onSubmit = async (data: any) => {
|
||||||
try {
|
try {
|
||||||
@@ -122,7 +133,7 @@ export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
|||||||
}
|
}
|
||||||
reset();
|
reset();
|
||||||
enqueueSnackbar(
|
enqueueSnackbar(
|
||||||
!isEdit ? 'Organizations Created Successfully!' : 'Organizations Udpated Successfully!',
|
!isEdit ? 'Organizations Created Successfully!' : 'Claim Udpated Successfully!',
|
||||||
{ variant: 'success' }
|
{ variant: 'success' }
|
||||||
);
|
);
|
||||||
navigate('/claims');
|
navigate('/claims');
|
||||||
@@ -154,443 +165,86 @@ export default function ClaimForm({ isEdit, currentClaim }: Props) {
|
|||||||
const headStyle = {};
|
const headStyle = {};
|
||||||
return (
|
return (
|
||||||
<FormProvider methods={methods} onSubmit={handleSubmit(onSubmit)}>
|
<FormProvider methods={methods} onSubmit={handleSubmit(onSubmit)}>
|
||||||
<Stack spacing={3}>
|
<Card sx={{paddingX:2, paddingY:3}}>
|
||||||
<Typography variant="h6">Member</Typography>
|
<Grid container spacing={2}>
|
||||||
|
{/* Baris ke 1 */}
|
||||||
<Stack spacing={2} direction="row">
|
<Grid item xs={3}>
|
||||||
<Grid item xs={12}>
|
<Typography marginBottom={2} variant="subtitle1">Plan ID*</Typography>
|
||||||
<RHFTextField
|
<RHFTextField name="plan_id" disabled />
|
||||||
name="member_id"
|
</Grid>
|
||||||
label="Member"
|
<Grid item xs={3}>
|
||||||
variant="outlined"
|
<Typography marginBottom={2} variant="subtitle1">Payor ID*</Typography>
|
||||||
fullWidth
|
<RHFTextField name="payor_id" disabled />
|
||||||
value={member?.name || ''}
|
</Grid>
|
||||||
InputProps={{
|
<Grid item xs={3}>
|
||||||
readOnly: true,
|
<Typography marginBottom={2} variant="subtitle1">Corporate ID*</Typography>
|
||||||
}}
|
<RHFTextField name="corporate_id"disabled />
|
||||||
onClick={() => {
|
</Grid>
|
||||||
if (!isEdit) setIsMemberDialogOpen(true);
|
<Grid item xs={3}>
|
||||||
if (isEdit) enqueueSnackbar('Cannot Change Member', { variant: 'error' });
|
<Typography marginBottom={2} variant="subtitle1">Policy Number*</Typography>
|
||||||
}}
|
<RHFTextField name="policy_number" disabled />
|
||||||
/>
|
|
||||||
</Grid>
|
|
||||||
{/* <Grid item xs={2}>
|
|
||||||
<Button variant="outlined" fullWidth sx={{ p: 1.8 }} onClick={() => {
|
|
||||||
setIsMemberDialogOpen(true)
|
|
||||||
}}>
|
|
||||||
{member ? 'Change' : 'Search'}
|
|
||||||
</Button>
|
|
||||||
</Grid> */}
|
|
||||||
</Stack>
|
|
||||||
|
|
||||||
{member?.id && (
|
|
||||||
<Stack>
|
|
||||||
<Grid container spacing={2}>
|
|
||||||
<Grid item xs={12} md={6}>
|
|
||||||
<Table border="light-700">
|
|
||||||
<TableBody>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
Name
|
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">{member?.full_name}</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
DOB
|
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">
|
|
||||||
{member?.birth_date} ({member?.age + ' years'})
|
|
||||||
</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
Marital Status
|
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">{member?.marital_status}</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
Record Type
|
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">{member?.record_type}</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
Principal ID
|
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">
|
|
||||||
{member?.principal_id} (
|
|
||||||
{member?.relation_with_principal})
|
|
||||||
</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
</TableBody>
|
|
||||||
</Table>
|
|
||||||
</Grid>
|
|
||||||
<Grid item xs={12} md={6}>
|
|
||||||
<Table border="light-700">
|
|
||||||
<TableBody>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
Plan
|
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">{member?.current_plan?.code}</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
Active
|
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">
|
|
||||||
{member?.current_plan?.start} -{' '}
|
|
||||||
{member?.current_plan?.end} (Active)
|
|
||||||
</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
Corporate Limit
|
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">
|
|
||||||
{fCurrency(0)} / {fCurrency(member?.current_plan?.limit_rules)}
|
|
||||||
</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
<TableRow>
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
Plan Usage
|
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">
|
|
||||||
{fCurrency(0)} / {fCurrency(member?.current_plan?.limit_rules)}
|
|
||||||
</TableCell>
|
|
||||||
</TableRow>
|
|
||||||
</TableBody>
|
|
||||||
</Table>
|
|
||||||
</Grid>
|
|
||||||
</Grid>
|
</Grid>
|
||||||
</Stack>
|
|
||||||
)}
|
|
||||||
|
|
||||||
<Controller
|
{/* Baris ke 2 */}
|
||||||
name="benefit"
|
<Grid item xs={3}>
|
||||||
control={control}
|
<Typography marginBottom={2} variant="subtitle1">Memeber ID*</Typography>
|
||||||
render={({ field: { onChange, value } }) => (
|
<RHFTextField name="member_id" disabled />
|
||||||
<Autocomplete
|
</Grid>
|
||||||
options={memberBenefits}
|
<Grid item xs={3}>
|
||||||
getOptionLabel={(option) =>
|
<Typography marginBottom={2} variant="subtitle1">Benefit Code*</Typography>
|
||||||
option ? `#${option.id} (${option.code}) ${option.description}` : ''
|
<RHFTextField name="benefit_code" disabled />
|
||||||
}
|
</Grid>
|
||||||
value={value || ''}
|
<Grid item xs={6}>
|
||||||
onChange={(event: any, newValue: any) => {
|
<Typography marginBottom={2} variant="subtitle1">Benefit Desc*</Typography>
|
||||||
setValue('benefit_id', newValue?.id);
|
<RHFTextField name="benefit_desc" label="Benefit Desc" />
|
||||||
onChange(newValue);
|
</Grid>
|
||||||
}}
|
|
||||||
renderInput={(params) => (
|
|
||||||
<TextField
|
|
||||||
name="benefit"
|
|
||||||
{...params}
|
|
||||||
label="Benefit"
|
|
||||||
variant="outlined"
|
|
||||||
fullWidth
|
|
||||||
// onKeyPress={(event) => {
|
|
||||||
// if (event.key === 'Enter')
|
|
||||||
// searchDiagnosis(event.target.value)
|
|
||||||
// }}
|
|
||||||
/>
|
|
||||||
)}
|
|
||||||
/>
|
|
||||||
)}
|
|
||||||
/>
|
|
||||||
|
|
||||||
<Controller
|
{/* Baris ke 3 */}
|
||||||
name="diagnosis"
|
<Grid item xs={3}>
|
||||||
control={control}
|
<Typography marginBottom={2} variant="subtitle1">Amount Incurred*</Typography>
|
||||||
render={({ field: { onChange, value } }) => (
|
<RHFTextField name="amount_incurred" label="Amount Incurred" type="number" />
|
||||||
<Autocomplete
|
</Grid>
|
||||||
options={diagnosisOption}
|
<Grid item xs={3}>
|
||||||
getOptionLabel={(option) => (option ? `(${option.code}) ${option.name}` : '')}
|
<Typography marginBottom={2} variant="subtitle1">Amount Approved*</Typography>
|
||||||
value={value || ''}
|
<RHFTextField name="amount_approved" label="Amount Approved" type="number" />
|
||||||
onChange={(event: any, newValue: any) => {
|
</Grid>
|
||||||
setValue('diagnosis_id', newValue?.id);
|
<Grid item xs={3}>
|
||||||
// setValue('diagnosis', newValue)
|
<Typography marginBottom={2} variant="subtitle1">Amount Not Approved*</Typography>
|
||||||
onChange(newValue);
|
<RHFTextField name="amount_not_approved" label="Amount Not Approved" type="number" />
|
||||||
}}
|
</Grid>
|
||||||
renderInput={(params) => (
|
<Grid item xs={3}>
|
||||||
<TextField
|
<Typography marginBottom={2} variant="subtitle1">Excess Paid*</Typography>
|
||||||
name="diagnosis"
|
<RHFTextField name="excess_paid" label="Excess Paid*" type="number" />
|
||||||
{...params}
|
</Grid>
|
||||||
label="Diagnosis"
|
</Grid>
|
||||||
variant="outlined"
|
</Card>
|
||||||
fullWidth
|
<Grid container marginTop={2}>
|
||||||
onKeyPress={(event) => {
|
<Grid item xs={12} md={12} >
|
||||||
if (event.key === 'Enter') searchDiagnosis(event.target.value);
|
<Stack direction="row" alignItems="center" justifyContent="flex-end">
|
||||||
}}
|
<Button
|
||||||
/>
|
sx={{
|
||||||
)}
|
margin: 1
|
||||||
/>
|
|
||||||
)}
|
|
||||||
/>
|
|
||||||
|
|
||||||
{isCheckingLimit && (
|
|
||||||
<Stack
|
|
||||||
sx={{
|
|
||||||
backgroundColor: 'gray',
|
|
||||||
paddingY: 1,
|
|
||||||
paddingX: 1.5,
|
|
||||||
mb: 2,
|
|
||||||
borderRadius: '3-xl',
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
{/* Checking */}
|
|
||||||
<Typography sx={{ typography: 'caption', display: 'flex', alignItems: 'center' }}>
|
|
||||||
<Iconify
|
|
||||||
icon="bxs:info-circle"
|
|
||||||
width={12}
|
|
||||||
height={13}
|
|
||||||
sx={{ color: '#424242', marginRight: '6px' }}
|
|
||||||
/>
|
|
||||||
<Typography variant="caption" component="span">
|
|
||||||
Please Wait, Checking Eligibilty
|
|
||||||
</Typography>
|
|
||||||
</Typography>
|
|
||||||
</Stack>
|
|
||||||
)}
|
|
||||||
{false && isCheckingLimit == false && isEligible == null && (
|
|
||||||
<Stack
|
|
||||||
sx={{
|
|
||||||
backgroundColor: 'gray',
|
|
||||||
paddingY: 1,
|
|
||||||
paddingX: 1.5,
|
|
||||||
mb: 2,
|
|
||||||
borderRadius: '3-xl',
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
{/* No Data Selected */}
|
|
||||||
<Typography sx={{ typography: 'caption', display: 'flex', alignItems: 'center' }}>
|
|
||||||
<Iconify
|
|
||||||
icon="bxs:info-circle"
|
|
||||||
width={12}
|
|
||||||
height={13}
|
|
||||||
sx={{ color: '#424242', marginRight: '6px' }}
|
|
||||||
/>
|
|
||||||
<Typography variant="caption" component="span">
|
|
||||||
Please Select Diagnosis !
|
|
||||||
</Typography>
|
|
||||||
</Typography>
|
|
||||||
</Stack>
|
|
||||||
)}
|
|
||||||
{!isCheckingLimit && isEligible !== null && isEligible && (
|
|
||||||
<Stack
|
|
||||||
sx={{
|
|
||||||
backgroundColor: '#B2E8E8',
|
|
||||||
paddingY: 1,
|
|
||||||
paddingX: 1.5,
|
|
||||||
mb: 2,
|
|
||||||
borderRadius: '3-xl',
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
{/* Eligible */}
|
|
||||||
<Typography sx={{ typography: 'caption', display: 'flex', alignItems: 'center' }}>
|
|
||||||
<Iconify
|
|
||||||
icon="bxs:lock-alt"
|
|
||||||
width={12}
|
|
||||||
height={13}
|
|
||||||
sx={{ color: '#424242', marginRight: '6px' }}
|
|
||||||
/>
|
|
||||||
<Typography variant="caption" component="span">
|
|
||||||
Diagnosis is Eligible
|
|
||||||
</Typography>
|
|
||||||
</Typography>
|
|
||||||
<Typography sx={{ typography: 'caption', color: '#637381' }}>
|
|
||||||
125.000.000 / 125.000.000
|
|
||||||
</Typography>
|
|
||||||
</Stack>
|
|
||||||
)}
|
|
||||||
{!isCheckingLimit && isEligible !== null && !isEligible && (
|
|
||||||
<Stack
|
|
||||||
sx={{
|
|
||||||
backgroundColor: '#B2E8E8',
|
|
||||||
paddingY: 1,
|
|
||||||
paddingX: 1.5,
|
|
||||||
mb: 2,
|
|
||||||
borderRadius: '3-xl',
|
|
||||||
}}
|
|
||||||
>
|
|
||||||
{/* Not Eligible */}
|
|
||||||
{/* <Typography sx={{ typography: 'caption', display: 'flex', alignItems: 'center' }}>
|
|
||||||
<Iconify
|
|
||||||
icon="bxs:lock-alt"
|
|
||||||
width={12}
|
|
||||||
height={13}
|
|
||||||
sx={{ color: '#424242', marginRight: '6px' }}
|
|
||||||
/>
|
|
||||||
<Typography variant="caption" component="span">
|
|
||||||
Not Eligible
|
|
||||||
</Typography>
|
|
||||||
</Typography>
|
|
||||||
<Typography sx={{ typography: 'caption', color: '#637381' }}>
|
|
||||||
125.000.000 / 125.000.000
|
|
||||||
</Typography> */}
|
|
||||||
</Stack>
|
|
||||||
)}
|
|
||||||
|
|
||||||
<RHFTextField type="number" name="total_claim" label="Total Claim" />
|
|
||||||
|
|
||||||
{isEdit && (
|
|
||||||
<React.Fragment>
|
|
||||||
<Typography variant="h6">Documents</Typography>
|
|
||||||
|
|
||||||
<List>
|
|
||||||
{(getValues('uploaded_files.invoice') && getValues('uploaded_files.invoice').length
|
|
||||||
? getValues('uploaded_files.invoice')
|
|
||||||
: []
|
|
||||||
).map((file, index) => (
|
|
||||||
<ListItem
|
|
||||||
secondaryAction={
|
|
||||||
<IconButton edge="end" aria-label="delete">
|
|
||||||
<DeleteOutline />
|
|
||||||
</IconButton>
|
|
||||||
}
|
|
||||||
>
|
|
||||||
<ListItemAvatar>
|
|
||||||
<Avatar>
|
|
||||||
{/* <FileIcon /> */}
|
|
||||||
I
|
|
||||||
</Avatar>
|
|
||||||
</ListItemAvatar>
|
|
||||||
<ListItemText primary={file.name} secondary={file.type} />
|
|
||||||
</ListItem>
|
|
||||||
))}
|
|
||||||
</List>
|
|
||||||
<Button
|
|
||||||
variant="outlined"
|
|
||||||
startIcon={<Add />}
|
|
||||||
component="label"
|
|
||||||
sx={{ paddingY: 2, width: '100%', ':hover': { border: 'none' } }}
|
|
||||||
>
|
|
||||||
Invoice
|
|
||||||
<input
|
|
||||||
name="invoice"
|
|
||||||
hidden
|
|
||||||
accept="image/*,application/pdf"
|
|
||||||
multiple
|
|
||||||
type="file"
|
|
||||||
onChange={(event) => {
|
|
||||||
fileSelected(event, 'invoice');
|
|
||||||
}}
|
}}
|
||||||
/>
|
type="submit"
|
||||||
</Button>
|
variant="contained"
|
||||||
<List>
|
size="large"
|
||||||
{(getValues('uploaded_files.prescription') && getValues('uploaded_files.prescription').length
|
color='inherit'
|
||||||
? getValues('uploaded_files.prescription')
|
onClick={() => navigate(`/claims`)}
|
||||||
: []
|
>
|
||||||
).map((file, index) => (
|
Cancel
|
||||||
<ListItem
|
</Button>
|
||||||
secondaryAction={
|
<LoadingButton
|
||||||
<IconButton edge="end" aria-label="delete">
|
type="submit"
|
||||||
<DeleteOutline />
|
variant="contained"
|
||||||
</IconButton>
|
size="large"
|
||||||
}
|
// fullWidth={true}
|
||||||
>
|
loading={isSubmitting}
|
||||||
<ListItemAvatar>
|
>
|
||||||
<Avatar>
|
Save
|
||||||
{/* <FileIcon /> */}
|
</LoadingButton>
|
||||||
P
|
</Stack>
|
||||||
</Avatar>
|
</Grid>
|
||||||
</ListItemAvatar>
|
</Grid>
|
||||||
<ListItemText primary={file.name} secondary={file.type} />
|
</FormProvider>
|
||||||
</ListItem>
|
|
||||||
))}
|
|
||||||
</List>
|
|
||||||
<Button
|
|
||||||
variant="outlined"
|
|
||||||
startIcon={<Add />}
|
|
||||||
component="label"
|
|
||||||
sx={{ paddingY: 2, width: '100%', ':hover': { border: 'none' } }}
|
|
||||||
>
|
|
||||||
Prescription
|
|
||||||
<input
|
|
||||||
name="prescription"
|
|
||||||
hidden
|
|
||||||
accept="image/*,application/pdf"
|
|
||||||
multiple
|
|
||||||
type="file"
|
|
||||||
onChange={(event) => {
|
|
||||||
fileSelected(event, 'prescription');
|
|
||||||
}}
|
|
||||||
/>
|
|
||||||
</Button>
|
|
||||||
|
|
||||||
<List>
|
|
||||||
{(getValues('uploaded_files.diagnosis') && getValues('uploaded_files.diagnosis').length
|
|
||||||
? getValues('uploaded_files.diagnosis')
|
|
||||||
: []
|
|
||||||
).map((file, index) => (
|
|
||||||
<ListItem
|
|
||||||
secondaryAction={
|
|
||||||
<IconButton edge="end" aria-label="delete">
|
|
||||||
<DeleteOutline />
|
|
||||||
</IconButton>
|
|
||||||
}
|
|
||||||
>
|
|
||||||
<ListItemAvatar>
|
|
||||||
<Avatar>
|
|
||||||
{/* <FileIcon /> */}
|
|
||||||
DR
|
|
||||||
</Avatar>
|
|
||||||
</ListItemAvatar>
|
|
||||||
<ListItemText primary={file.name} secondary={file.type} />
|
|
||||||
</ListItem>
|
|
||||||
))}
|
|
||||||
</List>
|
|
||||||
<Button
|
|
||||||
variant="outlined"
|
|
||||||
startIcon={<Add />}
|
|
||||||
component="label"
|
|
||||||
sx={{ paddingY: 2, width: '100%', ':hover': { border: 'none' } }}
|
|
||||||
>
|
|
||||||
Doctor Result
|
|
||||||
<input
|
|
||||||
name="invoice"
|
|
||||||
hidden
|
|
||||||
accept="image/*,application/pdf"
|
|
||||||
multiple
|
|
||||||
type="file"
|
|
||||||
onChange={(event) => {
|
|
||||||
fileSelected(event, 'diagnosis');
|
|
||||||
}}
|
|
||||||
/>
|
|
||||||
</Button>
|
|
||||||
</React.Fragment>
|
|
||||||
)}
|
|
||||||
|
|
||||||
{isEligible === true ? (
|
|
||||||
<LoadingButton
|
|
||||||
onClick={handleSubmit(onSubmit)}
|
|
||||||
variant="contained"
|
|
||||||
color="success"
|
|
||||||
style={{ color: '#ffffff' }}
|
|
||||||
size="large"
|
|
||||||
fullWidth={true}
|
|
||||||
loading={isCheckingLimit}
|
|
||||||
>
|
|
||||||
Create Claim
|
|
||||||
</LoadingButton>
|
|
||||||
) : (
|
|
||||||
<LoadingButton
|
|
||||||
onClick={checkLimit}
|
|
||||||
variant="outlined"
|
|
||||||
size="large"
|
|
||||||
fullWidth={true}
|
|
||||||
loading={isCheckingLimit}
|
|
||||||
>
|
|
||||||
Check Limit
|
|
||||||
</LoadingButton>
|
|
||||||
)}
|
|
||||||
</Stack>
|
|
||||||
|
|
||||||
<MemberSelectDialog
|
|
||||||
openDialog={isMemberDialogOpen}
|
|
||||||
setOpenDialog={setIsMemberDialogOpen}
|
|
||||||
onSelect={memberSelected}
|
|
||||||
></MemberSelectDialog>
|
|
||||||
</FormProvider>
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -16,13 +16,10 @@ import {
|
|||||||
Menu,
|
Menu,
|
||||||
ButtonGroup,
|
ButtonGroup,
|
||||||
Tooltip,
|
Tooltip,
|
||||||
|
TableHead,
|
||||||
} from '@mui/material';
|
} from '@mui/material';
|
||||||
import KeyboardArrowDownIcon from '@mui/icons-material/KeyboardArrowDown';
|
import FindInPageOutlinedIcon from '@mui/icons-material/FindInPageOutlined';
|
||||||
import KeyboardArrowRightIcon from '@mui/icons-material/KeyboardArrowRight';
|
|
||||||
import AddIcon from '@mui/icons-material/Add';
|
|
||||||
import AssessmentIcon from '@mui/icons-material/Assessment';
|
import AssessmentIcon from '@mui/icons-material/Assessment';
|
||||||
import UploadIcon from '@mui/icons-material/Upload';
|
|
||||||
import CancelIcon from '@mui/icons-material/Cancel';
|
|
||||||
// hooks
|
// hooks
|
||||||
import React, { ChangeEvent, useEffect, useRef, useState } from 'react';
|
import React, { ChangeEvent, useEffect, useRef, useState } from 'react';
|
||||||
import { Link, Navigate, useNavigate, useSearchParams } from 'react-router-dom';
|
import { Link, Navigate, useNavigate, useSearchParams } from 'react-router-dom';
|
||||||
@@ -36,6 +33,12 @@ import { Chip } from '@mui/material';
|
|||||||
import Iconify from '@/components/Iconify';
|
import Iconify from '@/components/Iconify';
|
||||||
import { enqueueSnackbar } from 'notistack';
|
import { enqueueSnackbar } from 'notistack';
|
||||||
import { fDate } from '../../utils/formatTime';
|
import { fDate } from '../../utils/formatTime';
|
||||||
|
import { Claims } from '@/@types/claims';
|
||||||
|
import Label from '@/components/Label';
|
||||||
|
import { capitalizeFirstLetter } from '@/utils/formatString';
|
||||||
|
import TableMoreMenu from '@/components/table/TableMoreMenu';
|
||||||
|
import Edit from '@mui/icons-material/Edit';
|
||||||
|
import { Download } from '@mui/icons-material';
|
||||||
|
|
||||||
export default function List() {
|
export default function List() {
|
||||||
const [searchParams, setSearchParams] = useSearchParams();
|
const [searchParams, setSearchParams] = useSearchParams();
|
||||||
@@ -84,10 +87,16 @@ export default function List() {
|
|||||||
fullWidth
|
fullWidth
|
||||||
onChange={handleSearchChange}
|
onChange={handleSearchChange}
|
||||||
value={searchText}
|
value={searchText}
|
||||||
|
placeholder='Search Code or Member ID...'
|
||||||
/>
|
/>
|
||||||
<Tooltip title="Benefit Usage Report">
|
<Button
|
||||||
<Button variant="outlined" startIcon={<AssessmentIcon />} sx={{ p: 1.8 }} onClick={handleGetData}/>
|
variant="contained"
|
||||||
</Tooltip>
|
startIcon={<Download />}
|
||||||
|
sx={{ p: 1.8 }}
|
||||||
|
onClick={handleGetData}
|
||||||
|
>
|
||||||
|
Export
|
||||||
|
</Button>
|
||||||
</Stack>
|
</Stack>
|
||||||
</form>
|
</form>
|
||||||
);
|
);
|
||||||
@@ -153,7 +162,7 @@ export default function List() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
// Called on every row to map the data to the columns
|
// Called on every row to map the data to the columns
|
||||||
function createData(data: any): any {
|
function createData(data: Claims): Claims {
|
||||||
return {
|
return {
|
||||||
...data,
|
...data,
|
||||||
};
|
};
|
||||||
@@ -176,36 +185,37 @@ export default function List() {
|
|||||||
</TableCell> */}
|
</TableCell> */}
|
||||||
<TableCell align="left">{row.claim_request?.code}</TableCell>
|
<TableCell align="left">{row.claim_request?.code}</TableCell>
|
||||||
{/* <TableCell align="left">{row.code}</TableCell> */}
|
{/* <TableCell align="left">{row.code}</TableCell> */}
|
||||||
<TableCell align="left">{fDate(row.created_at)}</TableCell>
|
<TableCell align="left">{row.member?.current_plan?.code}</TableCell>
|
||||||
<TableCell align="left">{row.member?.full_name}</TableCell>
|
<TableCell align="left">{row.member?.current_corporate?.payor_id}</TableCell>
|
||||||
<TableCell align="left">{row.plan?.code}</TableCell>
|
<TableCell align="left">{row.member?.current_corporate?.code}</TableCell>
|
||||||
<TableCell align="left">{row.claim_request?.service?.name}</TableCell>
|
<TableCell align="left">{row.member?.current_corporate?.current_policy?.code}</TableCell>
|
||||||
<TableCell align="left">
|
<TableCell align="left">{row.member?.member_id}</TableCell>
|
||||||
({row.diagnoses[0]?.icd?.code}) {row.diagnoses[0]?.icd?.name}
|
<TableCell align="left">{row.benefit ? row.benefit?.description : '-'}</TableCell>
|
||||||
</TableCell>
|
|
||||||
<TableCell align="left">{fCurrency(row.total_claim)}</TableCell>
|
|
||||||
<TableCell align="center">
|
<TableCell align="center">
|
||||||
{row.status == 'draft' && (<Chip label='Draft' color="default" variant="outlined" />)}
|
{row.status == 'draft' && (<Label color='secondary' variant='ghost'>{capitalizeFirstLetter(row.status)}</Label>)}
|
||||||
{row.status == 'requested' && (<Chip label='Requested' color="primary" />)}
|
{row.status == 'requested' && (<Label color='primary' variant='ghost'>{capitalizeFirstLetter(row.status)}</Label>)}
|
||||||
{row.status == 'received' && (<Chip label='Received' color="success" variant='outlined' />)}
|
{row.status == 'received' && (<Label color='secondary' variant='ghost'>{capitalizeFirstLetter(row.status)}</Label>)}
|
||||||
{row.status == 'approved' && (<Chip label='Approved' color="success" />)}
|
{row.status == 'approved' && (<Label color='success' variant='ghost'>{capitalizeFirstLetter(row.status)}</Label>)}
|
||||||
{row.status == 'postpone' && (<Chip label='Postpone' color="primary" variant="outlined" />)}
|
{row.status == 'postpone' && (<Label color='secondary' variant='ghost'>{capitalizeFirstLetter(row.status)}</Label>)}
|
||||||
{row.status == 'paid' && (<Chip label='Paid' color="warning" />)}
|
{row.status == 'paid' && (<Label color='secondary' variant='ghost'>{capitalizeFirstLetter(row.status)}</Label>)}
|
||||||
{row.status == 'declined' && (<Chip label='Declined' color="error" />)}
|
{row.status == 'declined' && (<Label color='error' variant='ghost'>{capitalizeFirstLetter(row.status)}</Label>)}
|
||||||
</TableCell>
|
</TableCell>
|
||||||
|
|
||||||
<TableCell align="right">
|
<TableMoreMenu actions={
|
||||||
{['approved', 'paid'].includes(row.status) && (
|
<>
|
||||||
<Iconify icon="eva:eye-fill" onClick={(e) => {
|
<MenuItem onClick={() =>navigate(`/claims/edit/${row.id}`) }>
|
||||||
navigate('/claims/' + row.id);
|
<Edit />
|
||||||
}}></Iconify>
|
Edit
|
||||||
)}
|
</MenuItem>
|
||||||
{!['approved', 'paid'].includes(row.status) && (
|
<MenuItem onClick={() => setOpen(!open) }>
|
||||||
<Iconify icon="eva:edit-outline" onClick={(e) => {
|
<FindInPageOutlinedIcon />
|
||||||
navigate('/claims/' + row.id);
|
Detail
|
||||||
}}></Iconify>
|
</MenuItem>
|
||||||
)}
|
</>
|
||||||
</TableCell>
|
} />
|
||||||
|
|
||||||
|
|
||||||
</TableRow>
|
</TableRow>
|
||||||
{/* COLLAPSIBLE ROW */}
|
{/* COLLAPSIBLE ROW */}
|
||||||
<TableRow>
|
<TableRow>
|
||||||
@@ -230,41 +240,38 @@ export default function List() {
|
|||||||
return (
|
return (
|
||||||
<Table aria-label="collapsible table">
|
<Table aria-label="collapsible table">
|
||||||
{/* ------------------ TABLE HEADER ------------------ */}
|
{/* ------------------ TABLE HEADER ------------------ */}
|
||||||
<TableBody>
|
<TableHead>
|
||||||
<TableRow>
|
<TableRow>
|
||||||
{/* <TableCell style={headStyle} align="left" /> */}
|
{/* <TableCell style={headStyle} align="left" /> */}
|
||||||
<TableCell style={headStyle} align="left">
|
<TableCell style={headStyle} align="left">
|
||||||
Code Request
|
Code
|
||||||
</TableCell>
|
</TableCell>
|
||||||
<TableCell style={headStyle} align="left">
|
<TableCell style={headStyle} align="left">
|
||||||
Date
|
Plan ID
|
||||||
</TableCell>
|
|
||||||
{/* <TableCell style={headStyle} align="left">
|
|
||||||
Code Claim
|
|
||||||
</TableCell> */}
|
|
||||||
<TableCell style={headStyle} align="left">
|
|
||||||
Member Name
|
|
||||||
</TableCell>
|
</TableCell>
|
||||||
<TableCell style={headStyle} align="left">
|
<TableCell style={headStyle} align="left">
|
||||||
Plan
|
Payor ID
|
||||||
</TableCell>
|
</TableCell>
|
||||||
<TableCell style={headStyle} align="left">
|
<TableCell style={headStyle} align="left">
|
||||||
Benefit
|
Corporate ID
|
||||||
</TableCell>
|
</TableCell>
|
||||||
<TableCell style={headStyle} align="left">
|
<TableCell style={headStyle} align="left">
|
||||||
Diagnosis
|
Policy Number
|
||||||
</TableCell>
|
</TableCell>
|
||||||
<TableCell style={headStyle} align="left">
|
<TableCell style={headStyle} align="left">
|
||||||
Total Claim
|
Member ID
|
||||||
|
</TableCell>
|
||||||
|
<TableCell style={headStyle} align="left">
|
||||||
|
Benefit Desc
|
||||||
</TableCell>
|
</TableCell>
|
||||||
<TableCell style={headStyle} align="left">
|
<TableCell style={headStyle} align="left">
|
||||||
Status
|
Status
|
||||||
</TableCell>
|
</TableCell>
|
||||||
<TableCell style={headStyle} align="right">
|
<TableCell style={headStyle} align="left">
|
||||||
Action
|
|
||||||
</TableCell>
|
</TableCell>
|
||||||
</TableRow>
|
</TableRow>
|
||||||
</TableBody>
|
</TableHead>
|
||||||
{/* ------------------ END TABLE HEADER ------------------ */}
|
{/* ------------------ END TABLE HEADER ------------------ */}
|
||||||
|
|
||||||
{/* ------------------ TABLE ROW ------------------ */}
|
{/* ------------------ TABLE ROW ------------------ */}
|
||||||
|
|||||||
@@ -70,6 +70,7 @@ export default function CorporateTabNavigations({ position }: Props) {
|
|||||||
// },
|
// },
|
||||||
];
|
];
|
||||||
useEffect(() => {
|
useEffect(() => {
|
||||||
|
console.log(position);
|
||||||
let currentIndex = mainTabItems.findIndex((item) => item.path === position);
|
let currentIndex = mainTabItems.findIndex((item) => item.path === position);
|
||||||
setCurrentTab(currentIndex);
|
setCurrentTab(currentIndex);
|
||||||
}, []);
|
}, []);
|
||||||
|
|||||||
@@ -44,7 +44,7 @@ export default function CorporateFormularium() {
|
|||||||
/>
|
/>
|
||||||
|
|
||||||
<Card>
|
<Card>
|
||||||
<CorporateTabNavigations position={'formularium'} />
|
<CorporateTabNavigations position={'formulariums'} />
|
||||||
<List />
|
<List />
|
||||||
</Card>
|
</Card>
|
||||||
</Page>
|
</Page>
|
||||||
|
|||||||
@@ -82,7 +82,6 @@ export default function CategoryDetail({props, formularium} : ParamsDetail) {
|
|||||||
} else {
|
} else {
|
||||||
active = "1"
|
active = "1"
|
||||||
}
|
}
|
||||||
console.log(corporate_id, id , active)
|
|
||||||
axios
|
axios
|
||||||
.put(`/corporates/${corporate_id}/formulariums-update-status/${id}`, {
|
.put(`/corporates/${corporate_id}/formulariums-update-status/${id}`, {
|
||||||
active: active,
|
active: active,
|
||||||
|
|||||||
@@ -60,7 +60,7 @@ export default function CorporateFormulariumCreateForm() {
|
|||||||
const [dataDropdownData, setDataDropdownData] = React.useState<DetailCorpFormularium[] | null>(null)
|
const [dataDropdownData, setDataDropdownData] = React.useState<DetailCorpFormularium[] | null>(null)
|
||||||
const loadDataDropdown = async () => {
|
const loadDataDropdown = async () => {
|
||||||
setDataDropdownLoading(true);
|
setDataDropdownLoading(true);
|
||||||
const resp = await axios.get(`corporates/${corporate_id}/formulariums/create`);
|
const resp = await axios.get(`corporates/${corporate_id}/formulariums-create`);
|
||||||
console.log(resp.data);
|
console.log(resp.data);
|
||||||
setDataDropdownLoading(false);
|
setDataDropdownLoading(false);
|
||||||
|
|
||||||
|
|||||||
Binary file not shown.
Reference in New Issue
Block a user