fix add params filter date on grid js, export excel and pdf payment recaps
This commit is contained in:
@@ -3,11 +3,13 @@
|
||||
namespace App\Http\Controllers\Api;
|
||||
|
||||
use App\Exports\ReportDirectorExport;
|
||||
use App\Exports\ReportPaymentRecapExport;
|
||||
use App\Http\Controllers\Controller;
|
||||
use App\Http\Resources\BigdataResumeResource;
|
||||
use App\Models\BigdataResume;
|
||||
use App\Models\DataSetting;
|
||||
use Barryvdh\DomPDF\Facade\Pdf;
|
||||
use Carbon\Carbon;
|
||||
use Illuminate\Http\Request;
|
||||
use Illuminate\Support\Facades\Log;
|
||||
use Maatwebsite\Excel\Facades\Excel;
|
||||
@@ -181,11 +183,14 @@ class BigDataResumeController extends Controller
|
||||
try {
|
||||
$query = BigdataResume::query()->orderBy('id', 'desc');
|
||||
|
||||
if ($request->filled('date')) {
|
||||
$query->where('year', 'LIKE', '%' . $request->input('search') . '%');
|
||||
if ($request->filled('start_date') && $request->filled('end_date')) {
|
||||
$startDate = Carbon::parse($request->input('start_date'))->startOfDay();
|
||||
$endDate = Carbon::parse($request->input('end_date'))->endOfDay();
|
||||
|
||||
$query->whereBetween('created_at', [$startDate, $endDate]);
|
||||
}
|
||||
|
||||
$data = $query->paginate(10);
|
||||
$data = $query->paginate(50);
|
||||
|
||||
// Restructure response
|
||||
$transformedData = [];
|
||||
@@ -210,7 +215,7 @@ class BigDataResumeController extends Controller
|
||||
return response()->json([
|
||||
'data' => $transformedData, // Flat array
|
||||
'pagination' => [
|
||||
'total' => $data->total(),
|
||||
'total' => count($transformedData),
|
||||
'per_page' => $data->perPage(),
|
||||
'current_page' => $data->currentPage(),
|
||||
'last_page' => $data->lastPage(),
|
||||
@@ -222,6 +227,69 @@ class BigDataResumeController extends Controller
|
||||
}
|
||||
}
|
||||
|
||||
public function export_excel_payment_recaps(Request $request)
|
||||
{
|
||||
$startDate = null;
|
||||
$endDate = null;
|
||||
|
||||
if ($request->filled('start_date') && $request->filled('end_date')) {
|
||||
$startDate = Carbon::parse($request->input('start_date'))->startOfDay();
|
||||
$endDate = Carbon::parse($request->input('end_date'))->endOfDay();
|
||||
}
|
||||
|
||||
return Excel::download(new ReportPaymentRecapExport($startDate, $endDate), 'laporan-rekap-pembayaran.xlsx');
|
||||
}
|
||||
|
||||
public function export_pdf_payment_recaps(Request $request){
|
||||
$query = BigdataResume::query()->orderBy('id', 'desc');
|
||||
|
||||
if ($request->filled('start_date') && $request->filled('end_date')) {
|
||||
$startDate = Carbon::parse($request->input('start_date'))->startOfDay();
|
||||
$endDate = Carbon::parse($request->input('end_date'))->endOfDay();
|
||||
|
||||
$query->whereBetween('created_at', [$startDate, $endDate]);
|
||||
}
|
||||
|
||||
$items = $query->get();
|
||||
|
||||
// Define category mapping
|
||||
$categoryMap = [
|
||||
'potention_sum' => 'Potensi',
|
||||
'non_verified_sum' => 'Belum Terverifikasi',
|
||||
'verified_sum' => 'Terverifikasi',
|
||||
'business_sum' => 'Usaha',
|
||||
'non_business_sum' => 'Non Usaha',
|
||||
'spatial_sum' => 'Tata Ruang',
|
||||
'waiting_click_dpmptsp_sum' => 'Menunggu Klik DPMPTSP',
|
||||
'issuance_realization_pbg_sum' => 'Realisasi Terbit PBG',
|
||||
'process_in_technical_office_sum' => 'Proses Di Dinas Teknis',
|
||||
];
|
||||
|
||||
// Restructure response
|
||||
$data = [];
|
||||
|
||||
foreach ($items as $item) {
|
||||
$createdAt = $item->created_at;
|
||||
$id = $item->id;
|
||||
|
||||
foreach ($item->toArray() as $key => $value) {
|
||||
// Only include columns with "sum" in their names
|
||||
if (strpos($key, 'sum') !== false) {
|
||||
$data[] = [
|
||||
'id' => $id,
|
||||
'category' => $categoryMap[$key] ?? $key, // Map category
|
||||
'nominal' => $value, // Format number
|
||||
'created_at' => $createdAt->format('Y-m-d H:i:s'), // Format date
|
||||
];
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
$pdf = Pdf::loadView('exports.payment_recaps_report', compact('data'));
|
||||
return $pdf->download('laporan-rekap-pembayaran.pdf');
|
||||
}
|
||||
|
||||
|
||||
public function export_excel_report_director(){
|
||||
return Excel::download(new ReportDirectorExport, 'laporan-pimpinan.xlsx');
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user