public function ImageUrlFormatter::viewElements in Drupal 9
Same name and namespace in other branches
- 8 core/modules/image/src/Plugin/Field/FieldFormatter/ImageUrlFormatter.php \Drupal\image\Plugin\Field\FieldFormatter\ImageUrlFormatter::viewElements()
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 ImageFormatter::viewElements
File
- core/
modules/ image/ src/ Plugin/ Field/ FieldFormatter/ ImageUrlFormatter.php, line 53
Class
- ImageUrlFormatter
- Plugin implementation of the 'image_url' formatter.
Namespace
Drupal\image\Plugin\Field\FieldFormatterCode
public function viewElements(FieldItemListInterface $items, $langcode) {
$elements = [];
/** @var \Drupal\Core\Field\EntityReferenceFieldItemListInterface $items */
if (empty($images = $this
->getEntitiesToView($items, $langcode))) {
// Early opt-out if the field is empty.
return $elements;
}
/** @var \Drupal\image\ImageStyleInterface $image_style */
$image_style = $this->imageStyleStorage
->load($this
->getSetting('image_style'));
/** @var \Drupal\Core\File\FileUrlGeneratorInterface $file_url_generator */
$file_url_generator = \Drupal::service('file_url_generator');
/** @var \Drupal\file\FileInterface[] $images */
foreach ($images as $delta => $image) {
$image_uri = $image
->getFileUri();
$url = $image_style ? $file_url_generator
->transformRelative($image_style
->buildUrl($image_uri)) : $file_url_generator
->generateString($image_uri);
// Add cacheability metadata from the image and image style.
$cacheability = CacheableMetadata::createFromObject($image);
if ($image_style) {
$cacheability
->addCacheableDependency(CacheableMetadata::createFromObject($image_style));
}
$elements[$delta] = [
'#markup' => $url,
];
$cacheability
->applyTo($elements[$delta]);
}
return $elements;
}