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
+1
View File
@@ -160,6 +160,7 @@ php artisan config:cache
php artisan route:cache php artisan route:cache
php artisan view:cache php artisan view:cache
php artisan permission:cache-reset php artisan permission:cache-reset
php artisan filament:optimize
``` ```
--- ---
@@ -8,20 +8,22 @@ use App\Filament\Resources\MemberDues\Pages\ListMemberDues;
use App\Filament\Resources\MemberDues\Schemas\MemberDueForm; use App\Filament\Resources\MemberDues\Schemas\MemberDueForm;
use App\Filament\Resources\MemberDues\Tables\MemberDuesTable; use App\Filament\Resources\MemberDues\Tables\MemberDuesTable;
use App\Models\MemberDue; use App\Models\MemberDue;
use BackedEnum;
use Filament\Resources\Resource; use Filament\Resources\Resource;
use Filament\Schemas\Schema; use Filament\Schemas\Schema;
use Filament\Support\Icons\Heroicon;
use Filament\Tables\Table; use Filament\Tables\Table;
class MemberDueResource extends Resource class MemberDueResource extends Resource
{ {
protected static ?string $model = MemberDue::class; 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|\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 public static function table(Table $table): Table
@@ -29,6 +31,13 @@ class MemberDueResource extends Resource
return MemberDuesTable::configure($table); return MemberDuesTable::configure($table);
} }
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array public static function getPages(): array
{ {
return [ return [
@@ -3,9 +3,17 @@
namespace App\Filament\Resources\MemberDues\Pages; namespace App\Filament\Resources\MemberDues\Pages;
use App\Filament\Resources\MemberDues\MemberDueResource; use App\Filament\Resources\MemberDues\MemberDueResource;
use Filament\Actions\DeleteAction;
use Filament\Resources\Pages\EditRecord; use Filament\Resources\Pages\EditRecord;
class EditMemberDue extends EditRecord class EditMemberDue extends EditRecord
{ {
protected static string $resource = MemberDueResource::class; 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 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\BulkActionGroup;
use Filament\Actions\DeleteBulkAction; use Filament\Actions\DeleteBulkAction;
use Filament\Actions\EditAction; use Filament\Actions\EditAction;
use Filament\Tables\Columns\BadgeColumn;
use Filament\Tables\Columns\TextColumn; use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Filters\SelectFilter; use Filament\Tables\Filters\SelectFilter;
use Filament\Tables\Table; use Filament\Tables\Table;
@@ -17,7 +17,7 @@ class PostResource extends Resource
{ {
protected static ?string $model = Post::class; protected static ?string $model = Post::class;
protected static string|\BackedEnum|null $navigationIcon = 'heroicon-o-newspaper'; 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'; protected static ?string $navigationLabel = 'Post';
// Label dinamis sesuai role // 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 public function viewAny(AuthUser $authUser): bool
{ {
return true; return $authUser->can('ViewAny:Vote');
} }
public function view(AuthUser $authUser, Vote $vote): bool public function view(AuthUser $authUser, Vote $vote): bool
{ {
return true; return $authUser->can('View:Vote');
} }
public function create(AuthUser $authUser): bool public function create(AuthUser $authUser): bool
@@ -36,9 +36,7 @@ class AdminPanelProvider extends PanelProvider
->resourceCreatePageRedirect('index') ->resourceCreatePageRedirect('index')
->resourceEditPageRedirect('index') ->resourceEditPageRedirect('index')
->databaseNotifications() ->databaseNotifications()
->databaseNotificationsPolling('30s')
->discoverResources(in: app_path('Filament/Resources'), for: 'App\Filament\Resources') ->discoverResources(in: app_path('Filament/Resources'), for: 'App\Filament\Resources')
->discoverPages(in: app_path('Filament/Pages'), for: 'App\Filament\Pages')
->pages([ ->pages([
Dashboard::class, Dashboard::class,
]) ])
+2 -1
View File
@@ -9,7 +9,8 @@ class DatabaseSeeder extends Seeder
public function run(): void public function run(): void
{ {
$this->call([ $this->call([
RolesAndPermissionsSeeder::class, // RolesAndPermissionsSeeder::class,
ShieldSeeder::class,
PermissionSeeder::class, PermissionSeeder::class,
DivisionSeeder::class, DivisionSeeder::class,
UserSeeder::class, UserSeeder::class,
+2 -1
View File
@@ -23,9 +23,10 @@ class PermissionSeeder extends Seeder
->where('name', 'not like', '%Permission%') ->where('name', 'not like', '%Permission%')
->get()); ->get());
// Bendahara: hanya kas + artikel sendiri // Bendahara: hanya kas + iuran + artikel sendiri
$bendahara->syncPermissions(Permission::where('name', 'like', '%CashRecord%') $bendahara->syncPermissions(Permission::where('name', 'like', '%CashRecord%')
->orWhere('name', 'like', '%CashCategory%') ->orWhere('name', 'like', '%CashCategory%')
->orWhere('name', 'like', '%MemberDue%')
->orWhereIn('name', ['ViewAny:Post', 'View:Post', 'Create:Post', 'Update:Post', 'Delete:Post']) ->orWhereIn('name', ['ViewAny:Post', 'View:Post', 'Create:Post', 'Update:Post', 'Delete:Post'])
->get()); ->get());
@@ -24,10 +24,10 @@ class RolesAndPermissionsSeeder extends Seeder
// super_admin mendapat semua permission via Shield config // super_admin mendapat semua permission via Shield config
$superAdmin = User::firstOrCreate( $superAdmin = User::firstOrCreate(
['email' => 'admin@persegi.id'], ['email' => 'admin@admin.com'],
[ [
'name' => 'Super Admin', 'name' => 'Super Admin',
'password' => bcrypt('password'), 'password' => bcrypt('admin'),
'phone' => '08123456789', 'phone' => '08123456789',
'status' => 'aktif', 'status' => 'aktif',
] ]
File diff suppressed because one or more lines are too long
+13
View File
@@ -22,6 +22,19 @@ class UserSeeder extends Seeder
['name' => 'Nur Hidayah', 'email' => 'anggota2@persegi.id', 'role' => 'anggota', 'division' => 'Humas'], ['name' => 'Nur Hidayah', 'email' => 'anggota2@persegi.id', 'role' => 'anggota', 'division' => 'Humas'],
]; ];
// super_admin mendapat semua permission via Shield config
$superAdmin = User::firstOrCreate(
['email' => 'admin@admin.com'],
[
'name' => 'Super Admin',
'password' => bcrypt('admin'),
'phone' => '08123456789',
'status' => 'aktif',
]
);
$superAdmin->assignRole('super_admin');
foreach ($users as $data) { foreach ($users as $data) {
$user = User::firstOrCreate( $user = User::firstOrCreate(
['email' => $data['email']], ['email' => $data['email']],