‪TYPO3CMS  ‪main
DatePickerViewHelper.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 
31 
40 {
44  protected ‪$tagName = 'input';
45 
47 
49  {
50  $this->propertyMapper = ‪$propertyMapper;
51  }
52 
56  public function ‪initializeArguments(): void
57  {
58  parent::initializeArguments();
59  $this->registerTagAttribute('size', 'int', 'The size of the input field');
60  $this->registerTagAttribute('placeholder', 'string', 'Specifies a short hint that describes the expected value of an input element');
61  $this->registerArgument('errorClass', 'string', 'CSS class to set if there are errors for this ViewHelper', false, 'f3-form-error');
62  $this->registerArgument('initialDate', 'string', 'Initial date (@see http://www.php.net/manual/en/datetime.formats.php for supported formats)');
63  $this->registerArgument('enableDatePicker', 'bool', 'Enable the Datepicker', false, true);
64  $this->registerArgument('previewMode', 'bool', 'Preview mde flag', true, false);
65  $this->registerArgument('dateFormat', 'string', 'The date format', false, 'Y-m-d');
66  // use the default value if custom templates have not yet adapted this property
67  $this->registerArgument('datePickerInitializationJavaScriptFile', 'string', 'The JavaScript file to initialize the date picker', false, 'EXT:form/Resources/Public/JavaScript/frontend/date-picker.js');
68  $this->registerUniversalTagAttributes();
69  }
70 
74  public function ‪render(): string
75  {
76  $enableDatePicker = $this->arguments['enableDatePicker'];
77  $dateFormat = $this->arguments['dateFormat'];
78  $previewMode = (bool)$this->arguments['previewMode'];
79  $placeholder = $this->arguments['additionalAttributes']['placeholder'] ?? $this->arguments['placeholder'];
80 
81  $name = $this->‪getName();
83 
84  $this->tag->addAttribute('type', 'text');
85  $this->tag->addAttribute('name', $name . '[date]');
86 
87  if ($this->hasArgument('id')) {
88  $id = $this->arguments['id'];
89  } else {
90  $id = 'field' . md5(‪StringUtility::getUniqueId());
91  }
92 
93  if (empty($placeholder)) {
94  $this->tag->addAttribute('placeholder', $dateFormat);
95  }
96 
97  if ($enableDatePicker) {
98  $this->tag->addAttribute('readonly', 'readonly');
99  if (!$previewMode) {
100  $datePickerDateFormat = $this->‪convertDateFormatToDatePickerFormat($dateFormat);
101  $this->tag->addAttribute('data-format', $datePickerDateFormat);
102  $this->tag->addAttribute('data-t3-form-datepicker', '');
103  if (!empty($this->arguments['datePickerInitializationJavaScriptFile'])) {
104  GeneralUtility::makeInstance(AssetCollector::class)
105  ->addJavaScript(
106  't3-form-datepicker',
107  $this->arguments['datePickerInitializationJavaScriptFile'],
108  []
109  );
110  }
111  }
112  }
113  $date = $this->‪getSelectedDate();
114  if ($date !== null) {
115  $this->tag->addAttribute('value', $date->format($dateFormat));
116  }
117 
118  $this->tag->addAttribute('id', $id);
119 
120  $this->‪setErrorClassAttribute();
121  $content = $this->tag->render();
122  $content .= '<input type="hidden" name="' . htmlspecialchars($name) . '[dateFormat]" value="' . htmlspecialchars($dateFormat) . '" />';
123 
124  return $content;
125  }
126 
127  protected function ‪getSelectedDate(): ?\DateTime
128  {
130  $formRuntime = $this->renderingContext
131  ->getViewHelperVariableContainer()
132  ->get(RenderRenderableViewHelper::class, 'formRuntime');
133 
134  $date = $formRuntime[$this->arguments['property']];
135  if ($date instanceof \DateTime) {
136  return $date;
137  }
138  if ($date !== null) {
139  $date = $this->propertyMapper->convert($date, \DateTime::class);
140  if (!$date instanceof \DateTime) {
141  return null;
142  }
143  return $date;
144  }
145  if ($this->hasArgument('initialDate')) {
146  return new \DateTime($this->arguments['initialDate']);
147  }
148 
149  return null;
150  }
151 
152  protected function ‪convertDateFormatToDatePickerFormat(string $dateFormat): string
153  {
154  $replacements = [
155  'd' => 'dd',
156  'D' => 'D',
157  'j' => 'o',
158  'l' => 'DD',
159 
160  'F' => 'MM',
161  'm' => 'mm',
162  'M' => 'M',
163  'n' => 'm',
164 
165  'Y' => 'yy',
166  'y' => 'y',
167  ];
168  return strtr($dateFormat, $replacements);
169  }
170 }
‪TYPO3\CMS\Fluid\ViewHelpers\Form\AbstractFormFieldViewHelper\setErrorClassAttribute
‪setErrorClassAttribute()
Definition: AbstractFormFieldViewHelper.php:331
‪TYPO3\CMS\Core\Page\AssetCollector
Definition: AssetCollector.php:42
‪TYPO3\CMS\Form\ViewHelpers\Form\DatePickerViewHelper\getSelectedDate
‪getSelectedDate()
Definition: DatePickerViewHelper.php:126
‪TYPO3\CMS\Form\ViewHelpers\Form\DatePickerViewHelper\convertDateFormatToDatePickerFormat
‪convertDateFormatToDatePickerFormat(string $dateFormat)
Definition: DatePickerViewHelper.php:151
‪TYPO3\CMS\Form\ViewHelpers\Form\DatePickerViewHelper\initializeArguments
‪initializeArguments()
Definition: DatePickerViewHelper.php:55
‪TYPO3\CMS\Form\ViewHelpers\Form\DatePickerViewHelper\$tagName
‪string $tagName
Definition: DatePickerViewHelper.php:43
‪TYPO3\CMS\Form\ViewHelpers\Form\DatePickerViewHelper\render
‪render()
Definition: DatePickerViewHelper.php:73
‪TYPO3\CMS\Fluid\ViewHelpers\Form\AbstractFormViewHelper\registerFieldNameForFormTokenGeneration
‪registerFieldNameForFormTokenGeneration(string $fieldName)
Definition: AbstractFormViewHelper.php:100
‪TYPO3\CMS\Form\ViewHelpers\Form\DatePickerViewHelper\injectPropertyMapper
‪injectPropertyMapper(PropertyMapper $propertyMapper)
Definition: DatePickerViewHelper.php:47
‪TYPO3\CMS\Form\ViewHelpers\Form\DatePickerViewHelper
Definition: DatePickerViewHelper.php:40
‪TYPO3\CMS\Form\ViewHelpers\Form\DatePickerViewHelper\$propertyMapper
‪PropertyMapper $propertyMapper
Definition: DatePickerViewHelper.php:45
‪TYPO3\CMS\Fluid\ViewHelpers\Form\AbstractFormFieldViewHelper\getName
‪getName()
Definition: AbstractFormFieldViewHelper.php:79
‪TYPO3\CMS\Form\ViewHelpers\RenderRenderableViewHelper
Definition: RenderRenderableViewHelper.php:41
‪TYPO3\CMS\Extbase\Property\PropertyMapper
Definition: PropertyMapper.php:30
‪TYPO3\CMS\Form\ViewHelpers\Form
Definition: DatePickerViewHelper.php:22
‪TYPO3\CMS\Form\Domain\Runtime\FormRuntime
Definition: FormSession.php:18
‪TYPO3\CMS\Fluid\ViewHelpers\Form\AbstractFormFieldViewHelper
Definition: AbstractFormFieldViewHelper.php:37
‪TYPO3\CMS\Core\Utility\GeneralUtility
Definition: GeneralUtility.php:52
‪TYPO3\CMS\Core\Utility\StringUtility
Definition: StringUtility.php:24
‪TYPO3\CMS\Core\Utility\StringUtility\getUniqueId
‪static getUniqueId(string $prefix='')
Definition: StringUtility.php:57