Note
This is a fork of tritum/repeatable_form_elements, the original extension by Ralf Zimmermann / dreistrom.land. This fork adds TYPO3 v14 compatibility, PSR-14 event migration, CI/CD infrastructure and a DDEV-based multi-version test environment.
A TYPO3 extension that adds a Repeatable container element to the TYPO3 form framework. It allows editors to create container elements with any type of fields. In the frontend, users can dynamically add and remove copies of the container. Validation is copied automatically and all form finishers are aware of the duplicated fields.
| Requirement | Version |
|---|---|
| PHP | 8.2 β 8.5 |
| TYPO3 | 13.4 LTS, 14.x |
composer require move-elevator/typo3-repeatable-form-elementsAdd the site set tritum/repeatable-form-elements to the dependencies of your site package's site set:
# Configuration/Sets/YourSitePackage/config.yaml
dependencies:
- tritum/repeatable-form-elements- Open the TYPO3 form editor and create or open a form.
- Add a new element β the modal lists the Repeatable container.
- Add fields with validators to the container.
- In the frontend, the container renders as a
<fieldset>with copy and remove buttons.
An extended version of the SaveToDatabaseFinisher is included for persisting repeatable container data. See the example form definition.
To deactivate the copying of variants, disable the feature flag:
$GLOBALS['TYPO3_CONF_VARS']['SYS']['features']['repeatableFormElements.copyVariants'] = false;| Event | Description |
|---|---|
CopyVariantEvent |
Modify or disable specific copied variants during container duplication. |
AfterBuildingFinishedEvent |
React after a form renderable has been built/copied by the repeatable container logic. Replaces the removed afterBuildingFinished SC_OPTIONS hook. |
Contributions are welcome! See CONTRIBUTING.md for setup instructions, linting, testing and the PR workflow.
See CHANGELOG.md for a list of changes.
Originally created by Ralf Zimmermann / dreistrom.land. See the original repository for the full list of contributors.
This fork is maintained by move:elevator.
GPL-2.0-or-later β see LICENSE for details.