Back to Filament

Toggle

packages/forms/docs/05-toggle.md

5.6.24.7 KB
Original Source

import AutoScreenshot from "@components/AutoScreenshot.astro" import UtilityInjection from "@components/UtilityInjection.astro"

Introduction

The toggle component, similar to a checkbox, allows you to interact a boolean value.

php
use Filament\Forms\Components\Toggle;

Toggle::make('is_admin')
<AutoScreenshot name="forms/fields/toggle/simple" alt="Toggle" version="5.x" />

If you're saving the boolean value using Eloquent, you should be sure to add a boolean cast to the model property:

php
use Illuminate\Database\Eloquent\Model;

class User extends Model
{
    /**
     * @return array<string, string>
     */
    protected function casts(): array
    {
        return [
            'is_admin' => 'boolean',
        ];
    }

    // ...
}

Adding icons to the toggle button

Toggles may also use an icon to represent the "on" and "off" state of the button. To add an icon to the "on" state, use the onIcon() method. To add an icon to the "off" state, use the offIcon() method:

php
use Filament\Forms\Components\Toggle;
use Filament\Support\Icons\Heroicon;

Toggle::make('is_admin')
    ->onIcon(Heroicon::Bolt)
    ->offIcon(Heroicon::User)

<UtilityInjection set="formFields" version="5.x">As well as allowing static values, the onIcon() and offIcon() methods also accept functions to dynamically calculate them. You can inject various utilities into the function as parameters.</UtilityInjection>

<AutoScreenshot name="forms/fields/toggle/icons" alt="Toggle icons" version="5.x" />

Customizing the color of the toggle button

You may also customize the color representing the "on" or "off" state of the toggle. To add a color to the "on" state, use the onColor() method. To add a color to the "off" state, use the offColor() method:

php
use Filament\Forms\Components\Toggle;

Toggle::make('is_admin')
    ->onColor('success')
    ->offColor('danger')

<UtilityInjection set="formFields" version="5.x">As well as allowing static values, the onColor() and offColor() methods also accept functions to dynamically calculate them. You can inject various utilities into the function as parameters.</UtilityInjection>

<AutoScreenshot name="forms/fields/toggle/off-color" alt="Toggle off color" version="5.x" /> <AutoScreenshot name="forms/fields/toggle/on-color" alt="Toggle on color" version="5.x" />

Positioning the label above

Toggle fields have two layout modes, inline and stacked. By default, they are inline.

When the toggle is inline, its label is adjacent to it:

php
use Filament\Forms\Components\Toggle;

Toggle::make('is_admin')
    ->inline()
<AutoScreenshot name="forms/fields/toggle/inline" alt="Toggle with its label inline" version="5.x" />

When the toggle is stacked, its label is above it:

php
use Filament\Forms\Components\Toggle;

Toggle::make('is_admin')
    ->inline(false)

<UtilityInjection set="formFields" version="5.x">As well as allowing a static value, the inline() method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters.</UtilityInjection>

<AutoScreenshot name="forms/fields/toggle/not-inline" alt="Toggle with its label above" version="5.x" />

Toggle validation

As well as all rules listed on the validation page, there are additional rules that are specific to toggles.

Accepted validation

You may ensure that the toggle is "on" using the accepted() method:

php
use Filament\Forms\Components\Toggle;

Toggle::make('terms_of_service')
    ->accepted()

Optionally, you may pass a boolean value to control if the validation rule should be applied or not:

php
use Filament\Forms\Components\Toggle;

Toggle::make('terms_of_service')
    ->accepted(FeatureFlag::active())

<UtilityInjection set="formFields" version="5.x">As well as allowing a static value, the accepted() method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters.</UtilityInjection>

Declined validation

You may ensure that the toggle is "off" using the declined() method:

php
use Filament\Forms\Components\Toggle;

Toggle::make('is_under_18')
    ->declined()

Optionally, you may pass a boolean value to control if the validation rule should be applied or not:

php
use Filament\Forms\Components\Toggle;

Toggle::make('is_under_18')
    ->declined(FeatureFlag::active())

<UtilityInjection set="formFields" version="5.x">As well as allowing a static value, the declined() method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters.</UtilityInjection>