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 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,12 +31,19 @@ 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 [
|
||||||
'index' => ListMemberDues::route('/'),
|
'index' => ListMemberDues::route('/'),
|
||||||
'create' => CreateMemberDue::route('/create'),
|
'create' => CreateMemberDue::route('/create'),
|
||||||
'edit' => EditMemberDue::route('/{record}/edit'),
|
'edit' => EditMemberDue::route('/{record}/edit'),
|
||||||
];
|
];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
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,
|
||||||
])
|
])
|
||||||
|
|||||||
@@ -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,
|
||||||
|
|||||||
@@ -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
@@ -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']],
|
||||||
|
|||||||
Reference in New Issue
Block a user