‪TYPO3CMS  11.5
TimePickerViewHelper.php
Go to the documentation of this file.
1 <?php
2 
3 declare(strict_types=1);
4 
5 /*
6  * This file is part of the TYPO3 CMS project.
7  *
8  * It is free software; you can redistribute it and/or modify it under
9  * the terms of the GNU General Public License, either version 2
10  * of the License, or any later version.
11  *
12  * For the full copyright and license information, please read the
13  * LICENSE.txt file that was distributed with this source code.
14  *
15  * The TYPO3 project - inspiring people to share!
16  */
17 
18 /*
19  * Inspired by and partially taken from the Neos.Form package (www.neos.io)
20  */
21 
23 
28 
35 {
39  protected ‪$tagName = 'select';
40 
44  protected ‪$propertyMapper;
45 
51  {
52  $this->propertyMapper = ‪$propertyMapper;
53  }
54 
60  public function ‪initializeArguments()
61  {
62  parent::initializeArguments();
63  $this->registerTagAttribute('size', 'int', 'The size of the select field');
64  $this->registerTagAttribute('placeholder', 'string', 'Specifies a short hint that describes the expected value of an input element');
65  $this->registerTagAttribute('disabled', 'string', 'Specifies that the select element should be disabled when the page loads');
66  $this->registerArgument('errorClass', 'string', 'CSS class to set if there are errors for this ViewHelper', false, 'f3-form-error');
67  $this->registerArgument('initialDate', 'string', 'Initial time (@see http://www.php.net/manual/en/datetime.formats.php for supported formats)');
68  $this->registerArgument('timeType', 'string', '"hour" or "minute"');
69  $this->registerUniversalTagAttributes();
70  }
71 
77  public function ‪render()
78  {
79  $name = $this->‪getName();
81  $this->tag->addAttribute('name', $name . '[hour]');
82 
83  $date = $this->‪getSelectedDate();
85 
86  $content = '';
87 
88  if ($this->arguments['timeType'] === 'hour') {
89  $content .= $this->‪buildHourSelector($date);
90  } else {
91  $content .= $this->‪buildMinuteSelector($date);
92  }
93 
94  return $content;
95  }
96 
100  protected function ‪getSelectedDate()
101  {
103  $formRuntime = $this->renderingContext
104  ->getViewHelperVariableContainer()
105  ->get(RenderRenderableViewHelper::class, 'formRuntime');
106 
107  $date = $formRuntime[$this->arguments['property']];
108  if ($date instanceof \DateTime) {
109  return $date;
110  }
111  if ($date !== null) {
112  $date = $this->propertyMapper->convert($date, \DateTime::class);
113  if (!$date instanceof \DateTime) {
114  return null;
115  }
116  return $date;
117  }
118  if ($this->hasArgument('initialDate')) {
119  return new \DateTime($this->arguments['initialDate']);
120  }
121 
122  return null;
123  }
124 
129  protected function ‪buildHourSelector(\DateTime $date = null): string
130  {
131  $value = $date !== null ? $date->format('H') : null;
132  $hourSelector = clone $this->tag;
133  $hourSelector->addAttribute('name', sprintf('%s[hour]', $this->‪getName()));
134  $options = '';
135  foreach (range(0, 23) as $hour) {
136  $hour = str_pad((string)$hour, 2, '0', STR_PAD_LEFT);
137  $selected = $hour === $value ? ' selected="selected"' : '';
138  $options .= '<option value="' . htmlspecialchars($hour) . '" ' . $selected . '>' . htmlspecialchars($hour) . '</option>';
139  }
140  $hourSelector->setContent($options);
141  return $hourSelector->render();
142  }
143 
148  protected function ‪buildMinuteSelector(\DateTime $date = null): string
149  {
150  $value = $date !== null ? $date->format('i') : null;
151  $minuteSelector = clone $this->tag;
152  if ($this->hasArgument('id')) {
153  $minuteSelector->addAttribute('id', $this->arguments['id'] . '-minute');
154  }
155  $minuteSelector->addAttribute('name', sprintf('%s[minute]', $this->‪getName()));
156  $options = '';
157  foreach (range(0, 59) as $minute) {
158  $minute = str_pad((string)$minute, 2, '0', STR_PAD_LEFT);
159  $selected = $minute === $value ? ' selected="selected"' : '';
160  $options .= '<option value="' . htmlspecialchars($minute) . '"' . $selected . '>' . htmlspecialchars($minute) . '</option>';
161  }
162  $minuteSelector->setContent($options);
163  return $minuteSelector->render();
164  }
165 }
‪TYPO3\CMS\Fluid\ViewHelpers\Form\AbstractFormFieldViewHelper\setErrorClassAttribute
‪setErrorClassAttribute()
Definition: AbstractFormFieldViewHelper.php:331
‪TYPO3\CMS\Form\ViewHelpers\Form\TimePickerViewHelper\injectPropertyMapper
‪injectPropertyMapper(PropertyMapper $propertyMapper)
Definition: TimePickerViewHelper.php:48
‪TYPO3\CMS\Form\ViewHelpers\Form\TimePickerViewHelper
Definition: TimePickerViewHelper.php:35
‪TYPO3\CMS\Form\ViewHelpers\Form\TimePickerViewHelper\getSelectedDate
‪DateTime null getSelectedDate()
Definition: TimePickerViewHelper.php:98
‪TYPO3\CMS\Form\ViewHelpers\Form\TimePickerViewHelper\$tagName
‪string $tagName
Definition: TimePickerViewHelper.php:38
‪TYPO3\CMS\Fluid\ViewHelpers\Form\AbstractFormViewHelper\registerFieldNameForFormTokenGeneration
‪registerFieldNameForFormTokenGeneration($fieldName)
Definition: AbstractFormViewHelper.php:106
‪TYPO3\CMS\Form\ViewHelpers\Form\TimePickerViewHelper\$propertyMapper
‪TYPO3 CMS Extbase Property PropertyMapper $propertyMapper
Definition: TimePickerViewHelper.php:42
‪TYPO3\CMS\Form\ViewHelpers\Form\TimePickerViewHelper\initializeArguments
‪initializeArguments()
Definition: TimePickerViewHelper.php:58
‪TYPO3\CMS\Form\ViewHelpers\RenderRenderableViewHelper
Definition: RenderRenderableViewHelper.php:41
‪TYPO3\CMS\Extbase\Property\PropertyMapper
Definition: PropertyMapper.php:39
‪TYPO3\CMS\Form\ViewHelpers\Form
Definition: DatePickerViewHelper.php:22
‪TYPO3\CMS\Form\Domain\Runtime\FormRuntime
Definition: FormSession.php:18
‪TYPO3\CMS\Form\ViewHelpers\Form\TimePickerViewHelper\buildMinuteSelector
‪string buildMinuteSelector(\DateTime $date=null)
Definition: TimePickerViewHelper.php:146
‪TYPO3\CMS\Fluid\ViewHelpers\Form\AbstractFormFieldViewHelper
Definition: AbstractFormFieldViewHelper.php:30
‪TYPO3\CMS\Fluid\ViewHelpers\Form\AbstractFormFieldViewHelper\getName
‪string getName()
Definition: AbstractFormFieldViewHelper.php:90
‪TYPO3\CMS\Form\ViewHelpers\Form\TimePickerViewHelper\render
‪string render()
Definition: TimePickerViewHelper.php:75
‪TYPO3\CMS\Form\ViewHelpers\Form\TimePickerViewHelper\buildHourSelector
‪string buildHourSelector(\DateTime $date=null)
Definition: TimePickerViewHelper.php:127