validate([ "year" => "required|integer" ]); $current_year = $request->get('year'); $startOfYear = "$current_year-01-01 00:00:00"; $endOfYear = "$current_year-12-31 23:59:59"; $query = once(function () use ($startOfYear, $endOfYear) { return DB::table('pbg_task AS pt') ->leftJoin('pbg_task_google_sheet AS ptgs', 'pt.registration_number', '=', 'ptgs.no_registrasi') ->leftJoin('pbg_task_retributions AS ptr', 'pt.uuid', '=', 'ptr.pbg_task_uid') ->whereBetween("pt.task_created_at", [$startOfYear, $endOfYear]) ->where(function ($query) { $query->whereRaw('LOWER(TRIM(ptgs.status_verifikasi)) != ?', [strtolower(trim('Selesai Verifikasi'))]) ->orWhereNull('ptgs.status_verifikasi'); }) ->where(function ($query) { $query->whereRaw('LOWER(TRIM(pt.function_type)) = ?', [strtolower(trim('Sebagai Tempat Usaha'))]); }) ->selectRaw('COUNT(pt.id) AS total_data, SUM(ptr.nilai_retribusi_bangunan) AS total_retribution') ->first(); }); $taskCount = $query->total_data ?? 0; $taskTotal = $query->total_retribution ?? 0; return $this->resSuccess([ "count" => $taskCount, "total" => $taskTotal ]); } public function nonBusinnessDocument(Request $request){ $request->validate([ "year" => "required|integer" ]); $current_year = $request->get('year'); $startOfYear = "$current_year-01-01 00:00:00"; $endOfYear = "$current_year-12-31 23:59:59"; $query = once( function () use ($startOfYear, $endOfYear) { return DB::table('pbg_task AS pt') ->leftJoin('pbg_task_google_sheet AS ptgs', 'pt.registration_number', '=', 'ptgs.no_registrasi') ->leftJoin('pbg_task_retributions AS ptr', 'pt.uuid', '=', 'ptr.pbg_task_uid') // Join ke pbg_task_retributions ->whereBetween("pt.task_created_at", [$startOfYear, $endOfYear]) ->where(function ($query) { $query->whereRaw('LOWER(TRIM(ptgs.status_verifikasi)) != ?', [strtolower(trim('Selesai Verifikasi'))]) ->orWhereNull('ptgs.status_verifikasi'); // Include NULL values }) ->where(function ($query) { $query->whereRaw('LOWER(TRIM(pt.function_type)) != ?', [strtolower(trim('Sebagai Tempat Usaha'))]) ->orWhereNull('pt.function_type'); // Include NULL values }) ->selectRaw('COUNT(pt.id) AS total_data, SUM(ptr.nilai_retribusi_bangunan) AS total_retribution') // Menambahkan SUM dari pbg_task_retributions ->first(); }); $taskCount = $query->total_data ?? 0; $taskTotal = $query->total_retribution ?? 0; return $this->resSuccess([ "count" => $taskCount, "total" => $taskTotal ]); } public function allTaskDocuments(Request $request){ $request->validate([ "year" => "required|integer" ]); $current_year = $request->get('year'); $startOfYear = "$current_year-01-01 00:00:00"; $endOfYear = "$current_year-12-31 23:59:59"; $query = once( function () use ($startOfYear, $endOfYear) { return DB::table('pbg_task as pt') ->leftJoin('pbg_task_retributions as ptr', 'pt.uuid', '=', 'ptr.pbg_task_uid') ->whereBetween("pt.task_created_at", [$startOfYear, $endOfYear]) ->select( DB::raw('COUNT(DISTINCT pt.id) as task_count'), DB::raw('SUM(ptr.nilai_retribusi_bangunan) as total_retribution') ) ->first(); }); $taskCount = $query->task_count ?? 0; $taskTotal = $query->total_retribution ?? 0; return $this->resSuccess([ "count" => $taskCount, "total" => $taskTotal ]); } public function verificationDocuments(Request $request){ $request->validate([ "year" => "required|integer" ]); $current_year = $request->get('year'); $startOfYear = "$current_year-01-01 00:00:00"; $endOfYear = "$current_year-12-31 23:59:59"; $query = once( function () use ($startOfYear, $endOfYear){ return DB::table('pbg_task AS pt') ->leftJoin('pbg_task_google_sheet AS ptgs', 'pt.registration_number', '=', 'ptgs.no_registrasi') ->leftJoin('pbg_task_retributions AS ptr', 'pt.uuid', '=', 'ptr.pbg_task_uid') ->whereBetween("pt.task_created_at", [$startOfYear, $endOfYear]) ->whereRaw('LOWER(TRIM(ptgs.status_verifikasi)) = ?', [strtolower(trim('Selesai Verifikasi'))]) ->selectRaw('COUNT(pt.id) AS total_data, SUM(ptr.nilai_retribusi_bangunan) AS total_retribution') ->first(); }); $taskCount = $query->total_data ?? 0; $taskTotal = $query->total_retribution ?? 0; return $this->resSuccess([ "count"=> $taskCount, "total"=> $taskTotal ]); } public function nonVerificationDocuments(Request $request){ $request->validate([ "year" => "required|integer" ]); $current_year = $request->get('year'); $startOfYear = "$current_year-01-01 00:00:00"; $endOfYear = "$current_year-12-31 23:59:59"; $query = once(function () use ($startOfYear, $endOfYear) { return DB::table('pbg_task AS pt') ->leftJoin('pbg_task_google_sheet AS ptgs', 'pt.registration_number', '=', 'ptgs.no_registrasi') ->leftJoin('pbg_task_retributions AS ptr', 'pt.uuid', '=', 'ptr.pbg_task_uid') // Join tabel pbg_task_retributions ->whereBetween("pt.task_created_at", [$startOfYear, $endOfYear]) ->where(function ($query) { $query->whereRaw('LOWER(TRIM(ptgs.status_verifikasi)) != ?', [strtolower(trim('Selesai Verifikasi'))]) ->orWhereNull('ptgs.status_verifikasi'); // Include NULL values }) ->selectRaw('COUNT(pt.id) AS total_data, SUM(ptr.nilai_retribusi_bangunan) AS total_retribution') // Menambahkan SUM dari pbg_task_retributions ->first(); }); $taskCount = $query->total_data ?? 0; $taskTotal = $query->total_retribution ?? 0; return $this->resSuccess([ "count"=> $taskCount, "total"=> $taskTotal ]); } public function pbgTaskDocuments(Request $request){ $request->validate([ 'status' => 'required|string' ]); $businessData = DB::table('pbg_task') ->leftJoin('pbg_task_retributions', 'pbg_task.uuid', '=', 'pbg_task_retributions.pbg_task_uid') ->select( DB::raw('COUNT(DISTINCT pbg_task.id) as task_count'), DB::raw('SUM(pbg_task_retributions.nilai_retribusi_bangunan) as total_retribution') ) ->where(function ($query) use ($request) { $query->where("pbg_task.status", "=", $request->get('status')); }) ->first(); $taskCount = $businessData->task_count; $taskTotal = $businessData->total_retribution; $result = [ "count" => $taskCount, "series" => [$taskCount], "total" => $taskTotal ]; return $this->resSuccess($result); } }