ansien / form-to-json-bundle
Convert Symfony forms to JSON
Installs: 33
Dependents: 0
Suggesters: 0
Security: 0
Stars: 4
Watchers: 1
Forks: 0
Open Issues: 0
Type:symfony-bundle
Requires
- php: >=8.0
- symfony/config: ^5.2
- symfony/form: ^5.2
- symfony/framework-bundle: ^5.2
- symfony/serializer: ^5.2
- symfony/translation: ^5.2
Requires (Dev)
- friendsofphp/php-cs-fixer: ^2.18
- phpro/grumphp: ^1.3
- phpunit/phpunit: ^9.5
- symfony/var-dumper: ^5.2
- symplify/easy-coding-standard: ^9.2
README
This bundle will allow you to transform Symfony forms into JSON.
Installation
You can install the package via Composer:
composer require ansien/form-to-json-bundle
Usage
Controller:
<?php declare(strict_types=1); namespace App\Controller; use Ansien\FormToJsonBundle\Transformer\Service\FormTransformerInterface; use Symfony\Bundle\FrameworkBundle\Controller\AbstractController; use Symfony\Component\HttpFoundation\JsonResponse; use Symfony\Component\HttpFoundation\Request; use Symfony\Component\Routing\Annotation\Route; use App\Entity\Example; use App\Form\ExampleType; class ExampleController extends AbstractController { public function __construct(private FormTransformerInterface $formTransformer) { } #[Route('/example', methods: ['GET'])] public function __invoke(Request $request): JsonResponse { $example = new Example('Hello!'); $form = $this->createForm(ExampleType::class, $example); return new JsonResponse($this->formTransformer->transform($form)); } }
Example output:
{ "schema": { "id": "test", "name": "test", "type": "super_form", "disabled": false, "label": null, "label_format": null, "label_html": false, "multipart": true, "unique_block_prefix": "_test", "row_attr": [], "translation_domain": null, "label_translation_parameters": [], "attr_translation_parameters": [], "valid": true, "required": true, "size": null, "label_attr": [], "help": null, "help_attr": [], "help_html": false, "help_translation_parameters": [], "compound": true, "method": "POST", "action": "", "submitted": false, "attr": [], "children": { "text": { "id": "test_text", "name": "text", "type": "text", "disabled": false, "label": null, "label_format": null, "label_html": false, "multipart": false, "unique_block_prefix": "_test_text", "row_attr": [], "translation_domain": null, "label_translation_parameters": [], "attr_translation_parameters": [], "valid": true, "required": true, "size": null, "label_attr": [], "help": null, "help_attr": [], "help_html": false, "help_translation_parameters": [], "compound": false, "method": "POST", "action": "", "submitted": false, "attr": [] } } }, "values": { "text": "Test 123" }, "errors": { "_global": [ "Test root error" ], "text": [ "Test error" ] } }
Extending the bundle
You can create your own form type transformer by making a new service that extends AbstractTypeTransformer and tagging it with form_to_json_bundle.type_transformer
.
Changelog
Please see CHANGELOG for more information on what has changed recently.
Contributing
Please see CONTRIBUTING for details.
Supporters
Credits
License
The MIT License (MIT). Please see License File for more information.