Merge remote-tracking branch 'origin/feature/primaya' into staging
This commit is contained in:
0
.editorconfig
Executable file → Normal file
0
.editorconfig
Executable file → Normal file
0
.env-example
Executable file → Normal file
0
.env-example
Executable file → Normal file
0
.gitattributes
vendored
Executable file → Normal file
0
.gitattributes
vendored
Executable file → Normal file
1
.gitignore
vendored
Executable file → Normal file
1
.gitignore
vendored
Executable file → Normal file
@@ -16,6 +16,7 @@ yarn-error.log
|
||||
/public/dashboard
|
||||
/public/dashboard-staging
|
||||
/public/dashboard-copy
|
||||
/public/dashboard-copy2
|
||||
|
||||
/public/client-portal
|
||||
/public/client-portal-staging
|
||||
|
||||
0
.styleci.yml
Executable file → Normal file
0
.styleci.yml
Executable file → Normal file
286
Modules/Client/Http/Controllers/Api/BillingSummaryController.php
Normal file
286
Modules/Client/Http/Controllers/Api/BillingSummaryController.php
Normal file
@@ -0,0 +1,286 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Client\Http\Controllers\Api;
|
||||
|
||||
use Illuminate\Contracts\Support\Renderable;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Routing\Controller;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
class BillingSummaryController extends Controller
|
||||
{
|
||||
public function index(Request $request, $corporate_id)
|
||||
{
|
||||
$year = $request->year ?? now()->year;
|
||||
$status = $request->status;
|
||||
$bn = $request->bn;
|
||||
$payorId = $request->payorId;
|
||||
$service = $request->service;
|
||||
$billing = $request->billing;
|
||||
$search = $request->search;
|
||||
|
||||
$rows = DB::table('invoice_payments')
|
||||
->join('invoice_payment_details', 'invoice_payment_details.invoice_payment_id', '=', 'invoice_payments.id')
|
||||
->join('claim_requests', 'claim_requests.id', '=', 'invoice_payment_details.claim_request_id')
|
||||
->join('request_logs', 'request_logs.id', '=', 'claim_requests.request_log_id')
|
||||
->join('corporate_employees', 'corporate_employees.member_id', '=', 'request_logs.member_id')
|
||||
->join('organizations', 'organizations.id', '=', 'request_logs.organization_id')
|
||||
->leftJoin('members', 'members.id', '=', 'request_logs.member_id')
|
||||
->whereYear('invoice_payments.created_at', $year)
|
||||
->where('corporate_employees.corporate_id', '=', $corporate_id)
|
||||
// FILTERS
|
||||
->when($status, fn ($q) =>
|
||||
$q->where('invoice_payments.status', $status)
|
||||
)
|
||||
->when($bn, fn ($q) =>
|
||||
$q->where('members.member_id', $bn)
|
||||
)
|
||||
->when($payorId, fn ($q) =>
|
||||
$q->where('members.payor_id', $payorId)
|
||||
)
|
||||
->when($service, fn ($q) =>
|
||||
$q->where('claim_requests.service_code', $service)
|
||||
)
|
||||
->when($billing, fn ($q) =>
|
||||
$q->where('invoice_payments.invoice_number', $billing)
|
||||
)
|
||||
|
||||
// 🔍 SEARCH PROVIDER (LIKE)
|
||||
->when($search, fn ($q) =>
|
||||
$q->where('organizations.name', 'like', '%' . $search . '%')
|
||||
)
|
||||
|
||||
->selectRaw("
|
||||
MONTH(invoice_payments.created_at) as month_number,
|
||||
organizations.name as provider,
|
||||
SUM(request_logs.nominal) as total
|
||||
")
|
||||
->groupBy('month_number', 'organizations.name')
|
||||
->orderBy('month_number')
|
||||
->get();
|
||||
|
||||
return response()->json(
|
||||
$this->formatMonthly($rows)
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
protected function formatMonthly($rows): array
|
||||
{
|
||||
$months = [
|
||||
1 => 'Januari', 2 => 'Februari', 3 => 'Maret',
|
||||
4 => 'April', 5 => 'Mei', 6 => 'Juni',
|
||||
7 => 'Juli', 8 => 'Agustus', 9 => 'September',
|
||||
10 => 'Oktober', 11 => 'November', 12 => 'Desember',
|
||||
];
|
||||
|
||||
return collect($rows)
|
||||
->groupBy('month_number')
|
||||
->map(function ($items, $monthNumber) use ($months) {
|
||||
return [
|
||||
'month' => $months[$monthNumber],
|
||||
'total' => $items->sum('total'),
|
||||
'items' => $items->map(fn ($item) => [
|
||||
'provider' => $item->provider,
|
||||
'total' => (float) $item->total,
|
||||
])->values(),
|
||||
];
|
||||
})
|
||||
->values()
|
||||
->toArray();
|
||||
}
|
||||
|
||||
public function providerSummary(Request $request, $corporate_id)
|
||||
{
|
||||
$year = $request->year ?? now()->year;
|
||||
$status = $request->status;
|
||||
$bn = $request->bn;
|
||||
$payorId = $request->payorId;
|
||||
$service = $request->service;
|
||||
$billing = $request->billing;
|
||||
$search = $request->search;
|
||||
|
||||
$query = DB::table('invoice_payments')
|
||||
->join('invoice_payment_details', 'invoice_payment_details.invoice_payment_id', '=', 'invoice_payments.id')
|
||||
->join('claim_requests', 'claim_requests.id', '=', 'invoice_payment_details.claim_request_id')
|
||||
->join('request_logs', 'request_logs.id', '=', 'claim_requests.request_log_id')
|
||||
->join('corporate_employees', 'corporate_employees.member_id', '=', 'request_logs.member_id')
|
||||
->join('organizations', 'organizations.id', '=', 'request_logs.organization_id')
|
||||
->leftJoin('members', 'members.id', '=', 'request_logs.member_id')
|
||||
->whereYear('invoice_payments.created_at', $year)
|
||||
->where('corporate_employees.corporate_id', '=', $corporate_id)
|
||||
// FILTER
|
||||
->when($status, fn ($q) =>
|
||||
$q->where('invoice_payments.status', $status)
|
||||
)
|
||||
->when($bn, fn ($q) =>
|
||||
$q->where('members.member_id', $bn)
|
||||
)
|
||||
->when($payorId, fn ($q) =>
|
||||
$q->where('members.payor_id', $payorId)
|
||||
)
|
||||
->when($service, fn ($q) =>
|
||||
$q->where('claim_requests.service_code', $service)
|
||||
)
|
||||
->when($billing, fn ($q) =>
|
||||
$q->where('invoice_payments.invoice_number', $billing)
|
||||
)
|
||||
->when($search, fn ($q) =>
|
||||
$q->where('organizations.name', 'like', '%' . $search . '%')
|
||||
);
|
||||
|
||||
$items = $query
|
||||
->selectRaw("
|
||||
organizations.name as provider,
|
||||
SUM(request_logs.nominal) as total
|
||||
")
|
||||
->groupBy('organizations.name')
|
||||
->orderByDesc('total')
|
||||
->get()
|
||||
->map(fn ($row) => [
|
||||
'provider' => $row->provider,
|
||||
'total' => (float) $row->total,
|
||||
]);
|
||||
|
||||
return response()->json([
|
||||
'total' => $items->sum('total'),
|
||||
'items' => $items,
|
||||
]);
|
||||
}
|
||||
|
||||
public function topDiagnosis(Request $request, $corporate_id)
|
||||
{
|
||||
$year = $request->year ?? now()->year;
|
||||
$status = $request->status;
|
||||
$bn = $request->bn;
|
||||
$payorId = $request->payorId;
|
||||
$service = $request->service;
|
||||
$billing = $request->billing;
|
||||
$search = $request->search;
|
||||
|
||||
$rows = DB::table('invoice_payments')
|
||||
->join('invoice_payment_details', 'invoice_payment_details.invoice_payment_id', '=', 'invoice_payments.id')
|
||||
->join('claim_requests', 'claim_requests.id', '=', 'invoice_payment_details.claim_request_id')
|
||||
->join('request_logs', 'request_logs.id', '=', 'claim_requests.request_log_id')
|
||||
->join('corporate_employees', 'corporate_employees.member_id', '=', 'request_logs.member_id')
|
||||
// 🔥 ICD JOIN
|
||||
->leftJoin(
|
||||
'icd',
|
||||
DB::raw("icd.code"),
|
||||
'=',
|
||||
DB::raw("SUBSTRING_INDEX(request_logs.diagnosis, ',', 1)")
|
||||
)
|
||||
|
||||
->leftJoin('members', 'members.id', '=', 'request_logs.member_id')
|
||||
->where('corporate_employees.corporate_id', '=', $corporate_id)
|
||||
->whereYear('invoice_payments.created_at', $year)
|
||||
|
||||
// FILTER
|
||||
->when($status, fn ($q) =>
|
||||
$q->where('invoice_payments.status', $status)
|
||||
)
|
||||
->when($bn, fn ($q) =>
|
||||
$q->where('members.member_id', $bn)
|
||||
)
|
||||
->when($payorId, fn ($q) =>
|
||||
$q->where('members.payor_id', $payorId)
|
||||
)
|
||||
->when($service, fn ($q) =>
|
||||
$q->where('claim_requests.service_code', $service)
|
||||
)
|
||||
->when($billing, fn ($q) =>
|
||||
$q->where('invoice_payments.invoice_number', $billing)
|
||||
)
|
||||
|
||||
->selectRaw("
|
||||
SUBSTRING_INDEX(request_logs.diagnosis, ',', 1) as code_diagnosis,
|
||||
icd.name as diagnosis,
|
||||
COUNT(request_logs.id) as total_case,
|
||||
SUM(request_logs.nominal) as total_billing
|
||||
")
|
||||
->groupBy('code_diagnosis', 'icd.name')
|
||||
->orderByDesc('total_case')
|
||||
->limit(10)
|
||||
->get();
|
||||
|
||||
return response()->json(
|
||||
$rows->map(fn ($row) => [
|
||||
'code' => $row->code_diagnosis,
|
||||
'diagnosis' => $row->diagnosis ?? '-',
|
||||
'total_case' => (int) $row->total_case,
|
||||
'total_billing' => (float) $row->total_billing,
|
||||
])
|
||||
);
|
||||
}
|
||||
|
||||
|
||||
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
* @return Renderable
|
||||
*/
|
||||
// public function index()
|
||||
// {
|
||||
// return view('client::index');
|
||||
// }
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
* @return Renderable
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
return view('client::create');
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
* @param Request $request
|
||||
* @return Renderable
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the specified resource.
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
return view('client::show');
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for editing the specified resource.
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
return view('client::edit');
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
* @param Request $request
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
}
|
||||
@@ -451,7 +451,7 @@ class ClaimController extends Controller
|
||||
if($dataMember->principal_id)
|
||||
{
|
||||
$dataNamaKaryawan = DB::table('members')
|
||||
->where('members.member_id', '=', $dataMember->principal_id)
|
||||
->where('members.principal_id', '=', $dataMember->principal_id)
|
||||
->select('members.name')
|
||||
->first();
|
||||
$data['namaKaryawan'] = $dataNamaKaryawan->name;
|
||||
@@ -492,7 +492,7 @@ class ClaimController extends Controller
|
||||
{
|
||||
$no += $item->no;
|
||||
}
|
||||
|
||||
|
||||
$total_billing = 0;
|
||||
$lastIndex = count($dataClaimLog) - 1;
|
||||
$firtIndex = 0;
|
||||
|
||||
@@ -1,6 +1,7 @@
|
||||
<?php
|
||||
|
||||
use Modules\Client\Http\Controllers\Api\AuthController;
|
||||
use Modules\Client\Http\Controllers\Api\BillingSummaryController;
|
||||
use Modules\Client\Http\Controllers\Api\CorporateDivisionController;
|
||||
use Modules\Client\Http\Controllers\Api\CorporateManageController;
|
||||
use Modules\Client\Http\Controllers\Api\CorporateMemberController;
|
||||
@@ -78,6 +79,9 @@ Route::prefix('client')->group(function () {
|
||||
Route::get('corporate', [CorporateCurrentController::class, 'index']);
|
||||
Route::put('corporate-update', [CorporateCurrentController::class, 'update']);
|
||||
Route::get('get-deposits', [CorporateMemberController::class, 'getDeposit']);
|
||||
Route::get('billing/summary', [BillingSummaryController::class, 'index']);
|
||||
Route::get('/billing/provider-summary', [BillingSummaryController::class, 'providerSummary']);
|
||||
Route::get('/billing/top-diagnosis', [BillingSummaryController::class, 'topDiagnosis']);
|
||||
|
||||
Route::get('get-limits/{member_id}', [CorporateMemberController::class, 'getLimits']);
|
||||
|
||||
|
||||
@@ -100,7 +100,10 @@ class MemberController extends Controller
|
||||
// Provider
|
||||
$providers = DB::table('organizations')
|
||||
->where('organizations.type', '=', 'hospital')
|
||||
->where('organizations.corporate_id_partner', '!=', 8)
|
||||
->orWhere('organizations.corporate_id_partner', NULL)
|
||||
->where('status', '=', 'active')
|
||||
->orderBy('organizations.name','asc')
|
||||
->select(
|
||||
'organizations.id',
|
||||
'organizations.name'
|
||||
|
||||
@@ -42,11 +42,15 @@ class RequestLogController extends Controller
|
||||
$validator = Validator::make($request->all(), [
|
||||
'member_id' => 'required',
|
||||
'service_code' => 'required',
|
||||
'submission_date' => 'required'
|
||||
'submission_date' => 'required',
|
||||
'specialities_id' => 'required',
|
||||
'dppj' => 'required',
|
||||
], [
|
||||
'member_id.required' => trans('Validation.required',['attribute' => 'Member ID']),
|
||||
'service_code.required' => trans('Validation.required',['attribute' => 'Service Code']),
|
||||
'submission_date.required' => trans('Validation.required',['attribute' => 'Submission Date']),
|
||||
'specialities_id.required' => trans('Validation.required',['attribute' => 'Specialities']),
|
||||
'dppj.required' => trans('Validation.required',['attribute' => 'DPJP']),
|
||||
]);
|
||||
if(!empty($request->organization_id))
|
||||
{
|
||||
@@ -54,12 +58,16 @@ class RequestLogController extends Controller
|
||||
'organization_id' => 'required',
|
||||
'member_id' => 'required',
|
||||
'service_code' => 'required',
|
||||
'submission_date' => 'required'
|
||||
'submission_date' => 'required',
|
||||
'specialities_id' => 'required',
|
||||
'dppj' => 'required',
|
||||
], [
|
||||
'organization_id.required' => trans('Validation.required',['attribute' => 'Provider ID']),
|
||||
'member_id.required' => trans('Validation.required',['attribute' => 'Member ID']),
|
||||
'service_code.required' => trans('Validation.required',['attribute' => 'Service Code']),
|
||||
'submission_date.required' => trans('Validation.required',['attribute' => 'Submission Date']),
|
||||
'specialities_id.required' => trans('Validation.required',['attribute' => 'Specialities']),
|
||||
'dppj.required' => trans('Validation.required',['attribute' => 'DPJP']),
|
||||
]);
|
||||
}
|
||||
if ($validator->fails())
|
||||
@@ -245,7 +253,7 @@ class RequestLogController extends Controller
|
||||
'request_logs.approved_at')
|
||||
->paginate($limit);
|
||||
|
||||
|
||||
|
||||
return response()->json(Helper::paginateResources($results));
|
||||
}
|
||||
|
||||
|
||||
@@ -7,6 +7,10 @@ use Modules\HospitalPortal\Http\Controllers\Api\MemberController;
|
||||
use Modules\HospitalPortal\Http\Controllers\ClaimController;
|
||||
use Modules\HospitalPortal\Http\Controllers\Api\NotificationController;
|
||||
use Modules\HospitalPortal\Http\Controllers\Api\RequestLogController;
|
||||
use Modules\Internal\Http\Controllers\Api\RequestLogController as RequestLogControllerInternal;
|
||||
use Modules\Internal\Http\Controllers\Api\RequestLogBenefitController;
|
||||
use Modules\Internal\Http\Controllers\Api\RequestLogMedicineController;
|
||||
|
||||
use Modules\HospitalPortal\Http\Controllers\ApotekController;
|
||||
use Modules\HospitalPortal\Http\Middleware\Authentication;
|
||||
use Modules\HospitalPortal\Http\Middleware\Authorization;
|
||||
@@ -35,12 +39,42 @@ Route::prefix('v1')->group(function() {
|
||||
Route::post('forget-password', [AuthController::class, 'forgetPassword']);
|
||||
Route::post('verify-email', [AuthController::class, 'verifyEmail'])->name('verify-email');
|
||||
Route::post('verify-code', [AuthController::class, 'verifCode']);
|
||||
|
||||
|
||||
Route::get('service-member/{id}', [AutocompleteController::class, 'serviceCode']);
|
||||
Route::get('specialis', [AutocompleteController::class, 'specialisList']);
|
||||
Route::get('diagnosis', [RequestLogControllerInternal::class, 'diagnosis']);
|
||||
|
||||
Route::middleware('auth:sanctum')->group(function () {
|
||||
|
||||
//dari Internal Prime center
|
||||
Route::get('customer-service/request', [RequestLogControllerInternal::class, 'index']);
|
||||
Route::post('customer-service/request', [RequestLogControllerInternal::class, 'createNew']);
|
||||
Route::put('customer-service/request/{id}', [RequestLogControllerInternal::class, 'update']);
|
||||
Route::get('customer-service/request/{id}', [RequestLogControllerInternal::class, 'show']);
|
||||
Route::put('customer-service/request/delete/{id}', [RequestLogControllerInternal::class, 'destroy']);
|
||||
Route::put('customer-service/request/final_log/{id}', [RequestLogControllerInternal::class, 'deleteFinalLog']);
|
||||
Route::get('customer-service/request/{id}/download', [RequestLogControllerInternal::class, 'generateRequestLog']);
|
||||
Route::post('customer-service/request/import', [RequestLogControllerInternal::class, 'importRequestLog']);
|
||||
Route::post('customer-service/request/import-invoice', [RequestLogControllerInternal::class, 'importInvoice']);
|
||||
Route::post('customer-service/request/exportFiledInvoice', [RequestLogControllerInternal::class, 'exportFiledInvoice']);
|
||||
Route::get('customer-service/request/data', [RequestLogControllerInternal::class, 'generateDataRequestLogExcel']);
|
||||
Route::post('customer-service/request/{id}/add_file', [RequestLogControllerInternal::class, 'requestFiles']);
|
||||
Route::post('customer-service/request/{id}/approval_files', [RequestLogControllerInternal::class, 'approvalFiles']);
|
||||
Route::post('customer-service/request/{id}/delete_file', [RequestLogControllerInternal::class, 'deleteFiles']);
|
||||
|
||||
Route::post('customer-service/request/final-log', [RequestLogControllerInternal::class, 'updateFinalLog']);
|
||||
|
||||
// insert benefit
|
||||
Route::post('customer-service/request/insert-benefit', [RequestLogBenefitController::class, 'store']);
|
||||
Route::post('customer-service/request/benefit_data/{id}', [RequestLogBenefitController::class, 'destroy']);
|
||||
Route::put('customer-service/request/benefit_data/{id}', [RequestLogBenefitController::class, 'update']);
|
||||
|
||||
// insert medicine
|
||||
Route::post('customer-service/request/medicine-data', [RequestLogMedicineController::class, 'store']);
|
||||
Route::delete('customer-service/request/medicine-data/{id}', [RequestLogMedicineController::class, 'destroy']);
|
||||
Route::put('customer-service/request/medicine-data/{id}', [RequestLogMedicineController::class, 'update']);
|
||||
// end prime center
|
||||
|
||||
// Navigation
|
||||
Route::get('navigations', [NavigationController::class, 'index']);
|
||||
|
||||
@@ -96,6 +130,6 @@ Route::prefix('v1')->group(function() {
|
||||
Route::post('claim-requests/{id}/request-files', [ClaimRequestController::class, 'requestFiles']);
|
||||
});
|
||||
|
||||
|
||||
|
||||
});
|
||||
});
|
||||
});
|
||||
@@ -116,7 +116,7 @@ class ClaimController extends Controller
|
||||
'),
|
||||
DB::raw('
|
||||
(Select SUM(request_log_benefits.amount_approved) as tot_bill FROM request_log_benefits
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id LIMIT 1) AS tot_bill
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id and deleted_by is null) AS tot_bill
|
||||
'),
|
||||
'claim_requests.status_claim_management as status',
|
||||
)
|
||||
@@ -179,7 +179,7 @@ class ClaimController extends Controller
|
||||
'),
|
||||
DB::raw('
|
||||
(Select SUM(request_log_benefits.amount_approved) as tot_bill FROM request_log_benefits
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id LIMIT 1) AS tot_bill
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id and deleted_by is null) AS tot_bill
|
||||
'),
|
||||
'claim_requests.status_claim_management as status',
|
||||
)
|
||||
@@ -537,7 +537,7 @@ class ClaimController extends Controller
|
||||
'),
|
||||
DB::raw('
|
||||
(Select SUM(request_log_benefits.amount_approved) as tot_bill FROM request_log_benefits
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id LIMIT 1) AS tot_bill
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id and deleted_by is null) AS tot_bill
|
||||
'),
|
||||
'claim_requests.status_claim_management as status',
|
||||
)
|
||||
|
||||
@@ -73,8 +73,8 @@ class ClaimRequestController extends Controller
|
||||
->when($request->status, function($q, $status) {
|
||||
$q->where('status', $status);
|
||||
})
|
||||
->paginate();
|
||||
|
||||
->paginate();
|
||||
|
||||
return Helper::paginateResources(ClaimRequestResource::collection($claimRequests));
|
||||
}
|
||||
|
||||
@@ -775,6 +775,7 @@ class ClaimRequestController extends Controller
|
||||
'tot_billing' => function ($query) {
|
||||
$query->select(DB::raw('SUM(request_log_benefits.amount_approved)'))
|
||||
->from('request_log_benefits')
|
||||
->whereNull('request_log_benefits.deleted_at')
|
||||
->whereColumn('request_log_benefits.request_log_id', 'claim_requests.request_log_id')
|
||||
->limit(1);
|
||||
}
|
||||
|
||||
@@ -167,15 +167,13 @@ class DashboardController extends Controller
|
||||
public function listDokter(Request $request)
|
||||
{
|
||||
$idDokter = [
|
||||
'68268',
|
||||
'75047',
|
||||
'75046',
|
||||
'75045',
|
||||
'75044',
|
||||
'75043',
|
||||
'75027',
|
||||
'75021',
|
||||
'75020',
|
||||
'120866',
|
||||
'107922',
|
||||
'107921',
|
||||
'107920',
|
||||
'101192',
|
||||
'99232',
|
||||
'99230',
|
||||
]; // List dokter
|
||||
|
||||
$listDokters = Dokter::with([])->whereIn('nIDUser', $idDokter)->get();
|
||||
@@ -184,8 +182,8 @@ class DashboardController extends Controller
|
||||
return [
|
||||
'id' => $dokter->nIDUser,
|
||||
'code' => $dokter->nIDUser,
|
||||
'name' => $dokter->user->fullName,
|
||||
'online' => $dokter->sStatus,
|
||||
'name' => $dokter->user ? $dokter->user->fullName : '-',
|
||||
'online' => $dokter->sIsOnline,
|
||||
];
|
||||
});
|
||||
|
||||
|
||||
@@ -12,6 +12,8 @@ use App\Helpers\Helper;
|
||||
use Box\Spout\Writer\Common\Creator\WriterEntityFactory;
|
||||
use Box\Spout\Writer\Common\Creator\Style\StyleBuilder;
|
||||
use Box\Spout\Common\Entity\Style\CellAlignment;
|
||||
use Illuminate\Support\Facades\Storage;
|
||||
use App\Services\ExportExcelService;
|
||||
|
||||
class InvoicePaymentController extends Controller
|
||||
{
|
||||
@@ -30,15 +32,11 @@ class InvoicePaymentController extends Controller
|
||||
|
||||
$query->orderBy($orderBy, $direction);
|
||||
})
|
||||
->when($request->input('start_date') , function ($query, $start_date) {
|
||||
$query->where(function ($query) use ($start_date) {
|
||||
$query->where('invoice_payments.created_at', '>=', $start_date);
|
||||
});
|
||||
->when($request->input('start_date'), function ($query, $start_date) {
|
||||
$query->whereDate('invoice_payments.created_at', '>=', $start_date);
|
||||
})
|
||||
->when($request->input('end_date') , function ($query, $end_date) {
|
||||
$query->where(function ($query) use ($end_date) {
|
||||
$query->where('invoice_payments.created_at', '<=', $end_date);
|
||||
});
|
||||
->when($request->input('end_date'), function ($query, $end_date) {
|
||||
$query->whereDate('invoice_payments.created_at', '<=', $end_date);
|
||||
})
|
||||
->when($request->input('status') , function ($query, $status) {
|
||||
$query->where(function ($query) use ($status) {
|
||||
@@ -63,114 +61,133 @@ class InvoicePaymentController extends Controller
|
||||
}
|
||||
public function claim(Request $request)
|
||||
{
|
||||
$limit = $request->has('per_page') ? $request->input('per_page') : 10;
|
||||
$limit = $request->input('per_page', 10);
|
||||
|
||||
$results = DB::table('claim_requests')
|
||||
->leftJoin('request_logs', 'claim_requests.request_log_id','=', 'request_logs.id')
|
||||
->leftJoin('members', 'request_logs.member_id', '=', 'members.id')
|
||||
->leftJoin('invoice_payment_details', function ($join) {
|
||||
$join->on('invoice_payment_details.claim_request_id', '=', 'claim_requests.id')
|
||||
->whereNull('invoice_payment_details.deleted_by')
|
||||
->orWhere('invoice_payment_details.deleted_by', 0);
|
||||
})
|
||||
// ->leftJoin('member_plans', 'member_plans.member_id', '=', 'members.id')
|
||||
->when($request->input('search'), function ($query, $search) {
|
||||
$query->where(function ($query) use ($search) {
|
||||
$query->orWhere('members.name', 'like', "%" . $search . "%");
|
||||
$query->orWhere('claim_requests.code', 'like', "%" . $search . "%");
|
||||
$query->orWhere('request_logs.code', 'like', "%" . $search . "%");
|
||||
$query->orWhere('members.member_id', 'like', "%" . $search . "%");
|
||||
});
|
||||
})
|
||||
->when($request->has('orderBy'), function ($query) use ($request) {
|
||||
$orderBy = $request->orderBy;
|
||||
$direction = $request->order ?? 'asc';
|
||||
->leftJoin('request_logs', 'claim_requests.request_log_id', '=', 'request_logs.id')
|
||||
->leftJoin('members', 'request_logs.member_id', '=', 'members.id')
|
||||
|
||||
$query->orderBy($orderBy, $direction);
|
||||
})
|
||||
->when($request->input('start_date') , function ($query, $start_date) {
|
||||
$query->where(function ($query) use ($start_date) {
|
||||
$query->where('claim_requests.created_at', '>=', $start_date);
|
||||
});
|
||||
})
|
||||
->when($request->input('end_date') , function ($query, $end_date) {
|
||||
$query->where(function ($query) use ($end_date) {
|
||||
$query->where('claim_requests.created_at', '<=', $end_date);
|
||||
});
|
||||
})
|
||||
->when($request->input('provider') , function ($query, $provider) {
|
||||
$query->where(function ($query) use ($provider) {
|
||||
$query->where('request_logs.organization_id', '=', $provider);
|
||||
});
|
||||
})
|
||||
->where('claim_management', '=', 1)
|
||||
->when($request->input('param') !== 'Edit', function ($query) {
|
||||
$query->whereNotIn('claim_requests.id', function ($query) {
|
||||
$query->select('claim_request_id')
|
||||
->from('invoice_payment_details');
|
||||
});
|
||||
})
|
||||
->when($request->input('param') === 'Edit', function ($query) use ($request) {
|
||||
$query->where(function ($q) use ($request) {
|
||||
$q->whereNotIn('claim_requests.id', function ($subquery) {
|
||||
$subquery->select('claim_request_id')
|
||||
->from('invoice_payment_details')
|
||||
->whereNull('invoice_payment_details.deleted_by')
|
||||
->orWhere('invoice_payment_details.deleted_by', 0);
|
||||
})
|
||||
->orWhereIn('claim_requests.id', function ($subquery) use ($request) {
|
||||
$subquery->select('claim_request_id')
|
||||
->from('invoice_payment_details')
|
||||
->where('invoice_payment_details.invoice_payment_id', $request->input('invoiceID'))
|
||||
->whereNull('invoice_payment_details.deleted_by')
|
||||
->orWhere('invoice_payment_details.deleted_by', 0);
|
||||
->leftJoin('invoice_payment_details', function ($join) {
|
||||
$join->on('invoice_payment_details.claim_request_id', '=', 'claim_requests.id')
|
||||
->where(function ($q) {
|
||||
$q->whereNull('invoice_payment_details.deleted_by')
|
||||
->orWhere('invoice_payment_details.deleted_by', 0);
|
||||
});
|
||||
})
|
||||
|
||||
->when($request->filled('search'), function ($query) use ($request) {
|
||||
$search = $request->search;
|
||||
$query->where(function ($q) use ($search) {
|
||||
$q->where('members.name', 'like', "%{$search}%")
|
||||
->orWhere('claim_requests.code', 'like', "%{$search}%")
|
||||
->orWhere('request_logs.code', 'like', "%{$search}%")
|
||||
->orWhere('members.member_id', 'like', "%{$search}%");
|
||||
});
|
||||
});
|
||||
})
|
||||
->select(
|
||||
'claim_requests.id',
|
||||
'request_logs.id AS id_log',
|
||||
'request_logs.code AS code_log',
|
||||
'claim_requests.code as code',
|
||||
'members.name',
|
||||
DB::raw('
|
||||
(SELECT members.member_id FROM members WHERE members.id = claim_requests.member_id LIMIT 1) AS member_id
|
||||
'),
|
||||
'claim_requests.created_at',
|
||||
// DB::raw('
|
||||
// (SELECT plans.code FROM plans WHERE plans.id = member_plans.plan_id LIMIT 1) AS plan_code
|
||||
// '),
|
||||
DB::raw('
|
||||
(SELECT plans.code
|
||||
FROM plans
|
||||
WHERE plans.id IN (
|
||||
SELECT member_plans.plan_id
|
||||
FROM member_plans
|
||||
WHERE member_plans.member_id = claim_requests.member_id
|
||||
)
|
||||
AND plans.service_code = claim_requests.service_code) AS plan_code
|
||||
'),
|
||||
DB::raw('
|
||||
(SELECT services.description FROM services WHERE services.code = claim_requests.service_code LIMIT 1) AS service_code
|
||||
'),
|
||||
DB::raw('
|
||||
(SELECT corporate_policies.code FROM corporate_policies WHERE corporate_policies.id = claim_requests.policy_id LIMIT 1) AS corporate_policies
|
||||
'),
|
||||
DB::raw('
|
||||
(SELECT organizations.name FROM organizations WHERE organizations.id = request_logs.organization_id LIMIT 1) AS provider
|
||||
'),
|
||||
DB::raw('
|
||||
(Select SUM(request_log_benefits.amount_approved) as tot_bill FROM request_log_benefits
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id LIMIT 1) AS tot_bill
|
||||
'),
|
||||
'claim_requests.status_claim_management as status',
|
||||
})
|
||||
|
||||
->when($request->filled('orderBy'), function ($query) use ($request) {
|
||||
$query->orderBy($request->orderBy, $request->order ?? 'asc');
|
||||
})
|
||||
|
||||
->when($request->filled('start_date'), fn ($q) =>
|
||||
$q->where('claim_requests.created_at', '>=', $request->start_date)
|
||||
)
|
||||
->groupBy('claim_requests.id')
|
||||
->paginate($limit);
|
||||
|
||||
->when($request->filled('end_date'), fn ($q) =>
|
||||
$q->where('claim_requests.created_at', '<=', $request->end_date)
|
||||
)
|
||||
|
||||
->when($request->filled('provider'), fn ($q) =>
|
||||
$q->where('request_logs.organization_id', $request->provider)
|
||||
)
|
||||
|
||||
->where('claim_management', 1)
|
||||
|
||||
->when($request->input('param') !== 'Edit', function ($query) {
|
||||
$query->whereNotIn('claim_requests.id', function ($q) {
|
||||
$q->select('claim_request_id')
|
||||
->from('invoice_payment_details')
|
||||
->where(function ($s) {
|
||||
$s->whereNull('deleted_by')
|
||||
->orWhere('deleted_by', 0);
|
||||
});
|
||||
});
|
||||
})
|
||||
|
||||
->when($request->input('param') === 'Edit', function ($query) use ($request) {
|
||||
$query->where(function ($q) use ($request) {
|
||||
|
||||
$q->whereNotIn('claim_requests.id', function ($sub) {
|
||||
$sub->select('claim_request_id')
|
||||
->from('invoice_payment_details')
|
||||
->where(function ($s) {
|
||||
$s->whereNull('deleted_by')
|
||||
->orWhere('deleted_by', 0);
|
||||
});
|
||||
})
|
||||
|
||||
->orWhereIn('claim_requests.id', function ($sub) use ($request) {
|
||||
$sub->select('claim_request_id')
|
||||
->from('invoice_payment_details')
|
||||
->where('invoice_payment_id', $request->invoiceID)
|
||||
->where(function ($s) {
|
||||
$s->whereNull('deleted_by')
|
||||
->orWhere('deleted_by', 0);
|
||||
});
|
||||
});
|
||||
});
|
||||
})
|
||||
|
||||
->select(
|
||||
'claim_requests.id',
|
||||
'request_logs.id AS id_log',
|
||||
'request_logs.code AS code_log',
|
||||
'claim_requests.code',
|
||||
'members.name',
|
||||
'members.member_id',
|
||||
'claim_requests.created_at',
|
||||
|
||||
DB::raw('(SELECT plans.code
|
||||
FROM plans
|
||||
JOIN member_plans ON member_plans.plan_id = plans.id
|
||||
WHERE member_plans.member_id = claim_requests.member_id
|
||||
AND plans.service_code = claim_requests.service_code
|
||||
LIMIT 1
|
||||
) AS plan_code'),
|
||||
|
||||
DB::raw('(SELECT services.description
|
||||
FROM services
|
||||
WHERE services.code = claim_requests.service_code
|
||||
LIMIT 1
|
||||
) AS service_code'),
|
||||
|
||||
DB::raw('(SELECT corporate_policies.code
|
||||
FROM corporate_policies
|
||||
WHERE corporate_policies.id = claim_requests.policy_id
|
||||
LIMIT 1
|
||||
) AS corporate_policies'),
|
||||
|
||||
DB::raw('(SELECT organizations.name
|
||||
FROM organizations
|
||||
WHERE organizations.id = request_logs.organization_id
|
||||
LIMIT 1
|
||||
) AS provider'),
|
||||
|
||||
DB::raw('(SELECT COALESCE(SUM(amount_approved),0)
|
||||
FROM request_log_benefits
|
||||
WHERE request_log_id = request_logs.id
|
||||
AND deleted_by IS NULL
|
||||
) AS tot_bill'),
|
||||
|
||||
'claim_requests.status_claim_management as status'
|
||||
)
|
||||
|
||||
->groupBy('claim_requests.id')
|
||||
->paginate($limit);
|
||||
|
||||
return response()->json(Helper::paginateResources($results));
|
||||
}
|
||||
|
||||
public function detail($id)
|
||||
{
|
||||
$invoice['invoice_payments'] = DB::table('invoice_payments')
|
||||
@@ -183,8 +200,10 @@ class InvoicePaymentController extends Controller
|
||||
->leftJoin('request_logs', 'claim_requests.request_log_id','=', 'request_logs.id')
|
||||
->leftJoin('members', 'request_logs.member_id', '=', 'members.id')
|
||||
->where('invoice_payment_details.invoice_payment_id', $id)
|
||||
->whereNull('invoice_payment_details.deleted_by')
|
||||
->orWhere('invoice_payment_details.deleted_by', 0)
|
||||
->where(function ($q) {
|
||||
$q->whereNull('invoice_payment_details.deleted_by')
|
||||
->orWhere('invoice_payment_details.deleted_by', 0);
|
||||
})
|
||||
->select(
|
||||
'claim_requests.id',
|
||||
'request_logs.invoice_no',
|
||||
@@ -222,7 +241,7 @@ class InvoicePaymentController extends Controller
|
||||
'),
|
||||
DB::raw('
|
||||
(Select SUM(request_log_benefits.amount_approved) as tot_bill FROM request_log_benefits
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id LIMIT 1) AS tot_bill
|
||||
WHERE request_log_benefits.request_log_id = request_logs.id and deleted_by is null) AS tot_bill
|
||||
'),
|
||||
'claim_requests.status_claim_management as status',
|
||||
)
|
||||
@@ -240,6 +259,7 @@ class InvoicePaymentController extends Controller
|
||||
'invoice_payments.id',
|
||||
'files.id as file_id',
|
||||
'invoice_payments.amount_paid',
|
||||
'invoice_payments.no_reference',
|
||||
'invoice_payments.payment_number',
|
||||
'files.path',
|
||||
'files.source',
|
||||
@@ -274,6 +294,7 @@ class InvoicePaymentController extends Controller
|
||||
return [
|
||||
'id' => $group->first()->id,
|
||||
'amount_paid' => $group->first()->amount_paid,
|
||||
'no_reference' => $group->first()->no_reference,
|
||||
'payment_number' => $group->first()->payment_number,
|
||||
'files' => $group->map(function ($file) {
|
||||
return [
|
||||
@@ -349,6 +370,7 @@ class InvoicePaymentController extends Controller
|
||||
'start_date' => $request->start_date,
|
||||
'end_date' => $request->start_date,
|
||||
'amount_paid' => $this->normalizeCurrency($valuePayments['amount']),
|
||||
'no_reference' => $valuePayments['noReference'],
|
||||
'status' => 'submitted',
|
||||
'created_by' => auth()->user()->id,
|
||||
'created_at' => date('Y-m-d H:i:s'),
|
||||
@@ -405,40 +427,56 @@ class InvoicePaymentController extends Controller
|
||||
'start_date' => $request->start_date,
|
||||
'end_date' => $request->end_date,
|
||||
'amount_paid' => $this->normalizeCurrency($valuePayments['amount']),
|
||||
'no_reference' => $valuePayments['noReference'],
|
||||
'updated_by' => auth()->user()->id,
|
||||
'updated_at' => date('Y-m-d H:i:s'),
|
||||
]);
|
||||
|
||||
$existingClaims = DB::table('invoice_payment_details')
|
||||
->where('invoice_payment_id', $invoicePaymentId)
|
||||
->whereNull('deleted_at') // hanya data aktif
|
||||
->pluck('claim_request_id')
|
||||
->map(fn($id) => (int)$id)
|
||||
->toArray();
|
||||
|
||||
$newClaims = $request->invoice_payment_details;
|
||||
// pastikan newClaims integer semua
|
||||
$newClaims = array_map('intval', $request->invoice_payment_details);
|
||||
|
||||
// Data yang mau di-insert
|
||||
|
||||
// =============================
|
||||
// INSERT DATA BARU
|
||||
// =============================
|
||||
$claimsToInsert = array_diff($newClaims, $existingClaims);
|
||||
foreach ($claimsToInsert as $claim) {
|
||||
DB::table('invoice_payment_details')->insert([
|
||||
'invoice_payment_id' => $invoicePaymentId,
|
||||
'claim_request_id' => $claim,
|
||||
'updated_by' => auth()->user()->id,
|
||||
'updated_at' => now(),
|
||||
]);
|
||||
|
||||
if (!empty($claimsToInsert)) {
|
||||
foreach ($claimsToInsert as $claim) {
|
||||
DB::table('invoice_payment_details')->insert([
|
||||
'invoice_payment_id' => $invoicePaymentId,
|
||||
'claim_request_id' => $claim,
|
||||
'created_by' => auth()->id(),
|
||||
'created_at' => now(),
|
||||
]);
|
||||
}
|
||||
}
|
||||
|
||||
// Data yang mau di-delete (tidak ada di data baru)
|
||||
|
||||
// =============================
|
||||
// SOFT DELETE DATA YANG DIHAPUS
|
||||
// =============================
|
||||
$claimsToDelete = array_diff($existingClaims, $newClaims);
|
||||
|
||||
if (!empty($claimsToDelete)) {
|
||||
DB::table('invoice_payment_details')
|
||||
->where('invoice_payment_id', $invoicePaymentId)
|
||||
->whereIn('claim_request_id', $claimsToDelete)
|
||||
->whereNull('deleted_at') // penting supaya tidak over-update
|
||||
->update([
|
||||
'deleted_by' => auth()->user()->id,
|
||||
'deleted_by' => auth()->id(),
|
||||
'deleted_at' => now(),
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
// Handle existing files
|
||||
$existingFiles = DB::table('files')
|
||||
->where('files.fileable_id', $invoicePaymentId)
|
||||
@@ -524,7 +562,22 @@ class InvoicePaymentController extends Controller
|
||||
return response()->json(['message' => 'Status berhasil diperbarui']);
|
||||
}
|
||||
|
||||
public function export(Request $request)
|
||||
public function export(Request $request, ExportExcelService $service)
|
||||
{
|
||||
\Log::info('EXPORT REQUEST', $request->all());
|
||||
$filters = [
|
||||
'search' => $request->input('search'),
|
||||
'start_date' => $request->input('start_date'),
|
||||
'end_date' => $request->input('end_date'),
|
||||
'orderBy' => $request->input('orderBy'),
|
||||
'order' => $request->input('order', 'asc'),
|
||||
];
|
||||
|
||||
return $service->exportReport($filters, 'Report-Vale-Payment.xlsx');
|
||||
|
||||
}
|
||||
|
||||
public function export3(Request $request)
|
||||
{
|
||||
$start_date = $request->input('start_date') ? $request->input('start_date') : 'all';
|
||||
$end_date = $request->input('end_date') ? $request->input('end_date') : 'all';
|
||||
|
||||
@@ -42,7 +42,8 @@ class PrescriptionController extends Controller
|
||||
$search = $request->search;
|
||||
$prescription->where(function ($query) use ($search) {
|
||||
$query->where('sDokterName', 'LIKE', '%' . $search . "%")
|
||||
->orWhere('sKodeResep', 'LIKE', '%' . $search . "%");
|
||||
->orWhere('sKodeResep', 'LIKE', '%' . $search . "%")
|
||||
->orWhere('tx_prescription_orders.sPenerima', 'LIKE', '%' . $search . "%");
|
||||
});
|
||||
}
|
||||
if (($request->has('prescription_start') || $request->has('prescription_end'))
|
||||
|
||||
@@ -67,6 +67,7 @@ class LivechatController extends Controller
|
||||
|
||||
public function export(Request $request)
|
||||
{
|
||||
ini_set('memory_limit', '1G');
|
||||
$startDate = $request->has('startDate') ? $request->input('startDate') : '';
|
||||
$endDate = $request->has('endDate') ? $request->input('endDate') : '';
|
||||
$type = $request->has('type') ? $request->input('type') : '';
|
||||
@@ -74,13 +75,21 @@ class LivechatController extends Controller
|
||||
return $this->exportMonthly($startDate, $endDate);
|
||||
} else {
|
||||
$liveChats = Livechat::with('userInsurance',
|
||||
'user:nID,sFirstName,sLastName,sEmail,sPhone,nIDUser,nIDHubunganKeluarga', 'user.detail:dTanggalLahir,nIDJenisKelamin',
|
||||
'doctor:nID,nIDSpesialis,nIDUser', 'doctor.user:nID,sFirstName,sLastName',
|
||||
'user:nID,sFirstName,sLastName,sEmail,sPhone,nIDUser,nIDHubunganKeluarga',
|
||||
'user.detail:dTanggalLahir,nIDJenisKelamin',
|
||||
'user.relation',
|
||||
'doctor:nID,nIDSpesialis,nIDUser',
|
||||
'doctor.user:nID,sFirstName,sLastName',
|
||||
'doctor.user.detail',
|
||||
'doctor.speciality',
|
||||
'appointment:nID,sPaymentStatus,sPaymentMethod',
|
||||
'appointment.appointmentDetail:nID,nIDAppointment,dTanggalAppointment,tTimeAppointment',
|
||||
'healthCare:nID,sHealthCare',
|
||||
'prescription',
|
||||
'rujukan'
|
||||
'prescription.items',
|
||||
'prescription.payment',
|
||||
'rujukan',
|
||||
'summary'
|
||||
)
|
||||
->whereHas('userInsurance', function (Builder $query) {
|
||||
// Kondisi pada relasi userInsurance
|
||||
@@ -103,39 +112,40 @@ class LivechatController extends Controller
|
||||
$headers = [
|
||||
['value' => 'No', 'cell' => 'A1', 'mergeCell' => true, 'mergeToCell' => 'A2'],
|
||||
['value' => 'Kode TC', 'cell' => 'B1', 'mergeCell' => true, 'mergeToCell' => 'B2'],
|
||||
['value' => 'Tanggal', 'cell' => 'C1', 'mergeCell' => true, 'mergeToCell' => 'C2'],
|
||||
['value' => 'Waktu', 'cell' => 'D1', 'mergeCell' => true, 'mergeToCell' => 'D2'],
|
||||
['value' => 'Faskes', 'cell' => 'E1', 'mergeCell' => true, 'mergeToCell' => 'E2'],
|
||||
['value' => 'Nama Dokter', 'cell' => 'F1', 'mergeCell' => true, 'mergeToCell' => 'F2'],
|
||||
['value' => 'Spesialis', 'cell' => 'G1', 'mergeCell' => true, 'mergeToCell' => 'G2'],
|
||||
['value' => 'Chat Via App/Website', 'cell' => 'H1', 'mergeCell' => true, 'mergeToCell' => 'I1'],
|
||||
['value' => 'Pasien', 'cell' => 'H2', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Dokter', 'cell' => 'I2', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'nIDUser', 'cell' => 'J1', 'mergeCell' => true, 'mergeToCell' => 'J2'],
|
||||
['value' => 'Nama Pasien', 'cell' => 'K1', 'mergeCell' => true, 'mergeToCell' => 'K2'],
|
||||
['value' => 'No Telepon Pasien', 'cell' => 'L1', 'mergeCell' => true, 'mergeToCell' => 'L2'],
|
||||
['value' => 'Email Pasien', 'cell' => 'M1', 'mergeCell' => true, 'mergeToCell' => 'M2'],
|
||||
['value' => 'No Kartu Insurance', 'cell' => 'N1', 'mergeCell' => true, 'mergeToCell' => 'N2'],
|
||||
['value' => 'Corporate ID', 'cell' => 'O1', 'mergeCell' => true, 'mergeToCell' => 'O2'],
|
||||
['value' => 'Corporate Name', 'cell' => 'P1', 'mergeCell' => true, 'mergeToCell' => 'P2'],
|
||||
['value' => 'Hubungan Pasien', 'cell' => 'Q1', 'mergeCell' => true, 'mergeToCell' => 'Q2'],
|
||||
['value' => 'Chanel', 'cell' => 'R1', 'mergeCell' => true, 'mergeToCell' => 'R2'],
|
||||
['value' => 'Status', 'cell' => 'S1', 'mergeCell' => true, 'mergeToCell' => 'S2'],
|
||||
['value' => 'Request Time', 'cell' => 'T1', 'mergeCell' => true, 'mergeToCell' => 'T2'],
|
||||
['value' => 'Accept Time', 'cell' => 'U1', 'mergeCell' => true, 'mergeToCell' => 'U2'],
|
||||
['value' => 'Start Time', 'cell' => 'V1', 'mergeCell' => true, 'mergeToCell' => 'V2'],
|
||||
['value' => 'End Time', 'cell' => 'W1', 'mergeCell' => true, 'mergeToCell' => 'W2'],
|
||||
['value' => 'Kode Diagnosa', 'cell' => 'X1', 'mergeCell' => true, 'mergeToCell' => 'X2'],
|
||||
['value' => 'Diagnosa', 'cell' => 'Y1', 'mergeCell' => true, 'mergeToCell' => 'Y2'],
|
||||
['value' => 'Kode Resep', 'cell' => 'Z1', 'mergeCell' => true, 'mergeToCell' => 'Z2'],
|
||||
['value' => 'Tanggal Resep', 'cell' => 'AA1', 'mergeCell' => true, 'mergeToCell' => 'AA2'],
|
||||
['value' => 'Obat', 'cell' => 'AB1', 'mergeCell' => true, 'mergeToCell' => 'AB2'],
|
||||
['value' => 'Tebus Resep', 'cell' => 'AC1', 'mergeCell' => true, 'mergeToCell' => 'AC2'],
|
||||
['value' => 'Tanggal Bayar', 'cell' => 'AD1', 'mergeCell' => true, 'mergeToCell' => 'AD2'],
|
||||
['value' => 'Provider Rujukan', 'cell' => 'AE1', 'mergeCell' => true, 'mergeToCell' => 'AE2'],
|
||||
['value' => 'Poli', 'cell' => 'AF1', 'mergeCell' => true, 'mergeToCell' => 'AF2'],
|
||||
['value' => 'Subjek', 'cell' => 'AG1', 'mergeCell' => true, 'mergeToCell' => 'AG2'],
|
||||
['value' => 'No SJP', 'cell' => 'AH1', 'mergeCell' => true, 'mergeToCell' => 'AH2'],
|
||||
['value' => 'Kode Livechat', 'cell' => 'C1', 'mergeCell' => true, 'mergeToCell' => 'C2'],
|
||||
['value' => 'Tanggal', 'cell' => 'D1', 'mergeCell' => true, 'mergeToCell' => 'D2'],
|
||||
['value' => 'Waktu', 'cell' => 'E1', 'mergeCell' => true, 'mergeToCell' => 'E2'],
|
||||
['value' => 'Faskes', 'cell' => 'F1', 'mergeCell' => true, 'mergeToCell' => 'F2'],
|
||||
['value' => 'Nama Dokter', 'cell' => 'G1', 'mergeCell' => true, 'mergeToCell' => 'G2'],
|
||||
['value' => 'Spesialis', 'cell' => 'H1', 'mergeCell' => true, 'mergeToCell' => 'H2'],
|
||||
['value' => 'Chat Via App/Website', 'cell' => 'I1', 'mergeCell' => true, 'mergeToCell' => 'J1'],
|
||||
['value' => 'Pasien', 'cell' => 'I2', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Dokter', 'cell' => 'J2', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'nIDUser', 'cell' => 'K1', 'mergeCell' => true, 'mergeToCell' => 'K2'],
|
||||
['value' => 'Nama Pasien', 'cell' => 'L1', 'mergeCell' => true, 'mergeToCell' => 'L2'],
|
||||
['value' => 'No Telepon Pasien', 'cell' => 'M1', 'mergeCell' => true, 'mergeToCell' => 'M2'],
|
||||
['value' => 'Email Pasien', 'cell' => 'N1', 'mergeCell' => true, 'mergeToCell' => 'N2'],
|
||||
['value' => 'No Kartu Insurance', 'cell' => 'O1', 'mergeCell' => true, 'mergeToCell' => 'O2'],
|
||||
['value' => 'Corporate ID', 'cell' => 'P1', 'mergeCell' => true, 'mergeToCell' => 'P2'],
|
||||
['value' => 'Corporate Name', 'cell' => 'Q1', 'mergeCell' => true, 'mergeToCell' => 'Q2'],
|
||||
['value' => 'Hubungan Pasien', 'cell' => 'R1', 'mergeCell' => true, 'mergeToCell' => 'R2'],
|
||||
['value' => 'Chanel', 'cell' => 'S1', 'mergeCell' => true, 'mergeToCell' => 'S2'],
|
||||
['value' => 'Status', 'cell' => 'T1', 'mergeCell' => true, 'mergeToCell' => 'T2'],
|
||||
['value' => 'Request Time', 'cell' => 'U1', 'mergeCell' => true, 'mergeToCell' => 'U2'],
|
||||
['value' => 'Accept Time', 'cell' => 'V1', 'mergeCell' => true, 'mergeToCell' => 'V2'],
|
||||
['value' => 'Start Time', 'cell' => 'W1', 'mergeCell' => true, 'mergeToCell' => 'W2'],
|
||||
['value' => 'End Time', 'cell' => 'X1', 'mergeCell' => true, 'mergeToCell' => 'X2'],
|
||||
['value' => 'Kode Diagnosa', 'cell' => 'Y1', 'mergeCell' => true, 'mergeToCell' => 'Y2'],
|
||||
['value' => 'Diagnosa', 'cell' => 'Z1', 'mergeCell' => true, 'mergeToCell' => 'Z2'],
|
||||
['value' => 'Kode Resep', 'cell' => 'AA1', 'mergeCell' => true, 'mergeToCell' => 'AA2'],
|
||||
['value' => 'Tanggal Resep', 'cell' => 'AB1', 'mergeCell' => true, 'mergeToCell' => 'AB2'],
|
||||
['value' => 'Obat', 'cell' => 'AC1', 'mergeCell' => true, 'mergeToCell' => 'AC2'],
|
||||
['value' => 'Tebus Resep', 'cell' => 'AD1', 'mergeCell' => true, 'mergeToCell' => 'AD2'],
|
||||
['value' => 'Tanggal Bayar', 'cell' => 'AE1', 'mergeCell' => true, 'mergeToCell' => 'AE2'],
|
||||
['value' => 'Provider Rujukan', 'cell' => 'AF1', 'mergeCell' => true, 'mergeToCell' => 'AF2'],
|
||||
['value' => 'Poli', 'cell' => 'AG1', 'mergeCell' => true, 'mergeToCell' => 'AG2'],
|
||||
['value' => 'Subjek', 'cell' => 'AH1', 'mergeCell' => true, 'mergeToCell' => 'AH2'],
|
||||
['value' => 'No SJP', 'cell' => 'AI1', 'mergeCell' => true, 'mergeToCell' => 'AI2'],
|
||||
];
|
||||
|
||||
$spreadsheet = new Spreadsheet();
|
||||
@@ -327,56 +337,62 @@ class LivechatController extends Controller
|
||||
$obat = implode('; ',$obatArray);
|
||||
}
|
||||
};
|
||||
|
||||
|
||||
|
||||
$kodeLivechat = '-';
|
||||
if ($liveChat->dRequestTime && $liveChat->nID) {
|
||||
$createOnCarbon = Carbon::parse($liveChat->dRequestTime);
|
||||
$formattedDate = $createOnCarbon->format('ymdHis');
|
||||
$kodeLivechat = 'LS-' . $formattedDate . $liveChat->nID;
|
||||
}
|
||||
|
||||
$sheet->setCellValue('A' . $startFrom, $indexLiveChat + 1);
|
||||
$sheet->setCellValue('B' . $startFrom, $liveChat->nID ?? '-');
|
||||
$sheet->setCellValue('C' . $startFrom, Carbon::parse($liveChat->dCreateOn)->format('d-m-Y'));
|
||||
$sheet->setCellValue('D' . $startFrom, Carbon::parse($liveChat->dCreateOn)->format('H:i:s'));
|
||||
// $sheet->setCellValue('D' . $startFrom, Carbon::parse($liveChat->dRequestTime)->format('H:i:s'));
|
||||
$sheet->setCellValue('E' . $startFrom, $liveChat->healthCare->sHealthCare ?? '-');
|
||||
$sheet->setCellValue('F' . $startFrom, $fullNameDoctor);
|
||||
$sheet->setCellValue('G' . $startFrom, $liveChat->doctor->speciality->sSpesialis ?? '-');
|
||||
$sheet->setCellValue('H' . $startFrom, $liveChat->sMedia ?? '-');
|
||||
$sheet->setCellValue('I' . $startFrom, $liveChat->sMediaDokter ?? '-');
|
||||
$sheet->setCellValue('J' . $startFrom, $liveChat->user->nID ?? '-');
|
||||
$sheet->setCellValue('K' . $startFrom, $liveChat->user->full_name ?? '-');
|
||||
$sheet->setCellValue('L' . $startFrom, preg_replace('/(\d{3})(\d{4})(\d{3})/', '$1$2$3', $phone));
|
||||
$sheet->setCellValue('M' . $startFrom, $liveChat->user->sEmail ?? '-');
|
||||
$sheet->setCellValue('N' . $startFrom, (string)($liveChat->userInsurance->sNoPolis ?? '-'));
|
||||
$sheet->setCellValue('O' . $startFrom, (string)($liveChat->userInsurance->sCorporateCode ?? '-'));
|
||||
$sheet->setCellValue('P' . $startFrom, (string)($liveChat->userInsurance->sCorporateName ?? '-'));
|
||||
$sheet->setCellValue('Q' . $startFrom, (string)($nIDHubunganKeluarga ?? '-'));
|
||||
$sheet->setCellValue('R' . $startFrom, (string)($liveChat->userInsurance->sChannel ?? '-'));
|
||||
$sheet->setCellValue('S' . $startFrom, $statusLivechat);
|
||||
// $sheet->setCellValue('O' . $startFrom, $recordType);
|
||||
// $sheet->setCellValue('P' . $startFrom, $nIDUser ?? '-');
|
||||
// $sheet->setCellValue('Q' . $startFrom, $paymentMethod ?? '-');
|
||||
$sheet->setCellValue('T' . $startFrom, $requestTime);
|
||||
$sheet->setCellValue('U' . $startFrom, $acceptTime);
|
||||
$sheet->setCellValue('V' . $startFrom, $startTime);
|
||||
$sheet->setCellValue('W' . $startFrom, $endTime);
|
||||
$sheet->setCellValue('C' . $startFrom, $kodeLivechat);
|
||||
$sheet->setCellValue('D' . $startFrom, Carbon::parse($liveChat->dCreateOn)->format('d-m-Y'));
|
||||
$sheet->setCellValue('E' . $startFrom, Carbon::parse($liveChat->dCreateOn)->format('H:i:s'));
|
||||
$sheet->setCellValue('F' . $startFrom, $liveChat->healthCare->sHealthCare ?? '-');
|
||||
$sheet->setCellValue('G' . $startFrom, $fullNameDoctor);
|
||||
$sheet->setCellValue('H' . $startFrom, $liveChat->doctor->speciality->sSpesialis ?? '-');
|
||||
$sheet->setCellValue('I' . $startFrom, $liveChat->sMedia ?? '-');
|
||||
$sheet->setCellValue('J' . $startFrom, $liveChat->sMediaDokter ?? '-');
|
||||
$sheet->setCellValue('K' . $startFrom, $liveChat->user->nID ?? '-');
|
||||
$sheet->setCellValue('L' . $startFrom, $liveChat->user->full_name ?? '-');
|
||||
$sheet->setCellValue('M' . $startFrom, preg_replace('/(\d{3})(\d{4})(\d{3})/', '$1$2$3', $phone));
|
||||
$sheet->setCellValue('N' . $startFrom, $liveChat->user->sEmail ?? '-');
|
||||
$sheet->setCellValue('O' . $startFrom, (string)($liveChat->userInsurance->sNoPolis ?? '-'));
|
||||
$sheet->setCellValue('P' . $startFrom, (string)($liveChat->userInsurance->sCorporateCode ?? '-'));
|
||||
$sheet->setCellValue('Q' . $startFrom, (string)($liveChat->userInsurance->sCorporateName ?? '-'));
|
||||
$sheet->setCellValue('R' . $startFrom, (string)($nIDHubunganKeluarga ?? '-'));
|
||||
$sheet->setCellValue('S' . $startFrom, (string)($liveChat->userInsurance->sChannel ?? '-'));
|
||||
$sheet->setCellValue('T' . $startFrom, $statusLivechat);
|
||||
$sheet->setCellValue('U' . $startFrom, $requestTime);
|
||||
// $sheet->setCellValue('V' . $startFrom, $recordType);
|
||||
// $sheet->setCellValue('W' . $startFrom, $nIDUser ?? '-');
|
||||
// $sheet->setCellValue('X' . $startFrom, $paymentMethod ?? '-');
|
||||
$sheet->setCellValue('V' . $startFrom, $acceptTime);
|
||||
$sheet->setCellValue('W' . $startFrom, $startTime);
|
||||
$sheet->setCellValue('X' . $startFrom, $endTime);
|
||||
|
||||
$sheet->setCellValue('X' . $startFrom, $diagnosaCode ?? '-');
|
||||
$sheet->setCellValue('Y' . $startFrom, $diagnosa ?? '-');
|
||||
$sheet->setCellValue('Y' . $startFrom, $diagnosaCode ?? '-');
|
||||
$sheet->setCellValue('Z' . $startFrom, $diagnosa ?? '-');
|
||||
|
||||
$sheet->setCellValue('Z' . $startFrom, $liveChat->prescription->sKodeResep ?? '-');
|
||||
$sheet->setCellValue('AA' . $startFrom, $liveChat->prescription->dCreateOn ?? '-');
|
||||
$sheet->setCellValue('AB' . $startFrom, $obat);
|
||||
$sheet->setCellValue('AC' . $startFrom, $tebusResep);
|
||||
$sheet->setCellValue('AA' . $startFrom, $liveChat->prescription->sKodeResep ?? '-');
|
||||
$sheet->setCellValue('AB' . $startFrom, $liveChat->prescription->dCreateOn ?? '-');
|
||||
$sheet->setCellValue('AC' . $startFrom, $obat);
|
||||
$sheet->setCellValue('AD' . $startFrom, $tebusResep);
|
||||
|
||||
$sheet->setCellValue('AD' . $startFrom, $paymentTebus);
|
||||
$sheet->setCellValue('AE' . $startFrom, $liveChat->rujukan->nIDHealthcare ?? '-');
|
||||
$sheet->setCellValue('AF' . $startFrom, $liveChat->rujukan->sDepartement ?? '-');
|
||||
$sheet->setCellValue('AG' . $startFrom, $liveChat->summary->sSubjective ?? '-');
|
||||
$sheet->setCellValue('AH' . $startFrom, $liveChat->sNoSpj ?? '-');
|
||||
$sheet->setCellValue('AE' . $startFrom, $paymentTebus);
|
||||
$sheet->setCellValue('AF' . $startFrom, $liveChat->rujukan->nIDHealthcare ?? '-');
|
||||
$sheet->setCellValue('AG' . $startFrom, $liveChat->rujukan->sDepartement ?? '-');
|
||||
$sheet->setCellValue('AH' . $startFrom, $liveChat->summary->sSubjective ?? '-');
|
||||
$sheet->setCellValue('AI' . $startFrom, $liveChat->sNoSpj ?? '-');
|
||||
$startFrom++;
|
||||
}
|
||||
|
||||
foreach (['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J','K', 'L', 'M', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AB', 'AC', 'AD', 'AF', 'AH'] as $header) {
|
||||
|
||||
foreach (['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J','K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z', 'AA', 'AB', 'AC', 'AD', 'AE', 'AF', 'AG', 'AH', 'AI'] as $header) {
|
||||
if ($header === 'A') {
|
||||
$spreadsheet->getActiveSheet()->getColumnDimension($header)->setWidth(35, 'px');
|
||||
} elseif ($header === 'H' || $header === 'I') {
|
||||
} elseif ($header === 'I' || $header === 'J') {
|
||||
$spreadsheet->getActiveSheet()->getColumnDimension($header)->setWidth(100, 'px');
|
||||
} else {
|
||||
$spreadsheet->getActiveSheet()->getColumnDimension($header)->setAutoSize(true);
|
||||
@@ -410,11 +426,19 @@ class LivechatController extends Controller
|
||||
{
|
||||
$liveChats = Livechat::with('userInsurance',
|
||||
'user:nID,sFirstName,sLastName,sEmail,sPhone,nIDUser,nIDHubunganKeluarga',
|
||||
'doctor:nID,nIDSpesialis,nIDUser', 'doctor.user:nID,sFirstName,sLastName',
|
||||
'user.detail',
|
||||
'user.relation',
|
||||
'doctor:nID,nIDSpesialis,nIDUser',
|
||||
'doctor.user:nID,sFirstName,sLastName',
|
||||
'doctor.user.detail',
|
||||
'doctor.speciality',
|
||||
'appointment:nID,sPaymentStatus,sPaymentMethod',
|
||||
'appointment.appointmentDetail:nID,nIDAppointment,dTanggalAppointment,tTimeAppointment',
|
||||
'healthCare:nID,sHealthCare',
|
||||
'prescription',
|
||||
'prescription.items',
|
||||
'prescription.payment',
|
||||
'summary',
|
||||
'rujukan'
|
||||
)
|
||||
->whereHas('userInsurance', function (Builder $query) {
|
||||
@@ -438,37 +462,38 @@ class LivechatController extends Controller
|
||||
$headers = [
|
||||
['value' => 'ConsultationId', 'cell' => 'A1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'No SJP', 'cell' => 'B1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'PKSKD', 'cell' => 'C1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'PKSNM', 'cell' => 'D1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Card Number', 'cell' => 'E1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'NamaPasien', 'cell' => 'F1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'JenisKelamin', 'cell' => 'G1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'TanggalLahir', 'cell' => 'H1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Usia', 'cell' => 'I1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Produk', 'cell' => 'J1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Plan', 'cell' => 'K1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'DependencyStatus', 'cell' => 'L1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'TanggalKonsultasi', 'cell' => 'M1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Keluhan', 'cell' => 'N1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Kode Diagnosa', 'cell' => 'O1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Diagnosa', 'cell' => 'P1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'StartTime', 'cell' => 'Q1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'EndTime', 'cell' => 'R1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'DurasiKonsultasi', 'cell' => 'S1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'StatusKonsultasi', 'cell' => 'T1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'PrescriptionNumber', 'cell' => 'U1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Nama Dokter', 'cell' => 'V1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Jenis Dokter', 'cell' => 'W1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Rujuk (Ya/Tidak)', 'cell' => 'X1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Provider Rujukan', 'cell' => 'Y1', 'mergeCell' => true, 'mergeToCell' => ''],
|
||||
['value' => 'Poli', 'cell' => 'Z1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Total', 'cell' => 'AA1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Obat', 'cell' => 'AB1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Apotek', 'cell' => 'AC1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Nama Obat', 'cell' => 'AD1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Jumlah Obat', 'cell' => 'AE1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'By', 'cell' => 'AF1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Frequency Livechat (1 Minggu)', 'cell' => 'AG1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Kode Livechat', 'cell' => 'C1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'PKSKD', 'cell' => 'D1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'PKSNM', 'cell' => 'E1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Card Number', 'cell' => 'F1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'NamaPasien', 'cell' => 'G1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'JenisKelamin', 'cell' => 'H1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'TanggalLahir', 'cell' => 'I1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Usia', 'cell' => 'J1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Produk', 'cell' => 'K1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Plan', 'cell' => 'L1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'DependencyStatus', 'cell' => 'M1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'TanggalKonsultasi', 'cell' => 'N1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Keluhan', 'cell' => 'O1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Kode Diagnosa', 'cell' => 'P1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Diagnosa', 'cell' => 'Q1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'StartTime', 'cell' => 'R1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'EndTime', 'cell' => 'S1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'DurasiKonsultasi', 'cell' => 'T1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'StatusKonsultasi', 'cell' => 'U1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'PrescriptionNumber', 'cell' => 'V1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Nama Dokter', 'cell' => 'W1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Jenis Dokter', 'cell' => 'X1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Rujuk (Ya/Tidak)', 'cell' => 'Y1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Provider Rujukan', 'cell' => 'Z1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Poli', 'cell' => 'AA1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Total', 'cell' => 'AB1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Obat', 'cell' => 'AC1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Apotek', 'cell' => 'AD1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Nama Obat', 'cell' => 'AE1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Jumlah Obat', 'cell' => 'AF1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'By', 'cell' => 'AG1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
['value' => 'Frequency Livechat (1 Minggu)', 'cell' => 'AH1', 'mergeCell' => false, 'mergeToCell' => ''],
|
||||
];
|
||||
|
||||
$spreadsheet = new Spreadsheet();
|
||||
@@ -675,46 +700,53 @@ class LivechatController extends Controller
|
||||
if ($liveChat->user->relation && $nIDHubunganKeluarga == '-'){
|
||||
$nIDHubunganKeluarga = $liveChat->user->relation->sHubunganKeluarga;
|
||||
}
|
||||
|
||||
|
||||
|
||||
$kodeLivechat = '-';
|
||||
if ($liveChat->dRequestTime && $liveChat->nID) {
|
||||
$createOnCarbon = Carbon::parse($liveChat->dRequestTime);
|
||||
$formattedDate = $createOnCarbon->format('ymdHis');
|
||||
$kodeLivechat = 'LS-' . $formattedDate . $liveChat->nID;
|
||||
}
|
||||
|
||||
$sheet->setCellValue('A' . $startFromSheet1, $liveChat->nID ?? '-');
|
||||
$sheet->setCellValue('B' . $startFromSheet1, $liveChat->sNoSpj ?? '-');
|
||||
$sheet->setCellValue('C' . $startFromSheet1, (string)($liveChat->userInsurance->sCorporateCode ?? '-'));
|
||||
$sheet->setCellValue('D' . $startFromSheet1, (string)($liveChat->userInsurance->sCorporateName ?? '-'));
|
||||
$sheet->setCellValue('E' . $startFromSheet1, (string)($liveChat->userInsurance->sNoPolis ?? '-'));
|
||||
$sheet->setCellValue('F' . $startFromSheet1, $liveChat->user->full_name ?? '-');
|
||||
$sheet->setCellValue('G' . $startFromSheet1, $liveChat->user->detail->nIDJenisKelamin == 1 ? 'Laki-laki' : 'Wanita');
|
||||
$sheet->setCellValue('H' . $startFromSheet1, $liveChat->user->detail->dTanggalLahir ?? '-');
|
||||
$sheet->setCellValue('I' . $startFromSheet1, Helper::calculateAge($liveChat->user->detail->dTanggalLahir, true) ?? '-'); $sheet->setCellValue('J' . $startFromSheet1, (string)($liveChat->userInsurance->sProductCode ?? '-'));
|
||||
$sheet->setCellValue('K' . $startFromSheet1, (string)($liveChat->userInsurance->sPlanCode ?? '-'));
|
||||
$sheet->setCellValue('L' . $startFromSheet1, $nIDHubunganKeluarga ?? '-');
|
||||
$sheet->setCellValue('M' . $startFromSheet1, $requestTime->format('Y-m-d'));
|
||||
$sheet->setCellValue('N' . $startFromSheet1, $liveChat->summary->sSubjective ?? '-');
|
||||
$sheet->setCellValue('O' . $startFromSheet1, $diagnosaCode ?? '-');
|
||||
$sheet->setCellValue('P' . $startFromSheet1, $diagnosa ?? '-');
|
||||
$sheet->setCellValue('Q' . $startFromSheet1, $startTime->format('H:i:s'));
|
||||
$sheet->setCellValue('R' . $startFromSheet1, $endTime->format('H:i:s'));
|
||||
$sheet->setCellValue('S' . $startFromSheet1, $chatTime);
|
||||
$sheet->setCellValue('C' . $startFromSheet1, (string)($kodeLivechat) ?? '-');
|
||||
$sheet->setCellValue('D' . $startFromSheet1, (string)($liveChat->userInsurance->sCorporateCode ?? '-'));
|
||||
$sheet->setCellValue('E' . $startFromSheet1, (string)($liveChat->userInsurance->sCorporateName ?? '-'));
|
||||
$sheet->setCellValue('F' . $startFromSheet1, (string)($liveChat->userInsurance->sNoPolis ?? '-'));
|
||||
$sheet->setCellValue('G' . $startFromSheet1, $liveChat->user->full_name ?? '-');
|
||||
$sheet->setCellValue('H' . $startFromSheet1, $liveChat->user->detail->nIDJenisKelamin == 1 ? 'Laki-laki' : 'Wanita');
|
||||
$sheet->setCellValue('I' . $startFromSheet1, $liveChat->user->detail->dTanggalLahir ?? '-');
|
||||
$sheet->setCellValue('J' . $startFromSheet1, Helper::calculateAge($liveChat->user->detail->dTanggalLahir, true) ?? '-');
|
||||
$sheet->setCellValue('K' . $startFromSheet1, (string)($liveChat->userInsurance->sProductCode ?? '-'));
|
||||
$sheet->setCellValue('L' . $startFromSheet1, (string)($liveChat->userInsurance->sPlanCode ?? '-'));
|
||||
$sheet->setCellValue('M' . $startFromSheet1, $nIDHubunganKeluarga ?? '-');
|
||||
$sheet->setCellValue('N' . $startFromSheet1, $requestTime->format('Y-m-d'));
|
||||
$sheet->setCellValue('O' . $startFromSheet1, $liveChat->summary->sSubjective ?? '-');
|
||||
$sheet->setCellValue('P' . $startFromSheet1, $diagnosaCode ?? '-');
|
||||
$sheet->setCellValue('Q' . $startFromSheet1, $diagnosa ?? '-');
|
||||
$sheet->setCellValue('R' . $startFromSheet1, $startTime->format('H:i:s'));
|
||||
$sheet->setCellValue('S' . $startFromSheet1, $endTime->format('H:i:s'));
|
||||
$sheet->setCellValue('T' . $startFromSheet1, $chatTime);
|
||||
// $sheet->setCellValue('O' . $startFromSheet1, $recordType);
|
||||
// $sheet->setCellValue('P' . $startFromSheet1, $nIDUser ?? '-');
|
||||
// $sheet->setCellValue('Q' . $startFromSheet1, $paymentMethod ?? '-');
|
||||
$sheet->setCellValue('T' . $startFromSheet1, $statusLivechat);
|
||||
$sheet->setCellValue('U' . $startFromSheet1, $liveChat->prescription->sKodeResep ?? '-');
|
||||
$sheet->setCellValue('V' . $startFromSheet1, $fullNameDoctor);
|
||||
$sheet->setCellValue('W' . $startFromSheet1, $liveChat->doctor->speciality->sSpesialis ?? '-');
|
||||
$sheet->setCellValue('X' . $startFromSheet1, $liveChat->rujukan ? 'Ya' : 'Tidak');
|
||||
$sheet->setCellValue('Y' . $startFromSheet1, $liveChat->rujukan->nIDHealthcare ?? '-');
|
||||
$sheet->setCellValue('Z' . $startFromSheet1, $liveChat->rujukan->sDepartement ?? '-' );
|
||||
$sheet->setCellValue('U' . $startFromSheet1, $statusLivechat);
|
||||
$sheet->setCellValue('V' . $startFromSheet1, $liveChat->prescription->sKodeResep ?? '-');
|
||||
$sheet->setCellValue('W' . $startFromSheet1, $fullNameDoctor);
|
||||
$sheet->setCellValue('X' . $startFromSheet1, $liveChat->doctor->speciality->sSpesialis ?? '-');
|
||||
$sheet->setCellValue('Y' . $startFromSheet1, $liveChat->rujukan ? 'Ya' : 'Tidak');
|
||||
$sheet->setCellValue('Z' . $startFromSheet1, $liveChat->rujukan->nIDHealthcare ?? '-');
|
||||
$sheet->setCellValue('AA' . $startFromSheet1, $liveChat->rujukan->sDepartement ?? '-');
|
||||
|
||||
$sheet->setCellValue('AA' . $startFromSheet1, $qtyTotal);
|
||||
$sheet->setCellValue('AB' . $startFromSheet1, $tebusResep);
|
||||
$sheet->setCellValue('AB' . $startFromSheet1, $qtyTotal);
|
||||
$sheet->setCellValue('AC' . $startFromSheet1, $tebusResep);
|
||||
|
||||
$sheet->setCellValue('AC' . $startFromSheet1, $apotek);
|
||||
$sheet->setCellValue('AD' . $startFromSheet1, $obat);
|
||||
$sheet->setCellValue('AE' . $startFromSheet1, $obatQty);
|
||||
$sheet->setCellValue('AF' . $startFromSheet1, 'LMS');
|
||||
$sheet->setCellValue('AG' . $startFromSheet1, $frequencyLivechat);
|
||||
$sheet->setCellValue('AD' . $startFromSheet1, $apotek);
|
||||
$sheet->setCellValue('AE' . $startFromSheet1, $obat);
|
||||
$sheet->setCellValue('AF' . $startFromSheet1, $obatQty);
|
||||
$sheet->setCellValue('AG' . $startFromSheet1, 'LMS');
|
||||
$sheet->setCellValue('AH' . $startFromSheet1, $frequencyLivechat);
|
||||
// $sheet->setCellValue('AC' . $startFrom, $liveChat->prescription->dCreateOn ?? '-');
|
||||
// $sheet->setCellValue('AD' . $startFrom, $obat);
|
||||
// $sheet->setCellValue('AE' . $startFrom, $tebusResep);
|
||||
@@ -913,41 +945,42 @@ class LivechatController extends Controller
|
||||
|
||||
$sheet2->setCellValue('A' . $startFromSheet2, $liveChat->nID ?? '-');
|
||||
$sheet2->setCellValue('B' . $startFromSheet2, $liveChat->sNoSpj ?? '-');
|
||||
$sheet2->setCellValue('C' . $startFromSheet2, (string)($liveChat->userInsurance->sCorporateCode ?? '-'));
|
||||
$sheet2->setCellValue('D' . $startFromSheet2, (string)($liveChat->userInsurance->sCorporateName ?? '-'));
|
||||
$sheet2->setCellValue('E' . $startFromSheet2, (string)($liveChat->userInsurance->sNoPolis ?? '-'));
|
||||
$sheet2->setCellValue('F' . $startFromSheet2, $liveChat->user->full_name ?? '-');
|
||||
$sheet2->setCellValue('G' . $startFromSheet2, $liveChat->user->detail->dTanggalLahir ?? '-');
|
||||
$sheet2->setCellValue('H' . $startFromSheet2, $liveChat->user->detail->nIDJenisKelamin == 1 ? 'Laki-laki' : 'Wanita');
|
||||
$sheet2->setCellValue('I' . $startFromSheet2, Helper::calculateAge($liveChat->user->detail->dTanggalLahir) ?? '-');
|
||||
$sheet2->setCellValue('J' . $startFromSheet2, (string)($liveChat->userInsurance->sProductCode ?? '-'));
|
||||
$sheet2->setCellValue('K' . $startFromSheet2, (string)($liveChat->userInsurance->sPlanCode ?? '-'));
|
||||
$sheet2->setCellValue('L' . $startFromSheet2, $nIDHubunganKeluarga ?? '-');
|
||||
$sheet2->setCellValue('M' . $startFromSheet2, $requestTime->format('Y-m-d'));
|
||||
$sheet2->setCellValue('N' . $startFromSheet2, $liveChat->summary->sSubjective ?? '-');
|
||||
$sheet2->setCellValue('O' . $startFromSheet2, $diagnosaCode ?? '-');
|
||||
$sheet2->setCellValue('P' . $startFromSheet2, $diagnosa ?? '-');
|
||||
$sheet2->setCellValue('Q' . $startFromSheet2, $startTime->format('H:i:s'));
|
||||
$sheet2->setCellValue('R' . $startFromSheet2, $endTime->format('H:i:s'));
|
||||
$sheet2->setCellValue('S' . $startFromSheet2, $chatTime);
|
||||
$sheet2->setCellValue('C' . $startFromSheet2, (string)($kodeLivechat) ?? '-');
|
||||
$sheet2->setCellValue('D' . $startFromSheet2, (string)($liveChat->userInsurance->sCorporateCode ?? '-'));
|
||||
$sheet2->setCellValue('E' . $startFromSheet2, (string)($liveChat->userInsurance->sCorporateName ?? '-'));
|
||||
$sheet2->setCellValue('F' . $startFromSheet2, (string)($liveChat->userInsurance->sNoPolis ?? '-'));
|
||||
$sheet2->setCellValue('G' . $startFromSheet2, $liveChat->user->full_name ?? '-');
|
||||
$sheet2->setCellValue('H' . $startFromSheet2, $liveChat->user->detail->dTanggalLahir ?? '-');
|
||||
$sheet2->setCellValue('I' . $startFromSheet2, $liveChat->user->detail->nIDJenisKelamin == 1 ? 'Laki-laki' : 'Wanita');
|
||||
$sheet2->setCellValue('J' . $startFromSheet2, Helper::calculateAge($liveChat->user->detail->dTanggalLahir) ?? '-');
|
||||
$sheet2->setCellValue('K' . $startFromSheet2, (string)($liveChat->userInsurance->sProductCode ?? '-'));
|
||||
$sheet2->setCellValue('L' . $startFromSheet2, (string)($liveChat->userInsurance->sPlanCode ?? '-'));
|
||||
$sheet2->setCellValue('M' . $startFromSheet2, $nIDHubunganKeluarga ?? '-');
|
||||
$sheet2->setCellValue('N' . $startFromSheet2, $requestTime->format('Y-m-d'));
|
||||
$sheet2->setCellValue('O' . $startFromSheet2, $liveChat->summary->sSubjective ?? '-');
|
||||
$sheet2->setCellValue('P' . $startFromSheet2, $diagnosaCode ?? '-');
|
||||
$sheet2->setCellValue('Q' . $startFromSheet2, $diagnosa ?? '-');
|
||||
$sheet2->setCellValue('R' . $startFromSheet2, $startTime->format('H:i:s'));
|
||||
$sheet2->setCellValue('S' . $startFromSheet2, $endTime->format('H:i:s'));
|
||||
$sheet2->setCellValue('T' . $startFromSheet2, $chatTime);
|
||||
// $sheet2->setCellValue('O' . $startFromSheet2, $recordType);
|
||||
// $sheet2->setCellValue('P' . $startFromSheet2, $nIDUser ?? '-');
|
||||
// $sheet2->setCellValue('Q' . $startFromSheet2, $paymentMethod ?? '-');
|
||||
$sheet2->setCellValue('T' . $startFromSheet2, $statusLivechat);
|
||||
$sheet2->setCellValue('U' . $startFromSheet2, $liveChat->prescription->sKodeResep ?? '-');
|
||||
$sheet2->setCellValue('V' . $startFromSheet2, $fullNameDoctor);
|
||||
$sheet2->setCellValue('W' . $startFromSheet2, $liveChat->doctor->speciality->sSpesialis ?? '-');
|
||||
$sheet2->setCellValue('X' . $startFromSheet2, $liveChat->rujukan ? 'Ya' : 'Tidak');
|
||||
$sheet2->setCellValue('Y' . $startFromSheet2, $liveChat->rujukan->nIDHealthcare ?? '-' );
|
||||
$sheet2->setCellValue('Z' . $startFromSheet2, $liveChat->rujukan->sDepartement ?? '-' );
|
||||
|
||||
$sheet2->setCellValue('AA' . $startFromSheet2, '-');
|
||||
$sheet2->setCellValue('AB' . $startFromSheet2, $tebusResep);
|
||||
|
||||
$sheet2->setCellValue('AC' . $startFromSheet2, $apotek );
|
||||
$sheet2->setCellValue('AD' . $startFromSheet2, $obat);
|
||||
$sheet2->setCellValue('AE' . $startFromSheet2, $obatQty);
|
||||
$sheet2->setCellValue('AF' . $startFromSheet2, 'LMS');
|
||||
$sheet2->setCellValue('U' . $startFromSheet2, $statusLivechat);
|
||||
$sheet2->setCellValue('V' . $startFromSheet2, $liveChat->prescription->sKodeResep ?? '-');
|
||||
$sheet2->setCellValue('W' . $startFromSheet2, $fullNameDoctor);
|
||||
$sheet2->setCellValue('X' . $startFromSheet2, $liveChat->doctor->speciality->sSpesialis ?? '-');
|
||||
$sheet2->setCellValue('Y' . $startFromSheet2, $liveChat->rujukan ? 'Ya' : 'Tidak');
|
||||
$sheet2->setCellValue('Z' . $startFromSheet2, $liveChat->rujukan->nIDHealthcare ?? '-');
|
||||
$sheet2->setCellValue('AA' . $startFromSheet2, $liveChat->rujukan->sDepartement ?? '-');
|
||||
|
||||
$sheet2->setCellValue('AB' . $startFromSheet2, '-');
|
||||
$sheet2->setCellValue('AC' . $startFromSheet2, $tebusResep);
|
||||
|
||||
$sheet2->setCellValue('AD' . $startFromSheet2, $apotek);
|
||||
$sheet2->setCellValue('AE' . $startFromSheet2, $obat);
|
||||
$sheet2->setCellValue('AF' . $startFromSheet2, $obatQty);
|
||||
$sheet2->setCellValue('AG' . $startFromSheet2, 'LMS');
|
||||
// $sheet->setCellValue('AC' . $startFromSheet2, $liveChat->prescription->dCreateOn ?? '-');
|
||||
// $sheet->setCellValue('AD' . $startFromSheet2, $obat);
|
||||
// $sheet->setCellValue('AE' . $startFromSheet2, $tebusResep);
|
||||
|
||||
@@ -16,7 +16,8 @@ class NavigationController extends Controller
|
||||
public function index(Request $request)
|
||||
{
|
||||
// Ambil semua navigasi dari tabel dan ubah menjadi array
|
||||
$navigations = Navigations::all()->toArray();
|
||||
// $navigations = Navigations::all()->toArray();
|
||||
$navigations = Navigations::orderBy('urutan', 'asc')->get()->toArray();
|
||||
$navigationMaster = [];
|
||||
|
||||
if ($navigations) {
|
||||
|
||||
@@ -72,7 +72,7 @@ class RequestLogBenefitController extends Controller
|
||||
'amount_approved' => $value['amount_approved'],
|
||||
'amount_not_approved' => $value['amount_not_approved'],
|
||||
'excess_paid' => $value['excess_paid'],
|
||||
'keterangan' => $value['keterangan'],
|
||||
'keterangan' => $value['keterangan'] ?? '',
|
||||
'created_by' => auth()->user()->id,
|
||||
// 'reason' => $value['reason'] ? $value['reason'] : null ,
|
||||
|
||||
|
||||
@@ -202,4 +202,34 @@ class UserManagementController extends Controller
|
||||
|
||||
return response()->json($userAccess);
|
||||
}
|
||||
|
||||
public function delete(Request $request, $id)
|
||||
{
|
||||
try {
|
||||
// Cari user berdasarkan ID
|
||||
$user = User::findOrFail($id);
|
||||
|
||||
// Hapus user
|
||||
$user->delete();
|
||||
|
||||
// Response sukses
|
||||
return response()->json([
|
||||
'code' => 200,
|
||||
'message' => 'User berhasil dihapus',
|
||||
'data' => null,
|
||||
]);
|
||||
} catch (\Illuminate\Database\Eloquent\ModelNotFoundException $e) {
|
||||
return response()->json([
|
||||
'code' => 404,
|
||||
'message' => 'User tidak ditemukan',
|
||||
'data' => null,
|
||||
], 404);
|
||||
} catch (\Exception $e) {
|
||||
return response()->json([
|
||||
'code' => 500,
|
||||
'message' => 'Terjadi kesalahan saat menghapus user',
|
||||
'error' => $e->getMessage(),
|
||||
], 500);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
@@ -54,6 +54,10 @@ use Modules\Internal\Http\Controllers\Api\CorporateManageController;
|
||||
use Modules\Internal\Http\Controllers\Api\UserManagementController;
|
||||
use Modules\Internal\Http\Controllers\ClaimEncounterController;
|
||||
use Modules\Linksehat\Http\Controllers\Api\AutocompleteController;
|
||||
use Modules\HospitalPortal\Http\Controllers\Api\MemberController as MemberControllerHospitalPortal;
|
||||
use Modules\HospitalPortal\Http\Controllers\Api\RequestLogController as RequestLogControllerHospitalPortal;
|
||||
|
||||
|
||||
|
||||
// Report
|
||||
use Modules\Internal\Http\Controllers\Api\ReportLogController;
|
||||
@@ -92,6 +96,9 @@ Route::prefix('internal')->group(function () {
|
||||
Route::get('signa', [AutocompleteController::class, 'signaList']);
|
||||
Route::post('signa-add', [AutocompleteController::class, 'signaAdd']);
|
||||
|
||||
Route::get('service-member/{id}', [AutocompleteController::class, 'serviceCode']);
|
||||
Route::get('specialis', [AutocompleteController::class, 'specialisList']);
|
||||
|
||||
|
||||
|
||||
Route::middleware('auth:sanctum')->group(function () {
|
||||
@@ -311,6 +318,49 @@ Route::prefix('internal')->group(function () {
|
||||
Route::get('claims/{id}/benefit-configuration', [ClaimController::class, 'getBenefitConfiguration']); // Bagaskoro, BSD 03 November 2023
|
||||
Route::put('claims/benefit-configuration/edit/{id}', [ClaimController::class, 'editBenefitConfiguration']); // Bagaskoro, BSD 03 November 2023
|
||||
|
||||
//dari hospital-portal
|
||||
//Search Member
|
||||
Route::post(
|
||||
'search-member',
|
||||
[MemberControllerHospitalPortal::class, 'search']
|
||||
);
|
||||
// Request LOG
|
||||
Route::post(
|
||||
'request-log',
|
||||
[RequestLogControllerHospitalPortal::class, 'requestLog']
|
||||
);
|
||||
|
||||
Route::get(
|
||||
'get-request-log',
|
||||
[RequestLogControllerHospitalPortal::class, 'getRequestLog']
|
||||
);
|
||||
|
||||
Route::get(
|
||||
'get-final-log',
|
||||
[RequestLogControllerHospitalPortal::class, 'getFinalLog']
|
||||
);
|
||||
|
||||
Route::post(
|
||||
'request-final-log',
|
||||
[RequestLogControllerHospitalPortal::class, 'requestFinalLog']
|
||||
);
|
||||
|
||||
Route::get(
|
||||
'download-log/{request_log_id}',
|
||||
[RequestLogControllerHospitalPortal::class, 'downlodLog']
|
||||
);
|
||||
|
||||
Route::get(
|
||||
'download-final-log/{request_log_id}',
|
||||
[RequestLogControllerHospitalPortal::class, 'downlodFinalLog']
|
||||
);
|
||||
|
||||
Route::post(
|
||||
'submit-claims',
|
||||
[RequestLogControllerHospitalPortal::class, 'submitClaims']
|
||||
);
|
||||
//end dari hospital-portal
|
||||
|
||||
Route::get('customer-service/request', [RequestLogController::class, 'index']);
|
||||
Route::post('customer-service/request', [RequestLogController::class, 'createNew']);
|
||||
Route::put('customer-service/request/{id}', [RequestLogController::class, 'update']);
|
||||
@@ -416,6 +466,7 @@ Route::prefix('internal')->group(function () {
|
||||
Route::post('user/access', [UserManagementController::class, 'store_access']);
|
||||
Route::get('user/access/{id}', [UserManagementController::class, 'edit_access']);
|
||||
Route::put('user/access/{id}', [UserManagementController::class, 'update_access']);
|
||||
Route::post('user/access/{id}/delete', [UserManagementController::class, 'delete']);
|
||||
Route::get('role-list', [UserManagementController::class, 'list_role']);
|
||||
Route::get('organization-list', [UserManagementController::class, 'list_organization']);
|
||||
|
||||
|
||||
@@ -412,7 +412,7 @@ class MemberEnrollmentService
|
||||
->first();
|
||||
|
||||
if (empty($member)) {
|
||||
throw new ImportRowException(__('enrollment.MAPING_ID_NOT_SAME_MEMBER_ID'), 0, null, $row);
|
||||
// throw new ImportRowException(__('enrollment.MAPING_ID_NOT_SAME_MEMBER_ID'), 0, null, $row);
|
||||
} else {
|
||||
// if ($member['record_type'] != 'P'){
|
||||
// throw new ImportRowException(__('enrollment.PRINCIPAL_ID_NOT_SAME_MEMBER_ID'), 0, null, $row);
|
||||
|
||||
@@ -27,7 +27,7 @@ class RequestLogResource extends JsonResource
|
||||
'submission_date' => $this->created_at, // submsion_date diambil dari kolom created_at
|
||||
'admission_date' => $this->submission_date, // admission_date diambil dari kolom submission
|
||||
'submission_date_fgl' => $this->approved_final_log_at,
|
||||
'member_name' => $this->member->name,
|
||||
'member_name' => $this->member->name ?? '-',
|
||||
'status' => $this->status ?? 'unknown',
|
||||
'provider' => $provider ? $provider->name : '-',
|
||||
'status_final_log' => $this->status_final_log ?? 'unknown',
|
||||
|
||||
@@ -30,13 +30,15 @@ class RequestLogShowResource extends JsonResource
|
||||
{
|
||||
|
||||
$requestLog = parent::toArray($request);
|
||||
|
||||
$corporateId = $requestLog['member']['current_plan']['corporate_id'] ?? 0;
|
||||
$member_id = $requestLog['member_id'];
|
||||
$planMember = MemberPlan::where('member_id', $member_id)->get('plan_id');
|
||||
|
||||
|
||||
$planId = Plan::whereIn('id', $planMember)->where('service_code', $requestLog['service_code'])->first();
|
||||
$benefit = CorporateBenefit::with(['benefit', 'plan'])->where('plan_id', $planId->id)->get()->toArray();
|
||||
$benefitDetailLog = RequestLogBenefit::with('benefit')->where('request_log_id', $requestLog['id'])->get()->toArray();
|
||||
|
||||
$medicineDetailLog = RequestLogMedicine::where('request_log_id', $requestLog['id'])->get()->toArray();
|
||||
$provider = Organization::where('id', $requestLog['organization_id'])->first();
|
||||
$claimRequest = ClaimRequest::where('request_log_id', $requestLog['id'])->first();
|
||||
@@ -139,10 +141,11 @@ class RequestLogShowResource extends JsonResource
|
||||
'invoice_no' => $requestLog['invoice_no'],
|
||||
'billing_no' => $requestLog['billing_no'],
|
||||
'specialities_id' => $name,
|
||||
'specialitiesID' => $requestLog['specialities_id'],
|
||||
'dppj' => $dppj,
|
||||
'code' => $requestLog['code'],
|
||||
'code_claim' => $claimCode,
|
||||
'member_id' => $requestLog['member']['member_id'],
|
||||
'id_member' => $requestLog['member']['id'],
|
||||
'type_of_member' => $requestLog['type_of_member'],
|
||||
'corporate_id' => $corporateId,
|
||||
'policy_number' =>$policyNumber->code ? $policyNumber->code : '-',
|
||||
@@ -160,6 +163,7 @@ class RequestLogShowResource extends JsonResource
|
||||
'approved_final_log_at' => $requestLog['approved_final_log_at'], // submission final log
|
||||
'discharge_date' => $requestLog['discharge_date'],
|
||||
'service_type' => Helper::serviceName($requestLog['service_code']),
|
||||
'service_code' => $requestLog['service_code'],
|
||||
'claim_method' => $requestLog['payment_type'],
|
||||
'status' => $requestLog['status'],
|
||||
'status_final_log' => $requestLog['status_final_log'],
|
||||
@@ -174,8 +178,8 @@ class RequestLogShowResource extends JsonResource
|
||||
'keterangan' => $requestLog['keterangan'],
|
||||
'hak_kamar_pasien' => $requestLog['hak_kamar_pasien'],
|
||||
'penempatan_kamar' => $requestLog['penempatan_kamar'],
|
||||
'nominal' => $requestLog['nominal'],
|
||||
'status_approval' => $requestLog['status_approval'],
|
||||
'nominal' => $requestLog['nominal'] ?? 0,
|
||||
'status_approval' => $requestLog['status_approval'] ?? '',
|
||||
'catatan' => $requestLog['catatan'],
|
||||
'reason' => $requestLog['reason'],
|
||||
'diagnosis' => $icd,
|
||||
|
||||
0
Modules/Primaya/Config/.gitkeep
Normal file
0
Modules/Primaya/Config/.gitkeep
Normal file
5
Modules/Primaya/Config/config.php
Normal file
5
Modules/Primaya/Config/config.php
Normal file
@@ -0,0 +1,5 @@
|
||||
<?php
|
||||
|
||||
return [
|
||||
'name' => 'Primaya'
|
||||
];
|
||||
0
Modules/Primaya/Console/.gitkeep
Normal file
0
Modules/Primaya/Console/.gitkeep
Normal file
0
Modules/Primaya/Database/Migrations/.gitkeep
Normal file
0
Modules/Primaya/Database/Migrations/.gitkeep
Normal file
0
Modules/Primaya/Database/Seeders/.gitkeep
Normal file
0
Modules/Primaya/Database/Seeders/.gitkeep
Normal file
21
Modules/Primaya/Database/Seeders/PrimayaDatabaseSeeder.php
Normal file
21
Modules/Primaya/Database/Seeders/PrimayaDatabaseSeeder.php
Normal file
@@ -0,0 +1,21 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Database\Seeders;
|
||||
|
||||
use Illuminate\Database\Seeder;
|
||||
use Illuminate\Database\Eloquent\Model;
|
||||
|
||||
class PrimayaDatabaseSeeder extends Seeder
|
||||
{
|
||||
/**
|
||||
* Run the database seeds.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function run()
|
||||
{
|
||||
Model::unguard();
|
||||
|
||||
// $this->call("OthersTableSeeder");
|
||||
}
|
||||
}
|
||||
0
Modules/Primaya/Database/factories/.gitkeep
Normal file
0
Modules/Primaya/Database/factories/.gitkeep
Normal file
0
Modules/Primaya/Entities/.gitkeep
Normal file
0
Modules/Primaya/Entities/.gitkeep
Normal file
21
Modules/Primaya/Helpers/ApiResponse.php
Normal file
21
Modules/Primaya/Helpers/ApiResponse.php
Normal file
@@ -0,0 +1,21 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Helpers;
|
||||
|
||||
class ApiResponse
|
||||
{
|
||||
public static function apiResponse(string $status, array|object $data = null, string|array|object $message = null, int $statusCode)
|
||||
{
|
||||
if ($message instanceof \Illuminate\Support\MessageBag) {
|
||||
$message = $message->first();
|
||||
}
|
||||
return response()->json([
|
||||
'meta' => [
|
||||
'status' => $status,
|
||||
'code' => $statusCode,
|
||||
'message' => $message
|
||||
],
|
||||
'data' => $data,
|
||||
], $statusCode);
|
||||
}
|
||||
}
|
||||
0
Modules/Primaya/Http/Controllers/.gitkeep
Normal file
0
Modules/Primaya/Http/Controllers/.gitkeep
Normal file
118
Modules/Primaya/Http/Controllers/Api/AuthController.php
Normal file
118
Modules/Primaya/Http/Controllers/Api/AuthController.php
Normal file
@@ -0,0 +1,118 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Http\Controllers\Api;
|
||||
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Models\User;
|
||||
use Crypt;
|
||||
use Error;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Auth;
|
||||
use Illuminate\Support\Facades\Hash;
|
||||
use Illuminate\Support\Facades\Mail;
|
||||
use Modules\Internal\Emails\SendVerifyEmail;
|
||||
use Modules\Internal\Events\ForgetPassword;
|
||||
use Illuminate\Support\Facades\Validator;
|
||||
use Modules\Primaya\Helpers\ApiResponse;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use App\Helpers\Helper;
|
||||
use App\Models\Corporate;
|
||||
use Illuminate\Support\Facades\View;
|
||||
use Tymon\JWTAuth\Facades\JWTAuth;
|
||||
use Tymon\JWTAuth\Exceptions\JWTException;
|
||||
|
||||
class AuthController extends Controller
|
||||
{
|
||||
public function loginJwt(Request $request)
|
||||
{
|
||||
$data = [
|
||||
'email' => $request->email,
|
||||
'password' => $request->password
|
||||
];
|
||||
|
||||
$validator = Validator::make($request->all(), [
|
||||
'email' => 'required|email',
|
||||
'password' => 'required'
|
||||
]);
|
||||
|
||||
if ($validator->fails()) {
|
||||
return ApiResponse::apiResponse(
|
||||
'Bad Request',
|
||||
$data,
|
||||
$validator->errors(),
|
||||
400
|
||||
);
|
||||
}
|
||||
|
||||
// 🔥 1️⃣ Ambil header
|
||||
$apiKey = $request->header('X-API-KEY');
|
||||
$apiSecret = $request->header('X-API-SECRET');
|
||||
|
||||
if (empty($apiKey) || empty($apiSecret)) {
|
||||
return ApiResponse::apiResponse(
|
||||
'Unauthorized',
|
||||
null,
|
||||
'API Key dan Secret wajib diisi',
|
||||
401
|
||||
);
|
||||
}
|
||||
|
||||
// 🔥 2️⃣ Validasi corporate
|
||||
$corporate = Corporate::where('api_key', $apiKey)
|
||||
->where('api_secret', $apiSecret)
|
||||
->first();
|
||||
|
||||
if (!$corporate) {
|
||||
return ApiResponse::apiResponse(
|
||||
'Unauthorized',
|
||||
null,
|
||||
'Invalid API Key',
|
||||
401
|
||||
);
|
||||
}
|
||||
|
||||
// 🔥 3️⃣ Cari user sesuai corporate
|
||||
$user = User::where('email', $request->email)
|
||||
->where('corporate_id', $corporate->id)
|
||||
->first();
|
||||
|
||||
if (!$user || !Hash::check($request->password, $user->password)) {
|
||||
return ApiResponse::apiResponse(
|
||||
'Unauthorized',
|
||||
$data,
|
||||
'Email atau password salah',
|
||||
401
|
||||
);
|
||||
}
|
||||
|
||||
try {
|
||||
// 🔥 4️⃣ Generate JWT dengan claim corporate_id
|
||||
$token = auth('corporate-api')->claims([
|
||||
'corporate_id' => $corporate->id
|
||||
])->login($user);
|
||||
|
||||
} catch (JWTException $e) {
|
||||
return ApiResponse::apiResponse(
|
||||
'Error',
|
||||
null,
|
||||
'Gagal membuat token',
|
||||
500
|
||||
);
|
||||
}
|
||||
|
||||
$res_data = [
|
||||
'user' => $user,
|
||||
'corporate_id' => $corporate->id,
|
||||
'token' => $token,
|
||||
'type' => 'Bearer',
|
||||
'expires_in' => auth('corporate-api')->factory()->getTTL() * 60
|
||||
];
|
||||
|
||||
return ApiResponse::apiResponse(
|
||||
"Success",
|
||||
$res_data,
|
||||
'Login berhasil',
|
||||
200
|
||||
);
|
||||
}
|
||||
}
|
||||
63
Modules/Primaya/Http/Controllers/Api/MasterController.php
Normal file
63
Modules/Primaya/Http/Controllers/Api/MasterController.php
Normal file
@@ -0,0 +1,63 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Http\Controllers\Api;
|
||||
use Illuminate\Contracts\Support\Renderable;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Routing\Controller;
|
||||
use Illuminate\Support\Facades\Validator;
|
||||
use Modules\Primaya\Helpers\ApiResponse;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Modules\Internal\Http\Controllers\Api\RequestLogController as primeCenterRequestLog;
|
||||
use App\Helpers\Helper;
|
||||
use App\Models\Benefit;
|
||||
use App\Models\File;
|
||||
use Dompdf\Dompdf;
|
||||
use Dompdf\Options;
|
||||
use Illuminate\Support\Facades\View;
|
||||
use App\Models\Member;
|
||||
use App\Models\RequestLog;
|
||||
use App\Models\Organization;
|
||||
use App\Services\ClaimRequestService;
|
||||
use App\Models\ClaimRequest;
|
||||
use App\Models\CorporateBenefit;
|
||||
use App\Models\RequestLogBenefit;
|
||||
use App\Models\Speciality;
|
||||
|
||||
class MasterController extends Controller
|
||||
{
|
||||
public function specialities()
|
||||
{
|
||||
$data = Speciality::select('id', 'name')->get();
|
||||
|
||||
return response()->json([
|
||||
'status' => 'success',
|
||||
'data' => $data
|
||||
]);
|
||||
}
|
||||
|
||||
public function benefits()
|
||||
{
|
||||
$corporateId = auth('corporate-api')->user()->corporate_id;
|
||||
|
||||
$data = Benefit::whereHas('corporateBenefits', function ($q) use ($corporateId) {
|
||||
$q->where('corporate_id', $corporateId);
|
||||
})
|
||||
->select('id', 'description')
|
||||
->get();
|
||||
|
||||
return response()->json([
|
||||
'status' => 'success',
|
||||
'data' => $data
|
||||
]);
|
||||
}
|
||||
|
||||
public function organizations()
|
||||
{
|
||||
$data = Organization::select('id', 'name', 'code')->get();
|
||||
|
||||
return response()->json([
|
||||
'status' => 'success',
|
||||
'data' => $data
|
||||
]);
|
||||
}
|
||||
}
|
||||
178
Modules/Primaya/Http/Controllers/Api/MemberController.php
Normal file
178
Modules/Primaya/Http/Controllers/Api/MemberController.php
Normal file
@@ -0,0 +1,178 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Http\Controllers\Api;
|
||||
|
||||
use App\Helpers\Helper;
|
||||
use App\Models\Member;
|
||||
use Illuminate\Contracts\Support\Renderable;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Routing\Controller;
|
||||
use Illuminate\Support\Facades\Validator;
|
||||
use Modules\Primaya\Helpers\ApiResponse;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
|
||||
class MemberController extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
* @return Renderable
|
||||
*/
|
||||
public function search(Request $request)
|
||||
{
|
||||
$data = [
|
||||
'no_polis' => $request->no_polis,
|
||||
'birth_date' => $request->birth_date
|
||||
];
|
||||
$validator = Validator::make($request->all(), [
|
||||
'no_polis' => 'required',
|
||||
'birth_date' => 'required'
|
||||
], [
|
||||
'no_polis.required' => trans('Validation.required',['attribute' => 'Member ID']),
|
||||
'birth_date.required' => trans('Validation.required',['attribute' => 'Birth Date']),
|
||||
]);
|
||||
if ($validator->fails())
|
||||
{
|
||||
return ApiResponse::apiResponse('Bad Request', $data, $validator->errors(), 400);
|
||||
}
|
||||
else
|
||||
{
|
||||
$members = DB::table('members')
|
||||
->leftJoin('member_policies', 'member_policies.member_id','=', 'members.member_id')
|
||||
->leftJoin('persons', 'persons.id', '=', 'members.person_id')
|
||||
->where('members.member_id', '=', $request->no_polis)
|
||||
->where('members.birth_date', '=', $request->birth_date)
|
||||
->select(
|
||||
'members.id',
|
||||
'members.name',
|
||||
'members.member_id',
|
||||
'member_policies.policy_id',
|
||||
'persons.nik',
|
||||
'members.email',
|
||||
'members.birth_date',
|
||||
'members.gender',
|
||||
'members.marital_status',
|
||||
'members.language',
|
||||
'members.race',
|
||||
'members.relation_with_principal')
|
||||
->first();
|
||||
if($members)
|
||||
{
|
||||
$res_data['members'] = $members;
|
||||
|
||||
$benefits = DB::table('member_plans')
|
||||
->leftJoin('corporate_benefits','corporate_benefits.plan_id', '=', 'member_plans.plan_id')
|
||||
->leftJoin('benefits', 'benefits.id', '=', 'corporate_benefits.benefit_id')
|
||||
->leftJoin('plans', 'plans.id', '=', 'member_plans.plan_id')
|
||||
->leftJoin('services', 'services.code', '=', 'plans.service_code')
|
||||
->where('member_plans.member_id', '=', $members->id)
|
||||
->select(
|
||||
'benefits.description',
|
||||
'benefits.code',
|
||||
'corporate_benefits.corporate_id',
|
||||
'plans.service_code'
|
||||
)
|
||||
->get();
|
||||
$res_data['benefits'] = $benefits;
|
||||
|
||||
$services = DB::table('member_plans')
|
||||
->leftJoin('plans', 'plans.id', '=', 'member_plans.plan_id')
|
||||
->leftJoin('services', 'services.code', '=', 'plans.service_code')
|
||||
->where('member_plans.member_id', $members->id)
|
||||
->whereNull('member_plans.deleted_at')
|
||||
->select('plans.service_code', 'services.name')
|
||||
->get();
|
||||
$res_data['services'] = $services;
|
||||
|
||||
// Group Services
|
||||
$groupServices = [];
|
||||
foreach ($res_data['benefits'] as $benefit) {
|
||||
$serviceCode = $benefit->service_code;
|
||||
$groupServices[$serviceCode][] = [
|
||||
'description' => $benefit->description,
|
||||
'code' => $benefit->code,
|
||||
];
|
||||
}
|
||||
|
||||
$res_data['groupServices'] = $groupServices;
|
||||
|
||||
$res_data['type'] = $request->type;
|
||||
|
||||
// Provider
|
||||
$providers = DB::table('organizations')
|
||||
->where('organizations.type', '=', 'hospital')
|
||||
->where('organizations.corporate_id_partner', '!=', 8)
|
||||
->orWhere('organizations.corporate_id_partner', NULL)
|
||||
->where('status', '=', 'active')
|
||||
->orderBy('organizations.name','asc')
|
||||
->select(
|
||||
'organizations.id',
|
||||
'organizations.name'
|
||||
)
|
||||
->get();
|
||||
|
||||
$res_data['providers'] = $providers;
|
||||
|
||||
//company
|
||||
$companies = DB::table('corporates')
|
||||
->where('corporates.active', '=', 1)
|
||||
->select(
|
||||
'corporates.id',
|
||||
'corporates.name'
|
||||
)
|
||||
->get();
|
||||
|
||||
$res_data['companies'] = $companies;
|
||||
|
||||
//company
|
||||
$companies = DB::table('corporates')
|
||||
->where('corporates.active', '=', 1)
|
||||
->select(
|
||||
'corporates.id',
|
||||
'corporates.name'
|
||||
)
|
||||
->get();
|
||||
|
||||
$res_data['companies'] = $companies;
|
||||
|
||||
$corporateEmployeePremi = DB::table('corporate_employees')
|
||||
->leftJoin('corporates', 'corporates.id', '=', 'corporate_employees.corporate_id')
|
||||
->leftJoin('corporate_policies', 'corporate_policies.corporate_id', '=', 'corporates.id')
|
||||
->where('corporate_employees.status', 'ACTIVE')
|
||||
->where('corporates.active', 1)
|
||||
->where('corporate_policies.active', 1)
|
||||
->where('corporate_employees.member_id', $members->id)
|
||||
->value('corporate_policies.total_premi');
|
||||
|
||||
$res_data['total_premi'] = $corporateEmployeePremi ?? 0;
|
||||
|
||||
$limitRules = DB::table('member_plans')
|
||||
->leftJoin('plans', 'plans.id', '=', 'member_plans.plan_id')
|
||||
->where('member_plans.member_id', $members->id)
|
||||
->where('member_plans.status', 'active')
|
||||
->where('plans.active', 1)
|
||||
->value('plans.limit_rules');
|
||||
|
||||
$res_data['limit_rules'] = $limitRules ?? 0;
|
||||
|
||||
// specialities
|
||||
$specialities = DB::table('specialities')
|
||||
->select(
|
||||
'specialities.id',
|
||||
'specialities.name'
|
||||
)
|
||||
->orderBy('specialities.name','asc')
|
||||
->get();
|
||||
|
||||
$res_data['specialities'] = $specialities;
|
||||
|
||||
|
||||
return ApiResponse::apiResponse("Success", $res_data, trans('Message.success'), 200);
|
||||
}
|
||||
else
|
||||
{
|
||||
return ApiResponse::apiResponse("Data Not Found", $data, trans('Message.not_found'), 404);
|
||||
}
|
||||
|
||||
}
|
||||
}
|
||||
}
|
||||
249
Modules/Primaya/Http/Controllers/Api/RequestLogController.php
Normal file
249
Modules/Primaya/Http/Controllers/Api/RequestLogController.php
Normal file
@@ -0,0 +1,249 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Http\Controllers\Api;
|
||||
use Illuminate\Contracts\Support\Renderable;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Routing\Controller;
|
||||
use Illuminate\Support\Facades\Validator;
|
||||
use Modules\Primaya\Helpers\ApiResponse;
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use Modules\Internal\Http\Controllers\Api\RequestLogController as primeCenterRequestLog;
|
||||
use App\Helpers\Helper;
|
||||
use App\Models\File;
|
||||
use Dompdf\Dompdf;
|
||||
use Dompdf\Options;
|
||||
use Illuminate\Support\Facades\View;
|
||||
use App\Models\Member;
|
||||
use App\Models\RequestLog;
|
||||
use App\Models\Organization;
|
||||
use App\Services\ClaimRequestService;
|
||||
use App\Models\ClaimRequest;
|
||||
use App\Models\RequestLogBenefit;
|
||||
|
||||
|
||||
class RequestLogController extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
* @return Renderable
|
||||
*/
|
||||
private static $code_prefix = 'CLAIM';
|
||||
public function requestLog(Request $request)
|
||||
{
|
||||
$data = [
|
||||
'member_id' => $request->member_id,
|
||||
'service_code' => $request->service_code,
|
||||
'organization_id' => $request->organization_id,
|
||||
'organization_name' => !empty($request->organization_name) ? $request->organization_name : null,
|
||||
'address_provider' => !empty($request->address_provider) ? $request->address_provider : null,
|
||||
'submission_date' => $request->submission_date,
|
||||
'discharge_date' => $request->discharge_date,
|
||||
'corporate_id_partner' => !empty($request->corporate_id_partner) ? $request->corporate_id_partner : [],
|
||||
'specialities_id' => $request->specialities_id,
|
||||
'dppj' => $request->dppj
|
||||
];
|
||||
$validator = Validator::make($request->all(), [
|
||||
'member_id' => 'required',
|
||||
'service_code' => 'required',
|
||||
'submission_date' => 'required',
|
||||
'discharge_date' => 'required',
|
||||
'specialities_id' => 'required',
|
||||
'dppj' => 'required',
|
||||
], [
|
||||
'member_id.required' => trans('Validation.required',['attribute' => 'Member ID']),
|
||||
'service_code.required' => trans('Validation.required',['attribute' => 'Service Code']),
|
||||
'submission_date.required' => trans('Validation.required',['attribute' => 'Submission Date']),
|
||||
'discharge_date.required' => trans('Validation.required',['attribute' => 'Discharge Date']),
|
||||
'specialities_id.required' => trans('Validation.required',['attribute' => 'Specialities']),
|
||||
'dppj.required' => trans('Validation.required',['attribute' => 'DPJP']),
|
||||
]);
|
||||
if(!empty($request->organization_id))
|
||||
{
|
||||
$validator = Validator::make($request->all(), [
|
||||
'organization_id' => 'required',
|
||||
'member_id' => 'required',
|
||||
'service_code' => 'required',
|
||||
'submission_date' => 'required',
|
||||
'discharge_date' => 'required',
|
||||
'specialities_id' => 'required',
|
||||
'dppj' => 'required',
|
||||
], [
|
||||
'organization_id.required' => trans('Validation.required',['attribute' => 'Provider ID']),
|
||||
'member_id.required' => trans('Validation.required',['attribute' => 'Member ID']),
|
||||
'service_code.required' => trans('Validation.required',['attribute' => 'Service Code']),
|
||||
'submission_date.required' => trans('Validation.required',['attribute' => 'Submission Date']),
|
||||
'discharge_date.required' => trans('Validation.required',['attribute' => 'Discharge Date']),
|
||||
'specialities_id.required' => trans('Validation.required',['attribute' => 'Specialities']),
|
||||
'dppj.required' => trans('Validation.required',['attribute' => 'DPJP']),
|
||||
]);
|
||||
}
|
||||
if ($validator->fails())
|
||||
{
|
||||
return ApiResponse::apiResponse('Bad Request', $data, $validator->errors(), 400);
|
||||
}
|
||||
else
|
||||
{
|
||||
//insert data to organization
|
||||
try {
|
||||
if (!empty($request->organization_name) && !empty($request->address_provider))
|
||||
{
|
||||
// Memulai transaksi
|
||||
DB::beginTransaction();
|
||||
|
||||
// Membuat singkatan dari nama rumah sakit
|
||||
$singkatan = "";
|
||||
$words = explode(' ', $request->organization_name);
|
||||
|
||||
foreach ($words as $word) {
|
||||
$singkatan .= strtoupper(substr($word, 0, 2));
|
||||
}
|
||||
|
||||
// Membuat kode organisasi
|
||||
$kodeOrganisasi = "ORG000" . $singkatan;
|
||||
|
||||
// Insert data ke tabel organizations
|
||||
$organization_id = DB::table('organizations')
|
||||
->insertGetId([
|
||||
'name' => $request->organization_name,
|
||||
'code' => $kodeOrganisasi,
|
||||
'type' => 'hospital',
|
||||
'corporate_id_partner' => $request->corporate_id_partner ? implode(',', $request->corporate_id_partner) : null,
|
||||
'created_at' => now(),
|
||||
'created_by' => auth()->user()->id
|
||||
]);
|
||||
|
||||
// Insert data ke tabel addresses
|
||||
$address_id = DB::table('addresses')
|
||||
->insertGetId([
|
||||
'text'=> $request->address_provider,
|
||||
'addressable_type' => 'App\Models\Organization',
|
||||
'addressable_id' => $organization_id,
|
||||
'type' => 'hospital',
|
||||
'created_at' => now(),
|
||||
'created_by' => auth()->user()->id
|
||||
]);
|
||||
|
||||
// Update main_address_id di tabel organizations
|
||||
DB::table('organizations')
|
||||
->where('organizations.id', '=', $organization_id)
|
||||
->update(['main_address_id' => $address_id]);
|
||||
|
||||
// Commit transaksi
|
||||
DB::commit();
|
||||
$request->merge(['organization_id' => $organization_id]);
|
||||
}
|
||||
|
||||
try {
|
||||
|
||||
DB::beginTransaction();
|
||||
|
||||
$requestLogControllerInstance = new PrimeCenterRequestLog();
|
||||
$code = $requestLogControllerInstance->getNextCode($request);
|
||||
|
||||
$member = Member::find($request->member_id);
|
||||
|
||||
$requestLogData = [
|
||||
'code' => $code,
|
||||
'member_id' => $request->member_id,
|
||||
'submission_date' => $request->submission_date ?? now(),
|
||||
'discharge_date' => $request->discharge_date ?? now(),
|
||||
'status' => 'approved',
|
||||
'status_final_log' => 'approved',
|
||||
'final_log' => 1,
|
||||
'payment_type' => 'cashless',
|
||||
'service_code' => $request->service_code,
|
||||
'policy_id' => $member->currentPolicy->id ?? null,
|
||||
'organization_id' => $request->organization_id ?? 0,
|
||||
'source' => $request->source,
|
||||
'specialities_id' => $request->specialities_id,
|
||||
'dppj' => $request->dppj
|
||||
];
|
||||
|
||||
// SIMPAN LOG
|
||||
$requestLog = RequestLog::create($requestLogData);
|
||||
|
||||
/*
|
||||
===============================
|
||||
INSERT BENEFIT DI SINI
|
||||
===============================
|
||||
*/
|
||||
|
||||
if (!empty($request->benefits)) {
|
||||
|
||||
$benefitData = [];
|
||||
|
||||
foreach ($request->benefits as $benefit) {
|
||||
$benefitData[] = [
|
||||
'request_log_id' => $requestLog->id,
|
||||
'benefit_id' => $benefit['benefit_id'],
|
||||
'amount_incurred' => $benefit['amount_incurred'] ?? 0,
|
||||
'amount_approved' => $benefit['amount_approved'] ?? 0,
|
||||
'amount_not_approved' => $benefit['amount_not_approved'] ?? 0,
|
||||
'excess_paid' => $benefit['excess_paid'] ?? 0,
|
||||
'keterangan' => $benefit['keterangan'] ?? '',
|
||||
];
|
||||
}
|
||||
|
||||
$insertBenefit = $this->insertBenefit($benefitData);
|
||||
|
||||
if (!$insertBenefit) {
|
||||
throw new \Exception('Insert Benefit Gagal');
|
||||
}
|
||||
}
|
||||
|
||||
DB::commit();
|
||||
|
||||
return ApiResponse::apiResponse(
|
||||
'Success Create Log',
|
||||
$requestLog,
|
||||
'Berhasil create LOG dan Benefit',
|
||||
200
|
||||
);
|
||||
|
||||
} catch (\Exception $e) {
|
||||
|
||||
DB::rollBack();
|
||||
|
||||
return ApiResponse::apiResponse(
|
||||
'Server Error Create Log',
|
||||
$data,
|
||||
$e->getMessage(),
|
||||
500
|
||||
);
|
||||
}
|
||||
} catch (\Exception $e) {
|
||||
// Rollback transaksi jika terjadi kesalahan
|
||||
DB::rollBack();
|
||||
|
||||
// Handle error, bisa di-log atau dikembalikan sebagai response
|
||||
return ApiResponse::apiResponse('Server Error 3', $data, $e->getMessage(), 500);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
public function insertBenefit($benefitData)
|
||||
{
|
||||
if (count($benefitData) > 0) {
|
||||
|
||||
foreach ($benefitData as $value) {
|
||||
|
||||
$data = [
|
||||
'request_log_id' => $value['request_log_id'],
|
||||
'benefit_id' => $value['benefit_id'],
|
||||
'amount_incurred' => $value['amount_incurred'],
|
||||
'amount_approved' => $value['amount_approved'],
|
||||
'amount_not_approved' => $value['amount_not_approved'],
|
||||
'excess_paid' => $value['excess_paid'],
|
||||
'keterangan' => $value['keterangan'] ?? '',
|
||||
'created_by' => auth()->user()->id,
|
||||
];
|
||||
|
||||
RequestLogBenefit::create($data);
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
|
||||
return true;
|
||||
}
|
||||
}
|
||||
79
Modules/Primaya/Http/Controllers/PrimayaController.php
Normal file
79
Modules/Primaya/Http/Controllers/PrimayaController.php
Normal file
@@ -0,0 +1,79 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Http\Controllers;
|
||||
|
||||
use Illuminate\Contracts\Support\Renderable;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Routing\Controller;
|
||||
|
||||
class PrimayaController extends Controller
|
||||
{
|
||||
/**
|
||||
* Display a listing of the resource.
|
||||
* @return Renderable
|
||||
*/
|
||||
public function index()
|
||||
{
|
||||
return view('primaya::index');
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for creating a new resource.
|
||||
* @return Renderable
|
||||
*/
|
||||
public function create()
|
||||
{
|
||||
return view('primaya::create');
|
||||
}
|
||||
|
||||
/**
|
||||
* Store a newly created resource in storage.
|
||||
* @param Request $request
|
||||
* @return Renderable
|
||||
*/
|
||||
public function store(Request $request)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the specified resource.
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function show($id)
|
||||
{
|
||||
return view('primaya::show');
|
||||
}
|
||||
|
||||
/**
|
||||
* Show the form for editing the specified resource.
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function edit($id)
|
||||
{
|
||||
return view('primaya::edit');
|
||||
}
|
||||
|
||||
/**
|
||||
* Update the specified resource in storage.
|
||||
* @param Request $request
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function update(Request $request, $id)
|
||||
{
|
||||
//
|
||||
}
|
||||
|
||||
/**
|
||||
* Remove the specified resource from storage.
|
||||
* @param int $id
|
||||
* @return Renderable
|
||||
*/
|
||||
public function destroy($id)
|
||||
{
|
||||
//
|
||||
}
|
||||
}
|
||||
0
Modules/Primaya/Http/Middleware/.gitkeep
Normal file
0
Modules/Primaya/Http/Middleware/.gitkeep
Normal file
65
Modules/Primaya/Http/Middleware/Authentication.php
Normal file
65
Modules/Primaya/Http/Middleware/Authentication.php
Normal file
@@ -0,0 +1,65 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Http\Middleware;
|
||||
use Modules\Primaya\Helpers\ApiResponse;
|
||||
|
||||
use Closure;
|
||||
use Illuminate\Http\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
use Illuminate\Support\Facades\App;
|
||||
|
||||
class Authentication
|
||||
{
|
||||
/**
|
||||
* Handle an incoming request.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next
|
||||
* @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse
|
||||
*/
|
||||
public function handle(Request $request, Closure $next)
|
||||
{
|
||||
$acceptHeader = $request->header('Accept');
|
||||
$contentType = $request->header('Content-Type');
|
||||
$locale = $request->header('Accept-Language');
|
||||
|
||||
// Add language
|
||||
if(!$locale)
|
||||
{
|
||||
return ApiResponse::apiResponse('Unauthorized', null, trans('validation.required', ['attribute' => 'Accept-Language']), 401);
|
||||
}
|
||||
if($locale !== 'en-US' && $locale !== 'id-ID')
|
||||
{
|
||||
return ApiResponse::apiResponse('Bad Request', null, trans('validation.invalid', ['attribute' => 'Accept-Language']), 400);
|
||||
}
|
||||
if ($locale === 'en-US')
|
||||
{
|
||||
App::setLocale('en');
|
||||
} elseif ($locale === 'id-ID')
|
||||
{
|
||||
App::setLocale('id');
|
||||
} else
|
||||
{
|
||||
App::setLocale('en');
|
||||
}
|
||||
|
||||
// Validate type accept & content type
|
||||
if (!$acceptHeader)
|
||||
{
|
||||
return ApiResponse::apiResponse('Unauthorized', null, trans('validation.required', ['attribute' => 'Accept']), 401);
|
||||
}
|
||||
if (!$contentType)
|
||||
{
|
||||
return ApiResponse::apiResponse('Unauthorized', null, trans('validation.required', ['attribute' => 'Content-Type']), 401);
|
||||
}
|
||||
if ($acceptHeader !== 'application/json')
|
||||
{
|
||||
return ApiResponse::apiResponse('Bad Request', null, trans('validation.invalid', ['attribute' => 'Accept']), 400);
|
||||
}
|
||||
if($contentType !== 'application/json')
|
||||
{
|
||||
return ApiResponse::apiResponse('Bad Request', null, trans('validation.invalid', ['attribute' => 'Content-Type']), 400);
|
||||
}
|
||||
return $next($request);
|
||||
}
|
||||
}
|
||||
61
Modules/Primaya/Http/Middleware/Authorization.php
Normal file
61
Modules/Primaya/Http/Middleware/Authorization.php
Normal file
@@ -0,0 +1,61 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Http\Middleware;
|
||||
use Modules\Primaya\Helpers\ApiResponse;
|
||||
|
||||
use Closure;
|
||||
use Illuminate\Http\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
use Illuminate\Support\Facades\App;
|
||||
|
||||
class Authorization
|
||||
{
|
||||
/**
|
||||
* Handle an incoming request.
|
||||
*
|
||||
* @param \Illuminate\Http\Request $request
|
||||
* @param \Closure(\Illuminate\Http\Request): (\Illuminate\Http\Response|\Illuminate\Http\RedirectResponse) $next
|
||||
* @return \Illuminate\Http\Response|\Illuminate\Http\RedirectResponse
|
||||
*/
|
||||
public function handle(Request $request, Closure $next)
|
||||
{
|
||||
$acceptHeader = $request->header('Accept');
|
||||
$contentType = $request->header('Content-Type');
|
||||
$locale = $request->header('Accept-Language');
|
||||
|
||||
if (!$locale) {
|
||||
return ApiResponse::apiResponse(
|
||||
'Unauthorized',
|
||||
null,
|
||||
trans('Validation.required', ['attribute' => 'Accept-Language']),
|
||||
401
|
||||
);
|
||||
}
|
||||
|
||||
if ($locale === 'en-US') {
|
||||
App::setLocale('en');
|
||||
} elseif ($locale === 'id-ID') {
|
||||
App::setLocale('id');
|
||||
}
|
||||
|
||||
if ($acceptHeader !== 'application/json') {
|
||||
return ApiResponse::apiResponse(
|
||||
'Bad Request',
|
||||
null,
|
||||
trans('Validation.invalid', ['attribute' => 'Accept']),
|
||||
400
|
||||
);
|
||||
}
|
||||
|
||||
if ($request->isMethod('post') && $contentType !== 'application/json') {
|
||||
return ApiResponse::apiResponse(
|
||||
'Bad Request',
|
||||
null,
|
||||
trans('Validation.invalid', ['attribute' => 'Content-Type']),
|
||||
400
|
||||
);
|
||||
}
|
||||
|
||||
return $next($request);
|
||||
}
|
||||
}
|
||||
36
Modules/Primaya/Http/Middleware/CheckCorporateKey.php
Normal file
36
Modules/Primaya/Http/Middleware/CheckCorporateKey.php
Normal file
@@ -0,0 +1,36 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Http\Middleware;
|
||||
|
||||
use App\Models\Corporate;
|
||||
use Closure;
|
||||
use Illuminate\Http\Request;
|
||||
use Symfony\Component\HttpFoundation\Response;
|
||||
|
||||
class CheckCorporateKey
|
||||
{
|
||||
public function handle(Request $request, Closure $next): Response
|
||||
{
|
||||
$apiKey = $request->header('X-API-KEY');
|
||||
$apiSecret = $request->header('X-API-SECRET');
|
||||
|
||||
// 🔥 WAJIB: Cegah null atau kosong
|
||||
if (empty($apiKey) || empty($apiSecret)) {
|
||||
return response()->json([
|
||||
'message' => 'API Key dan Secret wajib diisi'
|
||||
], 401);
|
||||
}
|
||||
|
||||
$corporate = Corporate::where('api_key', $apiKey)
|
||||
->where('api_secret', $apiSecret)
|
||||
->first();
|
||||
|
||||
if (!$corporate) {
|
||||
return response()->json([
|
||||
'message' => 'Invalid API Key'
|
||||
], 401);
|
||||
}
|
||||
|
||||
return $next($request);
|
||||
}
|
||||
}
|
||||
0
Modules/Primaya/Http/Requests/.gitkeep
Normal file
0
Modules/Primaya/Http/Requests/.gitkeep
Normal file
0
Modules/Primaya/Providers/.gitkeep
Normal file
0
Modules/Primaya/Providers/.gitkeep
Normal file
114
Modules/Primaya/Providers/PrimayaServiceProvider.php
Normal file
114
Modules/Primaya/Providers/PrimayaServiceProvider.php
Normal file
@@ -0,0 +1,114 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Providers;
|
||||
|
||||
use Illuminate\Support\ServiceProvider;
|
||||
use Illuminate\Database\Eloquent\Factory;
|
||||
|
||||
class PrimayaServiceProvider extends ServiceProvider
|
||||
{
|
||||
/**
|
||||
* @var string $moduleName
|
||||
*/
|
||||
protected $moduleName = 'Primaya';
|
||||
|
||||
/**
|
||||
* @var string $moduleNameLower
|
||||
*/
|
||||
protected $moduleNameLower = 'primaya';
|
||||
|
||||
/**
|
||||
* Boot the application events.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function boot()
|
||||
{
|
||||
$this->registerTranslations();
|
||||
$this->registerConfig();
|
||||
$this->registerViews();
|
||||
$this->loadMigrationsFrom(module_path($this->moduleName, 'Database/Migrations'));
|
||||
}
|
||||
|
||||
/**
|
||||
* Register the service provider.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function register()
|
||||
{
|
||||
$this->app->register(RouteServiceProvider::class);
|
||||
}
|
||||
|
||||
/**
|
||||
* Register config.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
protected function registerConfig()
|
||||
{
|
||||
$this->publishes([
|
||||
module_path($this->moduleName, 'Config/config.php') => config_path($this->moduleNameLower . '.php'),
|
||||
], 'config');
|
||||
$this->mergeConfigFrom(
|
||||
module_path($this->moduleName, 'Config/config.php'), $this->moduleNameLower
|
||||
);
|
||||
}
|
||||
|
||||
/**
|
||||
* Register views.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function registerViews()
|
||||
{
|
||||
$viewPath = resource_path('views/modules/' . $this->moduleNameLower);
|
||||
|
||||
$sourcePath = module_path($this->moduleName, 'Resources/views');
|
||||
|
||||
$this->publishes([
|
||||
$sourcePath => $viewPath
|
||||
], ['views', $this->moduleNameLower . '-module-views']);
|
||||
|
||||
$this->loadViewsFrom(array_merge($this->getPublishableViewPaths(), [$sourcePath]), $this->moduleNameLower);
|
||||
}
|
||||
|
||||
/**
|
||||
* Register translations.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function registerTranslations()
|
||||
{
|
||||
$langPath = resource_path('lang/modules/' . $this->moduleNameLower);
|
||||
|
||||
if (is_dir($langPath)) {
|
||||
$this->loadTranslationsFrom($langPath, $this->moduleNameLower);
|
||||
$this->loadJsonTranslationsFrom($langPath, $this->moduleNameLower);
|
||||
} else {
|
||||
$this->loadTranslationsFrom(module_path($this->moduleName, 'Resources/lang'), $this->moduleNameLower);
|
||||
$this->loadJsonTranslationsFrom(module_path($this->moduleName, 'Resources/lang'), $this->moduleNameLower);
|
||||
}
|
||||
}
|
||||
|
||||
/**
|
||||
* Get the services provided by the provider.
|
||||
*
|
||||
* @return array
|
||||
*/
|
||||
public function provides()
|
||||
{
|
||||
return [];
|
||||
}
|
||||
|
||||
private function getPublishableViewPaths(): array
|
||||
{
|
||||
$paths = [];
|
||||
foreach (\Config::get('view.paths') as $path) {
|
||||
if (is_dir($path . '/modules/' . $this->moduleNameLower)) {
|
||||
$paths[] = $path . '/modules/' . $this->moduleNameLower;
|
||||
}
|
||||
}
|
||||
return $paths;
|
||||
}
|
||||
}
|
||||
69
Modules/Primaya/Providers/RouteServiceProvider.php
Normal file
69
Modules/Primaya/Providers/RouteServiceProvider.php
Normal file
@@ -0,0 +1,69 @@
|
||||
<?php
|
||||
|
||||
namespace Modules\Primaya\Providers;
|
||||
|
||||
use Illuminate\Support\Facades\Route;
|
||||
use Illuminate\Foundation\Support\Providers\RouteServiceProvider as ServiceProvider;
|
||||
|
||||
class RouteServiceProvider extends ServiceProvider
|
||||
{
|
||||
/**
|
||||
* The module namespace to assume when generating URLs to actions.
|
||||
*
|
||||
* @var string
|
||||
*/
|
||||
protected $moduleNamespace = 'Modules\Primaya\Http\Controllers';
|
||||
|
||||
/**
|
||||
* Called before routes are registered.
|
||||
*
|
||||
* Register any model bindings or pattern based filters.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function boot()
|
||||
{
|
||||
parent::boot();
|
||||
}
|
||||
|
||||
/**
|
||||
* Define the routes for the application.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
public function map()
|
||||
{
|
||||
$this->mapApiRoutes();
|
||||
|
||||
$this->mapWebRoutes();
|
||||
}
|
||||
|
||||
/**
|
||||
* Define the "web" routes for the application.
|
||||
*
|
||||
* These routes all receive session state, CSRF protection, etc.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
protected function mapWebRoutes()
|
||||
{
|
||||
Route::middleware('web')
|
||||
->namespace($this->moduleNamespace)
|
||||
->group(module_path('Primaya', '/Routes/web.php'));
|
||||
}
|
||||
|
||||
/**
|
||||
* Define the "api" routes for the application.
|
||||
*
|
||||
* These routes are typically stateless.
|
||||
*
|
||||
* @return void
|
||||
*/
|
||||
protected function mapApiRoutes()
|
||||
{
|
||||
Route::prefix('api')
|
||||
->middleware('api')
|
||||
->namespace($this->moduleNamespace)
|
||||
->group(module_path('Primaya', '/Routes/api.php'));
|
||||
}
|
||||
}
|
||||
0
Modules/Primaya/Resources/assets/.gitkeep
Normal file
0
Modules/Primaya/Resources/assets/.gitkeep
Normal file
0
Modules/Primaya/Resources/assets/js/app.js
Normal file
0
Modules/Primaya/Resources/assets/js/app.js
Normal file
0
Modules/Primaya/Resources/assets/sass/app.scss
Normal file
0
Modules/Primaya/Resources/assets/sass/app.scss
Normal file
0
Modules/Primaya/Resources/lang/.gitkeep
Normal file
0
Modules/Primaya/Resources/lang/.gitkeep
Normal file
0
Modules/Primaya/Resources/views/.gitkeep
Normal file
0
Modules/Primaya/Resources/views/.gitkeep
Normal file
9
Modules/Primaya/Resources/views/index.blade.php
Normal file
9
Modules/Primaya/Resources/views/index.blade.php
Normal file
@@ -0,0 +1,9 @@
|
||||
@extends('primaya::layouts.master')
|
||||
|
||||
@section('content')
|
||||
<h1>Hello World</h1>
|
||||
|
||||
<p>
|
||||
This view is loaded from module: {!! config('primaya.name') !!}
|
||||
</p>
|
||||
@endsection
|
||||
19
Modules/Primaya/Resources/views/layouts/master.blade.php
Normal file
19
Modules/Primaya/Resources/views/layouts/master.blade.php
Normal file
@@ -0,0 +1,19 @@
|
||||
<!DOCTYPE html>
|
||||
<html lang="en">
|
||||
<head>
|
||||
<meta charset="utf-8">
|
||||
<meta http-equiv="X-UA-Compatible" content="IE=edge">
|
||||
<meta name="viewport" content="width=device-width, initial-scale=1">
|
||||
<title>Module Primaya</title>
|
||||
|
||||
{{-- Laravel Vite - CSS File --}}
|
||||
{{-- {{ module_vite('build-primaya', 'Resources/assets/sass/app.scss') }} --}}
|
||||
|
||||
</head>
|
||||
<body>
|
||||
@yield('content')
|
||||
|
||||
{{-- Laravel Vite - JS File --}}
|
||||
{{-- {{ module_vite('build-primaya', 'Resources/assets/js/app.js') }} --}}
|
||||
</body>
|
||||
</html>
|
||||
0
Modules/Primaya/Routes/.gitkeep
Normal file
0
Modules/Primaya/Routes/.gitkeep
Normal file
54
Modules/Primaya/Routes/api.php
Normal file
54
Modules/Primaya/Routes/api.php
Normal file
@@ -0,0 +1,54 @@
|
||||
<?php
|
||||
|
||||
use Illuminate\Http\Request;
|
||||
use Modules\Primaya\Http\Controllers\Api\AuthController;
|
||||
use Modules\Primaya\Http\Controllers\Api\MasterController;
|
||||
use Modules\Primaya\Http\Controllers\Api\MemberController;
|
||||
use Modules\Primaya\Http\Controllers\Api\RequestLogController;
|
||||
use Modules\Primaya\Http\Middleware\Authentication;
|
||||
use Modules\Primaya\Http\Middleware\Authorization;
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| API Routes
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Here is where you can register API routes for your application. These
|
||||
| routes are loaded by the RouteServiceProvider within a group which
|
||||
| is assigned the "api" middleware group. Enjoy building your API!
|
||||
|
|
||||
*/
|
||||
Route::prefix('v1')->group(function () {
|
||||
|
||||
Route::prefix('primaya')->group(function () {
|
||||
|
||||
// LOGIN (pakai corporate key)
|
||||
Route::middleware(['corporate.key'])->group(function () {
|
||||
Route::post('login', [AuthController::class, 'loginJwt']);
|
||||
});
|
||||
|
||||
// JWT Protected
|
||||
Route::middleware(['auth:corporate-api'])->group(function () {
|
||||
|
||||
Route::middleware(Authorization::class)->group(function () {
|
||||
Route::post('search-member', [MemberController::class, 'search']);
|
||||
});
|
||||
|
||||
// Request LOG
|
||||
Route::controller(RequestLogController::class)->group(function () {
|
||||
Route::post('request-log', 'requestLog');
|
||||
});
|
||||
|
||||
Route::prefix('master')->group(function () {
|
||||
|
||||
Route::get('specialities', [MasterController::class, 'specialities']);
|
||||
Route::get('benefits', [MasterController::class, 'benefits']);
|
||||
Route::get('organizations', [MasterController::class, 'organizations']);
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
|
||||
});
|
||||
16
Modules/Primaya/Routes/web.php
Normal file
16
Modules/Primaya/Routes/web.php
Normal file
@@ -0,0 +1,16 @@
|
||||
<?php
|
||||
|
||||
/*
|
||||
|--------------------------------------------------------------------------
|
||||
| Web Routes
|
||||
|--------------------------------------------------------------------------
|
||||
|
|
||||
| Here is where you can register web routes for your application. These
|
||||
| routes are loaded by the RouteServiceProvider within a group which
|
||||
| contains the "web" middleware group. Now create something great!
|
||||
|
|
||||
*/
|
||||
|
||||
Route::prefix('primaya')->group(function() {
|
||||
Route::get('/', 'PrimayaController@index');
|
||||
});
|
||||
0
Modules/Primaya/Tests/Feature/.gitkeep
Normal file
0
Modules/Primaya/Tests/Feature/.gitkeep
Normal file
0
Modules/Primaya/Tests/Unit/.gitkeep
Normal file
0
Modules/Primaya/Tests/Unit/.gitkeep
Normal file
23
Modules/Primaya/composer.json
Normal file
23
Modules/Primaya/composer.json
Normal file
@@ -0,0 +1,23 @@
|
||||
{
|
||||
"name": "nwidart/primaya",
|
||||
"description": "",
|
||||
"authors": [
|
||||
{
|
||||
"name": "Nicolas Widart",
|
||||
"email": "n.widart@gmail.com"
|
||||
}
|
||||
],
|
||||
"extra": {
|
||||
"laravel": {
|
||||
"providers": [],
|
||||
"aliases": {
|
||||
|
||||
}
|
||||
}
|
||||
},
|
||||
"autoload": {
|
||||
"psr-4": {
|
||||
"Modules\\Primaya\\": ""
|
||||
}
|
||||
}
|
||||
}
|
||||
11
Modules/Primaya/module.json
Normal file
11
Modules/Primaya/module.json
Normal file
@@ -0,0 +1,11 @@
|
||||
{
|
||||
"name": "Primaya",
|
||||
"alias": "primaya",
|
||||
"description": "",
|
||||
"keywords": [],
|
||||
"priority": 0,
|
||||
"providers": [
|
||||
"Modules\\Primaya\\Providers\\PrimayaServiceProvider"
|
||||
],
|
||||
"files": []
|
||||
}
|
||||
16
Modules/Primaya/package.json
Normal file
16
Modules/Primaya/package.json
Normal file
@@ -0,0 +1,16 @@
|
||||
{
|
||||
"private": true,
|
||||
"scripts": {
|
||||
"dev": "vite",
|
||||
"build": "vite build"
|
||||
},
|
||||
"devDependencies": {
|
||||
"axios": "^0.21.4",
|
||||
"dotenv": "^10.0.0",
|
||||
"dotenv-expand": "^5.1.0",
|
||||
"laravel-vite-plugin": "^0.6.0",
|
||||
"lodash": "^4.17.21",
|
||||
"postcss": "^8.3.7",
|
||||
"vite": "^3.0.9"
|
||||
}
|
||||
}
|
||||
0
_ide_helper.php
Executable file → Normal file
0
_ide_helper.php
Executable file → Normal file
0
app/Builders/MemberBuilder.php
Executable file → Normal file
0
app/Builders/MemberBuilder.php
Executable file → Normal file
0
app/Console/Kernel.php
Executable file → Normal file
0
app/Console/Kernel.php
Executable file → Normal file
0
app/Events/ChatMessageSent.php
Executable file → Normal file
0
app/Events/ChatMessageSent.php
Executable file → Normal file
0
app/Events/ClaimApproved.php
Executable file → Normal file
0
app/Events/ClaimApproved.php
Executable file → Normal file
0
app/Events/ClaimDeclined.php
Executable file → Normal file
0
app/Events/ClaimDeclined.php
Executable file → Normal file
0
app/Events/ClaimPaid.php
Executable file → Normal file
0
app/Events/ClaimPaid.php
Executable file → Normal file
0
app/Events/ClaimPostpone.php
Executable file → Normal file
0
app/Events/ClaimPostpone.php
Executable file → Normal file
0
app/Events/ClaimReceived.php
Executable file → Normal file
0
app/Events/ClaimReceived.php
Executable file → Normal file
0
app/Events/ClaimRequested.php
Executable file → Normal file
0
app/Events/ClaimRequested.php
Executable file → Normal file
0
app/Exceptions/Handler.php
Executable file → Normal file
0
app/Exceptions/Handler.php
Executable file → Normal file
0
app/Exceptions/ImportRowException.php
Executable file → Normal file
0
app/Exceptions/ImportRowException.php
Executable file → Normal file
23
app/Exports/ReportExport.php
Normal file
23
app/Exports/ReportExport.php
Normal file
@@ -0,0 +1,23 @@
|
||||
<?php
|
||||
|
||||
namespace App\Exports;
|
||||
|
||||
use App\Exports\Sheets\Invoices\VOPSheet;
|
||||
use Maatwebsite\Excel\Concerns\WithMultipleSheets;
|
||||
use App\Exports\Sheets\UsersSheet;
|
||||
use App\Exports\Sheets\OrdersSheet;
|
||||
|
||||
class ReportExport implements WithMultipleSheets
|
||||
{
|
||||
protected array $filters;
|
||||
public function __construct(array $filters = [])
|
||||
{
|
||||
$this->filters = $filters;
|
||||
}
|
||||
public function sheets(): array
|
||||
{
|
||||
return [
|
||||
new VOPSheet($this->filters),
|
||||
];
|
||||
}
|
||||
}
|
||||
349
app/Exports/Sheets/Invoices/VOPSheet.php
Normal file
349
app/Exports/Sheets/Invoices/VOPSheet.php
Normal file
@@ -0,0 +1,349 @@
|
||||
<?php
|
||||
|
||||
namespace App\Exports\Sheets\Invoices;
|
||||
|
||||
use Illuminate\Support\Facades\DB;
|
||||
use PhpOffice\PhpSpreadsheet\Cell\{
|
||||
Cell,
|
||||
DataType,
|
||||
StringValueBinder
|
||||
};
|
||||
use PhpOffice\PhpSpreadsheet\Worksheet\Worksheet;
|
||||
use Maatwebsite\Excel\Concerns\{
|
||||
FromCollection,
|
||||
WithHeadings,
|
||||
WithMapping,
|
||||
WithTitle,
|
||||
WithCustomValueBinder,
|
||||
WithEvents
|
||||
};
|
||||
use Maatwebsite\Excel\Events\AfterSheet;
|
||||
|
||||
class VOPSheet extends StringValueBinder implements
|
||||
FromCollection,
|
||||
WithHeadings,
|
||||
WithMapping,
|
||||
WithTitle,
|
||||
WithCustomValueBinder,
|
||||
WithEvents
|
||||
{
|
||||
protected array $filters;
|
||||
protected int $no = 0;
|
||||
protected float $grandTotal = 0;
|
||||
|
||||
protected array $benefits = [];
|
||||
|
||||
protected $benefitAmounts;
|
||||
|
||||
protected bool $benefitInitialized = false;
|
||||
|
||||
|
||||
public function __construct(array $filters = [])
|
||||
{
|
||||
$this->filters = $filters;
|
||||
}
|
||||
|
||||
public function collection()
|
||||
{
|
||||
$query = DB::table('invoice_payments')
|
||||
->leftJoin('invoice_payment_details', 'invoice_payment_details.invoice_payment_id', '=', 'invoice_payments.id')
|
||||
->leftJoin('claim_requests', 'claim_requests.id', '=', 'invoice_payment_details.claim_request_id')
|
||||
->leftJoin('request_logs', 'request_logs.id', '=', 'claim_requests.request_log_id')
|
||||
->leftJoin('organizations', 'organizations.id', '=', 'request_logs.organization_id')
|
||||
->leftJoin('members', 'members.id', '=', 'request_logs.member_id')
|
||||
->leftJoin('specialities', 'specialities.id', '=', 'request_logs.specialities_id')
|
||||
->leftJoin('icd', DB::raw("icd.code"), '=', DB::raw("SUBSTRING_INDEX(request_logs.diagnosis, ',', 1)"))
|
||||
->orderBy('request_logs.service_code', 'desc')
|
||||
->select(
|
||||
'invoice_payments.*',
|
||||
'organizations.name as organization_name',
|
||||
'members.name as member_name',
|
||||
'request_logs.diagnosis as code_diagnosis',
|
||||
'request_logs.service_code',
|
||||
'request_logs.dppj',
|
||||
'specialities.name as specialities_name',
|
||||
'request_logs.submission_date as in',
|
||||
'request_logs.discharge_date as out',
|
||||
'request_logs.code as code_log',
|
||||
'members.payor_id',
|
||||
'request_logs.nominal as amount',
|
||||
'claim_requests.request_log_id',
|
||||
'members.member_id as batch_number',
|
||||
'request_logs.keterangan',
|
||||
'icd.name as diagnosis',
|
||||
'request_logs.type_of_member'
|
||||
);
|
||||
|
||||
|
||||
if (!empty($this->filters['search'])) {
|
||||
$query->where('invoice_number', 'like', '%' . $this->filters['search'] . '%');
|
||||
}
|
||||
|
||||
if (!empty($this->filters['start_date'])) {
|
||||
$query->whereDate('invoice_payments.created_at', '>=', $this->filters['start_date']);
|
||||
}
|
||||
|
||||
if (!empty($this->filters['end_date'])) {
|
||||
$query->whereDate('invoice_payments.created_at', '<=', $this->filters['end_date']);
|
||||
}
|
||||
|
||||
if (!empty($this->filters['orderBy'])) {
|
||||
$query->orderBy(
|
||||
$this->filters['orderBy'],
|
||||
$this->filters['order'] ?? 'asc'
|
||||
);
|
||||
}
|
||||
|
||||
$items = $query->get();
|
||||
|
||||
// ambil request_log_id
|
||||
$requestLogIds = $items
|
||||
->pluck('request_log_id')
|
||||
->filter()
|
||||
->unique()
|
||||
->values();
|
||||
|
||||
// set benefit header (hanya yg dipakai)
|
||||
$this->benefits = DB::table('request_log_benefits')
|
||||
->join('benefits', 'benefits.id', '=', 'request_log_benefits.benefit_id')
|
||||
->whereIn('request_log_benefits.request_log_id', $requestLogIds)
|
||||
->select('benefits.id', 'benefits.description')
|
||||
->distinct()
|
||||
->orderBy('benefits.id')
|
||||
->pluck('benefits.description', 'benefits.id')
|
||||
->toArray();
|
||||
|
||||
// 🔥 preload benefit amount SEKALI (anti N+1)
|
||||
$this->benefitAmounts = DB::table('request_log_benefits')
|
||||
->whereIn('request_log_id', $requestLogIds)
|
||||
->get()
|
||||
->groupBy('request_log_id');
|
||||
|
||||
return $items;
|
||||
}
|
||||
|
||||
public function map($item): array
|
||||
{
|
||||
$this->no++;
|
||||
$this->grandTotal += (float) $item->amount_paid;
|
||||
$benefitData = $this->getBenefitAmountsWithTotal($item->request_log_id);
|
||||
|
||||
return array_merge([
|
||||
// $this->no,
|
||||
(string) $item->invoice_number,
|
||||
// (string) $item->payment_number,
|
||||
'',
|
||||
'',
|
||||
'',
|
||||
(string) $item->no_reference,
|
||||
'',
|
||||
'',
|
||||
(string) ($item->code_log ?? '-'),
|
||||
(string) ($item->payor_id ?? '-'),
|
||||
'',
|
||||
'',
|
||||
(string) ($item->organization_name ?? '-'),
|
||||
(string) ($item->member_name ?? '-'),
|
||||
(string) ($item->batch_number ?? '-'),
|
||||
(string) $benefitData['total'],
|
||||
'',
|
||||
'',
|
||||
],
|
||||
$benefitData['amounts'],
|
||||
[
|
||||
(string) ($item->in ?? '-'),
|
||||
(string) ($item->out ?? '-'),
|
||||
'',
|
||||
(string) ($item->diagnosis ?? '-'),
|
||||
(string) ($item->type_of_member ?? '-'), // omt
|
||||
(string) ($item->service_code == 'OP' ? 'RJ' : 'RI'),
|
||||
'',
|
||||
'',
|
||||
'',
|
||||
(string) ($item->dppj ?? '-'),
|
||||
(string) ($item->in ?? '-'),
|
||||
(string) ($item->out ?? '-'),
|
||||
(string) ($item->specialities_name ?? '-'),
|
||||
'Karyawan',
|
||||
'',
|
||||
'',
|
||||
'',
|
||||
(string) ($item->keterangan ?? '-'),
|
||||
// (string) $item->invoice_date,
|
||||
// (string) $item->start_date,
|
||||
// (string) $item->end_date,
|
||||
// (float) $item->amount_paid,
|
||||
// (string) $item->created_at,
|
||||
// (string) $item->updated_at,
|
||||
]);
|
||||
}
|
||||
|
||||
public function headings(): array
|
||||
{
|
||||
$this->initBenefits();
|
||||
return array_merge([
|
||||
// 'No',
|
||||
'No Invoice', //ok
|
||||
// 'Pembayaran Ke',
|
||||
'MONTH', //ok
|
||||
'PERIODE SES', //ok
|
||||
'SUBMIT INV/SES', //ok
|
||||
'REFERENCE', //ok
|
||||
'RECEIVED', //ok
|
||||
'INV. DATE', //ok
|
||||
'CODE', //ok
|
||||
'VENDOR', //ok
|
||||
'PO', //ok
|
||||
'SES', //ok
|
||||
'MAIN DESCRIPTION', //ok
|
||||
'DESCRIPTION', //ok
|
||||
'BN', //ok
|
||||
'AMOUNT', //ok
|
||||
'WBS', // ok
|
||||
'NOTE', // ok
|
||||
],
|
||||
array_values($this->benefits),
|
||||
[ 'DEPARTURE', // ok
|
||||
'ARRIVED', // ok
|
||||
'TEMPORARY DIAGNOSA', // ok
|
||||
'FINAL DIAGNOSA',
|
||||
'NOTE (OMT / NON OMT)',
|
||||
'RI/RJ', // OK
|
||||
'Dept', // OK
|
||||
'Cost Center', // OK
|
||||
'No.TA', // OK
|
||||
'DPJP', // OK
|
||||
'IN', // OK
|
||||
'OUT', // OK
|
||||
'SPECIALIST', // OK
|
||||
'Employee', // OK
|
||||
'Total Invoice sebelum BPJS', // OK
|
||||
'BPJS', // OK
|
||||
'Ditanggung Perusahaan', // OK
|
||||
'KETERANGAN', // OK
|
||||
// 'Tanggal Invoice',
|
||||
// 'Start Date',
|
||||
// 'End Date',
|
||||
// 'Nominal Pembayaran',
|
||||
// 'Created At',
|
||||
// 'Updated At',
|
||||
]);
|
||||
}
|
||||
|
||||
public function title(): string
|
||||
{
|
||||
return 'VOP & VIP';
|
||||
}
|
||||
|
||||
/**
|
||||
* FOOTER: Grand Total
|
||||
*/
|
||||
public function registerEvents(): array
|
||||
{
|
||||
return [
|
||||
AfterSheet::class => function (AfterSheet $event) {
|
||||
// $event->sheet->getStyle('A1:AO1')
|
||||
// ->getFont()
|
||||
// ->setBold(true);
|
||||
|
||||
$highestColumn = $event->sheet->getDelegate()->getHighestColumn();
|
||||
|
||||
$event->sheet->getStyle('A1:' . $highestColumn . '1')
|
||||
->getFont()
|
||||
->setBold(true);
|
||||
|
||||
|
||||
// $row = $event->sheet->getHighestRow() + 1;
|
||||
|
||||
// $event->sheet->setCellValue("A{$row}", 'Grand Total');
|
||||
// $event->sheet->setCellValue("G{$row}", $this->grandTotal);
|
||||
|
||||
// // Bold footer
|
||||
// $event->sheet->getStyle("A{$row}:G{$row}")
|
||||
// ->getFont()
|
||||
// ->setBold(true);
|
||||
},
|
||||
];
|
||||
}
|
||||
|
||||
/**
|
||||
* FORCE: object → string
|
||||
*/
|
||||
public function bindValue(Cell $cell, $value)
|
||||
{
|
||||
if (is_object($value) || is_array($value)) {
|
||||
$value = json_encode($value);
|
||||
}
|
||||
|
||||
$cell->setValueExplicit($value, DataType::TYPE_STRING);
|
||||
return true;
|
||||
}
|
||||
|
||||
protected function getBenefitAmountsWithTotal(?int $requestLogId): array
|
||||
{
|
||||
if (!$requestLogId || !isset($this->benefitAmounts[$requestLogId])) {
|
||||
return [
|
||||
'amounts' => array_fill(0, count($this->benefits), 0),
|
||||
'total' => 0,
|
||||
];
|
||||
}
|
||||
|
||||
$rows = $this->benefitAmounts[$requestLogId]
|
||||
->pluck('amount_approved', 'benefit_id')
|
||||
->toArray();
|
||||
|
||||
$amounts = [];
|
||||
$total = 0;
|
||||
|
||||
foreach ($this->benefits as $benefitId => $desc) {
|
||||
$amount = (float) ($rows[$benefitId] ?? 0);
|
||||
$amounts[] = $amount;
|
||||
$total += $amount;
|
||||
}
|
||||
|
||||
// 🔥 kalau ini memang mau jadi grand total global
|
||||
$this->grandTotal += $total;
|
||||
|
||||
return [
|
||||
'amounts' => $amounts,
|
||||
'total' => $total,
|
||||
];
|
||||
}
|
||||
|
||||
|
||||
protected function initBenefits(): void
|
||||
{
|
||||
if ($this->benefitInitialized) {
|
||||
return;
|
||||
}
|
||||
|
||||
// ambil request_log_id dulu
|
||||
$requestLogIds = DB::table('invoice_payments')
|
||||
->leftJoin('invoice_payment_details', 'invoice_payment_details.invoice_payment_id', '=', 'invoice_payments.id')
|
||||
->leftJoin('claim_requests', 'claim_requests.id', '=', 'invoice_payment_details.claim_request_id')
|
||||
->whereNotNull('claim_requests.request_log_id')
|
||||
->pluck('claim_requests.request_log_id')
|
||||
->unique()
|
||||
->values();
|
||||
|
||||
if ($requestLogIds->isEmpty()) {
|
||||
$this->benefits = [];
|
||||
return;
|
||||
}
|
||||
|
||||
$this->benefits = DB::table('request_log_benefits')
|
||||
->join('benefits', 'benefits.id', '=', 'request_log_benefits.benefit_id')
|
||||
->whereIn('request_log_benefits.request_log_id', $requestLogIds)
|
||||
->select('benefits.id', 'benefits.description')
|
||||
->distinct()
|
||||
->orderBy('benefits.id')
|
||||
->pluck('benefits.description', 'benefits.id')
|
||||
->toArray();
|
||||
|
||||
$this->benefitInitialized = true;
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
}
|
||||
0
app/Helpers/DuitkuHelper.php
Executable file → Normal file
0
app/Helpers/DuitkuHelper.php
Executable file → Normal file
0
app/Helpers/Helper.php
Executable file → Normal file
0
app/Helpers/Helper.php
Executable file → Normal file
0
app/Http/Controllers/Api/AuthController.php
Executable file → Normal file
0
app/Http/Controllers/Api/AuthController.php
Executable file → Normal file
0
app/Http/Controllers/Api/OLDLMS/ClaimController.php
Executable file → Normal file
0
app/Http/Controllers/Api/OLDLMS/ClaimController.php
Executable file → Normal file
0
app/Http/Controllers/Api/OLDLMS/MembershipController.php
Executable file → Normal file
0
app/Http/Controllers/Api/OLDLMS/MembershipController.php
Executable file → Normal file
0
app/Http/Controllers/Api/OLDLMS/PaymentController.php
Executable file → Normal file
0
app/Http/Controllers/Api/OLDLMS/PaymentController.php
Executable file → Normal file
0
app/Http/Controllers/Controller.php
Executable file → Normal file
0
app/Http/Controllers/Controller.php
Executable file → Normal file
0
app/Http/Controllers/GeneratedDocumentController.php
Executable file → Normal file
0
app/Http/Controllers/GeneratedDocumentController.php
Executable file → Normal file
3
app/Http/Kernel.php
Executable file → Normal file
3
app/Http/Kernel.php
Executable file → Normal file
@@ -67,11 +67,12 @@ class Kernel extends HttpKernel
|
||||
'throttle' => \Illuminate\Routing\Middleware\ThrottleRequests::class,
|
||||
'verified' => \Illuminate\Auth\Middleware\EnsureEmailIsVerified::class,
|
||||
'linksehat.old.auth' => \App\Http\Middleware\LinksehatOldAuthMiddleware::class,
|
||||
'corporate.key' => \Modules\Primaya\Http\Middleware\CheckCorporateKey::class,
|
||||
|
||||
// Role
|
||||
'role' => \Spatie\Permission\Middlewares\RoleMiddleware::class,
|
||||
'permission' => \Spatie\Permission\Middlewares\PermissionMiddleware::class,
|
||||
'role_or_permission' => \Spatie\Permission\Middlewares\RoleOrPermissionMiddleware::class,
|
||||
|
||||
|
||||
];
|
||||
}
|
||||
|
||||
23
app/Http/Middleware/Authenticate.php
Executable file → Normal file
23
app/Http/Middleware/Authenticate.php
Executable file → Normal file
@@ -21,12 +21,21 @@ class Authenticate extends Middleware
|
||||
}
|
||||
}
|
||||
|
||||
public function handle($request, Closure $next, ...$guards)
|
||||
{
|
||||
if (Auth::guard('sanctum')->guest()) {
|
||||
return response()->json(['error' => 'Bearer Authorization is required'], 401);
|
||||
}
|
||||
// public function handle($request, Closure $next, ...$guards)
|
||||
// {
|
||||
// // Kalau tidak ada guard dikirim dari route
|
||||
// if (empty($guards)) {
|
||||
// $guards = [null];
|
||||
// }
|
||||
|
||||
return parent::handle($request, $next, ...$guards);
|
||||
}
|
||||
// foreach ($guards as $guard) {
|
||||
// if (Auth::guard($guard)->check()) {
|
||||
// return $next($request);
|
||||
// }
|
||||
// }
|
||||
|
||||
// return response()->json([
|
||||
// 'error' => 'Unauthorized'
|
||||
// ], 401);
|
||||
// }
|
||||
}
|
||||
|
||||
0
app/Http/Middleware/EncryptCookies.php
Executable file → Normal file
0
app/Http/Middleware/EncryptCookies.php
Executable file → Normal file
0
app/Http/Middleware/LinksehatOldAuthMiddleware.php
Executable file → Normal file
0
app/Http/Middleware/LinksehatOldAuthMiddleware.php
Executable file → Normal file
0
app/Http/Middleware/PreventRequestsDuringMaintenance.php
Executable file → Normal file
0
app/Http/Middleware/PreventRequestsDuringMaintenance.php
Executable file → Normal file
0
app/Http/Middleware/RedirectIfAuthenticated.php
Executable file → Normal file
0
app/Http/Middleware/RedirectIfAuthenticated.php
Executable file → Normal file
0
app/Http/Middleware/TrimStrings.php
Executable file → Normal file
0
app/Http/Middleware/TrimStrings.php
Executable file → Normal file
0
app/Http/Middleware/TrustHosts.php
Executable file → Normal file
0
app/Http/Middleware/TrustHosts.php
Executable file → Normal file
0
app/Http/Middleware/TrustProxies.php
Executable file → Normal file
0
app/Http/Middleware/TrustProxies.php
Executable file → Normal file
0
app/Http/Middleware/VerifyCsrfToken.php
Executable file → Normal file
0
app/Http/Middleware/VerifyCsrfToken.php
Executable file → Normal file
0
app/Http/Resources/MemberDataTableResource.php
Executable file → Normal file
0
app/Http/Resources/MemberDataTableResource.php
Executable file → Normal file
0
app/Http/Resources/MemberListResource.php
Executable file → Normal file
0
app/Http/Resources/MemberListResource.php
Executable file → Normal file
0
app/Http/Resources/OLDLMS/MemberLimitResource.php
Executable file → Normal file
0
app/Http/Resources/OLDLMS/MemberLimitResource.php
Executable file → Normal file
0
app/Http/Resources/OLDLMS/MemberResource.php
Executable file → Normal file
0
app/Http/Resources/OLDLMS/MemberResource.php
Executable file → Normal file
Some files were not shown because too many files have changed in this diff Show More
Reference in New Issue
Block a user