5 var flatpickr_weekdays = {
6 shorthand: [ "Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
7 longhand: [ "Sunday", "Monday", "Tuesday", "Wednesday", "Thursday", "Friday", "Saturday" ]
10 var flatpickr_months = {
11 shorthand: [ "Jan", "Feb", "Mar", "Apr", "May", "Jun", "Jul", "Aug", "Sep", "Oct", "Nov", "Dec"],
12 longhand: [ "January", "February", "March", "April", "May", "June", "July", "August", "September", "October", "November", "December"]
14 var debug = "[% debug | html %]";
15 var dateformat_pref = "[% Koha.Preference('dateformat') | html %]";
17 if (debug > 1) {alert("dateformat: " + dateformat_pref + "\ndebug is on (level " + debug + ")");}
18 var calendarFirstDayOfWeek = '[% Koha.Preference('CalendarFirstDayOfWeek') | html %]';
19 var flatpickr_timeformat_string = [% IF Koha.Preference('TimeFormat') == '12hr' %]"G:i K"[% ELSE %]"H:i"[% END %];
20 var flatpickr_timeformat = [% IF Koha.Preference('TimeFormat') == '12hr' %]false[% ELSE %]true[% END %];
21 var flatpickr_dateformat_string = "";
22 switch ( dateformat_pref ){
24 flatpickr_dateformat_string = "m/d/Y";
27 flatpickr_dateformat_string = "d/m/Y";
30 flatpickr_dateformat_string = "d.m.Y";
33 flatpickr_dateformat_string = "Y-m-d";
36 function get_dateformat_str(dateformat) {
38 if (dateformat == 'us') {
39 dateformat_str = 'mm/dd/yyyy';
40 } else if (dateformat == 'metric') {
41 dateformat_str = 'dd/mm/yyyy';
42 } else if (dateformat == 'iso') {
43 dateformat_str = 'yyyy-mm-dd';
44 } else if (dateformat == 'dmydot') {
45 dateformat_str = 'dd.mm.yyyy';
47 return dateformat_str;
50 [% Asset.js("lib/flatpickr/flatpickr.min.js") | $raw %]
52 flatpickr.l10ns.default.weekdays = flatpickr_weekdays;
53 flatpickr.l10ns.default.months = flatpickr_months;
54 flatpickr.setDefaults({
58 altFormat: flatpickr_dateformat_string,
59 altInputClass: 'flatpickr-input',
60 nextArrow: '<i class="fa fa-fw fa-arrow-right" aria-hidden="true"></i>',
61 prevArrow: '<i class="fa fa-fw fa-arrow-left" aria-hidden="true"></i>',
62 time_24hr: flatpickr_timeformat,
64 "firstDayOfWeek": calendarFirstDayOfWeek
66 onReady: function( selectedDates, dateStr, instance ){
67 /* When flatpickr instance is created, automatically append a "clear date" link */
68 if( $(instance.input).hasClass("futuredate") ){
69 instance.set("minDate", new Date().fp_incr(1));
71 if( $(instance.input).hasClass("pastdate") ){
72 instance.set("maxDate", new Date().fp_incr(-1));
74 $(instance.input).find('~input.flatpickr:first')
75 /* Add a wrapper element so that we can prevent the clear button from wrapping */
76 .wrap("<span class='flatpickr_wrapper'></span>")
79 .addClass("clear_date")
80 .on("click", function(e){
84 .addClass("fa fa-fw fa-times")
85 .attr("aria-hidden", true)
86 .attr("aria-label", _("Clear date") )
87 ).keydown(function(e) {
88 var key = (event.keyCode ? event.keyCode : event.which);
90 instance.set('allowInput',false);
94 onClose: function( selectedDates, dateText, instance) {
95 validate_date( dateText, instance );
96 var thisInput = instance.input;
97 if ( thisInput.hasAttribute('data-start_for') ) {
98 var endPicker = document.querySelector("#"+thisInput.dataset.start_for)._flatpickr;
99 endPicker.set('minDate', selectedDates[0]);
104 var MSG_PLEASE_ENTER_A_VALID_DATE = ( _("Please enter a valid date (should match %s).") );
106 function is_valid_date(date) {
107 // An empty string is considered as a valid date for convenient reasons.
108 if (date === '') return 1;
109 var dateformat = flatpickr_dateformat_string;
110 switch ( dateformat_pref ){
112 flatpickr_dateformat_string = "m/d/Y";
115 flatpickr_dateformat_string = "d/m/Y";
118 flatpickr_dateformat_string = "d.m.Y";
121 flatpickr_dateformat_string = "Y-m-d";
124 flatpickr.parseDate(date, dateformat);
131 function validate_date(dateText, inst) {
132 if (!is_valid_date(dateText)) {
133 var dateformat_str = get_dateformat_str( dateformat_pref );
134 alert(MSG_PLEASE_ENTER_A_VALID_DATE.format(dateformat_str));
139 $(document).ready(function(){
140 $(".flatpickr").each(function(){
142 let refresh_max_date = 0;
143 let disable_buttons = [];
145 if( $(this).data("flatpickr-futureinclusive") === true
146 || $(this).data("flatpickr-futuredate") === true ) {
147 let original_date = $(this).val();
148 if ( original_date ) {
149 original_date = Date_from_syspref( original_date ).getTime();
150 let tomorrow = new Date().fp_incr(1).getTime();
152 options['enable'] = [function(date){
153 date = date.getTime();
154 if ( date == original_date ) return true;
155 if ( date >= tomorrow) return true;
159 if( $(this).data("flatpickr-futureinclusive") === true ) {
160 options['minDate'] = new Date().setHours(00, 00, 00, 00);
162 options['minDate'] = new Date().fp_incr(1);
166 disable_buttons.push(0); /* Yesterday */
168 if ( $(this).data("flatpickr-futuredate") === true ) {
169 disable_buttons.push(1); /* Today */
172 if( $(this).data("flatpickr-pastinclusive") === true ) {
173 options['maxDate'] = new Date(); /* Not today or hh:mm will be 00:00 */
174 refresh_max_date = 1;
175 disable_buttons.push(2); /* Tomorrow */
177 if( $(this).data("flatpickr-pastdate") === true ) {
178 options['maxDate'] = new Date().fp_incr(-1).setHours(23, 59, 00, 00);
179 disable_buttons.push(1); /* Today */
180 disable_buttons.push(2); /* Tomorrow */
182 if ( $(this).data('flatpickr-enable-time') === true ) {
183 options['enableTime'] = true;
184 options['dateFormat'] = flatpickr_dateformat_string + " " + flatpickr_timeformat_string;
187 let fp = $(this).flatpickr(options);
189 $(disable_buttons).each(function(index, value){
190 $(fp.calendarContainer).find(".shortcut-buttons-flatpickr-button[data-index='"+value+"']").prop("disabled", "disabled");
193 if ( refresh_max_date ) {
194 /* Refresh the maxDate every 30 secondes to make sure the user will not
195 be stuck with the minute passed.
196 Adding 1 minute to not introduce a gap.
197 Example: last update at 40s, a new minute passed at 00.
198 Between 00 and 10s the user won't be able click 'Today'.
201 let now = new Date();
202 fp.set("maxDate", now.setMinutes(now.getMinutes() + 1));