Tabs switcher allows separating the default Field Types in the content type from the Field Types that enhance the content with new functionalities. The best example of such Field Types are SEO or Taxonomy, as these are not typical Field Types but a Field Types that handle functionalities for the whole Content object.
The following example shows how to add a Meta tab with automatically assigned Taxonomy Field Type.
Before you start adding the Meta tab, make sure the content type you want to edit has [Taxonomy Entry Assignment Field Type]([[= user_doc =]]/taxonomy/#assign-tag-to-content-from-taxonomy-tree).
Next, provide the semantic configuration under the ibexa.system.<scope>.admin_ui_forms
configuration key:
ibexa:
system:
admin_group:
admin_ui_forms:
content_edit:
fieldtypes:
ibexa_taxonomy_entry_assignment:
meta: true
ibexa_taxonomy_entry_assignment
- identifier for the Field Type
meta
- when set to true
, puts the declared Field Type in the Meta tab
The default configuration makes the ibexa_taxonomy_entry_assignment
Field always visible in the Meta tab in the Content form.
With this new feature, you can indicate what Field types, previously set in the Back Office content type, are shown in the Meta tab section in the Content form.
You can automatically move all Field types from Metadata group to the Meta tab in the Content form.
To do it, use the following configuration:
ibexa:
system:
admin_group:
admin_ui_forms:
content_edit:
meta_field_groups_list:
- metadata
To disable the feature:
ibexa:
system:
admin_group:
admin_ui_forms:
content_edit:
meta_field_groups_list: []
The meta_field_groups_list
configuration can be easily overriden.
First, create an event listener in the src/EventListener/TextAnchorMenuTabListener.php
:
[[= include_file('code_samples/back_office/content_type/src/EventListener/TextAnchorMenuTabListener.php') =]]
A new custom tab is defined in the line 28, the line 31 defines items for the second level.
For new tabs it is also required to render its section in the Content editing form. To do it, register the UI Component:
[[= include_file('code_samples/back_office/content_type/config/custom_services.yaml') =]]
Finally, create the templates/themes/admin/content_type/edit/custom_tab.html.twig
file:
[[= include_file('code_samples/back_office/content_type/templates/themes/admin/content_type/edit/custom_tab.html.twig') =]]