TimestampDatetimeWidget.php in Publication Date 8.2
File
src/Plugin/Field/FieldWidget/TimestampDatetimeWidget.php
View source
<?php
namespace Drupal\publication_date\Plugin\Field\FieldWidget;
use Drupal\Core\Datetime\DrupalDateTime;
use Drupal\Core\Datetime\Element\Datetime;
use Drupal\Core\Datetime\Entity\DateFormat;
use Drupal\Core\Field\FieldItemListInterface;
use Drupal\Core\Field\WidgetBase;
use Drupal\Core\Form\FormStateInterface;
class TimestampDatetimeWidget extends WidgetBase {
public function formElement(FieldItemListInterface $items, $delta, array $element, array &$form, FormStateInterface $form_state) {
$date_format = DateFormat::load('html_date')
->getPattern();
$time_format = DateFormat::load('html_time')
->getPattern();
if (isset($items[$delta]->value) && $items[$delta]->value != PUBLICATION_DATE_DEFAULT) {
$default_value = DrupalDateTime::createFromTimestamp($items[$delta]->value);
}
else {
$default_value = '';
}
$element['value'] = $element + array(
'#type' => 'datetime',
'#default_value' => $default_value,
'#date_year_range' => '1902:2037',
);
$element['value']['#description'] = $this
->t('Format: %format. Leave blank to use the time of form submission.', array(
'%format' => Datetime::formatExample($date_format . ' ' . $time_format),
));
return $element;
}
public function massageFormValues(array $values, array $form, FormStateInterface $form_state) {
foreach ($values as &$item) {
$date = NULL;
if (isset($item['value']) && $item['value'] instanceof DrupalDateTime) {
$date = $item['value'];
}
elseif (isset($item['value']['object']) && $item['value']['object'] instanceof DrupalDateTime) {
$date = $item['value']['object'];
}
if ($date) {
$item['value'] = $date
->getTimestamp();
}
}
return $values;
}
}