class BlockFieldForm in Display Suite 8.4
Same name and namespace in other branches
- 8.2 src/Form/BlockFieldForm.php \Drupal\ds\Form\BlockFieldForm
- 8.3 src/Form/BlockFieldForm.php \Drupal\ds\Form\BlockFieldForm
Configure block fields.
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\ds\Form\FieldFormBase implements ContainerInjectionInterface
- class \Drupal\ds\Form\BlockFieldForm implements ContainerInjectionInterface
- class \Drupal\ds\Form\FieldFormBase implements ContainerInjectionInterface
- class \Drupal\Core\Form\ConfigFormBase uses ConfigFormBaseTrait
Expanded class hierarchy of BlockFieldForm
1 file declares its use of BlockFieldForm
- DynamicBlockField.php in src/
Plugin/ Derivative/ DynamicBlockField.php
1 string reference to 'BlockFieldForm'
File
- src/
Form/ BlockFieldForm.php, line 14
Namespace
Drupal\ds\FormView source
class BlockFieldForm extends FieldFormBase implements ContainerInjectionInterface {
/**
* The type of the dynamic ds field.
*/
const TYPE = 'block';
/**
* {@inheritdoc}
*/
public function getFormId() {
return 'ds_field_form';
}
/**
* {@inheritdoc}
*/
public function buildForm(array $form, FormStateInterface $form_state, $field_key = '') {
$form = parent::buildForm($form, $form_state, $field_key);
$field = $this->field;
$manager = \Drupal::service('plugin.manager.block');
$blocks = [];
foreach ($manager
->getDefinitions() as $plugin_id => $plugin_definition) {
$blocks[$plugin_id] = $plugin_definition['admin_label'];
}
asort($blocks);
$form['block_identity']['block'] = [
'#type' => 'select',
'#options' => $blocks,
'#title' => $this
->t('Block'),
'#required' => TRUE,
'#default_value' => isset($field['properties']['block']) ? $field['properties']['block'] : '',
];
$form['use_block_title'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Use block title as the field label'),
'#default_value' => isset($field['properties']['use_block_title']) ? $field['properties']['use_block_title'] : FALSE,
'#weight' => 90,
];
$form['add_block_wrappers'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Add block wrappers and classes'),
'#default_value' => isset($field['properties']['add_block_wrappers']) ? $field['properties']['add_block_wrappers'] : FALSE,
'#description' => $this
->t('Render using the block theme hook to add the block wrappers and clases.'),
'#weight' => 91,
];
return $form;
}
/**
* {@inheritdoc}
*/
public function getProperties(FormStateInterface $form_state) {
$properties['block'] = $form_state
->getValue('block');
// Preserve existing block config.
$field_key = $form_state
->getValue('id');
$field = $this
->config('ds.field.' . $field_key)
->get();
if (isset($field['properties']) && $field['properties']['block'] == $properties['block']) {
$properties = $field['properties'];
}
// Save configuration.
$properties['use_block_title'] = $form_state
->getValue('use_block_title');
$properties['add_block_wrappers'] = $form_state
->getValue('add_block_wrappers');
return $properties;
}
/**
* {@inheritdoc}
*/
public function getType() {
return BlockFieldForm::TYPE;
}
/**
* {@inheritdoc}
*/
public function getTypeLabel() {
return 'Block field';
}
/**
* {@inheritdoc}
*/
public function submitForm(array &$form, FormStateInterface $form_state) {
parent::submitForm($form, $form_state);
// Create an instance of the block to find out if it has a config form.
// Redirect to the block config form if there is one.
/* @var $block \Drupal\Core\Block\BlockPluginInterface */
$manager = \Drupal::service('plugin.manager.block');
$block_id = $this->field['properties']['block'];
$block = $manager
->createInstance($block_id);
// Inject default theme in form state (Site branding needs it for instance).
$form_state = new FormState();
$default_theme = $this
->config('system.theme')
->get('default');
$form_state
->set('block_theme', $default_theme);
$block_config_form = $block
->blockForm([], $form_state);
if ($block_config_form) {
$url = new Url('ds.manage_block_field_config', [
'field_key' => $this->field['id'],
]);
$form_state
->setRedirectUrl($url);
}
// Invalidate all blocks.
Cache::invalidateTags([
'config:ds.block_base',
]);
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
BlockFieldForm:: |
public | function |
Form constructor. Overrides FieldFormBase:: |
|
BlockFieldForm:: |
public | function |
Returns a unique string identifying the form. Overrides FieldFormBase:: |
|
BlockFieldForm:: |
public | function |
Returns the properties for the custom field. Overrides FieldFormBase:: |
|
BlockFieldForm:: |
public | function |
Returns the type of the field. Overrides FieldFormBase:: |
|
BlockFieldForm:: |
public | function |
Returns the admin label for the field on the field overview page. Overrides FieldFormBase:: |
|
BlockFieldForm:: |
public | function |
Form submission handler. Overrides FieldFormBase:: |
|
BlockFieldForm:: |
constant | The type of the dynamic ds field. | ||
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 | |
FieldFormBase:: |
protected | property | Holds the cache invalidator. | |
FieldFormBase:: |
protected | property | Holds the entity type manager. | |
FieldFormBase:: |
protected | property | The field properties. | |
FieldFormBase:: |
protected | property | Drupal module handler. | |
FieldFormBase:: |
public static | function |
Instantiates a new instance of this class. Overrides ConfigFormBase:: |
1 |
FieldFormBase:: |
public | function | Finishes the submit. | |
FieldFormBase:: |
protected | function |
Gets the configuration names that will be editable. Overrides ConfigFormBaseTrait:: |
|
FieldFormBase:: |
public | function | Returns whether a field machine name is unique. | |
FieldFormBase:: |
public | function |
Constructs a \Drupal\system\CustomFieldFormBase object. Overrides ConfigFormBase:: |
1 |
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. | |
FormBase:: |
public | function |
Form validation handler. Overrides FormInterface:: |
62 |
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. |