icetalker / filament-table-repeater
This is a package for Filament form component. Extends form Repeater, but shows in Table Layout.
Fund package maintenance!
paypal.me/termlong
Installs: 79 814
Dependents: 0
Suggesters: 0
Security: 0
Stars: 119
Watchers: 2
Forks: 21
Open Issues: 9
Requires
- php: ^8.0
- filament/forms: ^3.0
- illuminate/contracts: ^8.6|^9.0|^10.0|^11.0
- spatie/laravel-package-tools: ^1.9.2
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.8
- nunomaduro/collision: ^6.0|^8.0
- nunomaduro/larastan: ^2.0.1
- orchestra/testbench: ^7.0|^9.0
- pestphp/pest: ^1.21|^2.34
- pestphp/pest-plugin-laravel: ^1.1|^2.3
- phpstan/extension-installer: ^1.1
- phpstan/phpstan-deprecation-rules: ^1.0
- phpstan/phpstan-phpunit: ^1.0
- phpunit/phpunit: ^9.5|^10.5
- spatie/laravel-ray: ^1.26
README
Repeater Component in Table layout for Filament Package
This is a package for Filament form component. Extends from Repeater, but display in Table Layout.
Installation
You can install the package via composer:
composer require icetalker/filament-table-repeater
You can publish the views using
php artisan vendor:publish --tag="filament-table-repeater"
Usage
use Icetalker\FilamentTableRepeater\Forms\Components\TableRepeater; protected function form(Form $form): Form { return $form->schema([ ... TableRepeater::make('items') ->relationship('items') ->schema([ Forms\Components\TextInput::make('product'), ... ]) ->reorderable() ->cloneable() ->collapsible() ->minItems(3) ->maxItems(5) ->columnSpan('full'), ]); }
Since this component extends from
Filament\Forms\Components\Repeater
, you can use most of its methods, except for a few methods likeinset()
,grid()
,columns()
.
Other methods
colStyles
To customize styles for each cell, you can pass an array of component name as key and css style as value to colStyles()
. See example below:
use Icetalker\FilamentTableRepeater\Forms\Components\TableRepeater; protected function form(Form $form): Form { return $form->schema([ ... Forms\Components\Grid::make(1)->schema([ TableRepeater::make('items') ->relationship('items') ->schema([ Forms\Components\TextInput::make('product'), Forms\Components\TextInput::make('quantity'), ... ]) ->colStyles([ 'product' => 'color: #0000ff; width: 250px;', ]), ]), ]); }
Besides, you can also pass a callback function to colStyles()
. This may unlock more customization possibilities. See example below:
use Icetalker\FilamentTableRepeater\Forms\Components\TableRepeater; protected function form(Form $form): Form { return $form ->schema([ ... Forms\Components\Grid::make(1)->schema([ TableRepeater::make('items') ->relationship('items') ->schema([ Forms\Components\TextInput::make('product'), Forms\Components\TextInput::make('quantity'), ... ]) ->colStyles(function(){ return [ 'product' => 'color: #0000ff; width: 250px;', ] }), ]), ]); }
Style customization
Besides the colStyles()
method mentioned above, we use few css classes to provide extra ability for style customization. These classes were so called CSS "hook" classes. They are prefixed with it-
(short for icetalker
, which is the vendor name). Although we already have hook classes in old version, it's never been documented here. And for now, we rename these hook name by the new prefix it-
:
it-table-repeater
instead offilament-table-repeater
in old version: As what you can tell from the class name, it allows you to customize the style for the whole table.it-table-repeater-cell-label
instead offilament-table-repeater-header-cell
in old version: As what you can tell from the class name, it allows you to customize the style for the label of each column.it-table-repeater-cell
instead offilament-table-repeater-tbody-cell
in old version: As what you can tell from the class name, it allows you to customize the style for the cell of each column.it-table-repeater-row
. This is new hook class, so that you can customize the style for each row.
You may add CSS to these classes in your app.css
file, and filled with your own styles like this:
.it-table-repeater-cell-label { background-color: #fafafa; }
Testing
composer test
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Security Vulnerabilities
Please review our security policy on how to report security vulnerabilities.
Credits
License
The MIT License (MIT). Please see License File for more information.