class AutocompleteDeluxeWidget in Autocomplete Deluxe 8
Same name and namespace in other branches
- 2.0.x src/Plugin/Field/FieldWidget/AutocompleteDeluxeWidget.php \Drupal\autocomplete_deluxe\Plugin\Field\FieldWidget\AutocompleteDeluxeWidget
Plugin implementation of the 'options_buttons' widget.
Plugin annotation
@FieldWidget(
id = "autocomplete_deluxe",
label = @Translation("Autocomplete Deluxe"),
field_types = {
"entity_reference"
},
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\autocomplete_deluxe\Plugin\Field\FieldWidget\AutocompleteDeluxeWidget implements ContainerFactoryPluginInterface uses StringTranslationTrait
- 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 AutocompleteDeluxeWidget
File
- src/
Plugin/ Field/ FieldWidget/ AutocompleteDeluxeWidget.php, line 32
Namespace
Drupal\autocomplete_deluxe\Plugin\Field\FieldWidgetView source
class AutocompleteDeluxeWidget extends WidgetBase implements ContainerFactoryPluginInterface {
use StringTranslationTrait;
/**
* The module handler.
*
* @var \Drupal\Core\Extension\ModuleHandlerInterface
*/
protected $moduleHandler;
/**
* {@inheritdoc}
*
* @param string $plugin_id
* The plugin_id for the plugin instance.
* @param mixed $plugin_definition
* The plugin implementation definition.
* @param \Drupal\Core\Field\FieldDefinitionInterface $field_definition
* The field definition for the operation.
* @param array $settings
* The formatter settings.
* @param array $third_party_settings
* Any third party settings.
* @param \Drupal\Core\Extension\ModuleHandlerInterface $module_handler
* The module handler.
*/
public function __construct($plugin_id, $plugin_definition, FieldDefinitionInterface $field_definition, array $settings, array $third_party_settings, ModuleHandlerInterface $module_handler) {
parent::__construct($plugin_id, $plugin_definition, $field_definition, $settings, $third_party_settings);
$this->moduleHandler = $module_handler;
}
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
return new static($plugin_id, $plugin_definition, $configuration['field_definition'], $configuration['settings'], $configuration['third_party_settings'], $container
->get('module_handler'));
}
/**
* {@inheritdoc}
*/
public static function defaultSettings() {
return [
'match_operator' => 'CONTAINS',
'autocomplete_route_name' => 'autocomplete_deluxe.autocomplete',
'size' => 60,
'selection_handler' => 'default',
'limit' => 10,
'min_length' => 0,
'delimiter' => '',
'not_found_message_allow' => FALSE,
'not_found_message' => "The term '@term' will be added",
'new_terms' => FALSE,
'no_empty_message' => 'No terms could be found. Please type in order to add a new term.',
] + parent::defaultSettings();
}
/**
* {@inheritdoc}
*/
public function settingsForm(array $form, FormStateInterface $form_state) {
$element['limit'] = [
'#type' => 'textfield',
'#title' => $this
->t('Limit of the output.'),
'#description' => $this
->t('If set to zero no limit will be used'),
'#default_value' => $this
->getSetting('limit'),
'#element_validate' => [
[
get_class($this),
'validateInteger',
],
],
];
$element['min_length'] = [
'#type' => 'textfield',
'#title' => $this
->t('Minimum length.'),
'#description' => $this
->t('The minimum length of characters to enter to open the suggestion list.'),
'#default_value' => $this
->getSetting('min_length'),
'#element_validate' => [
[
get_class($this),
'validateInteger',
],
],
];
$element['delimiter'] = [
'#type' => 'textfield',
'#title' => $this
->t('Delimiter.'),
'#description' => $this
->t('A character which should be used beside the enter key, to separate terms.'),
'#default_value' => $this
->getSetting('delimiter'),
'#size' => 1,
];
$element['not_found_message_allow'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Show Term not found message'),
'#description' => $this
->t('If this is enabled, a message will be displayed when the term is not found.'),
'#default_value' => $this
->getSetting('not_found_message_allow'),
];
$element['not_found_message'] = [
'#type' => 'textfield',
'#title' => $this
->t('Term not found message.'),
'#description' => $this
->t('A message text which will be displayed, if the entered term was not found.'),
'#default_value' => $this
->getSetting('not_found_message'),
];
$element['new_terms'] = [
'#type' => 'checkbox',
'#title' => $this
->t('Allow new terms'),
'#description' => $this
->t('Should it be allowed, that user enter new terms?'),
'#default_value' => $this
->getSetting('new_terms'),
];
$element['no_empty_message'] = [
'#type' => 'textfield',
'#title' => $this
->t('Empty value message.'),
'#description' => $this
->t('A text message that will be displayed when the field is focused and it does not contain values.'),
'#default_value' => $this
->getSetting('no_empty_message'),
];
return $element;
}
/**
* {@inheritdoc}
*/
public function settingsSummary() {
$summary = [];
$summary[] = $this
->t('Limit: @limit', [
'@limit' => $this
->getSetting('limit'),
]);
$summary[] = $this
->t('Min length: @min_length', [
'@min_length' => $this
->getSetting('min_length'),
]);
$summary[] = $this
->t('Delimiter: @delimiter', [
'@delimiter' => $this
->getSetting('delimiter'),
]);
$summary[] = $this
->t('Allow Not Found message: @not_found_message_allow', [
'@not_found_message_allow' => $this
->getSetting('not_found_message_allow') ? 'Yes' : 'No',
]);
$summary[] = $this
->t('Not Found message: @not_found_message', [
'@not_found_message' => $this
->getSetting('not_found_message'),
]);
$summary[] = $this
->t('Allow new terms: @new_terms', [
'@new_terms' => $this
->getSetting('new_terms') ? 'Yes' : 'No',
]);
$summary[] = $this
->t('Empty value message: @no_empty_message', [
'@no_empty_message' => $this
->getSetting('no_empty_message'),
]);
return $summary;
}
/**
* {@inheritdoc}
*/
public function formElement(FieldItemListInterface $items, $delta, array $element, array &$form, FormStateInterface $form_state) {
$entity = $items
->getEntity();
$instance = $this->fieldDefinition;
$cardinality = $instance
->getFieldStorageDefinition()
->getCardinality();
$target_type = $instance
->getFieldStorageDefinition()
->getSetting('target_type');
$settings = $this
->getSettings();
$referenced_entities = $items
->referencedEntities();
$selection_settings = $this
->getFieldSetting('handler_settings') + [
'match_operator' => $this
->getSetting('match_operator'),
];
$new_terms = isset($settings['new_terms']) ? $settings['new_terms'] : FALSE;
$allow_message = isset($settings['not_found_message_allow']) ? $settings['not_found_message_allow'] : FALSE;
$not_found_message = isset($settings['not_found_message']) ? $settings['not_found_message'] : "The term '@term' will be added.";
if (!$new_terms) {
if ($allow_message) {
$not_found_message = "Cannot add '@term' because 'Allow new terms' is disabled on the widget settings.";
}
else {
$not_found_message = "";
}
}
$element += [
'#type' => 'autocomplete_deluxe',
'#title' => $this->fieldDefinition
->getLabel(),
'#target_type' => $target_type,
'#selection_handler' => $this
->getFieldSetting('handler'),
'#selection_settings' => $selection_settings,
'#size' => 60,
'#limit' => isset($settings['limit']) ? $settings['limit'] : 10,
'#min_length' => isset($settings['min_length']) ? $settings['min_length'] : 0,
'#delimiter' => isset($settings['delimiter']) ? $settings['delimiter'] : '',
'#not_found_message_allow' => $allow_message,
'#not_found_message' => $this
->t($not_found_message),
'#new_terms' => isset($settings['new_terms']) ? $settings['new_terms'] : FALSE,
'#no_empty_message' => isset($settings['no_empty_message']) ? $this
->t($settings['no_empty_message']) : '',
];
$multiple = $cardinality > 1 || $cardinality == FieldStorageDefinitionInterface::CARDINALITY_UNLIMITED;
// If new terms are allowed to be created, set the bundle and the uid of the
// term.
if ($this
->getSetting('new_terms') && $this
->getSelectionHandlerSetting('auto_create') && ($bundle = $this
->getAutocreateBundle())) {
$element['#autocreate'] = [
'bundle' => $bundle,
'uid' => $entity instanceof EntityOwnerInterface ? $entity
->getOwnerId() : \Drupal::currentUser()
->id(),
];
}
$entities = [];
foreach ($referenced_entities as $item) {
$entities[$item
->id()] = $item;
}
$selection_settings = isset($element['#selection_settings']) ? $element['#selection_settings'] : [];
$data = serialize($selection_settings) . $element['#target_type'] . $element['#selection_handler'];
$selection_settings_key = Crypt::hmacBase64($data, Settings::getHashSalt());
$key_value_storage = \Drupal::keyValue('entity_autocomplete');
if (!$key_value_storage
->has($selection_settings_key)) {
$key_value_storage
->set($selection_settings_key, $selection_settings);
}
$route_parameters = [
'target_type' => $target_type,
'selection_handler' => $element['#selection_handler'],
'selection_settings_key' => $selection_settings_key,
];
$element += [
'#multiple' => $multiple,
'#autocomplete_deluxe_path' => Url::fromRoute('autocomplete_deluxe.autocomplete', $route_parameters, [
'absolute' => TRUE,
])
->getInternalPath(),
'#default_value' => self::implodeEntities($entities),
];
return [
'target_id' => $element,
];
}
/**
* Implodes the tags from the taxonomy module.
*
* @param \Drupal\Core\Entity\EntityInterface[] $entities
* List of entities.
* @param string $bundle
* Bundle name.
*
* @return array
* Imploded list of entity labels.
*/
public static function implodeEntities(array $entities, $bundle = NULL) {
$typed_entities = [];
foreach ($entities as $entity) {
$label = $entity
->label();
// Extract entities belonging to the bundle in question.
if (!isset($bundle) || $entity
->bundle() == $bundle) {
// Make sure we have a completed loaded entity.
if ($entity && $label) {
// Commas and quotes in tag names are special cases, so encode 'em.
if (strpos($label, ',') !== FALSE || strpos($label, '"') !== FALSE) {
$label = '"' . str_replace('"', '""', $label) . '"';
}
$typed_entities[] = $label;
}
}
}
return implode(',', $typed_entities);
}
/**
* {@inheritdoc}
*/
public function massageFormValues(array $values, array $form, FormStateInterface $form_state) {
return $values['target_id'];
}
/**
* Form element validation handler for integer textfields.
*/
public static function validateInteger(&$element, FormStateInterface $form_state, &$complete_form) {
$value = $element['#value'];
if ($value !== '' && (!is_numeric($value) || intval($value) != $value)) {
$form_state
->setError($element, \Drupal::translation()
->translate('%name must be an integer.', [
'%name' => $element['#title'],
]));
}
}
/**
* Form element validation handler for positive integer textfields.
*/
public static function validateIntegerPositive(&$element, FormStateInterface $form_state, &$complete_form) {
$value = $element['#value'];
if ($value !== '' && (!is_numeric($value) || intval($value) != $value || $value <= 0)) {
$form_state
->setError($element, \Drupal::translation()
->translate('%name must be a positive integer.', [
'%name' => $element['#title'],
]));
}
}
/**
* Returns the name of the bundle which will be used for autocreated entities.
*
* @return string
* The bundle name.
*/
protected function getAutocreateBundle() {
$bundle = NULL;
if ($this
->getSelectionHandlerSetting('auto_create') && ($target_bundles = $this
->getSelectionHandlerSetting('target_bundles'))) {
// If there's only one target bundle, use it.
if (count($target_bundles) == 1) {
$bundle = reset($target_bundles);
}
elseif (!($bundle = $this
->getSelectionHandlerSetting('auto_create_bundle'))) {
// If no bundle has been set as auto create target means that there is
// an inconsistency in entity reference field settings.
trigger_error(sprintf("The 'Create referenced entities if they don't already exist' option is enabled but a specific destination bundle is not set. You should re-visit and fix the settings of the '%s' (%s) field.", $this->fieldDefinition
->getLabel(), $this->fieldDefinition
->getName()), E_USER_WARNING);
}
}
return $bundle;
}
/**
* Returns the value of a setting for the entity reference selection handler.
*
* @param string $setting_name
* The setting name.
*
* @return mixed
* The setting value.
*/
protected function getSelectionHandlerSetting($setting_name) {
$settings = $this
->getFieldSetting('handler_settings');
return isset($settings[$setting_name]) ? $settings[$setting_name] : NULL;
}
/**
* Returns the options for the match operator.
*
* @return array
* List of options.
*/
protected function getMatchOperatorOptions() {
return [
'STARTS_WITH' => $this
->t('Starts with'),
'CONTAINS' => $this
->t('Contains'),
];
}
}
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. | |
AutocompleteDeluxeWidget:: |
protected | property | The module handler. | |
AutocompleteDeluxeWidget:: |
public static | function |
Creates an instance of the plugin. Overrides WidgetBase:: |
|
AutocompleteDeluxeWidget:: |
public static | function |
Defines the default settings for this plugin. Overrides PluginSettingsBase:: |
|
AutocompleteDeluxeWidget:: |
public | function |
Returns the form for a single field widget. Overrides WidgetInterface:: |
|
AutocompleteDeluxeWidget:: |
protected | function | Returns the name of the bundle which will be used for autocreated entities. | |
AutocompleteDeluxeWidget:: |
protected | function | Returns the options for the match operator. | |
AutocompleteDeluxeWidget:: |
protected | function | Returns the value of a setting for the entity reference selection handler. | |
AutocompleteDeluxeWidget:: |
public static | function | Implodes the tags from the taxonomy module. | |
AutocompleteDeluxeWidget:: |
public | function |
Massages the form values into the format expected for field values. Overrides WidgetBase:: |
|
AutocompleteDeluxeWidget:: |
public | function |
Returns a form to configure settings for the widget. Overrides WidgetBase:: |
|
AutocompleteDeluxeWidget:: |
public | function |
Returns a short summary for the current widget settings. Overrides WidgetBase:: |
|
AutocompleteDeluxeWidget:: |
public static | function | Form element validation handler for integer textfields. | |
AutocompleteDeluxeWidget:: |
public static | function | Form element validation handler for positive integer textfields. | |
AutocompleteDeluxeWidget:: |
public | function |
Overrides WidgetBase:: |
|
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 | |
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 |
Calculates dependencies for the configured plugin. Overrides DependentPluginInterface:: |
6 |
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 |
Extracts field values from submitted form values. Overrides WidgetBaseInterface:: |
2 |
WidgetBase:: |
public | function |
Reports field-level validation errors against actual form elements. Overrides WidgetBaseInterface:: |
2 |
WidgetBase:: |
public | function |
Creates a form element for a field. Overrides WidgetBaseInterface:: |
3 |
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 value of a field setting. | |
WidgetBase:: |
protected | function | Returns the array of field settings. | |
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:: |