class EntityReferenceLabelClassFormatter in Element Class Formatter 8
Plugin implementation of the 'file with class' formatter.
Plugin annotation
@FieldFormatter(
  id = "entity_reference_label_class",
  label = @Translation("Label (with class)"),
  field_types = {
    "entity_reference"
  }
)
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\Core\Field\Plugin\Field\FieldFormatter\EntityReferenceFormatterBase- class \Drupal\Core\Field\Plugin\Field\FieldFormatter\EntityReferenceLabelFormatter- class \Drupal\element_class_formatter\Plugin\Field\FieldFormatter\EntityReferenceLabelClassFormatter uses ElementClassTrait
 
 
- class \Drupal\Core\Field\Plugin\Field\FieldFormatter\EntityReferenceLabelFormatter
 
- class \Drupal\Core\Field\Plugin\Field\FieldFormatter\EntityReferenceFormatterBase
 
- 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 EntityReferenceLabelClassFormatter
File
- src/Plugin/ Field/ FieldFormatter/ EntityReferenceLabelClassFormatter.php, line 21 
Namespace
Drupal\element_class_formatter\Plugin\Field\FieldFormatterView source
class EntityReferenceLabelClassFormatter extends EntityReferenceLabelFormatter {
  use ElementClassTrait;
  /**
   * {@inheritdoc}
   */
  public static function defaultSettings() {
    $default_settings = parent::defaultSettings() + [
      'tag' => '',
    ];
    return ElementClassTrait::elementClassDefaultSettings($default_settings);
  }
  /**
   * {@inheritdoc}
   */
  public function settingsForm(array $form, FormStateInterface $form_state) {
    $elements = parent::settingsForm($form, $form_state);
    $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',
      '#options' => $wrapper_options,
      '#default_value' => $this
        ->getSetting('tag'),
      '#description' => 'If not linked, set which tag should be used as the wrapper with the class.',
      '#states' => [
        'visible' => [
          ':input[name$="[link]"]' => [
            'checked' => FALSE,
          ],
        ],
      ],
    ];
    return $this
      ->elementClassSettingsForm($elements, $class);
  }
  /**
   * {@inheritdoc}
   */
  public function settingsSummary() {
    $summary = parent::settingsSummary();
    $class = $this
      ->getSetting('class');
    if ($tag = $this
      ->getSetting('tag')) {
      $summary[] = $this
        ->t('Tag: @tag', [
        '@tag' => $tag,
      ]);
    }
    return $this
      ->elementClassSettingsSummary($summary, $class);
  }
  /**
   * {@inheritdoc}
   */
  public function viewElements(FieldItemListInterface $items, $langcode) {
    $elements = parent::viewElements($items, $langcode);
    $class = $this
      ->getSetting('class');
    foreach ($this
      ->getEntitiesToView($items, $langcode) as $delta => $item) {
      // If it's a link add the class.
      if (isset($elements[$delta]['#type']) && $elements[$delta]['#type'] === 'link') {
        if (!empty($class)) {
          $elements[$delta]['#options']['attributes']['class'][] = $class;
        }
      }
      else {
        // Otherwise render as a div.
        $attributes = new Attribute();
        if (!empty($class)) {
          $attributes
            ->addClass($class);
        }
        // Otherwise collect the info needed for new render.
        $label = $elements[$delta]['#plain_text'];
        $cache = $elements[$delta]['#cache'];
        $elements[$delta] = [
          '#type' => 'html_tag',
          '#tag' => $this
            ->getSetting('tag'),
          '#attributes' => $attributes
            ->toArray(),
          '#value' => $label,
          '#cache' => $cache,
        ];
      }
    }
    return $elements;
  }
}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. | |
| EntityReferenceFormatterBase:: | protected | function | Returns the referenced entities for display. | 1 | 
| EntityReferenceFormatterBase:: | protected | function | Returns whether the entity referenced by an item needs to be loaded. | 1 | 
| EntityReferenceFormatterBase:: | public | function | Loads the entities referenced in that field across all the entities being
viewed. Overrides FormatterBase:: | |
| EntityReferenceFormatterBase:: | public | function | Overrides FormatterBase:: | |
| EntityReferenceLabelClassFormatter:: | public static | function | Defines the default settings for this plugin. Overrides EntityReferenceLabelFormatter:: | |
| EntityReferenceLabelClassFormatter:: | public | function | Returns a form to configure settings for the formatter. Overrides EntityReferenceLabelFormatter:: | |
| EntityReferenceLabelClassFormatter:: | public | function | Returns a short summary for the current formatter settings. Overrides EntityReferenceLabelFormatter:: | |
| EntityReferenceLabelClassFormatter:: | public | function | Builds a renderable array for a field value. Overrides EntityReferenceLabelFormatter:: | |
| EntityReferenceLabelFormatter:: | protected | function | Checks access to the given entity. Overrides EntityReferenceFormatterBase:: | |
| 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 | 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 | 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. | 
