View source
<?php
namespace Drupal\pdb_vue\Form;
use Drupal\Core\Form\ConfigFormBase;
use Drupal\Core\Form\FormStateInterface;
class VueForm extends ConfigFormBase {
protected function getEditableConfigNames() {
return [
'pdb_vue.settings',
];
}
public function getFormId() {
return 'pdb_vue_form';
}
public function buildForm(array $form, FormStateInterface $form_state) {
$config = $this
->config('pdb_vue.settings');
$form['version'] = [
'#type' => 'select',
'#title' => $this
->t('Choose the version of Vue'),
'#options' => [
'vue3' => $this
->t('Vue 3'),
'vue2' => $this
->t('Vue 2'),
],
'#default_value' => $config
->get('version'),
];
$form['development_mode'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Development Mode'),
'#description' => $this
->t('Checking the box enables development mode'),
'#default_value' => $config
->get('development_mode'),
];
$form['use_spa'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Use Vue components in a Single Page App format.'),
'#description' => $this
->t('Checking the box will initialize a Vue instance on a root element to overtake the entire page allowing each block to be a <a href="https://v3.vuejs.org/guide/component-basics.html#components-basics">Vue Components</a>.'),
'#default_value' => $config
->get('use_spa'),
];
$form['spa_element'] = [
'#type' => 'textfield',
'#title' => $this
->t('App Element Selector'),
'#description' => $this
->t('Set the element that the Vue instance will be attached to. By default it will use the Classy theme\'s wrapping element "#page-wrapper".'),
'#default_value' => $config
->get('spa_element') ? $config
->get('spa_element') : '#page-wrapper',
'#states' => [
'visible' => [
':input[name="use_spa"]' => [
'checked' => TRUE,
],
],
],
];
return parent::buildForm($form, $form_state);
}
public function submitForm(array &$form, FormStateInterface $form_state) {
parent::submitForm($form, $form_state);
$config = $this
->configFactory()
->getEditable('pdb_vue.settings');
$config
->set('version', $form_state
->getValue('version'));
$config
->set('development_mode', $form_state
->getValue('development_mode'));
$config
->set('use_spa', $form_state
->getValue('use_spa'));
$config
->set('spa_element', $form_state
->getValue('spa_element'));
$config
->save();
$this
->flushCaches();
}
public function flushCaches() {
drupal_flush_all_caches();
}
}