Table Repeater Plugin
Installation
You can install the package via composer:
composer require awcodes/filament-table-repeater
In an effort to align with Filament's theming methodology you will need to use a custom theme to use this plugin.
Note If you have not set up a custom theme and are using a Panel follow the instructions in the Filament Docs first. The following applies to both the Panels Package and the standalone Forms package.
- Import the plugin's stylesheet in your theme's css file.
@import '<path-to-vendor>/vendor/awcodes/filament-table-repeater/resources/css/plugin.css';
- Add the plugin's views to your
tailwind.config.js
file.
content: [
'<path-to-vendor>/awcodes/filament-table-repeater/resources/**/*.blade.php',
]
Usage
This field has most of the same functionality of the Filament Forms Repeater field. The main exception is that this field can not be collapsed.
TableRepeater::make('social')
->schema([
Select::make('platform')
->hiddenLabel()
->options([
'facebook' => 'Facebook',
'twitter' => 'Twitter',
'instagram' => 'Instagram'
]),
TextInput::make('handle')
->hiddenLabel(),
])
->columnSpan('full')
By default, Table Repeater will automatically create the table headers from your schema labels. This can be overridden by simply passing an array of your desired headers to the headers()
method.
TableRepeater::make('social')
->headers(['Platform', 'Handle'])
To change the headers alignment use the alignHeaders('center')
method.
TableRepeater::make('social')
->alignHeaders('center')
Labels
To automatically hide all the labels of the fields in the table use the hideLabels()
method.
TableRepeater::make('social')
->hideLabels()
Empty State Label
To customize the text shown when the table is empty, use the emptyLabel()
method.
TableRepeater::make('social')
->emptyLabel('There is no platform registered.')
Alternatively, you can hide the empty label with emptyLabel(false)
.
Without Header
Sometimes we don't want to have the table header at all. To achieve this, use the withoutHeader()
method.
TableRepeater::make('social')
->withoutHeader()
Column Widths
To set the width of columns in the table use the columnWidths()
method.
Widths should be set in px as a string. For fields that don't have names, such as Actions
and Group
, you have to give it an explicit id to target.
TableRepeater::make('social')
->columnWidths([
'platform' => '200px',
'action_field' => '100px',
])
->schema([
Select::make('platform'), // will be 200px wide
TextInput::make('handle'), // will be default stretched width
Actions::make([
...
])->id('action_field'), // will be 100px wide
])
Break Point
Below a specific break point the table will render as a set of panels to
make working with data easier on mobile devices. The default is 'md', but
can be overridden with the breakPoint()
method.
TableRepeater::make('social')
->breakPoint('sm') // accepts Tailwind CSS screen sizes
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.