Claude-skill-registry filament-resource
Generate FilamentPHP v4 resources with form, table, relation managers, and actions
install
source · Clone the upstream repo
git clone https://github.com/majiayu000/claude-skill-registry
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/majiayu000/claude-skill-registry "$T" && mkdir -p ~/.claude/skills && cp -r "$T/skills/data/filament-resource" ~/.claude/skills/majiayu000-claude-skill-registry-filament-resource && rm -rf "$T"
manifest:
skills/data/filament-resource/SKILL.mdsource content
FilamentPHP Resource Generation Skill
Overview
This skill generates complete FilamentPHP v4 resources including form schemas, table configurations, relation managers, and custom pages. All generated code follows official documentation patterns.
Documentation Reference
CRITICAL: Before generating any resource, read:
/home/mwguerra/projects/mwguerra/claude-code-plugins/filament-specialist/skills/filament-docs/references/general/03-resources//home/mwguerra/projects/mwguerra/claude-code-plugins/filament-specialist/skills/filament-docs/references/forms//home/mwguerra/projects/mwguerra/claude-code-plugins/filament-specialist/skills/filament-docs/references/tables/
Workflow
Step 1: Gather Requirements
Identify:
- Model name and namespace
- Fields to include in form
- Columns to display in table
- Relationships to manage
- Custom actions needed
- Authorization requirements
Step 2: Generate Base Resource
Use Laravel artisan to create the resource:
# Basic resource php artisan make:filament-resource ModelName # With generate flag (creates form/table from model) php artisan make:filament-resource ModelName --generate # Soft deletes support php artisan make:filament-resource ModelName --soft-deletes # View page only php artisan make:filament-resource ModelName --view # Simple resource (modal forms instead of pages) php artisan make:filament-resource ModelName --simple
Step 3: Customize Form Schema
Read form field documentation and implement:
use Filament\Forms; use Filament\Forms\Form; public static function form(Form $form): Form { return $form ->schema([ Forms\Components\Section::make('Basic Information') ->schema([ Forms\Components\TextInput::make('name') ->required() ->maxLength(255), Forms\Components\Textarea::make('description') ->rows(3) ->columnSpanFull(), ]), Forms\Components\Section::make('Settings') ->schema([ Forms\Components\Toggle::make('is_active') ->default(true), Forms\Components\Select::make('status') ->options([ 'draft' => 'Draft', 'published' => 'Published', ]), ]), ]); }
Step 4: Customize Table
Read table documentation and implement:
use Filament\Tables; use Filament\Tables\Table; public static function table(Table $table): Table { return $table ->columns([ Tables\Columns\TextColumn::make('name') ->searchable() ->sortable(), Tables\Columns\IconColumn::make('is_active') ->boolean(), Tables\Columns\BadgeColumn::make('status') ->colors([ 'warning' => 'draft', 'success' => 'published', ]), Tables\Columns\TextColumn::make('created_at') ->dateTime() ->sortable() ->toggleable(isToggledHiddenByDefault: true), ]) ->filters([ Tables\Filters\SelectFilter::make('status') ->options([ 'draft' => 'Draft', 'published' => 'Published', ]), Tables\Filters\TernaryFilter::make('is_active'), ]) ->actions([ Tables\Actions\ViewAction::make(), Tables\Actions\EditAction::make(), Tables\Actions\DeleteAction::make(), ]) ->bulkActions([ Tables\Actions\BulkActionGroup::make([ Tables\Actions\DeleteBulkAction::make(), ]), ]); }
Step 5: Add Relation Managers
For relationships, create relation managers:
php artisan make:filament-relation-manager ResourceName RelationName column_name
Register in resource:
public static function getRelations(): array { return [ RelationManagers\CommentsRelationManager::class, RelationManagers\TagsRelationManager::class, ]; }
Step 6: Configure Pages
Define resource pages:
public static function getPages(): array { return [ 'index' => Pages\ListModels::route('/'), 'create' => Pages\CreateModel::route('/create'), 'view' => Pages\ViewModel::route('/{record}'), 'edit' => Pages\EditModel::route('/{record}/edit'), ]; }
Step 7: Add Authorization
Implement policy methods:
public static function canViewAny(): bool { return auth()->user()->can('view_any_model'); } public static function canCreate(): bool { return auth()->user()->can('create_model'); }
Form Field Reference
Text Fields
- Single line textTextInput::make()
- Multi-line textTextarea::make()
- WYSIWYG editorRichEditor::make()
- Markdown editorMarkdownEditor::make()
Selection Fields
- Dropdown selectSelect::make()
- Radio buttonsRadio::make()
- Single checkboxCheckbox::make()
- Multiple checkboxesCheckboxList::make()
- Toggle switchToggle::make()
Date/Time Fields
- Date onlyDatePicker::make()
- Date and timeDateTimePicker::make()
- Time onlyTimePicker::make()
File Fields
- File uploadFileUpload::make()
- Media librarySpatieMediaLibraryFileUpload::make()
Relationship Fields
- BelongsTo selectSelect::make()->relationship()
- BelongsToManyCheckboxList::make()->relationship()
- HasMany inlineRepeater::make()->relationship()
Layout Components
- Card sectionSection::make()
- Fieldset groupingFieldset::make()
- Tabbed sectionsTabs::make()
- Grid layoutGrid::make()
- Split layoutSplit::make()
Table Column Reference
Text Columns
- Basic textTextColumn::make()
- Boolean iconIconColumn::make()
- Image thumbnailImageColumn::make()
- Badge stylingBadgeColumn::make()
- Color swatchColorColumn::make()
Column Modifiers
- Enable search->searchable()
- Enable sort->sortable()
- Can hide/show->toggleable()
- Wrap text->wrap()
- Truncate text->limit()
Output
For each resource, generate:
- Resource class -
app/Filament/Resources/ModelResource.php - Pages -
app/Filament/Resources/ModelResource/Pages/ - Relation Managers -
app/Filament/Resources/ModelResource/RelationManagers/ - Test file -
tests/Feature/Filament/ModelResourceTest.php