| Code Coverage | ||||||||||
| Classes and Traits | Functions and Methods | Lines | ||||||||
| Total |  | 0.00% | 0 / 1 |  | 0.00% | 0 / 5 | CRAP |  | 0.00% | 0 / 63 | 
| DateTimeDefaultFormatter |  | 0.00% | 0 / 1 |  | 0.00% | 0 / 5 | 132 |  | 0.00% | 0 / 63 | 
| defaultSettings |  | 0.00% | 0 / 1 | 2 |  | 0.00% | 0 / 4 | |||
| viewElements |  | 0.00% | 0 / 1 | 30 |  | 0.00% | 0 / 33 | |||
| formatDate |  | 0.00% | 0 / 1 | 6 |  | 0.00% | 0 / 4 | |||
| settingsForm |  | 0.00% | 0 / 1 | 6 |  | 0.00% | 0 / 17 | |||
| settingsSummary |  | 0.00% | 0 / 1 | 2 |  | 0.00% | 0 / 5 | |||
| <?php | |
| /** | |
| * @file | |
| * Contains \Drupal\datetime\Plugin\Field\FieldFormatter\DateTimeDefaultFormatter. | |
| */ | |
| namespace Drupal\datetime\Plugin\Field\FieldFormatter; | |
| use Drupal\Core\Datetime\DrupalDateTime; | |
| use Drupal\Core\Field\FieldItemListInterface; | |
| use Drupal\Core\Form\FormStateInterface; | |
| /** | |
| * Plugin implementation of the 'Default' formatter for 'datetime' fields. | |
| * | |
| * @FieldFormatter( | |
| * id = "datetime_default", | |
| * label = @Translation("Default"), | |
| * field_types = { | |
| * "datetime" | |
| * } | |
| * ) | |
| */ | |
| class DateTimeDefaultFormatter extends DateTimeFormatterBase { | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public static function defaultSettings() { | |
| return array( | |
| 'format_type' => 'medium', | |
| ) + parent::defaultSettings(); | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function viewElements(FieldItemListInterface $items, $langcode) { | |
| $elements = array(); | |
| foreach ($items as $delta => $item) { | |
| $output = ''; | |
| $iso_date = ''; | |
| if ($item->date) { | |
| /** @var \Drupal\Core\Datetime\DrupalDateTime $date */ | |
| $date = $item->date; | |
| // Create the ISO date in Universal Time. | |
| $iso_date = $date->format("Y-m-d\TH:i:s") . 'Z'; | |
| if ($this->getFieldSetting('datetime_type') == 'date') { | |
| // A date without time will pick up the current time, use the default. | |
| datetime_date_default_time($date); | |
| } | |
| $this->setTimeZone($date); | |
| $output = $this->formatDate($date); | |
| } | |
| // Display the date using theme datetime. | |
| $elements[$delta] = array( | |
| '#cache' => [ | |
| 'contexts' => [ | |
| 'timezone', | |
| ], | |
| ], | |
| '#theme' => 'time', | |
| '#text' => $output, | |
| '#html' => FALSE, | |
| '#attributes' => array( | |
| 'datetime' => $iso_date, | |
| ), | |
| ); | |
| if (!empty($item->_attributes)) { | |
| $elements[$delta]['#attributes'] += $item->_attributes; | |
| // Unset field item attributes since they have been included in the | |
| // formatter output and should not be rendered in the field template. | |
| unset($item->_attributes); | |
| } | |
| } | |
| return $elements; | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| protected function formatDate($date) { | |
| $format_type = $this->getSetting('format_type'); | |
| $timezone = $this->getSetting('timezone_override'); | |
| return $this->dateFormatter->format($date->getTimestamp(), $format_type, '', $timezone != '' ? $timezone : NULL); | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function settingsForm(array $form, FormStateInterface $form_state) { | |
| $form = parent::settingsForm($form, $form_state); | |
| $time = new DrupalDateTime(); | |
| $format_types = $this->dateFormatStorage->loadMultiple(); | |
| $options = []; | |
| foreach ($format_types as $type => $type_info) { | |
| $format = $this->dateFormatter->format($time->format('U'), $type); | |
| $options[$type] = $type_info->label() . ' (' . $format . ')'; | |
| } | |
| $form['format_type'] = array( | |
| '#type' => 'select', | |
| '#title' => t('Date format'), | |
| '#description' => t("Choose a format for displaying the date. Be sure to set a format appropriate for the field, i.e. omitting time for a field that only has a date."), | |
| '#options' => $options, | |
| '#default_value' => $this->getSetting('format_type'), | |
| ); | |
| return $form; | |
| } | |
| /** | |
| * {@inheritdoc} | |
| */ | |
| public function settingsSummary() { | |
| $summary = parent::settingsSummary(); | |
| $date = new DrupalDateTime(); | |
| $summary[] = t('Format: @display', array('@display' => $this->formatDate($date, $this->getFormatSettings()))); | |
| return $summary; | |
| } | |
| } |