public function ParagraphsTrimmedFormatter::viewElements in Paragraphs Trimmed 8
Builds a renderable array for a field value.
Parameters
\Drupal\Core\Field\FieldItemListInterface $items: The field values to be rendered.
string $langcode: The language that should be used to render the field.
Return value
array A renderable array for $items, as an array of child elements keyed by consecutive numeric indexes starting from 0.
Overrides EntityReferenceRevisionsEntityFormatter::viewElements
File
- src/Plugin/ Field/ FieldFormatter/ ParagraphsTrimmedFormatter.php, line 32 
Class
- ParagraphsTrimmedFormatter
- Plugin implementation of the 'paragraphs_trimmed' formatter.
Namespace
Drupal\paragraphs_trimmed\Plugin\Field\FieldFormatterCode
public function viewElements(FieldItemListInterface $items, $langcode) {
  // If we have a summary field, just render it and send it out
  if ($this
    ->getSummaryFieldValue($items)) {
    return $this
      ->getSummaryFieldElement($items);
  }
  // Render the paragraphs output
  $elements = parent::viewElements($items, $langcode);
  $output = \Drupal::service('renderer')
    ->render($elements);
  // Create a basic text field item list
  $definition = \Drupal::typedDataManager()
    ->createListDataDefinition('field_item:text');
  $text_items = \Drupal::typedDataManager()
    ->create($definition, [
    $output,
  ], NULL, $items
    ->getEntity()
    ->getTypedData());
  // Set the text format of our new text field item list item and process
  // using the smart trim formatter viewElements method with our settings.
  $text_items->format = $this
    ->getSetting('format');
  return $this->formatter
    ->setSettings($this
    ->getSettings())
    ->viewElements($text_items, $langcode);
}