class EntityAutocomplete in YAML Form 8
Provides a 'entity_autocomplete' element.
Plugin annotation
@YamlFormElement(
id = "entity_autocomplete",
api = "https://api.drupal.org/api/drupal/core!lib!Drupal!Core!Entity!Element!EntityAutocomplete.php/class/EntityAutocomplete",
label = @Translation("Entity autocomplete"),
category = @Translation("Entity reference elements"),
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\yamlform\YamlFormElementBase implements YamlFormElementInterface uses StringTranslationTrait
- class \Drupal\yamlform\Plugin\YamlFormElement\EntityAutocomplete implements YamlFormEntityReferenceInterface uses YamlFormEntityReferenceTrait
- class \Drupal\yamlform\YamlFormElementBase implements YamlFormElementInterface uses StringTranslationTrait
Expanded class hierarchy of EntityAutocomplete
File
- src/
Plugin/ YamlFormElement/ EntityAutocomplete.php, line 19
Namespace
Drupal\yamlform\Plugin\YamlFormElementView source
class EntityAutocomplete extends YamlFormElementBase implements YamlFormEntityReferenceInterface {
use YamlFormEntityReferenceTrait;
/**
* {@inheritdoc}
*/
public function getDefaultProperties() {
return parent::getDefaultProperties() + [
// Entity reference settings.
'target_type' => '',
'selection_handler' => 'default',
'selection_settings' => [],
'tags' => FALSE,
];
}
/**
* {@inheritdoc}
*/
public function setDefaultValue(array &$element) {
if (isset($element['#default_value']) && (!empty($element['#default_value']) || $element['#default_value'] === 0)) {
$target_storage = $this->entityTypeManager
->getStorage($element['#target_type']);
if ($this
->hasMultipleValues($element)) {
$entity_ids = $this
->getTargetEntityIds($element['#default_value']);
$element['#default_value'] = $entity_ids ? $target_storage
->loadMultiple($entity_ids) : [];
}
else {
$element['#default_value'] = $target_storage
->load($element['#default_value']) ?: NULL;
}
}
else {
$element['#default_value'] = NULL;
}
}
/**
* {@inheritdoc}
*/
public function hasMultipleValues(array $element) {
return !empty($element['#tags']) ? TRUE : parent::hasMultipleValues($element);
}
/**
* {@inheritdoc}
*/
public function prepare(array &$element, YamlFormSubmissionInterface $yamlform_submission) {
parent::prepare($element, $yamlform_submission);
// If #tags (aka multiple entities) use #after_builder to set #element_value
// which must be executed after
// \Drupal\Core\Entity\Element\EntityAutocomplete::validateEntityAutocomplete().
if ($this
->hasMultipleValues($element)) {
$element['#after_build'][] = [
get_class($this),
'afterBuildEntityAutocomplete',
];
}
// If selection handler include auto_create when need to also set it for
// the $element.
// @see \Drupal\Core\Entity\Element\EntityAutocomplete::validateEntityAutocomplete
if (!empty($element['#selection_settings']['auto_create_bundle'])) {
$element['#autocreate']['bundle'] = $element['#selection_settings']['auto_create_bundle'];
}
}
/**
* Form API callback. After build set the #element_validate handler.
*/
public static function afterBuildEntityAutocomplete(array $element, FormStateInterface $form_state) {
$element['#element_validate'][] = [
'\\Drupal\\yamlform\\Plugin\\YamlFormElement\\EntityAutocomplete',
'validateEntityAutocomplete',
];
return $element;
}
/**
* Form API callback. Remove target id property and create an array of entity ids.
*/
public static function validateEntityAutocomplete(array &$element, FormStateInterface $form_state) {
$name = $element['#name'];
$value = $form_state
->getValue($name);
if (is_array($value) && !empty($value)) {
$entity_ids = [];
foreach ($value as $item) {
if (isset($item['target_id'])) {
$entity_ids[] = $item['target_id'];
}
elseif (isset($item['entity'])) {
// If #auto_create is set then we need to save the entity and get
// the new entity's id.
// @todo Decide what level of access controls are needed to allow
// users to create entities.
$entity = $item['entity'];
$entity
->save();
$entity_ids[] = $entity
->id();
}
}
$form_state
->setValueForElement($element, $entity_ids);
}
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
EntityAutocomplete:: |
public static | function | Form API callback. After build set the #element_validate handler. | |
EntityAutocomplete:: |
public | function |
Only a few elements don't inherit these default properties. Overrides YamlFormElementBase:: |
|
EntityAutocomplete:: |
public | function |
Checks if element value has multiple values. Overrides YamlFormElementBase:: |
|
EntityAutocomplete:: |
public | function |
Prepare an element to be rendered within a form. Overrides YamlFormElementBase:: |
|
EntityAutocomplete:: |
public | function |
Set an element's default value using saved data. Overrides YamlFormElementBase:: |
|
EntityAutocomplete:: |
public static | function | Form API callback. Remove target id property and create an array of entity ids. | |
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. | |
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. | |
YamlFormElementBase:: |
protected | property | The configuration factory. | |
YamlFormElementBase:: |
protected | property | The current user. | |
YamlFormElementBase:: |
protected | property | A element info manager. | |
YamlFormElementBase:: |
protected | property | The form element manager. | |
YamlFormElementBase:: |
protected | property | The entity type manager. | |
YamlFormElementBase:: |
protected | property | A logger instance. | |
YamlFormElementBase:: |
protected | property | The token manager. | |
YamlFormElementBase:: |
protected | function | Build an element as text or HTML. | 2 |
YamlFormElementBase:: |
public | function |
Form constructor. Overrides PluginFormInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Build an element as HTML element. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Build an element as text element. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Check element access (rules). Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
YamlFormElementBase:: |
public | function |
Display element disabled warning. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Format an element's table column value. Overrides YamlFormElementInterface:: |
2 |
YamlFormElementBase:: |
public | function |
Get an element's admin label (#admin_title, #title or #yamlform_key). Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Get an associative array of element properties from configuration form. Overrides YamlFormElementInterface:: |
2 |
YamlFormElementBase:: |
protected | function | Get configuration property value. | 1 |
YamlFormElementBase:: |
protected | function | Get default base properties used by all elements. | |
YamlFormElementBase:: |
protected | function | Get an element's (sub)inputs selectors as options. | 7 |
YamlFormElementBase:: |
public | function |
Get an element's selectors as options. Overrides YamlFormElementInterface:: |
11 |
YamlFormElementBase:: |
public | function |
Get an element's supported states as options. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Get element's format name by looking for '#format' property, global settings, and finally default settings. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Retrieves the default properties for the defined element type. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Get an element's key/name. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Get an element's label (#title or #yamlform_key). Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Get link to element's API documentation. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Get the URL for the element's API documentation. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Gets the label of the plugin instance. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Get element's table column(s) settings. Overrides YamlFormElementInterface:: |
3 |
YamlFormElementBase:: |
public | function |
Get test value for an element. Overrides YamlFormElementInterface:: |
7 |
YamlFormElementBase:: |
public | function |
Get translatable properties. Overrides YamlFormElementInterface:: |
7 |
YamlFormElementBase:: |
public | function |
Gets the type name (aka id) of the plugin instance with the 'yamlform_' prefix. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Determine if an element supports a specified property. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Checks if the element has a wrapper. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Initialize an element to be displayed, rendered, or exported. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Checks if element is a composite element. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Checks if element is a container that can contain elements. Overrides YamlFormElementInterface:: |
3 |
YamlFormElementBase:: |
public | function |
Checks if element is disabled. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Checks if element is enabled. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Checks if element is hidden. Overrides YamlFormElementInterface:: |
|
YamlFormElementBase:: |
public | function |
Checks if the element carries a value. Overrides YamlFormElementInterface:: |
5 |
YamlFormElementBase:: |
public | function |
Checks if element is a root element. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Acts on a form submission element after it is created. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Delete any additional value associated with an element. Overrides YamlFormElementInterface:: |
2 |
YamlFormElementBase:: |
public | function |
Acts on loaded form submission. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function |
Acts on a saved form submission element before the insert or update hook is invoked. Overrides YamlFormElementInterface:: |
2 |
YamlFormElementBase:: |
public | function |
Changes the values of an entity before it is created. Overrides YamlFormElementInterface:: |
1 |
YamlFormElementBase:: |
public | function | 1 | |
YamlFormElementBase:: |
protected | function | Prefix an element's export header. | |
YamlFormElementBase:: |
protected | function | Set an elements Flexbox and #states wrapper. | 1 |
YamlFormElementBase:: |
public | function |
Acts on a form submission element before the presave hook is invoked. Overrides YamlFormElementInterface:: |
2 |
YamlFormElementBase:: |
protected | function | Set an element's configuration form element default value. | 2 |
YamlFormElementBase:: |
protected | function | Set configuration form default values recursively. | |
YamlFormElementBase:: |
public | function |
Form submission handler. Overrides PluginFormInterface:: |
|
YamlFormElementBase:: |
public static | function | Form API callback. Validate #unique value. | |
YamlFormElementBase:: |
public | function |
Constructs a Drupal\Component\Plugin\PluginBase object. Overrides PluginBase:: |
|
YamlFormEntityReferenceTrait:: |
public | function | AJAX callback for entity reference details element. | |
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
protected | function | Format an entity autocomplete targets as array of strings. | |
YamlFormEntityReferenceTrait:: |
protected | function | Format an entity autocomplete as a link or a list of links. | |
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
protected | function | Format an entity autocomplete targets using a view mode. | |
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
protected | function | Get referenced entities. | |
YamlFormEntityReferenceTrait:: |
protected | function | Get target entity ids from entity autocomplete element's value. | |
YamlFormEntityReferenceTrait:: |
public | function | ||
YamlFormEntityReferenceTrait:: |
protected | function | Replace #ajax = TRUE with a work #ajax callback. | |
YamlFormEntityReferenceTrait:: |
public | function |