123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239 |
- <?php
- /* For licensing terms, see /license.txt */
- /**
- * Form element to select a date.
- *
- * Class DatePicker
- */
- class DateTimeRangePicker extends DateRangePicker
- {
- /**
- * HTML code to display this datepicker.
- *
- * @return string
- */
- public function toHtml()
- {
- if ($this->_flagFrozen) {
- return $this->getFrozenHtml();
- }
- $id = $this->getAttribute('id');
- $dateRange = $this->getValue();
- $value = '';
- if (!empty($dateRange)) {
- $dates = $this->parseDateRange($dateRange);
- $value = api_format_date($dates['date'], DATE_FORMAT_LONG_NO_DAY);
- }
- return '
- <div class="input-group">
- <span class="input-group-addon cursor-pointer">
- <input '.$this->_getAttrString($this->_attributes).'>
- </span>
- <p class="form-control disabled" id="'.$id.'_alt_text">'.$value.'</p>
- <input class="form-control" type="hidden" id="'.$id.'_alt" value="'.$value.'">
- <span class="input-group-btn">
- <button class="btn btn-default" type="button"
- title="'.sprintf(get_lang('ResetFieldX'), $this->_label).'">
- <span class="fa fa-trash text-danger" aria-hidden="true"></span>
- <span class="sr-only">'.sprintf(get_lang('ResetFieldX'), $this->_label).'</span>
- </button>
- </span>
- </div>
- '.$this->getElementJS();
- }
- /**
- * @param string $layout
- *
- * @return string
- */
- public function getTemplate($layout)
- {
- $size = $this->calculateSize();
- $id = $this->getAttribute('id');
- switch ($layout) {
- case FormValidator::LAYOUT_INLINE:
- return '
- <div class="form-group {error_class}">
- <label {label-for} >
- <!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
- {label}
- </label>
- {element}
- </div>';
- break;
- case FormValidator::LAYOUT_HORIZONTAL:
- return '
- <span id="'.$id.'_date_time_wrapper">
- <div class="form-group {error_class}">
- <label {label-for} class="col-sm-'.$size[0].' control-label" >
- <!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
- {label}
- </label>
- <div class="col-sm-'.$size[1].'">
- {icon}
- {element}
- <!-- BEGIN label_2 -->
- <p class="help-block">{label_2}</p>
- <!-- END label_2 -->
- <!-- BEGIN error -->
- <span class="help-inline help-block">{error}</span>
- <!-- END error -->
- </div>
- <div class="col-sm-'.$size[2].'">
- <!-- BEGIN label_3 -->
- {label_3}
- <!-- END label_3 -->
- </div>
- </div>
- <div class="form-group {error_class}">
- <label class="col-sm-'.$size[0].' control-label" >
- <!-- BEGIN required --><span class="form_required">*</span><!-- END required -->
- '.get_lang('Hour').'
- </label>
- <div class="col-sm-'.$size[1].'">
- <div class="input-group">
- <p id="'.$id.'_time_range">
- <input type="text" id="'.$id.'_time_range_start" name="'.$id.'_time_range_start" class="time start" autocomplete="off">
- '.get_lang('To').'
- <input type="text" id="'.$id.'_time_range_end" name="'.$id.'_time_range_end" class="time end " autocomplete="off">
- </p>
- </div>
- </div>
- </div>
- </span>
- ';
- break;
- case FormValidator::LAYOUT_BOX_NO_LABEL:
- return '
- <label {label-for}>{label}</label>
- <div class="input-group">
-
- {icon}
- {element}
- </div>';
- break;
- }
- }
- /**
- * @param array $dateRange
- *
- * @return array
- */
- public function parseDateRange($dateRange)
- {
- $dateRange = Security::remove_XSS($dateRange);
- $dates = explode('@@', $dateRange);
- $dates = array_map('trim', $dates);
- $start = isset($dates[0]) ? $dates[0] : '';
- $end = isset($dates[1]) ? $dates[1] : '';
- $date = substr($start, 0, 10);
- $start = isset($dates[0]) ? $dates[0] : '';
- //$start = substr($start, 11, strlen($start));
- //$end = substr($end, 11, strlen($end));
- return [
- 'date' => $date,
- 'start_time' => $start,
- 'end_time' => $end,
- ];
- }
- /**
- * @param string $value
- */
- public function setValue($value)
- {
- $this->updateAttributes(
- [
- 'value' => $value,
- ]
- );
- }
- /**
- * Get the necessary javascript for this datepicker.
- *
- * @return string
- */
- private function getElementJS()
- {
- $js = null;
- $id = $this->getAttribute('id');
- $dateRange = $this->getValue();
- $defaultDate = '';
- $startTime = '';
- $endTime = '';
- if (!empty($dateRange)) {
- $dates = $this->parseDateRange($dateRange);
- $defaultDate = $dates['date'];
- $startTime = $dates['start_time'];
- $endTime = $dates['end_time'];
- }
- $js .= "<script>
- $(function() {
- var txtDate = $('#$id'),
- inputGroup = txtDate.parents('.input-group'),
- txtDateAlt = $('#{$id}_alt'),
- txtDateAltText = $('#{$id}_alt_text');
-
- txtDate
- .hide()
- .datepicker({
- defaultDate: '".$defaultDate."',
- dateFormat: 'yy-mm-dd',
- altField: '#{$id}_alt',
- altFormat: \"".get_lang('DateFormatLongNoDayJS')."\",
- showOn: 'both',
- buttonImage: '".Display::return_icon('attendance.png', null, [], ICON_SIZE_TINY, true, true)."',
- buttonImageOnly: true,
- buttonText: '".get_lang('SelectDate')."',
- changeMonth: true,
- changeYear: true,
- yearRange: 'c-60y:c+5y'
- })
- .on('change', function (e) {
- txtDateAltText.text(txtDateAlt.val());
- });
-
- txtDateAltText.on('click', function () {
- txtDate.datepicker('show');
- });
-
- inputGroup
- .find('button')
- .on('click', function (e) {
- e.preventDefault();
- $('#$id, #{$id}_alt').val('');
- $('#{$id}_alt_text').html('');
- });
-
- $('#".$id."_time_range .time').timepicker({
- 'showDuration': true,
- 'timeFormat': 'H:i:s',
- 'scrollDefault': 'now',
- });
-
- $('#".$id."_time_range_start').timepicker('setTime', new Date('".$startTime."'));
- $('#".$id."_time_range_end').timepicker('setTime', new Date('".$endTime."'));
-
- var timeOnlyExampleEl = document.getElementById('".$id."_time_range');
- var timeOnlyDatepair = new Datepair(timeOnlyExampleEl);
- });
- </script>";
- return $js;
- }
- }
|