class LinkAllyFormatter in Element Class Formatter 8
Defines a formatter that allows links with screenreader only text.
Plugin annotation
@FieldFormatter(
id = "link_ally_class",
label = @Translation("Link (with screenreader text)"),
field_types = {
"link",
"string",
}
)
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\element_class_formatter\Plugin\Field\FieldFormatter\LinkAllyFormatter uses ElementClassTrait
- 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 LinkAllyFormatter
File
- src/
Plugin/ Field/ FieldFormatter/ LinkAllyFormatter.php, line 26
Namespace
Drupal\element_class_formatter\Plugin\Field\FieldFormatterView source
class LinkAllyFormatter extends FormatterBase {
/**
* Token service.
*
* @var \Drupal\Core\Utility\Token
*/
protected $token;
use ElementClassTrait;
/**
* {@inheritdoc}
*/
public static function create(ContainerInterface $container, array $configuration, $plugin_id, $plugin_definition) {
/** @var self $instance */
$instance = parent::create($container, $configuration, $plugin_id, $plugin_definition);
$instance->token = $container
->get('token');
return $instance;
}
/**
* {@inheritdoc}
*/
public static function defaultSettings() {
$default_settings = parent::defaultSettings() + [
'link_text' => '',
'screenreader_text' => '',
'tag' => '',
];
return ElementClassTrait::elementClassDefaultSettings($default_settings);
}
/**
* {@inheritdoc}
*/
public function settingsForm(array $form, FormStateInterface $form_state) {
$elements = parent::settingsForm($form, $form_state);
$elements['link_text'] = [
'#title' => $this
->t('Link text'),
'#type' => 'textfield',
'#default_value' => $this
->getSetting('link_text'),
'#description' => $this
->t('Custom link text - leave empty to use the field value.'),
];
$elements['screenreader_text'] = [
'#title' => $this
->t('Screenreader text'),
'#type' => 'textfield',
'#default_value' => $this
->getSetting('screenreader_text'),
'#description' => $this
->t('Screenreader text - tokens are available.'),
];
$class = $this
->getSetting('class');
$wrapper_options = [
'span' => 'span',
'div' => 'div',
'p' => 'p',
];
foreach (range(1, 5) as $level) {
$wrapper_options['h' . $level] = 'H' . $level;
}
$elements['tag'] = [
'#title' => $this
->t('Tag'),
'#type' => 'select',
'#description' => $this
->t('Select an optional tag that will be wrapped around the link.'),
'#options' => $wrapper_options,
'#default_value' => $this
->getSetting('tag'),
'#empty_value' => '',
'#empty_option' => $this
->t('None'),
];
return $this
->elementClassSettingsForm($elements, $class);
}
/**
* {@inheritdoc}
*/
public function settingsSummary() {
$summary = parent::settingsSummary();
$class = $this
->getSetting('class');
if ($link_text = $this
->getSetting('link_text')) {
$summary[] = $this
->t('Link text: @text', [
'@text' => $link_text,
]);
}
if ($screenreader_text = $this
->getSetting('screenreader_text')) {
$summary[] = $this
->t('Screenreader text: @text', [
'@text' => $screenreader_text,
]);
}
if ($tag = $this
->getSetting('tag')) {
$summary[] = $this
->t('Tag: @tag', [
'@tag' => $tag,
]);
}
return $this
->elementClassSettingsSummary($summary, $class);
}
/**
* {@inheritdoc}
*/
public function viewElements(FieldItemListInterface $items, $langcode) {
$build = [];
$entity = $items
->getEntity();
$custom_link_text = $this
->getSetting('link_text');
$cache = new BubbleableMetadata();
$screenreader_text = trim($this->token
->replace($this
->getSetting('screenreader_text'), [
$entity
->getEntityTypeId() => $entity,
], [], $cache));
if ($screenreader_text) {
$screenreader_text = [
'#type' => 'inline_template',
'#template' => '<span class="visually-hidden">{{screenreader_text}}</span>',
'#context' => [
'screenreader_text' => [
'#markup' => $screenreader_text,
],
],
];
}
foreach ($items as $delta => $item) {
$label = $items
->getFieldDefinition()
->getType() === 'link' ? $item->title : $item->value;
$uri = $items
->getFieldDefinition()
->getType() === 'link' ? $item
->getUrl() ?: Url::fromRoute('<none>') : $entity
->toUrl('canonical');
if ($custom_link_text) {
$label = $custom_link_text;
}
if ($screenreader_text) {
$label = [
[
'#plain_text' => $label,
],
$screenreader_text,
];
}
$build[$delta] = [
'#type' => 'link',
'#title' => $label,
'#url' => $uri,
'#options' => $uri
->getOptions(),
];
}
$cache
->applyTo($build);
$build = $this
->setElementClass($build, $this
->getSetting('class'), $items);
if ($tag = $this
->getSetting('tag')) {
foreach (Element::children($build) as $delta) {
$build[$delta] = [
'#type' => 'inline_template',
'#template' => '<{{tag}}>{{element}}</{{tag}}>',
'#context' => [
'tag' => $tag,
'element' => $build[$delta],
],
];
}
}
return $build;
}
/**
* {@inheritdoc}
*/
public static function isApplicable(FieldDefinitionInterface $field_definition) {
$manager = \Drupal::entityTypeManager();
$type_id = $field_definition
->getTargetEntityTypeId();
// Either this is a link field, or this is an entity-type that has a
// canonical route.
return parent::isApplicable($field_definition) && ($field_definition
->getType() === 'link' || $manager
->hasDefinition($type_id) && ($type = $manager
->getDefinition($type_id)) && $type
->hasLinkTemplate('canonical'));
}
}
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 | |
ElementClassTrait:: |
public static | function | Default class value. | |
ElementClassTrait:: |
public | function | Setting form to collect class value. | |
ElementClassTrait:: |
public | function | Text for settings summary. | |
ElementClassTrait:: |
public | function | Set the class on the element. | |
ElementClassTrait:: |
public | function | Set the class on the entity. | |
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:: |
protected | function | Returns the value of a field setting. | |
FormatterBase:: |
protected | function | Returns the array of field settings. | |
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 |
LinkAllyFormatter:: |
protected | property | Token service. | |
LinkAllyFormatter:: |
public static | function |
Creates an instance of the plugin. Overrides FormatterBase:: |
|
LinkAllyFormatter:: |
public static | function |
Defines the default settings for this plugin. Overrides PluginSettingsBase:: |
|
LinkAllyFormatter:: |
public static | function |
Returns if the formatter can be used for the provided field. Overrides FormatterBase:: |
|
LinkAllyFormatter:: |
public | function |
Returns a form to configure settings for the formatter. Overrides FormatterBase:: |
|
LinkAllyFormatter:: |
public | function |
Returns a short summary for the current formatter settings. Overrides FormatterBase:: |
|
LinkAllyFormatter:: |
public | function |
Builds a renderable array for a field value. Overrides FormatterInterface:: |
|
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. |