linio / dynamic-form-bundle
Generates symfony forms based on YAML configuration files
Installs: 27 009
Dependents: 0
Suggesters: 0
Security: 0
Stars: 19
Watchers: 56
Forks: 11
Open Issues: 6
pkg:composer/linio/dynamic-form-bundle
Requires
- php: ^8.0
- symfony/form: ^2.8 || ^3.0 || ^4.0 || ^5.0 || ^6.0
Requires (Dev)
- friendsofphp/php-cs-fixer: ^3.0
- jaschilz/php-coverage-badger: ^2.0
- phpspec/prophecy-phpunit: ^2.0
- phpunit/phpunit: ^9.5
- symfony/security-bundle: ^5.0
- symfony/validator: ^2.8 || ^3.0 || ^4.0 || ^5.0 || ^6.0
- dev-master
- 3.0.0
- 2.3.0
- 2.2.0
- 2.1.0
- 2.0.0
- 1.2.1
- 1.2.0
- 1.1.0
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.1
- 1.0.0
- dev-chore/update-security-bundle
- dev-build/DIS-888-update-dependencies
- dev-fix/DIS-735-improve-features-of-born-date-type
- dev-feat/DIS-735-improve-features-of-born-date-type
- dev-build/update-project-base-code
- dev-feat/test
- dev-dependabot/add-v2-config-file
This package is auto-updated.
Last update: 2025-09-28 21:37:18 UTC
README
Generates symfony forms based on YAML configuration files
Getting Started
This plugin supports Symfony ^2.8|^3.0|^4.0|^5.0. Even tough we encorage you to use the latest version because of the Symfony maintained branches itself.
The recommended way to install Linio Dynamic Form Bundle is through composer.
{
    "require": {
        "linio/dynamic-form-bundle": "~2.0"
    }
}
Tests
To run the test suite, you need install the dependencies via composer, then run PHPUnit.
$ composer install
$ vendor/bin/phpunit
Usage
Add the bundle on registerBundles() at AppKernel.php
new Linio\DynamicFormBundle\DynamicFormBundle();
The service dynamic_form.factory will be available.
Create your form on the Configuration File. The YAML structure for the Form should follow the next structure:
+---dynamic_form
|   \--- Form Name
|       \---Field Name
|           \---Field Options
|           \---Field Transformer
|           \---Field Validators
The method createform() takes the form configuration named new_user from app/config/config.yml.
use Linio\DynamicFormBundle\DynamicFormAware; class TestController { use DynamicFormAware; public function testAction() { $form = $this->getDynamicFormFactory()->createForm('new_user'); return $this->render( 'WebBundle:Default:dynamicForms.html.twig', ['form' => $form->createView(),] ); } }
The method getJsonConfiguration() takes the configuration from app/config/config.yml. and returns a JSON with the Form Configuration.
Example
Here's an example of a form named new_user with a single field called first_name:
dynamic_form: new_user: first_name: enabled: true type: text options: type: password required: true transformers: validators:
Options
Field options are the same as symfony, refer to the documentation
Birthday Type
Supports Symfony >= 4.4.
In addition to the own options that the field brings by default (see documentation), we added 3 new attributes to make its behavior more flexible.
minAgeAllowed and maxAgeAllowed:
These options work together and it is an improvement to the years option because it is too strict to only receive an array with the allowed years (and that in our case we should leave static in our Yaml file). With them we can determine (taking the current date) the minimum and maximum number of ages to generate the years that will be displayed in the form. These options only accept whole numbers greater than or equal to zero.
For example, if we want to have a field of type birthday but we only want children who have between 5 and 10 years of life to be registered, we would have something like the following:
dynamic_form: new_user: birthday: enabled: true type: birthday options: minAgeAllowed: 5 maxAgeAllowed: 10
The above would generate this array of years => [2016, 2015, 2014, 2013, 2012, 2011] taking into account 2021 as the current year.
Order:
This option is used together with minAgeAllowed and maxAgeAllowed and is for the cases where we want to show our drop-down list of years in one order or another. The accepted values are asc and desc, the latter by default.
Transformers
When using transformers write both the class where it is defined and the calls you need.
dynamic_form: new_user: birthday: enabled: true type: text transformer: class: 'Linio\Frontend\CustomerBundle\Form\DataTransformer\BirthdayTransformer' calls: - [setUserFormat, ['d/m/Y']] - [setInputFormat, ['Y-m-d']]
Validators
When using validators call each validator constraint and its parameters like shown down below.
dynamic_form: new_user: first_name: enabled: true type: text validation: 'Symfony\Component\Validator\Constraints\True': message: 'The token is invalid.' 'Symfony\Component\Validator\Constraints\Length': min: 2 max: 50