This commit is contained in:
arifal hidayat
2025-08-15 03:58:17 +07:00
parent 3ff3dc8f17
commit 48a340d684
2 changed files with 3 additions and 26 deletions

View File

@@ -68,30 +68,7 @@ class RequestAssignmentController extends Controller
break; break;
case 'potention': case 'potention':
$potentionStatuses = PbgTaskStatus::getPotention(); $query->whereIn("status", PbgTaskStatus::getPotention());
$rejectedStatuses = PbgTaskStatus::getRejected();
$nonVerifiedStatuses = PbgTaskStatus::getNonVerified();
$query->where(function($q) use ($potentionStatuses, $rejectedStatuses, $nonVerifiedStatuses) {
$q->where(function($q1) use ($potentionStatuses, $rejectedStatuses, $nonVerifiedStatuses) {
// Verified potention (main logic)
$q1->whereIn("status", $potentionStatuses)
->whereNotIn("status", $rejectedStatuses)
->whereNotIn("status", $nonVerifiedStatuses);
})
->orWhere(function($q2) use ($nonVerifiedStatuses) {
// Add non-verified WITH retributions (business logic exception)
$q2->whereIn("status", $nonVerifiedStatuses)
->whereHas('pbg_task_retributions');
});
});
Log::info('Potention filter applied', [
'status_list' => $potentionStatuses,
'excluded_rejected' => $rejectedStatuses,
'excluded_non_verified_without_retributions' => $nonVerifiedStatuses,
'included_non_verified_with_retributions' => true,
'count_before_filter' => PbgTask::count(),
'count_after_filter' => $query->count()
]);
break; break;
case 'issuance-realization-pbg': case 'issuance-realization-pbg':
$query->whereIn("status", PbgTaskStatus::getIssuanceRealizationPbg()); $query->whereIn("status", PbgTaskStatus::getIssuanceRealizationPbg());

View File

@@ -69,8 +69,8 @@ class BigdataResume extends Model
SUM(CASE WHEN pbg_task.status in (".implode(',', PbgTaskStatus::getIssuanceRealizationPbg()).") THEN ptr.nilai_retribusi_bangunan ELSE 0 END) AS issuance_realization_pbg_total, SUM(CASE WHEN pbg_task.status in (".implode(',', PbgTaskStatus::getIssuanceRealizationPbg()).") THEN ptr.nilai_retribusi_bangunan ELSE 0 END) AS issuance_realization_pbg_total,
COUNT(CASE WHEN pbg_task.status in (".implode(',', PbgTaskStatus::getProcessInTechnicalOffice()).") THEN pbg_task.uuid END) AS process_in_technical_office_count, COUNT(CASE WHEN pbg_task.status in (".implode(',', PbgTaskStatus::getProcessInTechnicalOffice()).") THEN pbg_task.uuid END) AS process_in_technical_office_count,
SUM(CASE WHEN pbg_task.status in (".implode(',', PbgTaskStatus::getProcessInTechnicalOffice()).") THEN ptr.nilai_retribusi_bangunan ELSE 0 END) AS process_in_technical_office_total, SUM(CASE WHEN pbg_task.status in (".implode(',', PbgTaskStatus::getProcessInTechnicalOffice()).") THEN ptr.nilai_retribusi_bangunan ELSE 0 END) AS process_in_technical_office_total,
COUNT(CASE WHEN (pbg_task.status in (".implode(',', PbgTaskStatus::getPotention()).") AND pbg_task.status not in (".implode(',', PbgTaskStatus::getRejected()).") AND pbg_task.status not in (".implode(',', PbgTaskStatus::getNonVerified()).")) OR (pbg_task.status in (".implode(',', PbgTaskStatus::getNonVerified()).") AND ptr.pbg_task_uid IS NOT NULL) THEN pbg_task.uuid END) AS potention_count, COUNT(CASE WHEN pbg_task.status in (".implode(',', PbgTaskStatus::getPotention()).") THEN pbg_task.uuid END) AS potention_count,
SUM(CASE WHEN (pbg_task.status in (".implode(',', PbgTaskStatus::getPotention()).") AND pbg_task.status not in (".implode(',', PbgTaskStatus::getRejected()).") AND pbg_task.status not in (".implode(',', PbgTaskStatus::getNonVerified()).")) OR (pbg_task.status in (".implode(',', PbgTaskStatus::getNonVerified()).") AND ptr.pbg_task_uid IS NOT NULL) THEN ptr.nilai_retribusi_bangunan ELSE 0 END) AS potention_total SUM(CASE WHEN pbg_task.status in (".implode(',', PbgTaskStatus::getPotention()).") THEN ptr.nilai_retribusi_bangunan ELSE 0 END) AS potention_total
") ")
->first(); ->first();