f965e218489ac766e24e62e7ff04f038d4fdb7ff
[yaffs-website] / web / core / modules / datetime / src / Plugin / Field / FieldWidget / DateTimeWidgetBase.php
1 <?php
2
3 namespace Drupal\datetime\Plugin\Field\FieldWidget;
4
5 use Drupal\Core\Datetime\DrupalDateTime;
6 use Drupal\Core\Field\FieldItemListInterface;
7 use Drupal\Core\Field\WidgetBase;
8 use Drupal\Core\Form\FormStateInterface;
9 use Drupal\datetime\Plugin\Field\FieldType\DateTimeItem;
10
11 /**
12  * Base class for the 'datetime_*' widgets.
13  */
14 class DateTimeWidgetBase extends WidgetBase {
15
16   /**
17    * {@inheritdoc}
18    */
19   public function formElement(FieldItemListInterface $items, $delta, array $element, array &$form, FormStateInterface $form_state) {
20     $element['value'] = [
21       '#type' => 'datetime',
22       '#default_value' => NULL,
23       '#date_increment' => 1,
24       '#date_timezone' => drupal_get_user_timezone(),
25       '#required' => $element['#required'],
26     ];
27
28     if ($this->getFieldSetting('datetime_type') == DateTimeItem::DATETIME_TYPE_DATE) {
29       // A date-only field should have no timezone conversion performed, so
30       // use the same timezone as for storage.
31       $element['value']['#date_timezone'] = DATETIME_STORAGE_TIMEZONE;
32     }
33
34     if ($items[$delta]->date) {
35       $date = $items[$delta]->date;
36       // The date was created and verified during field_load(), so it is safe to
37       // use without further inspection.
38       if ($this->getFieldSetting('datetime_type') == DateTimeItem::DATETIME_TYPE_DATE) {
39         // A date without time will pick up the current time, use the default
40         // time.
41         datetime_date_default_time($date);
42       }
43       $date->setTimezone(new \DateTimeZone($element['value']['#date_timezone']));
44       $element['value']['#default_value'] = $date;
45     }
46
47     return $element;
48   }
49
50   /**
51    * {@inheritdoc}
52    */
53   public function massageFormValues(array $values, array $form, FormStateInterface $form_state) {
54     // The widget form element type has transformed the value to a
55     // DrupalDateTime object at this point. We need to convert it back to the
56     // storage timezone and format.
57     foreach ($values as &$item) {
58       if (!empty($item['value']) && $item['value'] instanceof DrupalDateTime) {
59         $date = $item['value'];
60         switch ($this->getFieldSetting('datetime_type')) {
61           case DateTimeItem::DATETIME_TYPE_DATE:
62             // If this is a date-only field, set it to the default time so the
63             // timezone conversion can be reversed.
64             datetime_date_default_time($date);
65             $format = DATETIME_DATE_STORAGE_FORMAT;
66             break;
67
68           default:
69             $format = DATETIME_DATETIME_STORAGE_FORMAT;
70             break;
71         }
72         // Adjust the date for storage.
73         $date->setTimezone(new \DateTimezone(DATETIME_STORAGE_TIMEZONE));
74         $item['value'] = $date->format($format);
75       }
76     }
77     return $values;
78   }
79
80 }