Merge remote-tracking branch 'origin/feature/primaya' into staging
This commit is contained in:
@@ -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);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user