Images not generated when used in CSS

Created on 23 October 2020, about 4 years ago
Updated 1 August 2024, 5 months ago

Problem/Motivation

After installing Focal Points and updating image styles to use it, images that are used in CSS background-image: url(path); no longer get generated. Images referenced in img tags render. And if I pass the image path first through file_exists() in PHP, that seems to be enough to trigger the generation. But something about CSS doesn't do this.

Steps to reproduce

  /**
   * Code to get file path.
   */
  protected function getFilePath(MediaInterface $entity, string $image_style) {
    $fid = $entity->getSource()->getSourceFieldValue($entity);
    /** @var \Drupal\file\FileInterface $file */
    $file = $this->entityTypeManager->getStorage('file')->load($fid);
    /** @var \Drupal\image\ImageStyleInterface $style */
    $style = $this->entityTypeManager->getStorage('image_style')->load($image_style);
    $file_path = $style->buildUrl($file->getFileUri());

    return $file_path;
  }

  /**
   * Code to create CSS.
   */
  protected function generateStyles(string $selector, string $file_path) {
    // @todo It's possible to pass this off to Twig which would make writing
    // the CSS easier.
    $css = sprintf('%s {', $selector);
    $css .= sprintf('background-image: url(\'%s\');', file_url_transform_relative($file_path));
    $css .= '}';

    return $css;
  }

I'm not sure yet why CSS doesn't trigger the image derivatives.

🐛 Bug report
Status

Active

Version

1.0

Component

Miscellaneous

Created by

🇺🇸United States jnettik Denver, CO

Live updates comments and jobs are added and updated live.
Sign in to follow issues

Comments & Activities

Not all content is available!

It's likely this issue predates Contrib.social: some issue and comment data are missing.

  • 🇺🇸United States DamienMcKenna NH, USA

    Is the problem happening because the image URL is missing the "itok" security token, thus the system blocks generation of the new image variation? This seems more like a core issue than something specific to Focal Point.

  • 🇮🇳India dev2.addweb

    Hi, I have generated image style with focal point programatically by passing static x and y coordinate.
    Please use file_url_generator service instead of file_url_transform_relative(),

    namespace Drupal\custom_image_style\Service;
    
    use Drupal\Core\Entity\EntityTypeManagerInterface;
    use Drupal\media\MediaInterface;
    use Drupal\Core\File\FileUrlGeneratorInterface;
    
    class ImageStyleService {
    
      protected $entityTypeManager;
      protected $fileUrlGenerator;
    
      public function __construct(EntityTypeManagerInterface $entityTypeManager, FileUrlGeneratorInterface $fileUrlGenerator) {
        $this->entityTypeManager = $entityTypeManager;
        $this->fileUrlGenerator = $fileUrlGenerator;
      }
    
      /**
       * Code to get file path.
       */
      public function getFilePath(MediaInterface $entity, string $image_style) {
        $fid = $entity->getSource()->getSourceFieldValue($entity);
        /** @var \Drupal\file\FileInterface $file */
        $file = $this->entityTypeManager->getStorage('file')->load($fid);
    
        //Add crop type and focal point
        $focal_point_manager = \Drupal::service('focal_point.manager');
        $crop = $focal_point_manager->getCropEntity($file, 'focal_point');
    
        $width = 300;
        $height = 200;
        $focal_point = "9,20";
        if ($focal_point && $width && $height) {
            [$x, $y] = explode(',', $focal_point);
            $focal_point_manager->saveCropEntity($x, $y, $width, $height, $crop);
        }
    
        /** @var \Drupal\image\ImageStyleInterface $style */
        $style = $this->entityTypeManager->getStorage('image_style')->load($image_style);
        $file_path = $style->buildUrl($file->getFileUri());
    
        return $file_path;
      }
    
      /**
       * Code to create CSS.
       */
      public function generateStyles(string $selector, string $file_path) {
        // Use file_url_generator to transform the file URL to relative.
        $relative_url = $this->fileUrlGenerator->transformRelative($file_path);
    
        $css = sprintf('%s {', $selector);
        $css .= sprintf('background-image: url(\'%s\');', $relative_url);
        $css .= '}';
    
        return $css;
      }
    
    }
Production build 0.71.5 2024