mirror of
https://github.com/pelican-dev/panel.git
synced 2025-06-11 00:58:59 +02:00

* add spatie/permissions * add policies * add role resource * add root admin role handling * replace some "root_admin" with function * add model specific permissions * make permission selection nicer * fix user creation * fix tests * add back subuser checks in server policy * add custom model for role * assign new users to role if root_admin is set * add api for roles * fix phpstan * add permissions for settings page * remove "restore" and "forceDelete" permissions * add user count to list * prevent deletion if role has users * update user list * fix server policy * remove old `root_admin` column * small refactor * fix tests * forgot can checks here * forgot use * disable editing own roles & disable assigning root admin * don't allow to rename root admin role * remove php bombing exception handler * fix role assignment when creating a user * fix disableOptionWhen * fix missing `root_admin` attribute on react frontend * add permission check for bulk delete * rename viewAny to viewList * improve canAccessPanel check * fix admin not displaying for non-root admins * make sure non root admins can't edit root admins * fix import * fix settings page permission check * fix server permissions for non-subusers * fix settings page permission check v2 * small cleanup * cleanup config file * move consts from resouce into enum & model * Update database/migrations/2024_08_01_114538_remove_root_admin_column.php Co-authored-by: Lance Pioch <lancepioch@gmail.com> * fix config * fix phpstan * fix phpstan 2.0 --------- Co-authored-by: Lance Pioch <lancepioch@gmail.com>
69 lines
2.2 KiB
PHP
69 lines
2.2 KiB
PHP
<?php
|
|
|
|
namespace App\Filament\Resources\RoleResource\Pages;
|
|
|
|
use App\Filament\Resources\RoleResource;
|
|
use App\Models\Role;
|
|
use Filament\Actions\CreateAction;
|
|
use Filament\Resources\Pages\ListRecords;
|
|
use Filament\Tables\Actions\BulkActionGroup;
|
|
use Filament\Tables\Actions\CreateAction as CreateActionTable;
|
|
use Filament\Tables\Actions\DeleteBulkAction;
|
|
use Filament\Tables\Actions\EditAction;
|
|
use Filament\Tables\Columns\TextColumn;
|
|
use Filament\Tables\Table;
|
|
|
|
class ListRoles extends ListRecords
|
|
{
|
|
protected static string $resource = RoleResource::class;
|
|
|
|
public function table(Table $table): Table
|
|
{
|
|
return $table
|
|
->columns([
|
|
TextColumn::make('name')
|
|
->sortable()
|
|
->searchable(),
|
|
TextColumn::make('guard_name')
|
|
->hidden()
|
|
->sortable()
|
|
->searchable(),
|
|
TextColumn::make('permissions_count')
|
|
->label('Permissions')
|
|
->badge()
|
|
->counts('permissions')
|
|
->formatStateUsing(fn (Role $role, $state) => $role->isRootAdmin() ? 'All' : $state),
|
|
TextColumn::make('users_count')
|
|
->label('Users')
|
|
->counts('users')
|
|
->icon('tabler-users'),
|
|
])
|
|
->actions([
|
|
EditAction::make(),
|
|
])
|
|
->checkIfRecordIsSelectableUsing(fn (Role $role) => !$role->isRootAdmin() && $role->users_count <= 0)
|
|
->bulkActions([
|
|
BulkActionGroup::make([
|
|
DeleteBulkAction::make()
|
|
->authorize(fn () => auth()->user()->can('delete role')),
|
|
]),
|
|
])
|
|
->emptyStateIcon('tabler-users-group')
|
|
->emptyStateDescription('')
|
|
->emptyStateHeading('No Roles')
|
|
->emptyStateActions([
|
|
CreateActionTable::make('create')
|
|
->label('Create Role')
|
|
->button(),
|
|
]);
|
|
}
|
|
|
|
protected function getHeaderActions(): array
|
|
{
|
|
return [
|
|
CreateAction::make()
|
|
->label('Create Role'),
|
|
];
|
|
}
|
|
}
|