itplusx / headless-container
Container Content Elements (EXT:container) json output for EXT:headless
Installs: 9 968
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 7
Open Issues: 1
Type:typo3-cms-extension
pkg:composer/itplusx/headless-container
Requires
- php: ^8.1
- b13/container: >=3.1.2
- friendsoftypo3/headless: ^4.0
- typo3/cms-core: ^12.4 || ^13.4
Replaces
- typo3-ter/headless-container: v3.0.0
This package is auto-updated.
Last update: 2025-10-01 00:10:26 UTC
README
This TYPO3 extension makes it possible to use EXT:container together with EXT:headless.
Installation
Installation with composer
(recommended)
$ composer require itplusx/headless-container
Installation with the TYPO3 Extension Manager
see: Extension Management
Requirements and compatibility
Requirement | v1 & v2 | v3 |
---|---|---|
PHP | >= 8.1 | >= 8.1 |
TYPO3 | 12.4 & 13.4 | 12.4 & 13.4 |
Headless | 4 | 4 |
Container | 2 - 3.1.1 | >= 3.1.2 |
Usage
- Include TypoScript (as described by the TypoScript Reference) or just add the Site Set to your Site Configuration (as described by the Site sets Reference)
- Register your custom container element (as described by EXT:container)
- Define TypoScript ...
(assuming you CType isb13-2cols-with-header-container
)- ... for simple container elements:
tt_content.b13-2cols-with-header-container =< lib.container
- ... for container elements with header TCA fields:
tt_content.b13-2cols-with-header-container =< lib.containerWithHeader
- ... for container elements with custom TCA fields:
(see EXT:headless docs for further info)tt_content.b13-2cols-with-header-container =< lib.container tt_content.b13-2cols-with-header-container.fields.content.fields { myCustomField = TEXT myCustomField.field = myCustomTcaField }
- ... for simple container elements:
- That's all! You should now see JSON output for your custom container element!
Example json output
{ "id": 2, "type": "b13-2cols-with-header-container", "colPos": 0, "categories": "", "appearance": { "layout": "default", "frameClass": "default", "spaceBefore": "", "spaceAfter": "" }, "content": { "header": "Container Header", "subheader": "Container Subheader", "headerLayout": 0, "headerPosition": "", "headerLink": "", "myCustomField": "myCustomValue", "items": [ { "config": { "name": "header", "colPos": 200 }, "contentElements": [ { "id": 3, "type": "text", "colPos": 200, "categories": "", "appearance": {...}, "content": {...} } ] }, { "config": { "name": "left side", "colPos": 201 }, "contentElements": [ { "id": 4, "type": "text", "colPos": 201, "categories": "", "appearance": {...}, "content": {...} }, { "id": 9, "type": "text", "colPos": 201, "categories": "", "appearance": {...}, "content": {...} } ] }, { "config": { "name": "right side", "colPos": 202 }, "contentElements": [ { "id": 5, "type": "text", "colPos": 202, "categories": "", "appearance": {...}, "content": {...} } ] } ] } }
Contribution
Any help on this project is very welcome! May it be as code contribution or just an idea for improvement. But we would like to ask you to follow some rules:
- Issues:
When adding issues please always describe the bug/feature/task as detailed as possible. Only providing a title is not enough. Please use issue templates. - Commits:
Our team is following the Conventional Commits. We would like ask you stick to these rules whenever you want to contribute. - Pull Requests:
Before you submit a PR please create an issue first and link it to the pull request or at least add a PR description with detailed information about what this PR does. Otherwise we are not able to decide if this PR is worth going into the main branch.