filament-admin / custom-fields
User Defined Custom Fields for Laravel Filament
Installs: 1
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 0
Forks: 0
Open Issues: 0
pkg:composer/filament-admin/custom-fields
Requires
- php: ^8.4
- filament/filament: ^4.0
- kirschbaum-development/eloquent-power-joins: ^4.0
- postare/blade-mdi: ^1.0
- spatie/laravel-data: ^4.0.0
- spatie/laravel-package-tools: ^1.15.0
Requires (Dev)
- larastan/larastan: ^3.0
- laravel/pint: ^1.0
- nunomaduro/collision: ^8.1
- orchestra/testbench: ^9.0
- pestphp/pest: ^4.0
- pestphp/pest-plugin-arch: ^4.0
- pestphp/pest-plugin-laravel: ^4.0
- pestphp/pest-plugin-livewire: ^4.0
- pestphp/pest-plugin-type-coverage: ^4
- phpstan/phpstan-deprecation-rules: *
- phpstan/phpstan-phpunit: ^2.0
- rector/rector: *
- spatie/laravel-ray: ^1.26
This package is not auto-updated.
Last update: 2025-11-27 21:04:39 UTC
README
A powerful Laravel/Filament plugin for adding dynamic custom fields to any Eloquent model without database migrations.
Features
- 20+ Field Types - Text, date, select, file upload, rich editor, and more
- Conditional Visibility - Show/hide fields based on other field values
- Multi-tenancy - Complete tenant isolation and context management
- Filament Integration - Forms, tables, infolists, and admin interface
- Import/Export - Built-in CSV capabilities
- Security - Optional field encryption and type-safe validation
- Extensible - Custom field types and automatic discovery
Requirements
- PHP 8.3+
- Laravel via Filament 4.0+
Getting Started
Integrating Custom Fields Plugin into a panel
use FilamentAdmin\CustomFields\CustomFieldsPlugin; use Filament\Panel; public function panel(Panel $panel): Panel { return $panel // ... other panel configurations ->plugins([ CustomFieldsPlugin::make(), ]); }
Setting Up the Model
Add the trait to your model:
use FilamentAdmin\CustomFields\Models\Contracts\HasCustomFields; use FilamentAdmin\CustomFields\Models\Concerns\UsesCustomFields; class Post extends Model implements HasCustomFields { use UsesCustomFields; }
Add to your Filament form:
use Filament\Schemas\Schema; use FilamentAdmin\CustomFields\Facades\CustomFields; public function form(Schema $schema): Form { return $schema->components([ // Your existing form fields... CustomFields::form()->forSchema($schema)->build() ]); }
Documentation
For complete installation instructions, configuration options, and examples, visit our documentation.
Licensing
This plugin is dual-licensed: Open Source (AGPL-3.0) for open source projects, and Commercial License for closed-source projects.
AGPL-3.0 requires your entire application to be open source. For private/closed-source projects, you need a commercial license.
Please take a look at our documentation for licensing details.
