fix: perbaiki type navigationGroup MemberDue, tambah MemberDuePolicy, update PermissionSeeder untuk iuran, update README deployment
This commit is contained in:
@@ -160,6 +160,7 @@ php artisan config:cache
|
||||
php artisan route:cache
|
||||
php artisan view:cache
|
||||
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\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,6 +31,13 @@ class MemberDueResource extends Resource
|
||||
return MemberDuesTable::configure($table);
|
||||
}
|
||||
|
||||
public static function getRelations(): array
|
||||
{
|
||||
return [
|
||||
//
|
||||
];
|
||||
}
|
||||
|
||||
public static function getPages(): array
|
||||
{
|
||||
return [
|
||||
|
||||
@@ -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
|
||||
|
||||
@@ -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');
|
||||
}
|
||||
|
||||
}
|
||||
@@ -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,
|
||||
])
|
||||
|
||||
@@ -9,7 +9,8 @@ class DatabaseSeeder extends Seeder
|
||||
public function run(): void
|
||||
{
|
||||
$this->call([
|
||||
RolesAndPermissionsSeeder::class,
|
||||
// RolesAndPermissionsSeeder::class,
|
||||
ShieldSeeder::class,
|
||||
PermissionSeeder::class,
|
||||
DivisionSeeder::class,
|
||||
UserSeeder::class,
|
||||
|
||||
@@ -23,9 +23,10 @@ class PermissionSeeder extends Seeder
|
||||
->where('name', 'not like', '%Permission%')
|
||||
->get());
|
||||
|
||||
// Bendahara: hanya kas + artikel sendiri
|
||||
// Bendahara: hanya kas + iuran + artikel sendiri
|
||||
$bendahara->syncPermissions(Permission::where('name', 'like', '%CashRecord%')
|
||||
->orWhere('name', 'like', '%CashCategory%')
|
||||
->orWhere('name', 'like', '%MemberDue%')
|
||||
->orWhereIn('name', ['ViewAny:Post', 'View:Post', 'Create:Post', 'Update:Post', 'Delete:Post'])
|
||||
->get());
|
||||
|
||||
|
||||
@@ -24,10 +24,10 @@ class RolesAndPermissionsSeeder extends Seeder
|
||||
|
||||
// super_admin mendapat semua permission via Shield config
|
||||
$superAdmin = User::firstOrCreate(
|
||||
['email' => 'admin@persegi.id'],
|
||||
['email' => 'admin@admin.com'],
|
||||
[
|
||||
'name' => 'Super Admin',
|
||||
'password' => bcrypt('password'),
|
||||
'password' => bcrypt('admin'),
|
||||
'phone' => '08123456789',
|
||||
'status' => 'aktif',
|
||||
]
|
||||
|
||||
File diff suppressed because one or more lines are too long
@@ -22,6 +22,19 @@ class UserSeeder extends Seeder
|
||||
['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) {
|
||||
$user = User::firstOrCreate(
|
||||
['email' => $data['email']],
|
||||
|
||||
Reference in New Issue
Block a user