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; | |
} | |
} |