You are here

public function AmpTextTrimmedFormatter::viewElements in Accelerated Mobile Pages (AMP) 8

Same name and namespace in other branches
  1. 8.3 src/Plugin/Field/FieldFormatter/AmpTextTrimmedFormatter.php \Drupal\amp\Plugin\Field\FieldFormatter\AmpTextTrimmedFormatter::viewElements()
  2. 8.2 src/Plugin/Field/FieldFormatter/AmpTextTrimmedFormatter.php \Drupal\amp\Plugin\Field\FieldFormatter\AmpTextTrimmedFormatter::viewElements()

Exactly like TextTrimmedFormatter except '#type' => 'processed_text' was changed to: '#type' => 'amp_processed_text'

and 'text_summary_or_trimmed' was changed to 'amp_text_summary_or_trimmed'

Overrides TextTrimmedFormatter::viewElements

File

src/Plugin/Field/FieldFormatter/AmpTextTrimmedFormatter.php, line 40
Contains Drupal\amp\Plugin\Field\FieldFormatter\AmpTextTrimmedFormatter

Class

AmpTextTrimmedFormatter
Plugin implementation of the 'amp_text_trimmed' formatter.

Namespace

Drupal\amp\Plugin\Field\FieldFormatter

Code

public function viewElements(FieldItemListInterface $items, $langcode) {
  $elements = array();
  $render_as_summary = function (&$element) {

    // Make sure any default #pre_render callbacks are set on the element,
    // because text_pre_render_summary() must run last.
    $element += \Drupal::service('element_info')
      ->getInfo($element['#type']);

    // Add the #pre_render callback that renders the text into a summary.
    $element['#pre_render'][] = [
      TextTrimmedFormatter::class,
      'preRenderSummary',
    ];

    // Pass on the trim length to the #pre_render callback via a property.
    $element['#text_summary_trim_length'] = $this
      ->getSetting('trim_length');
  };

  // The ProcessedText element already handles cache context & tag bubbling.
  // @see \Drupal\filter\Element\ProcessedText::preRenderText()
  foreach ($items as $delta => $item) {
    $elements[$delta] = array(
      '#type' => 'amp_processed_text',
      '#text' => NULL,
      '#format' => $item->format,
      '#langcode' => $item
        ->getLangcode(),
    );
    if ($this
      ->getPluginId() == 'amp_text_summary_or_trimmed' && !empty($item->summary)) {
      $elements[$delta]['#text'] = $item->summary;
    }
    else {
      $elements[$delta]['#text'] = $item->value;
      $render_as_summary($elements[$delta]);
    }
  }
  return $elements;
}