class ConfigDevelSettingsForm in Configuration development 8
Settings form for config devel.
Hierarchy
- class \Drupal\Core\Form\FormBase implements ContainerInjectionInterface, FormInterface uses DependencySerializationTrait, LoggerChannelTrait, MessengerTrait, LinkGeneratorTrait, RedirectDestinationTrait, UrlGeneratorTrait, StringTranslationTrait
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
- class \Drupal\config_devel\Form\ConfigDevelSettingsForm
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
Expanded class hierarchy of ConfigDevelSettingsForm
1 string reference to 'ConfigDevelSettingsForm'
File
- src/
Form/ ConfigDevelSettingsForm.php, line 12
Namespace
Drupal\config_devel\FormView source
class ConfigDevelSettingsForm extends ConfigFormBase {
/**
* Name of the config being edited.
*/
const CONFIGNAME = 'config_devel.settings';
/**
* @var array
*/
protected $keys;
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state) {
$default_value = '';
foreach ($this
->config(static::CONFIGNAME)
->get('auto_import') as $file) {
$default_value .= $file['filename'] . "\n";
}
$form['auto_import'] = array(
'#type' => 'textarea',
'#title' => $this
->t('Auto import'),
'#default_value' => $default_value,
'#description' => $this
->t('When these files change, they will be automatically imported at the beginning of the next request.') . '<br>' . $this
->t('Enter one item per line. Each item should consist of a path relative to the Drupal root and a filename in the same form as a config YML file.') . '<br>' . $this
->t('For example: "modules/mymodule/config/install/node.type.mytype.yml".'),
);
$form['auto_export'] = array(
'#type' => 'textarea',
'#title' => $this
->t('Auto export'),
'#default_value' => implode("\n", $this
->config(static::CONFIGNAME)
->get('auto_export')),
'#description' => $this
->t('Automatically export to the files specified when the corresponding config item is changed in the admin UI.') . '<br>' . $this
->t('Enter one item per line. Each item should consist of a path relative to the Drupal root and a filename in the same form as a config YML file.') . '<br>' . $this
->t('For example: "modules/mymodule/config/install/node.type.mytype.yml".'),
);
return parent::buildForm($form, $form_state);
}
/**
* {@inheritdoc}
*/
public function validateForm(array &$form, FormStateInterface $form_state) {
foreach (array(
'auto_import',
'auto_export',
) as $key) {
$form_state
->setValue($key, array_filter(preg_split("/\r\n/", $form_state
->getValues()[$key])));
}
foreach ($form_state
->getValues()['auto_import'] as $file) {
$name = basename($file, '.' . FileStorage::getFileExtension());
if (in_array($name, array(
'system.site',
'core.extension',
'simpletest.settings',
))) {
$form_state
->setErrorByName('auto_import', $this
->t('@name is not compatible with this module', array(
'@name' => $name,
)));
}
}
parent::validateForm($form, $form_state);
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
$auto_import = array();
foreach ($form_state
->getValues()['auto_import'] as $file) {
$auto_import[] = array(
'filename' => $file,
'hash' => '',
);
}
$this
->config(static::CONFIGNAME)
->set('auto_import', $auto_import)
->set('auto_export', $form_state
->getValues()['auto_export'])
->save();
parent::submitForm($form, $form_state);
}
/**
* {@inheritdoc}
*/
public function getFormId() {
return 'config_devel_settings';
}
/**
* {@inheritdoc}
*/
protected function getEditableConfigNames() {
return [
'config_devel.settings',
];
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
ConfigDevelSettingsForm:: |
protected | property | ||
ConfigDevelSettingsForm:: |
public | function |
Form constructor. Overrides ConfigFormBase:: |
|
ConfigDevelSettingsForm:: |
constant | Name of the config being edited. | ||
ConfigDevelSettingsForm:: |
protected | function |
Gets the configuration names that will be editable. Overrides ConfigFormBaseTrait:: |
|
ConfigDevelSettingsForm:: |
public | function |
Returns a unique string identifying the form. Overrides FormInterface:: |
|
ConfigDevelSettingsForm:: |
public | function |
Form submission handler. Overrides ConfigFormBase:: |
|
ConfigDevelSettingsForm:: |
public | function |
Form validation handler. Overrides FormBase:: |
|
ConfigFormBase:: |
public static | function |
Instantiates a new instance of this class. Overrides FormBase:: |
13 |
ConfigFormBase:: |
public | function | Constructs a \Drupal\system\ConfigFormBase object. | 11 |
ConfigFormBaseTrait:: |
protected | function | Retrieves a configuration object. | |
DependencySerializationTrait:: |
protected | property | An array of entity type IDs keyed by the property name of their storages. | |
DependencySerializationTrait:: |
protected | property | An array of service IDs keyed by property name used for serialization. | |
DependencySerializationTrait:: |
public | function | 1 | |
DependencySerializationTrait:: |
public | function | 2 | |
FormBase:: |
protected | property | The config factory. | 1 |
FormBase:: |
protected | property | The request stack. | 1 |
FormBase:: |
protected | property | The route match. | |
FormBase:: |
protected | function | Gets the config factory for this form. | 1 |
FormBase:: |
private | function | Returns the service container. | |
FormBase:: |
protected | function | Gets the current user. | |
FormBase:: |
protected | function | Gets the request object. | |
FormBase:: |
protected | function | Gets the route match. | |
FormBase:: |
protected | function | Gets the logger for a specific channel. | |
FormBase:: |
protected | function |
Returns a redirect response object for the specified route. Overrides UrlGeneratorTrait:: |
|
FormBase:: |
public | function | Resets the configuration factory. | |
FormBase:: |
public | function | Sets the config factory for this form. | |
FormBase:: |
public | function | Sets the request stack object to use. | |
LinkGeneratorTrait:: |
protected | property | The link generator. | 1 |
LinkGeneratorTrait:: |
protected | function | Returns the link generator. | |
LinkGeneratorTrait:: |
protected | function | Renders a link to a route given a route name and its parameters. | |
LinkGeneratorTrait:: |
public | function | Sets the link generator service. | |
LoggerChannelTrait:: |
protected | property | The logger channel factory service. | |
LoggerChannelTrait:: |
protected | function | Gets the logger for a specific channel. | |
LoggerChannelTrait:: |
public | function | Injects the logger channel factory. | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
RedirectDestinationTrait:: |
protected | property | The redirect destination service. | 1 |
RedirectDestinationTrait:: |
protected | function | Prepares a 'destination' URL query parameter for use with \Drupal\Core\Url. | |
RedirectDestinationTrait:: |
protected | function | Returns the redirect destination service. | |
RedirectDestinationTrait:: |
public | function | Sets the redirect destination service. | |
StringTranslationTrait:: |
protected | property | The string translation service. | 1 |
StringTranslationTrait:: |
protected | function | Formats a string containing a count of items. | |
StringTranslationTrait:: |
protected | function | Returns the number of plurals supported by a given language. | |
StringTranslationTrait:: |
protected | function | Gets the string translation service. | |
StringTranslationTrait:: |
public | function | Sets the string translation service to use. | 2 |
StringTranslationTrait:: |
protected | function | Translates a string to the current language or to a given language. | |
UrlGeneratorTrait:: |
protected | property | The url generator. | |
UrlGeneratorTrait:: |
protected | function | Returns the URL generator service. | |
UrlGeneratorTrait:: |
public | function | Sets the URL generator service. | |
UrlGeneratorTrait:: |
protected | function | Generates a URL or path for a specific route based on the given parameters. |