class BricksTreeDynamicInlineWidget in Bricks 8
Same name and namespace in other branches
- 2.x modules/bricks_dynamic/src/Plugin/Field/FieldWidget/BricksTreeDynamicInlineWidget.php \Drupal\bricks_dynamic\Plugin\Field\FieldWidget\BricksTreeDynamicInlineWidget
Plugin annotation
@FieldWidget(
id = "bricks_tree_dynamic_inline",
label = @Translation("Bricks tree Dynamic (Inline entity form)"),
description = @Translation("A tree of inline entity forms."),
field_types = {
"bricks_dynamic"
},
multiple_values = true
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\Core\Field\PluginSettingsBase implements DependentPluginInterface, PluginSettingsInterface
- class \Drupal\Core\Field\WidgetBase implements WidgetInterface, ContainerFactoryPluginInterface uses AllowedTagsXssTrait
- class \Drupal\inline_entity_form\Plugin\Field\FieldWidget\InlineEntityFormBase implements ContainerFactoryPluginInterface
- class \Drupal\inline_entity_form\Plugin\Field\FieldWidget\InlineEntityFormComplex implements ContainerFactoryPluginInterface
- class \Drupal\bricks_dynamic\Plugin\Field\FieldWidget\BricksTreeDynamicInlineWidget
- class \Drupal\inline_entity_form\Plugin\Field\FieldWidget\InlineEntityFormComplex implements ContainerFactoryPluginInterface
- class \Drupal\inline_entity_form\Plugin\Field\FieldWidget\InlineEntityFormBase implements ContainerFactoryPluginInterface
- class \Drupal\Core\Field\WidgetBase implements WidgetInterface, ContainerFactoryPluginInterface uses AllowedTagsXssTrait
- class \Drupal\Core\Field\PluginSettingsBase implements DependentPluginInterface, PluginSettingsInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of BricksTreeDynamicInlineWidget
File
- modules/
bricks_dynamic/ src/ Plugin/ Field/ FieldWidget/ BricksTreeDynamicInlineWidget.php, line 29
Namespace
Drupal\bricks_dynamic\Plugin\Field\FieldWidgetView source
class BricksTreeDynamicInlineWidget extends InlineEntityFormComplex {
/**
* Module handler service.
*
* @var \Drupal\Core\Extension\ModuleHandlerInterface
*/
protected $moduleHandler;
protected $entityType;
/**
* Constructs a InlineEntityFormBase object.
*
* @param array $plugin_id
* The plugin_id for the widget.
* @param mixed $plugin_definition
* The plugin implementation definition.
* @param \Drupal\Core\Field\FieldDefinitionInterface $field_definition
* The definition of the field to which the widget is associated.
* @param array $settings
* The widget settings.
* @param array $third_party_settings
* Any third party settings.
* @param \Drupal\Core\Entity\EntityTypeBundleInfoInterface $entity_type_bundle_info
* The entity type bundle info.
* @param \Drupal\Core\Entity\EntityTypeManagerInterface $entity_type_manager
* The entity type manager.
* @param \Drupal\Core\Entity\EntityDisplayRepositoryInterface
* The entity display repository.
* @param \Drupal\Core\Extension\ModuleHandlerInterface $module_handler
* Module handler service.
*/
public function __construct($plugin_id, $plugin_definition, FieldDefinitionInterface $field_definition, array $settings, array $third_party_settings, EntityTypeBundleInfoInterface $entity_type_bundle_info, EntityTypeManagerInterface $entity_type_manager, EntityDisplayRepositoryInterface $entity_display_repository, ModuleHandlerInterface $module_handler) {
parent::__construct($plugin_id, $plugin_definition, $field_definition, $settings, $third_party_settings, $entity_type_bundle_info, $entity_type_manager, $entity_display_repository, $module_handler);
$this->moduleHandler = $module_handler;
}
/**
* Creates an instance of the inline form handler for the current entity type.
*/
protected function createInlineFormHandler() {
if (!isset($this->inlineFormHandler) && $this
->getEntityType()) {
$entity_type = $this
->getEntityType();
$this->inlineFormHandler = $this->entityTypeManager
->getHandler($entity_type, 'inline_form');
}
}
protected function getEntityType() {
$name = $this->fieldDefinition
->getName();
// TODO explain why this is used.
if (isset($_POST[$name]['actions']['entity_type'])) {
return $_POST[$name]['actions']['entity_type'];
}
$entity_types = DynamicEntityReferenceItem::getTargetTypes($this->fieldDefinition
->getSettings());
if (isset($entity_types[0])) {
return $entity_types[0];
}
}
/**
* Returns the array of field settings.
*
* @return array
* The array of settings.
*/
protected function getFieldSettings() {
$settings = $this->fieldDefinition
->getSettings();
$settings['target_type'] = $this
->getEntityType();
return $settings;
}
/**
* Returns the value of a field setting.
*
* @param string $setting_name
* The setting name.
*
* @return mixed
* The setting value.
*/
protected function getFieldSetting($setting_name) {
if ($setting_name == 'target_type') {
return $this
->getEntityType();
}
return $this->fieldDefinition
->getSetting($setting_name);
}
/**
* Gets the target bundles for the current field.
*
* @return string[]
* A list of bundles.
*/
protected function getTargetBundles() {
$target_bundles = [];
$entity_type = $this
->getEntityType();
$field_settings = $this
->getFieldSettings();
if (isset($field_settings[$entity_type]) && isset($field_settings[$entity_type]['handler_settings']['target_bundles'])) {
$entity_type_settings = $field_settings[$entity_type];
$target_bundles = array_values($entity_type_settings['handler_settings']['target_bundles']);
}
return $target_bundles;
}
/**
* Gets the access handler for the target entity type.
*
* @return \Drupal\Core\Entity\EntityAccessControlHandlerInterface
* The access handler.
*/
protected function getAccessHandler() {
return $this->entityTypeManager
->getAccessControlHandler($this
->getEntityType());
}
/**
* {@inheritdoc}
*/
public function form(FieldItemListInterface $items, array &$form, FormStateInterface $form_state, $get_delta = NULL) {
$elements = parent::form($items, $form, $form_state, $get_delta);
// Signal to content_translation that this field should be treated as
// multilingual and not be hidden, see
// \Drupal\content_translation\ContentTranslationHandler::entityFormSharedElements().
$elements['#multilingual'] = TRUE;
return $elements;
}
/**
* {@inheritdoc}
*/
public function formElement(FieldItemListInterface $items, $delta, array $element, array &$form, FormStateInterface $form_state) {
$element = parent::formElement($items, $delta, $element, $form, $form_state);
$element['entities']['#widget'] = 'bricks_tree_inline';
$allowed_entity_types = DynamicEntityReferenceItem::getTargetTypes($this
->getFieldSettings());
$entity_type_definitions = \Drupal::entityTypeManager()
->getDefinitions();
$entity_type_options = [];
foreach ($allowed_entity_types as $allowed_entity_type) {
if (isset($entity_type_definitions[$allowed_entity_type])) {
$entity_type_options[$allowed_entity_type] = $entity_type_definitions[$allowed_entity_type]
->getLabel();
}
}
$element['actions']['entity_type'] = [
'#type' => 'select',
'#options' => $entity_type_options,
'#default_value' => $this
->getEntityType(),
'#weight' => -9,
'#ajax' => [
'callback' => [
$this,
'rebuild',
],
'wrapper' => 'inline-entity-form-' . $element['#ief_id'],
],
];
$element['actions']['bundle']['#element_validate'] = [
[
$this,
'correctBundle',
],
];
$entities = $form_state
->get([
'inline_entity_form',
$this
->getIefId(),
'entities',
]);
foreach ($entities as $delta => $value) {
_bricks_form_element_alter($element['entities'][$delta], $items[$delta], $value['entity']);
}
return $element;
}
public function rebuild(array &$form, FormStateInterface $form_state) {
$parents = $form_state
->getTriggeringElement()['#parents'];
array_pop($parents);
array_pop($parents);
$fieldset = NestedArray::getValue($form, $parents);
return $fieldset;
}
public function correctBundle(array &$element, FormStateInterface $form_state) {
if (!isset($element['#options'][$element['#value']])) {
$form_state
->clearErrors();
}
}
/**
* {@inheritdoc}
*/
public function massageFormValues(array $values, array $form, FormStateInterface $form_state) {
$field_name = $this->fieldDefinition
->getName();
$field_value = $form_state
->getValue($field_name);
foreach ($values as $delta => $value) {
if (isset($field_value['entities'][$delta])) {
$values[$delta]['depth'] = $field_value['entities'][$delta]['depth'];
if (isset($field_value['entities'][$delta]['options'])) {
$values[$delta]['options'] = $field_value['entities'][$delta]['options'];
}
}
}
return $values;
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
AllowedTagsXssTrait:: |
public | function | Returns a list of tags allowed by AllowedTagsXssTrait::fieldFilterXss(). | |
AllowedTagsXssTrait:: |
public | function | Returns a human-readable list of allowed tags for display in help texts. | |
AllowedTagsXssTrait:: |
public | function | Filters an HTML string to prevent XSS vulnerabilities. | |
BricksTreeDynamicInlineWidget:: |
protected | property | ||
BricksTreeDynamicInlineWidget:: |
protected | property |
Module handler service. Overrides InlineEntityFormComplex:: |
|
BricksTreeDynamicInlineWidget:: |
public | function | ||
BricksTreeDynamicInlineWidget:: |
protected | function |
Creates an instance of the inline form handler for the current entity type. Overrides InlineEntityFormBase:: |
|
BricksTreeDynamicInlineWidget:: |
public | function |
Creates a form element for a field. Overrides InlineEntityFormBase:: |
|
BricksTreeDynamicInlineWidget:: |
public | function |
Returns the form for a single field widget. Overrides InlineEntityFormComplex:: |
|
BricksTreeDynamicInlineWidget:: |
protected | function |
Gets the access handler for the target entity type. Overrides InlineEntityFormBase:: |
|
BricksTreeDynamicInlineWidget:: |
protected | function | ||
BricksTreeDynamicInlineWidget:: |
protected | function |
Returns the value of a field setting. Overrides WidgetBase:: |
|
BricksTreeDynamicInlineWidget:: |
protected | function |
Returns the array of field settings. Overrides WidgetBase:: |
|
BricksTreeDynamicInlineWidget:: |
protected | function |
Gets the target bundles for the current field. Overrides InlineEntityFormBase:: |
|
BricksTreeDynamicInlineWidget:: |
public | function |
Massages the form values into the format expected for field values. Overrides WidgetBase:: |
|
BricksTreeDynamicInlineWidget:: |
public | function | ||
BricksTreeDynamicInlineWidget:: |
public | function |
Constructs a InlineEntityFormBase object. Overrides InlineEntityFormComplex:: |
|
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. | |
InlineEntityFormBase:: |
protected | property | The entity display repository. | |
InlineEntityFormBase:: |
protected | property | The entity type bundle info. | |
InlineEntityFormBase:: |
protected | property | The entity type manager. | |
InlineEntityFormBase:: |
protected | property | The inline entity form id. | |
InlineEntityFormBase:: |
protected | property | The inline entity from handler. | |
InlineEntityFormBase:: |
public static | function | Adds submit callbacks to the inline entity form. | |
InlineEntityFormBase:: |
public | function |
Calculates dependencies for the configured plugin. Overrides PluginSettingsBase:: |
|
InlineEntityFormBase:: |
protected | function | Determines if the current user can add any new entities. | |
InlineEntityFormBase:: |
protected | function | Checks whether we can build entity form at all. | |
InlineEntityFormBase:: |
protected | function | Gets the bundles for which the current user has create access. | |
InlineEntityFormBase:: |
protected | function | Gets the entity form mode instance for this widget. | |
InlineEntityFormBase:: |
protected | function | Gets the entity type managed by this handler. | |
InlineEntityFormBase:: |
protected | function | Gets inline entity form ID. | |
InlineEntityFormBase:: |
protected | function | Gets inline entity form element. | |
InlineEntityFormBase:: |
protected | function | Determines whether there's a translation in progress. | |
InlineEntityFormBase:: |
protected | function | Makes an IEF ID from array parents. | |
InlineEntityFormBase:: |
protected | function | Prepares the form state for the current widget. | |
InlineEntityFormBase:: |
public static | function | After-build callback for removing the translatability clue from the widget. | |
InlineEntityFormBase:: |
protected | function | Sets inline entity form ID. | |
InlineEntityFormBase:: |
public static | function | Marks created/edited entity with "needs save" flag. | |
InlineEntityFormBase:: |
public | function |
Overrides DependencySerializationTrait:: |
|
InlineEntityFormBase:: |
public | function |
Overrides DependencySerializationTrait:: |
|
InlineEntityFormComplex:: |
protected | property | Selection Plugin Manager service. | |
InlineEntityFormComplex:: |
public static | function | Add common submit callback functions and mark element as a IEF trigger. | |
InlineEntityFormComplex:: |
public static | function | Adds actions to the inline entity form. | |
InlineEntityFormComplex:: |
protected | function | Builds remove form. | |
InlineEntityFormComplex:: |
public static | function | Button #submit callback: Closes all open child forms in the IEF widget. | |
InlineEntityFormComplex:: |
public static | function | Button #submit callback: Closes a form in the IEF widget. | |
InlineEntityFormComplex:: |
public static | function |
Creates an instance of the plugin. Overrides InlineEntityFormBase:: |
|
InlineEntityFormComplex:: |
public static | function |
Defines the default settings for this plugin. Overrides InlineEntityFormBase:: |
|
InlineEntityFormComplex:: |
protected | function | Determines bundle to be used when creating entity. | |
InlineEntityFormComplex:: |
public | function |
Extracts field values from submitted form values. Overrides WidgetBase:: |
|
InlineEntityFormComplex:: |
protected | function | Returns the options for the match operator. | |
InlineEntityFormComplex:: |
public static | function | Hides cancel button. | |
InlineEntityFormComplex:: |
public static | function | IEF widget #element_validate callback: Required field validation. | |
InlineEntityFormComplex:: |
public | function |
Returns a form to configure settings for the widget. Overrides InlineEntityFormBase:: |
|
InlineEntityFormComplex:: |
public | function |
Returns a short summary for the current widget settings. Overrides InlineEntityFormBase:: |
|
InlineEntityFormComplex:: |
public static | function | Button #submit callback: Closes a row form in the IEF widget. | |
InlineEntityFormComplex:: |
public static | function | Remove form submit callback. | |
InlineEntityFormComplex:: |
public static | function | Updates entity weights based on their weights in the widget. | |
MessengerTrait:: |
protected | property | The messenger. | 29 |
MessengerTrait:: |
public | function | Gets the messenger. | 29 |
MessengerTrait:: |
public | function | Sets the messenger. | |
PluginBase:: |
protected | property | Configuration information passed into the plugin. | 1 |
PluginBase:: |
protected | property | The plugin implementation definition. | 1 |
PluginBase:: |
protected | property | The plugin_id. | |
PluginBase:: |
constant | A string which is used to separate base plugin IDs from the derivative ID. | ||
PluginBase:: |
public | function |
Gets the base_plugin_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the derivative_id of the plugin instance. Overrides DerivativeInspectionInterface:: |
|
PluginBase:: |
public | function |
Gets the definition of the plugin implementation. Overrides PluginInspectionInterface:: |
3 |
PluginBase:: |
public | function |
Gets the plugin_id of the plugin instance. Overrides PluginInspectionInterface:: |
|
PluginBase:: |
public | function | Determines if the plugin is configurable. | |
PluginSettingsBase:: |
protected | property | Whether default settings have been merged into the current $settings. | |
PluginSettingsBase:: |
protected | property | The plugin settings injected by third party modules. | |
PluginSettingsBase:: |
public | function |
Returns the value of a setting, or its default value if absent. Overrides PluginSettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Returns the array of settings, including defaults for missing settings. Overrides PluginSettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Gets the list of third parties that store information. Overrides ThirdPartySettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Gets the value of a third-party setting. Overrides ThirdPartySettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Gets all third-party settings of a given module. Overrides ThirdPartySettingsInterface:: |
|
PluginSettingsBase:: |
protected | function | Merges default settings values into $settings. | |
PluginSettingsBase:: |
public | function |
Informs the plugin that some configuration it depends on will be deleted. Overrides PluginSettingsInterface:: |
3 |
PluginSettingsBase:: |
public | function |
Sets the value of a setting for the plugin. Overrides PluginSettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Sets the settings for the plugin. Overrides PluginSettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Sets the value of a third-party setting. Overrides ThirdPartySettingsInterface:: |
|
PluginSettingsBase:: |
public | function |
Unsets a third-party setting. Overrides ThirdPartySettingsInterface:: |
|
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. | |
WidgetBase:: |
protected | property | The field definition. | |
WidgetBase:: |
protected | property |
The widget settings. Overrides PluginSettingsBase:: |
|
WidgetBase:: |
public static | function | Ajax callback for the "Add another item" button. | |
WidgetBase:: |
public static | function | Submission handler for the "Add another item" button. | |
WidgetBase:: |
public static | function | After-build handler for field elements in a form. | |
WidgetBase:: |
public | function |
Assigns a field-level validation error to the right widget sub-element. Overrides WidgetInterface:: |
8 |
WidgetBase:: |
public | function |
Reports field-level validation errors against actual form elements. Overrides WidgetBaseInterface:: |
2 |
WidgetBase:: |
protected | function | Special handling to create form elements for multiple values. | 1 |
WidgetBase:: |
protected | function | Generates the form element for a single copy of the widget. | |
WidgetBase:: |
protected | function | Returns the filtered field description. | |
WidgetBase:: |
public static | function |
Retrieves processing information about the widget from $form_state. Overrides WidgetBaseInterface:: |
|
WidgetBase:: |
protected static | function | Returns the location of processing information within $form_state. | |
WidgetBase:: |
protected | function | Returns whether the widget handles multiple values. | |
WidgetBase:: |
public static | function |
Returns if the widget can be used for the provided field. Overrides WidgetInterface:: |
4 |
WidgetBase:: |
protected | function | Returns whether the widget used for default value form. | |
WidgetBase:: |
public static | function |
Stores processing information about the widget in $form_state. Overrides WidgetBaseInterface:: |