class EntityReferenceUser in Workbench Email 8
Same name and namespace in other branches
- 2.x src/Plugin/RecipientType/EntityReferenceUser.php \Drupal\workbench_email\Plugin\RecipientType\EntityReferenceUser
Provides a recipient type based on entity reference fields.
Plugin annotation
@RecipientType(
id = "entity_reference_user",
title = @Translation("Entity Reference: User"),
description = @Translation("Send to users referenced in an entity reference field."),
settings = {
"fields" = {},
},
)
Hierarchy
- class \Drupal\Component\Plugin\PluginBase implements DerivativeInspectionInterface, PluginInspectionInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
- class \Drupal\workbench_email\Plugin\RecipientTypeBase implements RecipientTypeInterface uses PluginWithFormsTrait
- class \Drupal\workbench_email\Plugin\RecipientType\EmailField implements ContainerFactoryPluginInterface
- class \Drupal\workbench_email\Plugin\RecipientType\EntityReferenceUser
- class \Drupal\workbench_email\Plugin\RecipientType\EmailField implements ContainerFactoryPluginInterface
- class \Drupal\workbench_email\Plugin\RecipientTypeBase implements RecipientTypeInterface uses PluginWithFormsTrait
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of EntityReferenceUser
File
- src/
Plugin/ RecipientType/ EntityReferenceUser.php, line 20
Namespace
Drupal\workbench_email\Plugin\RecipientTypeView source
class EntityReferenceUser extends EmailField {
/**
* {@inheritdoc}
*/
public function buildConfigurationForm(array $form, FormStateInterface $form_state) {
// Add the fields.
$fields = $this->entityFieldManager
->getFieldMapByFieldType('entity_reference');
$field_options = [];
foreach ($fields as $entity_type_id => $entity_type_fields) {
$entity_type = $this->entityTypeManager
->getDefinition($entity_type_id);
if (!$this
->isModeratableEntityType($entity_type)) {
// These fields are irrelevant, the entity type isn't moderated.
continue;
}
$base = $this->entityFieldManager
->getBaseFieldDefinitions($entity_type_id);
foreach ($entity_type_fields as $field_name => $field_detail) {
if (in_array($field_name, array_keys($base), TRUE)) {
if ($base[$field_name]
->getSetting('target_type') !== 'user') {
continue;
}
$field_options[$entity_type_id . ':' . $field_name] = $base[$field_name]
->getLabel() . ' (' . $entity_type
->getLabel() . ')';
continue;
}
$sample_bundle = reset($field_detail['bundles']);
$bundle_fields = $this->entityFieldManager
->getFieldDefinitions($entity_type_id, $sample_bundle);
if (!isset($bundle_fields[$field_name])) {
// Stale field map reference.
continue;
}
$sample_field = $bundle_fields[$field_name];
if ($sample_field
->getSetting('target_type') !== 'user') {
continue;
}
$field_options[$entity_type_id . ':' . $field_name] = $sample_field
->label() . ' (' . $entity_type
->getLabel() . ')';
}
}
return [
'fields' => [
'#type' => 'checkboxes',
'#title' => $this
->t('Entity Reference User Fields'),
'#description' => $this
->t('Send to users referenced by the selected fields.'),
'#options' => $field_options,
'#default_value' => $this
->getFields(),
],
];
}
/**
* {@inheritdoc}
*/
protected function getEmailFromFieldItem(FieldItemInterface $field_item) {
return $field_item->entity
->getEmail();
}
}
Members
Name | Modifiers | Type | Description | Overrides |
---|---|---|---|---|
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 | |
EmailField:: |
protected | property | The entity field manager. | |
EmailField:: |
protected | property | The entity type manager. | |
EmailField:: |
protected | property | Moderation info service. | |
EmailField:: |
public | function |
Calculates dependencies for the configured plugin. Overrides RecipientTypeBase:: |
|
EmailField:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
|
EmailField:: |
protected | function | Gets value of roles. | |
EmailField:: |
protected | function | Determines if an entity type has been marked as moderatable. | |
EmailField:: |
public | function |
Informs the plugin that a dependency of the recipient type will be deleted. Overrides RecipientTypeBase:: |
|
EmailField:: |
public | function |
Returns email address(s) matching this recipient type's configuration. Overrides RecipientTypeBase:: |
|
EmailField:: |
protected | function | Sets roles. | |
EmailField:: |
public | function |
Form submission handler. Overrides RecipientTypeBase:: |
|
EmailField:: |
public | function |
Constructs a new EmailField object. Overrides RecipientTypeBase:: |
|
EntityReferenceUser:: |
public | function |
Generates a recipient types's settings form. Overrides EmailField:: |
|
EntityReferenceUser:: |
protected | function |
Overrides EmailField:: |
|
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. | |
PluginWithFormsTrait:: |
public | function | ||
PluginWithFormsTrait:: |
public | function | ||
RecipientTypeBase:: |
public | property | The name of the provider that owns this recipient type. | |
RecipientTypeBase:: |
public | property | An associative array containing the configured settings of this recipient type. | |
RecipientTypeBase:: |
public | property | A Boolean indicating whether this recipient type is enabled. | |
RecipientTypeBase:: |
public | function |
Gets default configuration for this plugin. Overrides ConfigurableInterface:: |
|
RecipientTypeBase:: |
public | function |
Gets this plugin's configuration. Overrides ConfigurableInterface:: |
|
RecipientTypeBase:: |
public | function |
Returns the administrative description for this recipient type plugin. Overrides RecipientTypeInterface:: |
|
RecipientTypeBase:: |
public | function |
Returns the administrative label for this recipient type plugin. Overrides RecipientTypeInterface:: |
|
RecipientTypeBase:: |
public | function |
Checks status. Overrides RecipientTypeInterface:: |
|
RecipientTypeBase:: |
public | function |
Sets the configuration for this plugin instance. Overrides ConfigurableInterface:: |
|
RecipientTypeBase:: |
public | function |
Form validation handler. Overrides PluginFormInterface:: |
|
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. |