How to use (Extbase forms <f:form>)
This section explains how to integrate the mosparo form element into an Extbase form <f:form>.
- 
    Add the validator to your controller EXT:my_extension/Classes/Controller/SearchController.phpuse TYPO3\CMS\Extbase\Annotation\Validate; use Denkwerk\MosparoForm\Validation\Validator\MosparoCaptchaValidator; ... #[Validate(['param' => 'form', 'validator' => MosparoCaptchaValidator::class, 'options' => [ 'selectedProject' => 'example', 'requiredFields' => 'tx_exampleform_exampleform[form][name],tx_exampleform_exampleform[form][email],' ]])] public function searchAction(array $search = []): ResponseInterfaceCopied!- You can specify the mosparo project to be used by setting the selectedoption.Project 
- To ensure that all relevant form fields are checked by mosparo, use the requiredand optionallyFields verifiableoptions.Fields 
 See also 
- You can specify the mosparo project to be used by setting the 
- Include the mosparo Extbase partials in your TypoScript configurationWe include the partials because mosparo provides a custom Fluid partial/Resources/that renders the required HTML container, loads the JavaScript, and applies the selected configuration automatically.Private/ Frontend/ Partials/ Extbase Forms/ Mosparo Captcha. html EXT:my_extension/Configuration/TypoScript/setup.typoscriptplugin.tx_blogexample { view { templateRootPaths.10 = {$plugin.tx_blogexample.view.templateRootPath} partialRootPaths.10 = {$plugin.tx_blogexample.view.partialRootPath} partialRootPaths.20 = EXT:mosparo_form/Resources/Private/Frontend/Partials/ExtbaseForms/ layoutRootPaths.10 = {$plugin.tx_blogexample.view.layoutRootPath} } }Copied!Note For more information, see the TYPO3 documentation: View configuration 
- Render the mosparo partial in your form templateMinimal:EXT:my_extension/Resources/Private/Templates/Form/Form.html<f:render partial="MosparoCaptcha" />Copied!Full configuration: EXT:my_extension/Resources/Private/Templates/Form/Form.html<f:render partial="MosparoCaptcha" arguments="{ selectedProject: 'default', formId: 'form' }" />Copied!- Use theselectedargument to choose a specific mosparo project.Project If omitted, the default project will be used.
- To enable dynamic enabling/disabling of the submit button based on mosparo validation, pass the form’s HTML id as theformargument.Id The JavaScript included by the partial will then control the first submit button found in the form.If formId is not set or empty, this functionality will be disabled.
- When using Invisible Mode, the submit button will automatically be enabled after mosparo is initialized.
 
- Display validation errorsIf validation fails and you don't render the error output, users won't see any feedback.EXT:my_extension/Resources/Private/Templates/Form/Form.html<f:form.validationResults for="form"> <f:if condition="{validationResults.errors}"> <ul> <f:for each="{validationResults.errors}" as="error"> <li>{error.message}</li> </f:for> </ul> </f:if> </f:form.validationResults>Copied!Note For more information, see the TYPO3 documentation: Form.validationResults ViewHelper <f:form.validationResults>