File: /home/posscale/public_html/printmanager/app/Filament/Resources/RoleResource.php
<?php
namespace App\Filament\Resources;
use App\Filament\Resources\RoleResource\Pages;
use Filament\Forms;
use Filament\Forms\Components\Select;
use Filament\Forms\Components\TextInput;
use Filament\Forms\Form;
use Filament\Resources\Resource;
use Filament\Tables;
use Filament\Tables\Columns\TagsColumn;
use Filament\Tables\Columns\TextColumn;
use Filament\Tables\Table;
use Spatie\Permission\Models\Permission;
use Spatie\Permission\Models\Role;
class RoleResource extends Resource
{
protected static ?string $model = Role::class;
protected static ?string $navigationIcon = 'heroicon-o-lock-closed';
protected static ?string $navigationGroup = 'Access Control';
protected static ?int $navigationSort = 1;
public static function canViewAny(): bool
{
// Only show in central (super-admin) panel
return app()->request->getHost() === env('APP_CENTRAL_DOMAIN');
}
public static function form(Form $form): Form
{
return $form
->schema([
TextInput::make('name')
->label('Role Name')
->required()
->unique(ignoreRecord: true),
Select::make('permissions')
->label('Permissions')
->multiple()
->relationship('permissions', 'name')
->preload(),
]);
}
public static function table(Table $table): Table
{
return $table
->columns([
TextColumn::make('name')->sortable()->searchable(),
TagsColumn::make('permissions.name')->label('Permissions'),
])
->filters([
//
])
->actions([
Tables\Actions\EditAction::make(),
])
->bulkActions([
Tables\Actions\DeleteBulkAction::make(),
]);
}
public static function getRelations(): array
{
return [
//
];
}
public static function getPages(): array
{
return [
'index' => Pages\ListRoles::route('/'),
'create' => Pages\CreateRole::route('/create'),
'edit' => Pages\EditRole::route('/{record}/edit'),
];
}
}