mirror of
				https://github.com/pelican-dev/panel.git
				synced 2025-11-04 06:26:52 +01: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'),
 | 
						|
        ];
 | 
						|
    }
 | 
						|
}
 |