fix: null check budget, cegah duplikasi approval/vote, tambah related_type di votes
This commit is contained in:
@@ -47,23 +47,29 @@ class ActivityObserver
|
||||
|
||||
// Threshold budget
|
||||
$budget = $activity->budget;
|
||||
if ($budget >= 500_000 && $budget <= 2_000_000) {
|
||||
Approval::create([
|
||||
'model_type' => Activity::class,
|
||||
'model_id' => $activity->id,
|
||||
'required_approvals' => 1,
|
||||
'status' => 'pending',
|
||||
]);
|
||||
} elseif ($budget > 2_000_000) {
|
||||
Vote::create([
|
||||
'title' => "Persetujuan Budget Kegiatan: {$activity->title}",
|
||||
'description' => "Budget kegiatan senilai Rp " . number_format($budget, 0, ',', '.') . " memerlukan persetujuan voting.",
|
||||
'type' => 'finance',
|
||||
'related_id' => $activity->id,
|
||||
'status' => 'open',
|
||||
'deadline' => now()->addDays(3),
|
||||
'created_by' => Auth::id() ?? $activity->created_by,
|
||||
]);
|
||||
if ($budget !== null && $budget >= 500_000 && $budget <= 2_000_000) {
|
||||
Approval::firstOrCreate(
|
||||
['model_type' => Activity::class, 'model_id' => $activity->id],
|
||||
['required_approvals' => 1, 'status' => 'pending']
|
||||
);
|
||||
} elseif ($budget !== null && $budget > 2_000_000) {
|
||||
$exists = Vote::where('related_type', Activity::class)
|
||||
->where('related_id', $activity->id)
|
||||
->where('type', 'finance')
|
||||
->exists();
|
||||
|
||||
if (! $exists) {
|
||||
Vote::create([
|
||||
'title' => "Persetujuan Budget Kegiatan: {$activity->title}",
|
||||
'description' => "Budget kegiatan senilai Rp " . number_format($budget, 0, ',', '.') . " memerlukan persetujuan voting.",
|
||||
'type' => 'finance',
|
||||
'related_id' => $activity->id,
|
||||
'related_type' => Activity::class,
|
||||
'status' => 'open',
|
||||
'deadline' => now()->addDays(3),
|
||||
'created_by' => Auth::id() ?? $activity->created_by,
|
||||
]);
|
||||
}
|
||||
}
|
||||
}
|
||||
|
||||
|
||||
@@ -41,13 +41,14 @@ class CashRecordObserver
|
||||
// Threshold: > 2jt → buat voting + notif semua anggota
|
||||
if ($record->amount > 2_000_000) {
|
||||
Vote::create([
|
||||
'title' => "Persetujuan Transaksi: {$record->description}",
|
||||
'description' => "Transaksi senilai Rp " . number_format($record->amount, 0, ',', '.') . " memerlukan persetujuan voting.",
|
||||
'type' => 'finance',
|
||||
'related_id' => $record->id,
|
||||
'status' => 'open',
|
||||
'deadline' => now()->addDays(3),
|
||||
'created_by' => Auth::id() ?? $record->created_by,
|
||||
'title' => "Persetujuan Transaksi: {$record->description}",
|
||||
'description' => "Transaksi senilai Rp " . number_format($record->amount, 0, ',', '.') . " memerlukan persetujuan voting.",
|
||||
'type' => 'finance',
|
||||
'related_id' => $record->id,
|
||||
'related_type' => CashRecord::class,
|
||||
'status' => 'open',
|
||||
'deadline' => now()->addDays(3),
|
||||
'created_by' => Auth::id() ?? $record->created_by,
|
||||
]);
|
||||
|
||||
NotificationService::toRole('ketua',
|
||||
|
||||
Reference in New Issue
Block a user