--- title: Wizards --- import Aside from "@components/Aside.astro" import AutoScreenshot from "@components/AutoScreenshot.astro" import UtilityInjection from "@components/UtilityInjection.astro" ## Introduction Similar to [tabs](tabs), you may want to use a multistep wizard to reduce the number of components that are visible at once. These are especially useful if your form has a definite chronological order, in which you want each step to be validated as the user progresses. ```php use Filament\Schemas\Components\Wizard; use Filament\Schemas\Components\Wizard\Step; Wizard::make([ Step::make('Order') ->schema([ // ... ]), Step::make('Delivery') ->schema([ // ... ]), Step::make('Billing') ->schema([ // ... ]), ]) ``` ## Rendering a submit button on the last step You may use the `submitAction()` method to render submit button HTML or a view at the end of the wizard, on the last step. This provides a clearer UX than displaying a submit button below the wizard at all times: ```php use Filament\Schemas\Components\Wizard; use Illuminate\Support\HtmlString; Wizard::make([ // ... ])->submitAction(view('order-form.submit-button')) Wizard::make([ // ... ])->submitAction(new HtmlString('')) ``` Alternatively, you can use the built-in Filament button Blade component: ```php use Filament\Schemas\Components\Wizard; use Illuminate\Support\Facades\Blade; use Illuminate\Support\HtmlString; Wizard::make([ // ... ])->submitAction(new HtmlString(Blade::render(<< Submit BLADE))) ``` You could extract this component to a separate Blade view if you prefer. ## Setting a step icon Steps may have an [icon](../styling/icons), which you can set using the `icon()` method: ```php use Filament\Schemas\Components\Wizard\Step; use Filament\Support\Icons\Heroicon; Step::make('Order') ->icon(Heroicon::ShoppingBag) ->schema([ // ... ]), ``` As well as allowing a static value, the `icon()` method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters. ## Customizing the icon for completed steps You may customize the [icon](#setting-up-step-icons) of a completed step using the `completedIcon()` method: ```php use Filament\Schemas\Components\Wizard\Step; use Filament\Support\Icons\Heroicon; Step::make('Order') ->completedIcon(Heroicon::HandThumbUp) ->schema([ // ... ]), ``` As well as allowing a static value, the `completedIcon()` method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters. ## Adding descriptions to steps You may add a short description after the title of each step using the `description()` method: ```php use Filament\Schemas\Components\Wizard\Step; Step::make('Order') ->description('Review your basket') ->schema([ // ... ]), ``` As well as allowing a static value, the `description()` method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters. ## Setting the default active step You may use the `startOnStep()` method to load a specific step in the wizard: ```php use Filament\Schemas\Components\Wizard; Wizard::make([ // ... ])->startOnStep(2) ``` As well as allowing a static value, the `startOnStep()` method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters. ## Allowing steps to be skipped If you'd like to allow free navigation, so all steps are skippable, use the `skippable()` method: ```php use Filament\Schemas\Components\Wizard; Wizard::make([ // ... ])->skippable() ``` Optionally, the `skippable()` method accepts a boolean value to control if the step is skippable or not: ```php use Filament\Schemas\Components\Wizard\Step; Step::make('Order') ->skippable(FeatureFlag::active()) ->schema([ // ... ]), ``` As well as allowing a static value, the `skippable()` method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters. ## Persisting the current step in the URL's query string By default, the current step is not persisted in the URL's query string. You can change this behavior using the `persistStepInQueryString()` method: ```php use Filament\Schemas\Components\Wizard; Wizard::make([ // ... ])->persistStepInQueryString() ``` When enabled, the current step is persisted in the URL's query string using the `step` key. You can change this key by passing it to the `persistStepInQueryString()` method: ```php use Filament\Schemas\Components\Wizard; Wizard::make([ // ... ])->persistStepInQueryString('wizard-step') ``` As well as allowing a static value, the `persistStepInQueryString()` method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters. ## Step lifecycle hooks You may use the `afterValidation()` and `beforeValidation()` methods to run code before and after validation occurs on the step: ```php use Filament\Schemas\Components\Wizard\Step; Step::make('Order') ->afterValidation(function () { // ... }) ->beforeValidation(function () { // ... }) ->schema([ // ... ]), ``` You can inject various utilities into the `afterValidation()` and `beforeValidation()` functions as parameters. ### Preventing the next step from being loaded Inside `afterValidation()` or `beforeValidation()`, you may throw `Filament\Support\Exceptions\Halt`, which will prevent the wizard from loading the next step: ```php use Filament\Schemas\Components\Wizard\Step; use Filament\Support\Exceptions\Halt; Step::make('Order') ->afterValidation(function () { // ... if (true) { throw new Halt(); } }) ->schema([ // ... ]), ``` ## Using grid columns within a step You may use the `columns()` method to customize the [grid](layouts#grid-system) within the step: ```php use Filament\Schemas\Components\Wizard; use Filament\Schemas\Components\Wizard\Step; Wizard::make([ Step::make('Order') ->columns(2) ->schema([ // ... ]), // ... ]) ``` As well as allowing a static value, the `columns()` method also accepts a function to dynamically calculate it. You can inject various utilities into the function as parameters. ## Customizing the wizard action objects This component uses action objects for easy customization of buttons within it. You can customize these buttons by passing a function to an action registration method. The function has access to the `$action` object, which you can use to [customize it](../actions/overview). The following methods are available to customize the actions: - `nextAction()` - `previousAction()` Here is an example of how you might customize an action: ```php use Filament\Actions\Action; use Filament\Schemas\Components\Wizard; Wizard::make([ // ... ]) ->nextAction( fn (Action $action) => $action->label('Next step'), ) ``` The action registration methods can inject various utilities into the function as parameters.