basic-8.x-2.x-dev/theme-settings.php
theme-settings.php
<?php
/**
* @file
* Provides an additional config form for theme settings.
*/
use Drupal\Core\Form\FormStateInterface;
/**
* Implements hook_form_system_theme_settings_alter().
*
* Form override for theme settings.
*/
function basic_form_system_theme_settings_alter(array &$form, FormStateInterface $form_state) {
$form['options_settings'] = [
'#type' => 'fieldset',
'#title' => t('Theme Specific Settings'),
];
// BrowserSync support.
$form['options_settings']['basic_browser_sync'] = [
'#type' => 'fieldset',
'#title' => t('BrowserSync Settings'),
];
$form['options_settings']['basic_browser_sync']['browser_sync']['#tree'] = TRUE;
$form['options_settings']['basic_browser_sync']['browser_sync']['enabled'] = [
'#type' => 'checkbox',
'#title' => t('Enable BrowserSync support for theme'),
'#default_value' => theme_get_setting('browser_sync.enabled'),
'#description' => t("Checking this box will automatically add the BrowserSync JS to your theme for development."),
];
$form['options_settings']['basic_browser_sync']['browser_sync']['host'] = [
'#type' => 'textfield',
'#title' => t('BrowserSync host'),
'#default_value' => theme_get_setting('browser_sync.host'),
'#description' => t("Default: localhost. Enter 'HOST' which will be replaced by your site's hostname."),
'#states' => [
'visible' => [':input[name="browser_sync[enabled]"]' => ['checked' => TRUE]],
],
];
$form['options_settings']['basic_browser_sync']['browser_sync']['port'] = [
'#type' => 'number',
'#title' => t('Enable BrowserSync support for theme'),
'#default_value' => theme_get_setting('browser_sync.port'),
'#description' => t("Default: '3000'."),
'#states' => [
'visible' => [':input[name="browser_sync[enabled]"]' => ['checked' => TRUE]],
],
];
}
