-
Notifications
You must be signed in to change notification settings - Fork 61
Tabs
Tabs are a great way to create a concise and usable admin UI. Creating a tab with ACF Builder is as easy as adding any other type of field.
use StoutLogic\AcfBuilder\FieldsBuilder;
$banner = new FieldsBuilder('banner');
$banner
->addTab('Content')
->addText('title')
->addWysiwyg('content')
->addTab('Background Settings')
->addImage('background_image')
->addColorPicker('background_color');
addTab('Content')
will generate:
[
'key' => 'field_banner_content_tab',
'name' => 'content_tab',
'label' => 'Content',
'type' => 'tab'
]
addTab('Background Settings')
will generate:
[
'key' => 'field_banner_background_settings_tab',
'name' => 'background_settings_tab',
'label' => 'Background Settings',
'type' => 'tab'
]
The name
and key
will have '_tab'
appended their values.
ACF provides a placement setting for 'top' (default) or 'left'. Note 'left' will be ignored if the field group is configured with a table layout.
ACF also provides an endpoint
setting to denote that a tab is the start of a new row or group of tabs. If the field group has a lot of tabs this may be helpful. It can either be passed in as an option like placement, or the endPoint()
function can be called after addTab()
.
$banner
->addTab('Content')
...
->addTab('Settings')
->endPoint()
...
By default repeaters will utilize a table layout. Tabs won't work correctly and will break the UI in a table layout repeater. Be sure to set the layout to block or row:
...
->addRepeater('columns', ['layout' => 'block']
...
Want to contribute to this Wiki? Fork it and send a pull request.
© Stout Logic, LLC