function FileMediaFormatterBase::getSourceFiles

Same name and namespace in other branches
  1. 9 core/modules/file/src/Plugin/Field/FieldFormatter/FileMediaFormatterBase.php \Drupal\file\Plugin\Field\FieldFormatter\FileMediaFormatterBase::getSourceFiles()
  2. 8.9.x core/modules/file/src/Plugin/Field/FieldFormatter/FileMediaFormatterBase.php \Drupal\file\Plugin\Field\FieldFormatter\FileMediaFormatterBase::getSourceFiles()
  3. 11.x core/modules/file/src/Plugin/Field/FieldFormatter/FileMediaFormatterBase.php \Drupal\file\Plugin\Field\FieldFormatter\FileMediaFormatterBase::getSourceFiles()

Gets source files with attributes.

Parameters

\Drupal\Core\Field\EntityReferenceFieldItemListInterface $items: The item list.

string $langcode: The language code of the referenced entities to display.

Return value

array Numerically indexed array, which again contains an associative array with the following key/values:

1 call to FileMediaFormatterBase::getSourceFiles()
FileMediaFormatterBase::viewElements in core/modules/file/src/Plugin/Field/FieldFormatter/FileMediaFormatterBase.php
Builds a renderable array for a field value.

File

core/modules/file/src/Plugin/Field/FieldFormatter/FileMediaFormatterBase.php, line 189

Class

FileMediaFormatterBase
Base class for media file formatter.

Namespace

Drupal\file\Plugin\Field\FieldFormatter

Code

protected function getSourceFiles(EntityReferenceFieldItemListInterface $items, $langcode) {
  $source_files = [];
  // Because we can have the files grouped in a single media tag, we do a
  // grouping in case the multiple file behavior is not 'tags'.
  /** @var \Drupal\file\Entity\File $file */
  foreach ($this->getEntitiesToView($items, $langcode) as $file) {
    if (static::mimeTypeApplies($file->getMimeType())) {
      $source_attributes = new Attribute();
      $source_attributes->setAttribute('src', $file->createFileUrl())
        ->setAttribute('type', $file->getMimeType());
      if ($this->getSetting('multiple_file_display_type') === 'tags') {
        $source_files[] = [
          [
            'file' => $file,
            'source_attributes' => $source_attributes,
          ],
        ];
      }
      else {
        $source_files[0][] = [
          'file' => $file,
          'source_attributes' => $source_attributes,
        ];
      }
    }
  }
  return $source_files;
}

Buggy or inaccurate documentation? Please file an issue. Need support? Need help programming? Connect with the Drupal community.