Overview
Filament allows you to build dynamic dashboards, comprised of “widgets”, very easily. The following document will explain how to use these widgets to assemble a dashboard using the panel.Available widgets
Filament ships with these widgets:- Stats overview widgets display any data, often numeric data, as stats in a row.
- Chart widgets display numeric data in a visual chart.
- Table widgets which display a table on your dashboard.
Sorting widgets
Each widget class contains a$sort property that may be used to change its order on the page, relative to other widgets:
Customizing widget width
You may customize the width of a widget using the$columnSpan property. You may use a number between 1 and 12 to indicate how many columns the widget should span, or full to make it occupy the full width of the page:
Responsive widget widths
You may wish to change the widget width based on the responsive breakpoint of the browser. You can do this using an array that contains the number of columns that the widget should occupy at each breakpoint:Customizing the widgets’ grid
You may change how many grid columns are used to display widgets. Firstly, you must replace the original Dashboard page. Now, in your newapp/Filament/Pages/Dashboard.php file, you may override the getColumns() method to return a number of grid columns to use:
Responsive widgets grid
You may wish to change the number of widget grid columns based on the responsive breakpoint of the browser. You can do this using an array that contains the number of columns that should be used at each breakpoint:Conditionally hiding widgets
You may override the staticcanView() method on widgets to conditionally hide them:
Table widgets
You may easily add tables to your dashboard. Start by creating a widget with the command:Custom widgets
To get started building aBlogPostsOverview widget:
/Widgets directory of the Filament directory, and a view in the /widgets directory of the Filament views directory.
Filtering widget data
You may add a form to the dashboard that allows the user to filter the data displayed across all widgets. When the filters are updated, the widgets will be reloaded with the new data. Firstly, you must replace the original Dashboard page. Now, in your newapp/Filament/Pages/Dashboard.php file, you may add the HasFiltersForm trait, and add the filtersForm() method to return form components:
InteractsWithPageFilters trait, which will allow you to use the $this->filters property to access the raw data from the filters form:
$this->filters array will always reflect the current form data. Please note that this data is not validated, as it is available live and not intended to be used for anything other than querying the database. You must ensure that the data is valid before using it. In this example, we check if the start date is set before using it in the query.
Filtering widget data using an action modal
Alternatively, you can swap out the filters form for an action modal, that can be opened by clicking a button in the header of the page. There are many benefits to using this approach:- The filters form is not always visible, which allows you to use the full height of the page for widgets.
- The filters do not update the widgets until the user clicks the “Apply” button, which means that the widgets are not reloaded until the user is ready. This can improve performance if the widgets are expensive to load.
- Validation can be performed on the filters form, which means that the widgets can rely on the fact that the data is valid - the user cannot submit the form until it is. Canceling the modal will discard the user’s changes.
HasFiltersAction trait instead of HasFiltersForm. Then, register the FilterAction class as an action in getHeaderActions():
InteractsWithPageFilters trait still applies.
Persisting widget filters in the user’s session
By default, the dashboard filters applied will persist in the user’s session between page loads. To disable this, override the$persistsFiltersInSession property in the dashboard page class:
persistsFiltersInSession() method in the dashboard page class:
Disabling the default widgets
By default, two widgets are displayed on the dashboard. These widgets can be disabled by updating thewidgets() array of the configuration:
Customizing the dashboard page
If you want to customize the dashboard class, for example, to change the number of widget columns, create a new file atapp/Filament/Pages/Dashboard.php:
Dashboard class from configuration file:
Creating multiple dashboards
If you want to create multiple dashboards, you can do so by repeating the process described above. Creating new pages that extend theDashboard class will allow you to create as many dashboards as you need.
You will also need to define the URL path to the extra dashboard, otherwise it will be at /:
$title property:
canAccess() method), according to the defined navigation sort order.
The default sort order for dashboards is -2. You can control the sort order of custom dashboards with $navigationSort: