fix: perbaiki type navigationGroup MemberDue, tambah MemberDuePolicy, update PermissionSeeder untuk iuran, update README deployment

This commit is contained in:
2026-04-04 06:21:27 +07:00
parent 003cadfba9
commit 98110e519b
14 changed files with 331 additions and 17 deletions
@@ -8,20 +8,22 @@ use App\Filament\Resources\MemberDues\Pages\ListMemberDues;
use App\Filament\Resources\MemberDues\Schemas\MemberDueForm;
use App\Filament\Resources\MemberDues\Tables\MemberDuesTable;
use App\Models\MemberDue;
use BackedEnum;
use Filament\Resources\Resource;
use Filament\Schemas\Schema;
use Filament\Support\Icons\Heroicon;
use Filament\Tables\Table;
class MemberDueResource extends Resource
{
protected static ?string $model = MemberDue::class;
protected static string|\BackedEnum|null $navigationIcon = 'heroicon-o-currency-dollar';
protected static string|BackedEnum|null $navigationIcon = Heroicon::OutlinedRectangleStack;
protected static string|\UnitEnum|null $navigationGroup = 'Organisasi';
protected static ?string $modelLabel = 'Iuran Anggota';
protected static ?string $navigationLabel = 'Iuran Anggota';
public static function form(Schema $form): Schema
public static function form(Schema $schema): Schema
{
return MemberDueForm::configure($form);
return MemberDueForm::configure($schema);
}
public static function table(Table $table): Table
@@ -29,12 +31,19 @@ class MemberDueResource extends Resource
return MemberDuesTable::configure($table);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
'index' => ListMemberDues::route('/'),
'index' => ListMemberDues::route('/'),
'create' => CreateMemberDue::route('/create'),
'edit' => EditMemberDue::route('/{record}/edit'),
'edit' => EditMemberDue::route('/{record}/edit'),
];
}
}
@@ -3,9 +3,17 @@
namespace App\Filament\Resources\MemberDues\Pages;
use App\Filament\Resources\MemberDues\MemberDueResource;
use Filament\Actions\DeleteAction;
use Filament\Resources\Pages\EditRecord;
class EditMemberDue extends EditRecord
{
protected static string $resource = MemberDueResource::class;
protected function getHeaderActions(): array
{
return [
DeleteAction::make(),
];
}
}
@@ -12,6 +12,8 @@ class ListMemberDues extends ListRecords
protected function getHeaderActions(): array
{
return [CreateAction::make()];
return [
CreateAction::make(),
];
}
}
@@ -5,7 +5,6 @@ namespace App\Filament\Resources\MemberDues\Tables;
use Filament\Actions\BulkActionGroup;
use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction;
use Filament\Tables\Columns\BadgeColumn;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Filters\SelectFilter;
use Filament\Tables\Table;
@@ -17,7 +17,7 @@ class PostResource extends Resource
{
protected static ?string $model = Post::class;
protected static string|\BackedEnum|null $navigationIcon = 'heroicon-o-newspaper';
protected static string|\UnitEnum|null $navigationGroup = 'Konten';
protected static string|\UnitEnum|null $navigationGroup = 'Blog';
protected static ?string $navigationLabel = 'Post';
// Label dinamis sesuai role
+75
View File
@@ -0,0 +1,75 @@
<?php
declare(strict_types=1);
namespace App\Policies;
use Illuminate\Foundation\Auth\User as AuthUser;
use App\Models\MemberDue;
use Illuminate\Auth\Access\HandlesAuthorization;
class MemberDuePolicy
{
use HandlesAuthorization;
public function viewAny(AuthUser $authUser): bool
{
return $authUser->can('ViewAny:MemberDue');
}
public function view(AuthUser $authUser, MemberDue $memberDue): bool
{
return $authUser->can('View:MemberDue');
}
public function create(AuthUser $authUser): bool
{
return $authUser->can('Create:MemberDue');
}
public function update(AuthUser $authUser, MemberDue $memberDue): bool
{
return $authUser->can('Update:MemberDue');
}
public function delete(AuthUser $authUser, MemberDue $memberDue): bool
{
return $authUser->can('Delete:MemberDue');
}
public function deleteAny(AuthUser $authUser): bool
{
return $authUser->can('DeleteAny:MemberDue');
}
public function restore(AuthUser $authUser, MemberDue $memberDue): bool
{
return $authUser->can('Restore:MemberDue');
}
public function forceDelete(AuthUser $authUser, MemberDue $memberDue): bool
{
return $authUser->can('ForceDelete:MemberDue');
}
public function forceDeleteAny(AuthUser $authUser): bool
{
return $authUser->can('ForceDeleteAny:MemberDue');
}
public function restoreAny(AuthUser $authUser): bool
{
return $authUser->can('RestoreAny:MemberDue');
}
public function replicate(AuthUser $authUser, MemberDue $memberDue): bool
{
return $authUser->can('Replicate:MemberDue');
}
public function reorder(AuthUser $authUser): bool
{
return $authUser->can('Reorder:MemberDue');
}
}
+2 -2
View File
@@ -14,12 +14,12 @@ class VotePolicy
public function viewAny(AuthUser $authUser): bool
{
return true;
return $authUser->can('ViewAny:Vote');
}
public function view(AuthUser $authUser, Vote $vote): bool
{
return true;
return $authUser->can('View:Vote');
}
public function create(AuthUser $authUser): bool
@@ -36,9 +36,7 @@ class AdminPanelProvider extends PanelProvider
->resourceCreatePageRedirect('index')
->resourceEditPageRedirect('index')
->databaseNotifications()
->databaseNotificationsPolling('30s')
->discoverResources(in: app_path('Filament/Resources'), for: 'App\Filament\Resources')
->discoverPages(in: app_path('Filament/Pages'), for: 'App\Filament\Pages')
->pages([
Dashboard::class,
])