Badgeable Column
Display additional context as badges alongside your Filament table column values.
Author:
Adam Weston
Documentation
- Compatibility
- Installation
- Usage
- Badge Shape
- Separator
- Font Family
- Font Weight
- Size
- Changelog
- Contributing
- Security Vulnerabilities
- Credits
- License
Display additional context as badges alongside your Filament table column values.
#Compatibility
| Package Version | Filament Version |
|---|---|
| 1.x | 2.x |
| 2.x | 3.x |
| 3.x | 4.x |
| 4.x | 5.x |
#Installation
You can install the package via composer:
composer require awcodes/filament-badgeable-column
[!IMPORTANT] If you have not set up a custom theme and are using Filament Panels follow the instructions in the Filament Docs first. The following applies to both the Panels Package and the standalone Tables package.
After setting up a custom theme add the plugin's views to your theme css file or your app's css file if using the standalone tables package.
@source '../../../../vendor/awcodes/filament-badgeable-column/resources/**/*.blade.php';
#Usage
use Awcodes\BadgeableColumn\Components\Badge;
use Awcodes\BadgeableColumn\Components\BadgeableColumn;
return $table
->columns([
BadgeableColumn::make('name')
->prefixBadges([
Badge::make('brand_name')
->label(fn(Model $record) => $record->status)
->color(function(Model $record) {
return match ($record->status) {
'active' => 'success',
'inactive' => 'danger',
default => 'warning',
};
})
])
->suffixBadges([
Badge::make('hot')
->label('Hot')
->color('danger')
->visible(fn(Model $record) => $record->qty < 5),
]),
]);
You can also define the array of badges via a closure, if you want the array of badges to be based on dynamic data. The closure should return an array of Badge objects, similar to above.
The example below assumes the records have a BelongsToMany relationship called topics, and shows how to display each topic name as a badge.
use Awcodes\BadgeableColumn\Components\Badge;
use Awcodes\BadgeableColumn\Components\BadgeableColumn;
return $table
->columns([
BadgeableColumn::make('title')
->suffixBadges(function($record) {
return $record->topics->map(function($topic) {
return Badge::make($topic->name)->color($topic->color);
});
})
->searchable()
->sortable(),
]);
#Badge Shape
If you prefer to have a more "rounded" shape you can use the asPills() method to set the shape of the badges.
use Awcodes\BadgeableColumn\Components\Badge;
use Awcodes\BadgeableColumn\Components\BadgeableColumn;
return $table
->columns([
BadgeableColumn::make('name')
->asPills()
]);
#Separator
The default separator between the column text and the badges is '—'. If you would like to use a different separator, use the separator() method to set a character to be used as a separator.
use Awcodes\BadgeableColumn\Components\Badge;
use Awcodes\BadgeableColumn\Components\BadgeableColumn;
return $table
->columns([
BadgeableColumn::make('name')
->separator(':')
]);
#Font Family
If you would like to use a different font family for the badges, you can use the fontFamily() method to set the font family.
use Awcodes\BadgeableColumn\Components\Badge;
use Awcodes\BadgeableColumn\Components\BadgeableColumn;
use Filament\Support\Enums\FontFamily;
return $table
->columns([
BadgeableColumn::make('name')
->fontFamily(FontFamily::Mono)
]);
#Font Weight
If you would like to use a different font weight for the badges, you can use the weight() method to set the font weight.
use Awcodes\BadgeableColumn\Components\Badge;
use Awcodes\BadgeableColumn\Components\BadgeableColumn;
use Filament\Support\Enums\FontWeight;
return $table
->columns([
BadgeableColumn::make('name')
->weight(FontWeight::Bold)
]);
#Size
If you would like to use a different size for the badges, you can use the size() method to set the size.
use Awcodes\BadgeableColumn\Components\Badge;
use Awcodes\BadgeableColumn\Components\BadgeableColumn;
use Filament\Support\Enums\Size;
return $table
->columns([
BadgeableColumn::make('name')
->size(Size::Small)
]);
#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.
The author
Adam is a full-stack web developer (with a focus on Laravel) who has been coding for close to 20 years. He is a core Filament team member as well and has authored numerous plugins for Filament such as Curator, Tiptap Editor and Table Repeater, to name a few. You can learn more about Adam on his website.
From the same author
Recently
Easily track and access recently viewed records in your filament panels.
Author:
Adam Weston
Sticky Header
A Filament Panels plugin to make headers sticky when scrolling.
Author:
Adam Weston
Table Repeater
A modified version of the Filament Forms Repeater to display it as a table.
Author:
Adam Weston
Versions
A mostly useless package to display framework versions on Filament panels.
Author:
Adam Weston
Featured Plugins
A selection of plugins curated by the Filament team
Custom Dashboards
Let your users build and share their own dashboards with a drag-and-drop interface. Define your data sources in PHP and let them do the rest.
Filament
Custom Fields
Eliminate custom field migrations forever. Let your users create and manage form fields directly in Filament admin panels with 20+ built-in field types, validation, and zero database changes.
Relaticle
Data Lens
Advanced Data Visualization for Laravel Filament - a premium reporting solution enabling custom column creation, sophisticated filtering, and enterprise-grade data insights within admin panels.
Padmission