harian); Log::info($request->tanggal); $selectDate = $request->tanggal; $start = microtime(true); $harian = $request->harian ?? 1; // $dateNow = Carbon::now()->format('Y-m-d'); $dateNow = '2026-01-25'; // $startDate = Carbon::today()->startOfDay(); // $endDate = Carbon::today()->endOfDay(); // $startDate = $selectDate . ' 00:00:00'; // $endDate = $selectDate . ' 23:59:59'; $startDate = $selectDate ? $selectDate : $dateNow; $endDate = $selectDate ? $selectDate : $dateNow; Log::info('Tanggal laporan', [ 'start' => $startDate, 'end' => $endDate ]); // ========================= // QUERY UTAMA (LEFT JOIN) // ========================= Log::info('Query transaksi dimulai'); // $dateColumn = $harian == 1 // ? 'tp.waktu_keluar' // : 'tp.pklogin'; if ($harian == 1) { // $dateColumn = ['tp.waktu_masuk', 'tp.waktu_keluar']; $dateColumn = ['tp.waktu_keluar']; } else { // $dateColumn = ['tp.pmlogin', 'tp.pklogin']; $dateColumn = ['tp.pklogin']; } $transactions = DB::table('transaksi_parkir as tp') ->leftJoin('jenis_mobil as jm', 'jm.id', '=', 'tp.id_kendaraan') ->leftJoin('pegawai as pm', 'pm.nomer', '=', 'tp.id_op_masuk') ->leftJoin('pegawai as pk', 'pk.nomer', '=', 'tp.id_op_keluar') ->where(function ($q) use ($dateColumn, $startDate, $endDate, $selectDate) { $q->whereBetween($dateColumn[0], [$startDate . ' 00:00:00', $endDate . ' 23:59:59']) ->orWhereBetween($dateColumn[0], [$startDate . ' 00:00:00', $endDate . ' 23:59:59']); // $q->whereRaw('DATE(tp.waktu_masuk) = ?', [$selectDate]) // ->orWhereRaw('DATE(tp.waktu_keluar) = ?', [$selectDate]); }) // ->whereRaw("DATE($dateColumn) = ?", [$dateNow]) // ->whereBetween($dateColumn, [$startDate, $endDate]) ->select( 'tp.id', 'jm.nama as jenis_mobil', 'tp.id_kendaraan', 'pm.nama as kasir_masuk', 'pk.nama as kasir_keluar', 'tp.id_op_masuk', 'tp.waktu_masuk', 'tp.waktu_keluar', 'tp.status', 'tp.bayar_masuk', 'tp.bayar_keluar', 'tp.status_transaksi', 'tp.cara_bayar', ) ->get(); Log::info('Query transaksi selesai', [ 'rows' => $transactions->count(), 'query_time_ms' => round((microtime(true) - $start) * 1000, 2) ]); // ========================= // REKAP PER KENDARAAN // ========================= Log::info('Rekap kendaraan dimulai'); $tunai = $transactions ->sortBy('id_kendaraan') ->groupBy('id_kendaraan') ->map(function ($items, $idKendaraan) { // ====================== // PISAH MASUK & KELUAR // ====================== // $masuk = $items->where('status', 1); // $keluar = $items->where('status', 0); $keluar = $items->filter(fn ($r) => (int) $r->status === 0); // $tunai = $keluar->where('cara_bayar', '!=', 3); $tunai = $keluar->filter(fn ($row) => in_array(data_get($row, 'cara_bayar'), [null, 0, '0'], true) ); // ====================== // MASUK // ====================== // $masukCasual = $masuk->where('status_transaksi', '0'); // $masukMember = $masuk->where('status_transaksi', '3'); // ====================== // KELUAR // ====================== // $keluarCasual = $tunai->where('status_transaksi', '0'); // $keluarMember = $tunai->where('status_transaksi', '3'); // $keluarLost = $tunai->where('status_transaksi', '32'); $keluarCasual = $tunai->filter(fn ($r) => (string) data_get($r, 'status_transaksi') === '0' && data_get($r, 'id_op_masuk') !== null ); $keluarMember = $tunai->filter(fn ($r) => (string) data_get($r, 'status_transaksi') === '3'); $keluarLost = $tunai->filter(fn ($r) => (string) data_get($r, 'status_transaksi') === '32'); $keluarManual = $tunai->filter(fn ($r) => data_get($r, 'id_op_masuk') === null); $keluarMasalah = $tunai->filter(fn ($r) => (string) data_get($r, 'status_transaksi') === '-1'); // ====================== // PEMBAYARAN (KELUAR) // ====================== // $nonTunai = $keluar->where('cara_bayar', 3); // $tunai = $keluar->where('cara_bayar', '!=', 3); $totalCash = $keluarCasual->sum('bayar_keluar') + $keluarLost->sum('bayar_keluar') + $keluarMember->sum('bayar_keluar') + $keluarManual->sum('bayar_keluar'); return [ 'id_kendaraan' => $idKendaraan, 'jenis_mobil' => $items->first()->jenis_mobil, 'total' => $items->count(), 'tunaiOut' => $tunai->count(), // ========= MASUK ========= // 'masuk' => [ // 'casual' => [ // 'jumlah' => $masukCasual->count(), // 'income' => $masukCasual->sum('bayar_masuk'), // ], // 'member' => [ // 'jumlah' => $masukMember->count(), // 'income' => $masukMember->sum('bayar_masuk'), // ], // ], // ========= KELUAR ========= 'keluar' => [ 'casual' => [ 'jumlah' => $keluarCasual->count(), 'income' => $keluarCasual->sum('bayar_keluar'), ], 'lost' => [ 'jumlah' => $keluarLost->count(), 'income' => $keluarLost->sum('bayar_keluar'), ], 'member' => [ 'jumlah' => $keluarMember->count(), 'income' => $keluarMember->sum('bayar_keluar'), ], 'manual' => [ 'jumlah' => $keluarManual->count(), 'income' => $keluarManual->sum('bayar_keluar'), ], 'masalah' => [ 'jumlah' => $keluarMasalah->count(), 'income' => $keluarMasalah->sum('bayar_keluar'), ], ], 'totalCash' => $totalCash, ]; } )->values(); $cashless = $transactions ->sortBy('id_kendaraan') ->groupBy('id_kendaraan') ->map(function ($items, $idKendaraan) { // ====================== // PISAH MASUK & KELUAR // ====================== // $masuk = $items->where('status', 1); // $keluar = $items->where('status', 0); // $nonTunai = $keluar->where('cara_bayar', 3); $keluar = $items->filter(fn ($r) => (int) $r->status === 0); // $tunai = $keluar->where('cara_bayar', '!=', 3); $nonTunai = $keluar->filter(fn ($row) => (string) data_get($row, 'cara_bayar') === '3' ); // ====================== // MASUK // ====================== // $masukCasual = $masuk->where('status_transaksi', '0'); // $masukMember = $masuk->where('status_transaksi', '3'); // ====================== // KELUAR // ====================== // $keluarCasual = $nonTunai->where('status_transaksi', '0'); // $keluarMember = $nonTunai->where('status_transaksi', '3'); // $keluarLost = $nonTunai->where('status_transaksi', '32'); $keluarCasual = $nonTunai->filter(fn ($r) => (string) data_get($r, 'status_transaksi') === '0' && data_get($r, 'id_op_masuk') !== null ); $keluarMember = $nonTunai->filter(fn ($r) => (string) data_get($r, 'status_transaksi') === '3'); $keluarLost = $nonTunai->filter(fn ($r) => (string) data_get($r, 'status_transaksi') === '32'); $keluarManual = $nonTunai->filter(fn ($r) => data_get($r, 'id_op_masuk') === null); $totalCashless = $keluarCasual->sum('bayar_keluar') + $keluarLost->sum('bayar_keluar') + $keluarMember->sum('bayar_keluar') + $keluarManual->sum('bayar_keluar'); // ====================== // PEMBAYARAN (KELUAR) // ====================== return [ 'id_kendaraan' => $idKendaraan, 'jenis_mobil' => $items->first()->jenis_mobil, 'total' => $items->count(), 'nonTunaiOut' => $nonTunai->count(), // ========= MASUK ========= // 'masuk' => [ // 'casual' => [ // 'jumlah' => $masukCasual->count(), // 'income' => $masukCasual->sum('bayar_masuk'), // ], // 'member' => [ // 'jumlah' => $masukMember->count(), // 'income' => $masukMember->sum('bayar_masuk'), // ], // ], // ========= KELUAR ========= 'keluar' => [ 'casual' => [ 'jumlah' => $keluarCasual->count(), 'income' => $keluarCasual->sum('bayar_keluar'), ], 'lost' => [ 'jumlah' => $keluarLost->count(), 'income' => $keluarLost->sum('bayar_keluar'), ], 'member' => [ 'jumlah' => $keluarMember->count(), 'income' => $keluarMember->sum('bayar_keluar'), ], 'manual' => [ 'jumlah' => $keluarManual->count(), 'income' => $keluarManual->sum('bayar_keluar'), ], ], 'totalCashless' => $totalCashless, ]; } )->values(); $transactions = DB::table('transaksi_parkir as tp') ->leftJoin('jenis_mobil as jm', 'jm.id', '=', 'tp.id_kendaraan') ->leftJoin('pegawai as pm', 'pm.nomer', '=', 'tp.id_op_masuk') ->leftJoin('pegawai as pk', 'pk.nomer', '=', 'tp.id_op_keluar') ->whereDate('waktu_masuk', '<', $dateNow) ->select( 'tp.id_kendaraan', 'jm.nama as jenis_mobil', DB::raw("SUM(CASE WHEN tp.status = 1 THEN 1 ELSE 0 END) as overnight"), DB::raw("SUM(CASE WHEN tp.status = 3 THEN 1 ELSE 0 END) as onexpired") ) ->groupBy('tp.id_kendaraan', 'jm.nama') ->orderBy('tp.id_kendaraan') // dd($transactions->toSql()); ->get(); $onCheck = $transactions // ->sortBy('id_kendaraan') // ->groupBy('id_kendaraan') ->map(function ($items) { // $overNight = $items->filter(fn ($r) => (int) $r->status === 1); // $onExpired = $items->filter(fn ($r) => (int) $r->status === 3); return [ 'id_kendaraan' => $items->id_kendaraan, 'jenis_mobil' => $items->jenis_mobil, 'overNight' => (int) $items->overnight, 'onExpired' => (int) $items->onexpired, ]; } )->values(); Log::info('Rekap kendaraan selesai', [ 'total_kendaraan' => $tunai->count() ]); Log::info('== allReportData END ==', [ 'total_time_ms' => round((microtime(true) - $start) * 1000, 2) ]); return response()->json([ // 'date' => $startDate->format('Y-m-d'),รท 'date' => $startDate, 'tunai' => $tunai, 'nontunai' => $cashless, 'overNight' => $onCheck // 'transactions' => $transactions->groupBy('id_kendaraan') ]); } }