TypeRocket v1 Pro users can now upgrade to TypeRocket v5 at their convenience.
Theme Options
( v1 )
- # Enabling Theme Options
- # Your options, your ideas
- # Going custom
- # Configuring the custom page
- # Configuring the theme name
- # Adding custom fields
- # Fields into your templates
- # Text field
- # Image field
- # Textarea field
- # Advanced fields
- # Adding tabs and fields
Enabling Theme Options
TypeRocket works as a theme options framework for WordPress by providing the custom fields you need to customize your themes. To get started all you need to do is ensure the ThemeOptions
extension is in the TypeRocket configuration in the file config/app.php
.
Important note, null
does not mean the extension is not activated. The values of the extensions array are the constructor params passed to the named class. So, null
means ThemeOptions
does not require any arguments for its class constructor.
/*
|--------------------------------------------------------------------------
| Extensions
|--------------------------------------------------------------------------
|
| The class names of the TypeRocket extensions you wish to enable.
|
*/
'extensions' => [
'\TypeRocket\Extensions\Seo' => [ null ],
'\TypeRocket\Extensions\PageBuilder' => null,
'\TypeRocket\Extensions\PostTypesUI' => null,
'\TypeRocket\Extensions\ThemeOptions' => null,
'\TypeRocket\Extensions\DevTools' => [ true ],
'\TypeRocket\Extensions\PostMessages' => null,
'\TypeRocket\Extensions\Gutenberg' => [ true ],
],
Your options, your ideas
Theme options are commonly used to manage the global elements of a WordPress theme's design. These elements could be as simple as the copyright information at the bottom of every page to API keys for Google Maps.
You can use any of the fields that come with the forms api.
Going custom
Out of the box, the theme options plugin comes with its own view file under app/resources/pages/extensions/theme-options.php
. You will need to tell the extensions you want to use another file.
- Duplicate the
theme-options.php
file. - Place the new file in the root of your active theme's directory.
If you want to start from scratch delete the code inside the file.
Next, you need to let the theme options plugin know that you are going to use theme-options.php
as the new admin page.
Configuring the custom page
In your theme's functions.php
file add a filter for tr_theme_options_controller
and add your own controller code.
// functions.php
add_filter('tr_theme_options_controller', function() {
$form = tr_form()->useRest()->setGroup( $this->getName() );
return tr_view( __DIR__ . '/theme-options.php', ['form' => $form]);
});
Configuring the theme name
To wrap up configuration, change the theme options name with the filter tr_theme_options_name
.
// functions.php
add_filter('tr_theme_options_name', function() {
return 'my_theme_options';
});
Adding custom fields
Now, let us start with the bare minimum. Use the code below as the contents of the theme-options.php
file.
<h1>Theme Options</h1>
<?php
/** @var \TypeRocket\Elements\Form $form */
echo $form->useRest()->open();
// About
$about = $form->fieldset('Company', 'Details about your company.', [
$form->text('Company Name'),
$form->image('Company Logo'),
$form->texteditor('Company Info'),
]);
// Save
$save = $form->submit( 'Save Changes' );
// Layout
$tabs = tr_tabs()->setFooter( $save )->layoutLeft();
$tabs->tab('About', 'building', $about)->setDescription('Company information');
$tabs->render();
echo $form->close();
?>
Fields into your templates
With debug mode enabled, you can copy the code hints into any theme template file.
Finally, you can get the basic field types into the templates: Text, Image, and Textarea.
Text field
For text fields, using echo
will work just fine. However, don't forget to sanitize all user-entered data on output.
// footer.php
echo tr_option_field('my_theme_options.company_name');
Image field
// header.php
echo tr_option_field(':img:full:my_theme_options.company_logo');
Textarea field
For a textarea you can use nl2br()
or wpautop()
. Because wpautop()
adds <p>
tags over <br>
tags in most cases you should use that.
// sidebar.php
$about = tr_options_field('my_theme_options.company_info');
echo wpautop(esc_html($about));
Or, for rich HTML content.
echo tr_options_field('html:my_theme_options.company_info');
Advanced fields
If you decide to use advanced fields like repeaters and galleries, you can use var_dump()
to inspect the fields.
Adding tabs and fields
Now that you have the most basic setup, you can start adding more tabs and fields.
- Tabs API
- Forms API (fields are near the bottom)
- Fields API
Found a typo? Something is wrong in this documentation? Fork and edit it!