You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
207 lines
6.8 KiB
207 lines
6.8 KiB
<?php
|
|
|
|
/* For licensing terms, see /license.txt */
|
|
|
|
/**
|
|
* Form element to select a date.
|
|
*/
|
|
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 id="'.$id.'" class="flex flex-row mt-1">
|
|
<input '.$this->_getAttrString($this->_attributes).'
|
|
class="form-control" type="text" value="'.$value.'" data-input>
|
|
<div class="ml-1" id="button-addon3">
|
|
<button class="btn btn--secondary-outline" type="button" data-toggle>
|
|
<i class="pi pi-calendar pi-lg"></i>
|
|
</button>
|
|
<button class="btn btn--secondary-outline" type="button" data-clear>
|
|
<i class="pi pi-times pi-lg"></i>
|
|
</button>
|
|
</div>
|
|
</div>
|
|
'.$this->getElementJS();
|
|
}
|
|
|
|
public function getTemplate(string $layout): string
|
|
{
|
|
$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;
|
|
}
|
|
|
|
return '';
|
|
}
|
|
|
|
public function parseDateRange(string $dateRange): array
|
|
{
|
|
$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'];
|
|
}
|
|
|
|
$id = $this->getAttribute('id');
|
|
|
|
$js .= "<script>
|
|
$(function() {
|
|
var config = {
|
|
altInput: true,
|
|
altFormat: '".get_lang('F d, Y')."',
|
|
enableTime: false,
|
|
dateFormat: 'Y-m-d',
|
|
wrap: true,
|
|
locale: {
|
|
firstDayOfWeek: 1
|
|
}
|
|
};
|
|
$('#{$id}').flatpickr(config);
|
|
|
|
|
|
$('#".$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;
|
|
}
|
|
}
|
|
|