The package is based on the HTTP Stepped Form and built for the Laravel & Lumen framework.
Table of Contents
PHP: >=8.1
Laravel: ^9.0 || ^10.0
Via Composer
composer require lexal/laravel-stepped-form
Add the following snippet to the bootstrap/app.php
file under the providers section as follows:
$app->register(Lexal\LaravelSteppedForm\ServiceProvider\ServiceProvider::class);
Run the following command to publish the package config file:
php artisan vendor:publish --provider="Lexal\LaravelSteppedForm\ServiceProvider\ServiceProvider"
The configuration file config/stepped-form.php
has the following options:
renderer
- contains Renderer class, instance or service alias that will translate step's template definition to the response. Must implement RendererInterface;redirector
- contains Redirector class, instance or service alias that will redirect user between different steps. Must implement RedirectorInterface;entity_copy
- contains Entity Copy class, instance or service alias that will clone entity of the given step. Must implement EntityCopyInterface;event_dispatcher
- contains Event Dispatcher class, instance or service alias that will dispatch form events. Must implement EventDispatcherInterface;exception_normalizers
- contains exception normalizers that the form will use to normalize SteppedFormException into the Response instance. Read more about them in the HTTP Stepped Form docs;forms
- contains array of all application forms definitions. Form definition must have builder class for dynamic forms or array of steps for the static forms, settings class and storage where the form will store data.
-
Replace with custom implementation of redirector, renderer and entity copy if necessary. Add custom exception normalizers if necessary.
-
Declare your form settings.
use Lexal\HttpSteppedForm\Settings\FormSettingsInterface; use Lexal\SteppedForm\Step\StepKey; final class FormSettings implements FormSettingsInterface { public function getStepUrl(StepKey $key): string { // return step URL } public function getUrlBeforeStart(): string { // returns a URL to redirect to when there is no previously renderable step } public function getUrlAfterFinish(): string { // return a URL to redirect to when the form was finishing } } $formSettings = new FormSettings();
-
Add forms definitions.
- Static form
return [ // ... 'forms' => [ 'customer' => [ 'steps' => [ 'customer' => CustomerStep::class, 'broker' => BrokerStep::class, 'confirmation' => ConfirmationStep::class, // other steps ], 'settings_class' => FormSettings::class, 'storage' => SessionStorage::class, 'session_storage' => SessionSessionKeyStorage::class, ], ], // ... ];
- Dynamic form
return [ // ... 'forms' => [ 'customer' => [ 'builder_class' => CustomBuilder::class, 'settings_class' => FormSettings::class, 'storage' => SessionStorage::class, 'session_storage' => SessionSessionKeyStorage::class, ], ], // ... ];
- Static form
-
Use Stepped Form in you controller. Stepped Form will have service alias as "stepped-form." + form key form configuration.
ServiceProvider.php
use Lexal\HttpSteppedForm\SteppedFormInterface; $this->app->when(CustomerController::class) ->needs(SteppedFormInterface::class) ->give('stepped-form.customer');
CustomerController.php
use Lexal\HttpSteppedForm\SteppedFormInterface; final class CustomerController { public function __construct(private readonly SteppedFormInterface $form) { } // POST /customers public function start(): Response { return $this->form->start(new Customer(), /* nothing or customer id to split different sessions */); } // GET /customers/step/{step-key} public function render(string $key): Response { return $this->form->render($key); } // POST /customers/step/{step-key} public function handle(Request $request, string $key): Response { return $this->form->handle($key, $request); } // POST /customers/cansel public function cancel(): Response { return $this->form->cancel(route('customer.index')); } }
See configuration file for more information.
Laravel & Lumen Stepped Form is licensed under the MIT License. See LICENSE for the full license text.