You cannot select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
47 lines
1.3 KiB
JavaScript
47 lines
1.3 KiB
JavaScript
define([
|
|
'jquery',
|
|
'/lib/datepicker/flatpickr.js',
|
|
|
|
'css!/lib/datepicker/flatpickr.min.css',
|
|
], function ($, Flatpickr) {
|
|
var createRangePicker = function (cfg) {
|
|
var start = cfg.startpicker;
|
|
var end = cfg.endpicker;
|
|
|
|
var e = $(end.input)[0];
|
|
var endPickr = Flatpickr(e, {
|
|
enableTime: true,
|
|
minDate: start.date
|
|
});
|
|
endPickr.setDate(end.date);
|
|
|
|
var s = $(start.input)[0];
|
|
var startPickr = Flatpickr(s, {
|
|
enableTime: true,
|
|
onChange: function () {
|
|
endPickr.set('minDate', startPickr.parseDate(s.value));
|
|
}
|
|
});
|
|
startPickr.setDate(start.date);
|
|
window.CP_startPickr = startPickr;
|
|
window.CP_endPickr = endPickr;
|
|
|
|
var getStartDate = function () {
|
|
setTimeout(function () { $(startPickr.calendarContainer).remove(); });
|
|
return startPickr.parseDate(s.value);
|
|
};
|
|
var getEndDate = function () {
|
|
setTimeout(function () { $(endPickr.calendarContainer).remove(); });
|
|
return endPickr.parseDate(e.value);
|
|
};
|
|
|
|
return {
|
|
getStartDate: getStartDate,
|
|
getEndDate: getEndDate,
|
|
};
|
|
};
|
|
return {
|
|
createRangePicker: createRangePicker
|
|
};
|
|
});
|