class ViewsContactFormEmailFormatter in Views Contact Form 8
Plugin implementation of the 'ViewsContactFormEmailFormatter' formatter
Plugin annotation
@FieldFormatter(
id = "views_contact_form_email_formatter",
label = @Translation("Views Contact Form"),
field_types = {
"email"
},
settings = {
"category" = "feedback",
"category_recipients_include" = 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\FormatterBase implements FormatterInterface, ContainerFactoryPluginInterface
- class \Drupal\views_contact_form\Plugin\Field\FieldFormatter\ViewsContactFormEmailFormatter
- class \Drupal\Core\Field\FormatterBase implements FormatterInterface, ContainerFactoryPluginInterface
- class \Drupal\Core\Field\PluginSettingsBase implements DependentPluginInterface, PluginSettingsInterface
- class \Drupal\Core\Plugin\PluginBase uses DependencySerializationTrait, MessengerTrait, StringTranslationTrait
Expanded class hierarchy of ViewsContactFormEmailFormatter
File
- lib/
Drupal/ views_contact_form/ Plugin/ Field/ FieldFormatter/ ViewsContactFormEmailFormatter.php, line 29 - Definition of Drupal\views_contact_form\Plugin\field\formatter\ViewsContactFormEmailFormatter.
Namespace
Drupal\views_contact_form\Plugin\Field\FieldFormatterView source
class ViewsContactFormEmailFormatter extends FormatterBase {
/**
* {@inheritdoc}
*/
public function viewElements(FieldItemListInterface $items) {
module_load_include('pages.inc', 'contact');
// Get the category entity from the configuration.
$category = clone entity_load('contact_category', $this
->getSetting('category'));
// Get value from the items and store it.
$recipients = array();
foreach ($items as $delta => $item) {
$recipients[] = $item->value;
}
// If we want to send email also to the recipients from the category,
// merge recipients from items and category.
if ($this
->getSetting('category_recipients_include') == TRUE) {
$recipients = array_merge($recipients, $category->recipients);
}
// Remove the doubles to avoid double mail.
$recipients = array_unique($recipients);
// Finally override the recipients on the category entity.
$category
->set('recipients', $recipients);
// Create the Message entity from the category.
$message = entity_create('contact_message', array(
'category' => $category
->id(),
));
// Override the entity category in the Message.
// So the recipients are also set.
$message->category->entity = $category;
// Get the form
$form = \Drupal::entityManager()
->getForm($message);
// Override the title
$form['#title'] = String::checkPlain($category
->label());
// Render the form and return the element.
return array(
0 => array(
'#markup' => drupal_render($form),
),
);
}
/**
* {@inheritdoc}
*/
public function settingsSummary() {
$summary = array();
$entity = entity_load('contact_category', $this
->getSetting('category'));
$category_recipients_include = $this
->getSetting('category_recipients_include') == TRUE ? 'Yes' : 'No';
$summary[] = t('Category: <a href="@url">@category</a>', array(
'@url' => '/admin/structure/contact/manage/' . $entity->id,
'@category' => $entity->label,
));
$summary[] = t('Include category recipient(s): @category_recipients_include', array(
'@category_recipients_include' => $category_recipients_include,
));
return $summary;
}
/**
* {@inheritdoc}
*/
public function settingsForm(array $form, array &$form_state) {
$categories = entity_load_multiple('contact_category');
foreach ($categories as $id => $category) {
$options[$id] = $category->label;
}
$form['category'] = array(
'#title' => 'Choose the category',
'#type' => 'select',
'#options' => $options,
'#default_value' => $this
->getSetting('category'),
);
$form['category_recipients_include'] = array(
'#title' => 'Category recipient(s)',
'#description' => 'Should we also send the mail to the default category recipient(s) ?',
'#type' => 'checkbox',
'#default_value' => $this
->getSetting('category_recipients_include'),
);
$form['form_display'] = array(
'#title' => 'Form display',
'#markup' => 'You can customize the display of the form by editing the ' . 'category form display. Click on the corresponding link: ' . '<em>Manage form display</em> on ' . l('this page', 'admin/structure/contact', array(
'attributes' => array(
'target' => '_blank',
),
)),
'#type' => 'item',
);
return $form;
}
}
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 | |
FormatterBase:: |
protected | property | The field definition. | |
FormatterBase:: |
protected | property | The label display setting. | |
FormatterBase:: |
protected | property |
The formatter settings. Overrides PluginSettingsBase:: |
|
FormatterBase:: |
protected | property | The view mode. | |
FormatterBase:: |
public static | function |
Creates an instance of the plugin. Overrides ContainerFactoryPluginInterface:: |
11 |
FormatterBase:: |
protected | function | Returns the value of a field setting. | |
FormatterBase:: |
protected | function | Returns the array of field settings. | |
FormatterBase:: |
public static | function |
Returns if the formatter can be used for the provided field. Overrides FormatterInterface:: |
14 |
FormatterBase:: |
public | function |
Allows formatters to load information for field values being displayed. Overrides FormatterInterface:: |
2 |
FormatterBase:: |
public | function |
Builds a renderable array for a fully themed field. Overrides FormatterInterface:: |
1 |
FormatterBase:: |
public | function |
Constructs a FormatterBase object. Overrides PluginBase:: |
11 |
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 static | function |
Defines the default settings for this plugin. Overrides PluginSettingsInterface:: |
42 |
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. | |
ViewsContactFormEmailFormatter:: |
public | function |
Returns a form to configure settings for the formatter. Overrides FormatterBase:: |
|
ViewsContactFormEmailFormatter:: |
public | function |
Returns a short summary for the current formatter settings. Overrides FormatterBase:: |
|
ViewsContactFormEmailFormatter:: |
public | function |
Builds a renderable array for a field value. Overrides FormatterInterface:: |