Skip to main content
Glama
brianirish

Laravel 12 Docs MCP Server

by brianirish
forms-layout-tabs.md6.07 kB
# Filament - Forms/Layout/Tabs Source: https://filamentphp.com/docs/3.x/forms/layout/tabs #Overview --------- Some forms can be long and complex. You may want to use tabs to reduce the number of components that are visible at once: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Tab 1') ->schema([ // ... ]), Tabs\Tab::make('Tab 2') ->schema([ // ... ]), Tabs\Tab::make('Tab 3') ->schema([ // ... ]), ]) ``` ![Tabs](/docs/3.x/images/light/forms/layout/tabs/simple.jpg) ![Tabs](/docs/3.x/images/dark/forms/layout/tabs/simple.jpg) #Setting the default active tab ------------------------------- The first tab will be open by default. You can change the default open tab using the `activeTab()` method: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Tab 1') ->schema([ // ... ]), Tabs\Tab::make('Tab 2') ->schema([ // ... ]), Tabs\Tab::make('Tab 3') ->schema([ // ... ]), ]) ->activeTab(2) ``` #Setting a tab icon ------------------- Tabs may have an icon, which you can set using the `icon()` method: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Notifications') ->icon('heroicon-m-bell') ->schema([ // ... ]), // ... ]) ``` ![Tabs with icons](/docs/3.x/images/light/forms/layout/tabs/icons.jpg) ![Tabs with icons](/docs/3.x/images/dark/forms/layout/tabs/icons.jpg) ### #Setting the tab icon position The icon of the tab may be positioned before or after the label using the `iconPosition()` method: ```php use Filament\Forms\Components\Tabs; use Filament\Support\Enums\IconPosition; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Notifications') ->icon('heroicon-m-bell') ->iconPosition(IconPosition::After) ->schema([ // ... ]), // ... ]) ``` ![Tabs with icons after their labels](/docs/3.x/images/light/forms/layout/tabs/icons-after.jpg) ![Tabs with icons after their labels](/docs/3.x/images/dark/forms/layout/tabs/icons-after.jpg) #Setting a tab badge -------------------- Tabs may have a badge, which you can set using the `badge()` method: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Notifications') ->badge(5) ->schema([ // ... ]), // ... ]) ``` ![Tabs with badges](/docs/3.x/images/light/forms/layout/tabs/badges.jpg) ![Tabs with badges](/docs/3.x/images/dark/forms/layout/tabs/badges.jpg) If you’d like to change the color for a badge, you can use the `badgeColor()` method: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Notifications') ->badge(5) ->badgeColor('success') ->schema([ // ... ]), // ... ]) ``` #Using grid columns within a tab -------------------------------- You may use the `columns()` method to customize the grid within the tab: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Tab 1') ->schema([ // ... ]) ->columns(3), // ... ]) ``` #Removing the styled container ------------------------------ By default, tabs and their content are wrapped in a container styled as a card. You may remove the styled container using `contained()`: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Tab 1') ->schema([ // ... ]), Tabs\Tab::make('Tab 2') ->schema([ // ... ]), Tabs\Tab::make('Tab 3') ->schema([ // ... ]), ]) ->contained(false) ``` #Persisting the current tab --------------------------- By default, the current tab is not persisted in the browser’s local storage. You can change this behavior using the `persistTab()` method. You must also pass in a unique `id()` for the tabs component, to distinguish it from all other sets of tabs in the app. This ID will be used as the key in the local storage to store the current tab: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ // ... ]) ->persistTab() ->id('order-tabs') ``` ### #Persisting the current tab in the URL’s query string By default, the current tab is not persisted in the URL’s query string. You can change this behavior using the `persistTabInQueryString()` method: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Tab 1') ->schema([ // ... ]), Tabs\Tab::make('Tab 2') ->schema([ // ... ]), Tabs\Tab::make('Tab 3') ->schema([ // ... ]), ]) ->persistTabInQueryString() ``` By default, the current tab is persisted in the URL’s query string using the `tab` key. You can change this key by passing it to the `persistTabInQueryString()` method: ```php use Filament\Forms\Components\Tabs; Tabs::make('Tabs') ->tabs([ Tabs\Tab::make('Tab 1') ->schema([ // ... ]), Tabs\Tab::make('Tab 2') ->schema([ // ... ]), Tabs\Tab::make('Tab 3') ->schema([ // ... ]), ]) ->persistTabInQueryString('settings-tab') ``` Edit on GitHub Still need help? Join our Discord community or open a GitHub discussion

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/brianirish/laravel-docs-mcp'

If you have feedback or need assistance with the MCP directory API, please join our Discord server