function template_preprocess_file_link in Zircon Profile 8
Same name and namespace in other branches
- 8.0 core/modules/file/file.module \template_preprocess_file_link()
 
Prepares variables for file link templates.
Default template: file-link.html.twig.
Parameters
array $variables: An associative array containing:
- file: A file object to which the link will be created.
 - icon_directory: (optional) A path to a directory of icons to be used for files. Defaults to the value of the "icon.directory" variable.
 - description: A description to be displayed instead of the filename.
 - attributes: An associative array of attributes to be placed in the a tag.
 
File
- core/
modules/ file/ file.module, line 1226  - Defines a "managed_file" Form API field and a "file" field for Field module.
 
Code
function template_preprocess_file_link(&$variables) {
  $file = $variables['file'];
  $options = array();
  $file_entity = $file instanceof File ? $file : File::load($file->fid);
  $url = file_create_url($file_entity
    ->getFileUri());
  $mime_type = $file
    ->getMimeType();
  // Set options as per anchor format described at
  // http://microformats.org/wiki/file-format-examples
  $options['attributes']['type'] = $mime_type . '; length=' . $file
    ->getSize();
  // Use the description as the link text if available.
  if (empty($variables['description'])) {
    $link_text = $file_entity
      ->getFilename();
  }
  else {
    $link_text = $variables['description'];
    $options['attributes']['title'] = $file_entity
      ->getFilename();
  }
  // Classes to add to the file field for icons.
  $classes = array(
    'file',
    // Add a specific class for each and every mime type.
    'file--mime-' . strtr($mime_type, array(
      '/' => '-',
      '.' => '-',
    )),
    // Add a more general class for groups of well known mime types.
    'file--' . file_icon_class($mime_type),
  );
  // Set file classes to the options array.
  $variables['attributes'] = new Attribute($variables['attributes']);
  $variables['attributes']
    ->addClass($classes);
  $variables['link'] = \Drupal::l($link_text, Url::fromUri($url, $options));
}