Customizing data before saving
Sometimes, you may wish to modify form data before it is finally saved to the database. To do this, you may define amutateFormDataBeforeCreate() method on the Create page class, which accepts the $data as an array, and returns the modified version:
Customizing the creation process
You can tweak how the record is created using thehandleRecordCreation() method on the Create page class:
Customizing redirects
By default, after saving the form, the user will be redirected to the Edit page of the resource, or the View page if it is present. You may set up a custom redirect when the form is saved by overriding thegetRedirectUrl() method on the Create page class.
For example, the form can redirect back to the List page:
Customizing the save notification
When the record is successfully created, a notification is dispatched to the user, which indicates the success of their action. To customize the title of this notification, define agetCreatedNotificationTitle() method on the create page class:
getCreatedNotification() method on the create page class:
null from the getCreatedNotification() method on the create page class:
Creating another record
Disabling create another
To disable the “create and create another” feature, define the$canCreateAnother property as false on the Create page class:
canCreateAnother() method on the Create page class:
Preserving data when creating another
By default, when the user uses the “create and create another” feature, all the form data is cleared so the user can start fresh. If you’d like to preserve some of the data in the form, you may override thepreserveFormDataWhenCreatingAnother() method on the Create page class, and return the part of the $data array that you’d like to keep:
$data array:
Lifecycle hooks
Hooks may be used to execute code at various points within a page’s lifecycle, like before a form is saved. To set up a hook, create a protected method on the Create page class with the name of the hook:beforeCreate() method will be called before the data in the form is saved to the database.
There are several available hooks for the Create page:
Halting the creation process
At any time, you may call$this->halt() from inside a lifecycle hook or mutation method, which will halt the entire creation process:
Authorization
For authorization, Filament will observe any model policies that are registered in your app. Users may access the Create page if thecreate() method of the model policy returns true.
Using a wizard
You may easily transform the creation process into a multistep wizard. On the page class, add the correspondingHasWizard trait:
getSteps() array, return your wizard steps:
hasSkippableSteps() method:
Sharing fields between the form schema and wizards
If you’d like to reduce the amount of repetition between the resource form and wizard steps, it’s a good idea to extract public static form functions for your fields, where you can easily retrieve an instance of a field from the form schema or the wizard:Importing resource records
Filament includes anImportAction that you can add to the getHeaderActions() of the List page. It allows users to upload a CSV of data to import into the resource:
ImportAction in the Actions documentation.
Custom actions
“Actions” are buttons that are displayed on pages, which allow the user to run a Livewire method on the page or visit a URL. On resource pages, actions are usually in 2 places: in the top right of the page, and below the form. For example, you may add a new button action in the header of the Create page:Adding a create action button to the header
The “Create” button can be moved to the header of the page by overriding thegetHeaderActions() method and using getCreateFormAction(). You need to pass formId() to the action, to specify that the action should submit the form with the ID of form, which is the <form> ID used in the view of the page:
getFormActions() method to return an empty array:
Custom page content
Each page in Filament has its own schema, which defines the overall structure and content. You can override the schema for the page by defining acontent() method on it. The content() method for the Create page contains the following components by default:
components() array, you can insert any schema component. You can reorder the components by changing the order of the array or remove any of the components that are not needed.
Using a custom Blade view
For further customization opportunities, you can override the static$view property on the page class to a custom view in your app:
resources/views/filament/resources/users/pages/create-user.blade.php: