feat: implementasi threshold keuangan otomatis via observer dan action approval
This commit is contained in:
@@ -2,9 +2,13 @@
|
||||
|
||||
namespace App\Filament\Resources\Approvals\Tables;
|
||||
|
||||
use App\Models\Approval;
|
||||
use App\Models\ApprovalItem;
|
||||
use Filament\Actions\Action;
|
||||
use Filament\Actions\BulkActionGroup;
|
||||
use Filament\Actions\DeleteBulkAction;
|
||||
use Filament\Actions\EditAction;
|
||||
use Filament\Forms\Components\Textarea;
|
||||
use Filament\Tables\Columns\TextColumn;
|
||||
use Filament\Tables\Filters\SelectFilter;
|
||||
use Filament\Tables\Table;
|
||||
@@ -15,7 +19,8 @@ class ApprovalsTable
|
||||
{
|
||||
return $table
|
||||
->columns([
|
||||
TextColumn::make('model_type')->label('Tipe'),
|
||||
TextColumn::make('model_type')->label('Tipe')
|
||||
->formatStateUsing(fn ($state) => class_basename($state)),
|
||||
TextColumn::make('model_id')->label('ID'),
|
||||
TextColumn::make('required_approvals')->label('Dibutuhkan'),
|
||||
TextColumn::make('items_count')->counts('items')->label('Sudah Approve'),
|
||||
@@ -25,6 +30,7 @@ class ApprovalsTable
|
||||
'rejected' => 'danger',
|
||||
default => 'warning',
|
||||
}),
|
||||
TextColumn::make('created_at')->label('Dibuat')->date('d M Y'),
|
||||
])
|
||||
->filters([
|
||||
SelectFilter::make('status')->options([
|
||||
@@ -33,7 +39,69 @@ class ApprovalsTable
|
||||
'rejected' => 'Ditolak',
|
||||
]),
|
||||
])
|
||||
->recordActions([EditAction::make()])
|
||||
->recordActions([
|
||||
Action::make('approve')
|
||||
->label('Setujui')
|
||||
->icon('heroicon-o-check-circle')
|
||||
->color('success')
|
||||
->requiresConfirmation()
|
||||
->visible(fn (Approval $record) => $record->status === 'pending')
|
||||
->form([
|
||||
Textarea::make('notes')->label('Catatan')->rows(2),
|
||||
])
|
||||
->action(function (Approval $record, array $data): void {
|
||||
ApprovalItem::create([
|
||||
'approval_id' => $record->id,
|
||||
'user_id' => auth()->id(),
|
||||
'decision' => 'approve',
|
||||
'notes' => $data['notes'] ?? null,
|
||||
]);
|
||||
|
||||
$approveCount = $record->items()->where('decision', 'approve')->count();
|
||||
|
||||
if ($approveCount >= $record->required_approvals) {
|
||||
$record->update(['status' => 'approved']);
|
||||
}
|
||||
|
||||
\App\Models\ActivityLog::create([
|
||||
'user_id' => auth()->id(),
|
||||
'action' => 'approved',
|
||||
'model_type' => Approval::class,
|
||||
'model_id' => $record->id,
|
||||
'description' => auth()->user()->name . " menyetujui " . class_basename($record->model_type) . " #{$record->model_id}",
|
||||
]);
|
||||
}),
|
||||
|
||||
Action::make('reject')
|
||||
->label('Tolak')
|
||||
->icon('heroicon-o-x-circle')
|
||||
->color('danger')
|
||||
->requiresConfirmation()
|
||||
->visible(fn (Approval $record) => $record->status === 'pending')
|
||||
->form([
|
||||
Textarea::make('notes')->label('Alasan Penolakan')->required()->rows(2),
|
||||
])
|
||||
->action(function (Approval $record, array $data): void {
|
||||
ApprovalItem::create([
|
||||
'approval_id' => $record->id,
|
||||
'user_id' => auth()->id(),
|
||||
'decision' => 'reject',
|
||||
'notes' => $data['notes'],
|
||||
]);
|
||||
|
||||
$record->update(['status' => 'rejected']);
|
||||
|
||||
\App\Models\ActivityLog::create([
|
||||
'user_id' => auth()->id(),
|
||||
'action' => 'rejected',
|
||||
'model_type' => Approval::class,
|
||||
'model_id' => $record->id,
|
||||
'description' => auth()->user()->name . " menolak " . class_basename($record->model_type) . " #{$record->model_id}",
|
||||
]);
|
||||
}),
|
||||
|
||||
EditAction::make(),
|
||||
])
|
||||
->toolbarActions([BulkActionGroup::make([DeleteBulkAction::make()])]);
|
||||
}
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user