guava/filament-icon-select-column

Adds a icon select (via dropdown) column to your filament tables.

Fund package maintenance!
GuavaCZ

Installs: 168

Dependents: 0

Suggesters: 0

Security: 0

Stars: 30

Watchers: 3

Forks: 3

Open Issues: 0

Language:Blade

1.1.0 2024-12-02 14:08 UTC

This package is auto-updated.

Last update: 2025-01-02 14:19:48 UTC


README

Filament Icon Select Column Banner

Adds a icon select (via dropdown) column to your filament tables.

Latest Version on Packagist GitHub Tests Action Status GitHub Code Style Action Status Total Downloads

This plugin adds an Icon Select Column to your filament tables.

Showcase

Screen.Recording.2024-12-01.at.18.35.41.mov

Screenshot 1

Support us

Your support is key to the continual advancement of our plugin. We appreciate every user who has contributed to our journey so far.

While our plugin is available for all to use, if you are utilizing it for commercial purposes and believe it adds significant value to your business, we kindly ask you to consider supporting us through GitHub Sponsors. This sponsorship will assist us in continuous development and maintenance to keep our plugin robust and up-to-date. Any amount you contribute will greatly help towards reaching our goals. Join us in making this plugin even better and driving further innovation.

Installation

You can install the package via composer:

composer require guava/filament-icon-select-column

Usage

In any filament table, simply use it like any other column.

The package works best in combination with backed enums, such as in the below example.

The enum should implement HasLabel, HasIcon and optionally HasColor as described in the filament documentation here.

use Guava\FilamentIconSelectColumn\Tables\Columns\IconSelectColumn;

$table->columns([
    IconSelectColumn::make('state')
        ->options(MyStateEnum::class)
]);

Alternatively, you can pass an array of options and icons directly to the column:

$table->columns([
    IconSelectColumn::make('state')
        ->options([
            'opt1' => 'Option 1',
            'opt2' => 'Option 2',
        ])
        ->icons([
            'opt1' => 'heroicon-o-check',
            'opt2' => 'heroicon-o-x-mark',
        ])
]);

Close on selection

If you want the dropdown to automatically close after you select an option, you can use the closeOnSelection method:

use Guava\FilamentIconSelectColumn\Tables\Columns\IconSelectColumn;

IconSelectColumn::make('state')
    ->closeOnSelection()
    // ...

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.