tags.
*/
@@ -3170,7 +3170,7 @@ showdown.subParser('completeHTMLDocument', function (text, options, globals) {
text = globals.converter._dispatch('completeHTMLDocument.after', text, options, globals);
return text;
});
-
+
/**
* Convert all tabs to spaces
*/
@@ -3203,7 +3203,7 @@ showdown.subParser('detab', function (text, options, globals) {
text = globals.converter._dispatch('detab.after', text, options, globals);
return text;
});
-
+
showdown.subParser('ellipsis', function (text, options, globals) {
text = globals.converter._dispatch('ellipsis.before', text, options, globals);
@@ -3213,7 +3213,7 @@ showdown.subParser('ellipsis', function (text, options, globals) {
return text;
});
-
+
/**
* These are all the transformations that occur *within* block-level
* tags like paragraphs, headers, and list items.
@@ -3238,7 +3238,7 @@ showdown.subParser('emoji', function (text, options, globals) {
return text;
});
-
+
/**
* Smart processing for ampersands and angle brackets that need to be encoded.
*/
@@ -3261,7 +3261,7 @@ showdown.subParser('encodeAmpsAndAngles', function (text, options, globals) {
text = globals.converter._dispatch('encodeAmpsAndAngles.after', text, options, globals);
return text;
});
-
+
/**
* Returns the string, with after processing the following backslash escape sequences.
*
@@ -3282,7 +3282,7 @@ showdown.subParser('encodeBackslashEscapes', function (text, options, globals) {
text = globals.converter._dispatch('encodeBackslashEscapes.after', text, options, globals);
return text;
});
-
+
/**
* Encode/escape certain characters inside Markdown code runs.
* The point is that in code, these characters are literals,
@@ -3304,7 +3304,7 @@ showdown.subParser('encodeCode', function (text, options, globals) {
text = globals.converter._dispatch('encodeCode.after', text, options, globals);
return text;
});
-
+
/**
* Within tags -- meaning between < and > -- encode [\ ` * _ ~ =] so they
* don't conflict with their use in Markdown for code, italics and strong.
@@ -3330,7 +3330,7 @@ showdown.subParser('escapeSpecialCharsWithinTagAttributes', function (text, opti
text = globals.converter._dispatch('escapeSpecialCharsWithinTagAttributes.after', text, options, globals);
return text;
});
-
+
/**
* Handle github codeblocks prior to running HashHTML so that
* HTML contained within the codeblock gets escaped properly
@@ -3374,7 +3374,7 @@ showdown.subParser('githubCodeBlocks', function (text, options, globals) {
return globals.converter._dispatch('githubCodeBlocks.after', text, options, globals);
});
-
+
showdown.subParser('hashBlock', function (text, options, globals) {
text = globals.converter._dispatch('hashBlock.before', text, options, globals);
text = text.replace(/(^\n+|\n+$)/g, '');
@@ -3382,7 +3382,7 @@ showdown.subParser('hashBlock', function (text, options, globals) {
text = globals.converter._dispatch('hashBlock.after', text, options, globals);
return text;
});
-
+
/**
* Hash and escape elements that should not be parsed as markdown
*/
@@ -3400,7 +3400,7 @@ showdown.subParser('hashCodeTags', function (text, options, globals) {
text = globals.converter._dispatch('hashCodeTags.after', text, options, globals);
return text;
});
-
+
showdown.subParser('hashElement', function (text, options, globals) {
return function (wholeMatch, m1) {
var blockText = m1;
@@ -3418,7 +3418,7 @@ showdown.subParser('hashElement', function (text, options, globals) {
return blockText;
};
});
-
+
showdown.subParser('hashHTMLBlocks', function (text, options, globals) {
text = globals.converter._dispatch('hashHTMLBlocks.before', text, options, globals);
@@ -3516,7 +3516,7 @@ showdown.subParser('hashHTMLBlocks', function (text, options, globals) {
text = globals.converter._dispatch('hashHTMLBlocks.after', text, options, globals);
return text;
});
-
+
/**
* Hash span elements that should not be parsed as markdown
*/
@@ -3579,7 +3579,7 @@ showdown.subParser('unhashHTMLSpans', function (text, options, globals) {
text = globals.converter._dispatch('unhashHTMLSpans.after', text, options, globals);
return text;
});
-
+
/**
* Hash and escape elements that should not be parsed as markdown
*/
@@ -3598,7 +3598,7 @@ showdown.subParser('hashPreCodeTags', function (text, options, globals) {
text = globals.converter._dispatch('hashPreCodeTags.after', text, options, globals);
return text;
});
-
+
showdown.subParser('headers', function (text, options, globals) {
text = globals.converter._dispatch('headers.before', text, options, globals);
@@ -3723,7 +3723,7 @@ showdown.subParser('headers', function (text, options, globals) {
text = globals.converter._dispatch('headers.after', text, options, globals);
return text;
});
-
+
/**
* Turn Markdown link shortcuts into XHTML tags.
*/
@@ -3738,7 +3738,7 @@ showdown.subParser('horizontalRule', function (text, options, globals) {
text = globals.converter._dispatch('horizontalRule.after', text, options, globals);
return text;
});
-
+
/**
* Turn Markdown image shortcuts into tags.
*/
@@ -3841,7 +3841,7 @@ showdown.subParser('images', function (text, options, globals) {
text = globals.converter._dispatch('images.after', text, options, globals);
return text;
});
-
+
showdown.subParser('italicsAndBold', function (text, options, globals) {
text = globals.converter._dispatch('italicsAndBold.before', text, options, globals);
@@ -3910,7 +3910,7 @@ showdown.subParser('italicsAndBold', function (text, options, globals) {
text = globals.converter._dispatch('italicsAndBold.after', text, options, globals);
return text;
});
-
+
/**
* Form HTML ordered (numbered) and unordered (bulleted) lists.
*/
@@ -4105,7 +4105,7 @@ showdown.subParser('lists', function (text, options, globals) {
text = globals.converter._dispatch('lists.after', text, options, globals);
return text;
});
-
+
/**
* Parse metadata at the top of the document
*/
@@ -4153,7 +4153,7 @@ showdown.subParser('metadata', function (text, options, globals) {
text = globals.converter._dispatch('metadata.after', text, options, globals);
return text;
});
-
+
/**
* Remove one level of line-leading tabs or spaces
*/
@@ -4170,7 +4170,7 @@ showdown.subParser('outdent', function (text, options, globals) {
text = globals.converter._dispatch('outdent.after', text, options, globals);
return text;
});
-
+
/**
*
*/
@@ -4239,7 +4239,7 @@ showdown.subParser('paragraphs', function (text, options, globals) {
text = text.replace(/\n+$/g, '');
return globals.converter._dispatch('paragraphs.after', text, options, globals);
});
-
+
/**
* Run extension
*/
@@ -4258,7 +4258,7 @@ showdown.subParser('runExtension', function (ext, text, options, globals) {
return text;
});
-
+
/**
* These are all the transformations that occur *within* block-level
* tags like paragraphs, headers, and list items.
@@ -4306,7 +4306,7 @@ showdown.subParser('spanGamut', function (text, options, globals) {
text = globals.converter._dispatch('spanGamut.after', text, options, globals);
return text;
});
-
+
showdown.subParser('strikethrough', function (text, options, globals) {
function parseInside (txt) {
if (options.simplifiedAutoLink) {
@@ -4323,7 +4323,7 @@ showdown.subParser('strikethrough', function (text, options, globals) {
return text;
});
-
+
/**
* Strips link definitions from text, stores the URLs and titles in
* hash references.
@@ -4375,7 +4375,7 @@ showdown.subParser('stripLinkDefinitions', function (text, options, globals) {
return text;
});
-
+
showdown.subParser('tables', function (text, options, globals) {
if (!options.tables) {
return text;
@@ -4516,7 +4516,7 @@ showdown.subParser('tables', function (text, options, globals) {
return text;
});
-
+
showdown.subParser('underline', function (text, options, globals) {
if (!options.underline) {
return text;
@@ -4541,7 +4541,7 @@ showdown.subParser('underline', function (text, options, globals) {
return text;
});
-
+
/**
* Swap back in all the special characters we've hidden.
*/
@@ -4556,7 +4556,7 @@ showdown.subParser('unescapeSpecialChars', function (text, options, globals) {
text = globals.converter._dispatch('unescapeSpecialChars.after', text, options, globals);
return text;
});
-
+
var root = this;
// AMD Loader
@@ -4573,9 +4573,9 @@ if (typeof undefined === 'function' && undefined.amd) {
} else {
root.showdown = showdown;
}
-}).call(commonjsGlobal);
-
+}).call(commonjsGlobal);
+//# sourceMappingURL=showdown.js.map
});
var moment = createCommonjsModule(function (module, exports) {
@@ -23066,7 +23066,7 @@ Popper.placements = placements;
Popper.Defaults = Defaults;
-
+//# sourceMappingURL=popper.js.map
var popper = Object.freeze({
@@ -26965,7 +26965,7 @@ exports.Tooltip = Tooltip;
Object.defineProperty(exports, '__esModule', { value: true });
})));
-
+//# sourceMappingURL=bootstrap.js.map
});
unwrapExports(bootstrap);
@@ -27022,6 +27022,43 @@ Dropdown.instances = 0;
var dropdown = Dropdown;
var ui = {
+ create(tag, o) {
+ let element = document.createElement(tag);
+
+ let $ = (expr, con) => {
+ return typeof expr === "string"
+ ? (con || document).querySelector(expr)
+ : expr || null;
+ };
+
+ for (var i in o) {
+ let val = o[i];
+
+ if (i === "inside") {
+ $(val).appendChild(element);
+ }
+ else if (i === "around") {
+ let ref = $(val);
+ ref.parentNode.insertBefore(element, ref);
+ element.appendChild(ref);
+
+ } else if (i === "styles") {
+ if(typeof val === "object") {
+ Object.keys(val).map(prop => {
+ element.style[prop] = val[prop];
+ });
+ }
+ } else if (i in element ) {
+ element[i] = val;
+ }
+ else {
+ element.setAttribute(i, val);
+ }
+ }
+
+ return element;
+ },
+
add(tag, className, parent, textContent) {
let element = document.createElement(tag);
if (className) {
@@ -39817,11 +39854,6 @@ var htmlmixed = createCommonjsModule(function (module, exports) {
});
});
-// const frappe = require('frappejs');
-
- // eslint-disable-line
- // eslint-disable-line
-
class CodeControl extends base {
makeInput() {
if (!this.options) {
@@ -39865,2082 +39897,2082 @@ var flatpickr = createCommonjsModule(function (module, exports) {
/* flatpickr v4.3.2, @license MIT */
(function (global, factory) {
factory(exports);
-}(commonjsGlobal, (function (exports) { var __assign = Object.assign || function __assign(t) {
- for (var s, i = 1, n = arguments.length; i < n; i++) {
- s = arguments[i];
- for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
- }
- return t;
+}(commonjsGlobal, (function (exports) { var __assign = Object.assign || function __assign(t) {
+ for (var s, i = 1, n = arguments.length; i < n; i++) {
+ s = arguments[i];
+ for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
+ }
+ return t;
};
-var pad = function (number) { return ("0" + number).slice(-2); };
-var int = function (bool) { return (bool === true ? 1 : 0); };
-function debounce(func, wait, immediate) {
- if (immediate === void 0) { immediate = false; }
- var timeout;
- return function () {
- var context = this, args = arguments;
- timeout !== null && clearTimeout(timeout);
- timeout = window.setTimeout(function () {
- timeout = null;
- if (!immediate)
- func.apply(context, args);
- }, wait);
- if (immediate && !timeout)
- func.apply(context, args);
- };
-}
-var arrayify = function (obj) {
- return obj instanceof Array ? obj : [obj];
+var pad = function (number) { return ("0" + number).slice(-2); };
+var int = function (bool) { return (bool === true ? 1 : 0); };
+function debounce(func, wait, immediate) {
+ if (immediate === void 0) { immediate = false; }
+ var timeout;
+ return function () {
+ var context = this, args = arguments;
+ timeout !== null && clearTimeout(timeout);
+ timeout = window.setTimeout(function () {
+ timeout = null;
+ if (!immediate)
+ func.apply(context, args);
+ }, wait);
+ if (immediate && !timeout)
+ func.apply(context, args);
+ };
+}
+var arrayify = function (obj) {
+ return obj instanceof Array ? obj : [obj];
};
-var do_nothing = function () { return undefined; };
-var revFormat = {
- D: do_nothing,
- F: function (dateObj, monthName, locale) {
- dateObj.setMonth(locale.months.longhand.indexOf(monthName));
- },
- G: function (dateObj, hour) {
- dateObj.setHours(parseFloat(hour));
- },
- H: function (dateObj, hour) {
- dateObj.setHours(parseFloat(hour));
- },
- J: function (dateObj, day) {
- dateObj.setDate(parseFloat(day));
- },
- K: function (dateObj, amPM, locale) {
- dateObj.setHours(dateObj.getHours() % 12 +
- 12 * int(new RegExp(locale.amPM[1], "i").test(amPM)));
- },
- M: function (dateObj, shortMonth, locale) {
- dateObj.setMonth(locale.months.shorthand.indexOf(shortMonth));
- },
- S: function (dateObj, seconds) {
- dateObj.setSeconds(parseFloat(seconds));
- },
- U: function (_, unixSeconds) { return new Date(parseFloat(unixSeconds) * 1000); },
- W: function (dateObj, weekNum) {
- var weekNumber = parseInt(weekNum);
- return new Date(dateObj.getFullYear(), 0, 2 + (weekNumber - 1) * 7, 0, 0, 0, 0);
- },
- Y: function (dateObj, year) {
- dateObj.setFullYear(parseFloat(year));
- },
- Z: function (_, ISODate) { return new Date(ISODate); },
- d: function (dateObj, day) {
- dateObj.setDate(parseFloat(day));
- },
- h: function (dateObj, hour) {
- dateObj.setHours(parseFloat(hour));
- },
- i: function (dateObj, minutes) {
- dateObj.setMinutes(parseFloat(minutes));
- },
- j: function (dateObj, day) {
- dateObj.setDate(parseFloat(day));
- },
- l: do_nothing,
- m: function (dateObj, month) {
- dateObj.setMonth(parseFloat(month) - 1);
- },
- n: function (dateObj, month) {
- dateObj.setMonth(parseFloat(month) - 1);
- },
- s: function (dateObj, seconds) {
- dateObj.setSeconds(parseFloat(seconds));
- },
- w: do_nothing,
- y: function (dateObj, year) {
- dateObj.setFullYear(2000 + parseFloat(year));
- },
-};
-var tokenRegex = {
- D: "(\\w+)",
- F: "(\\w+)",
- G: "(\\d\\d|\\d)",
- H: "(\\d\\d|\\d)",
- J: "(\\d\\d|\\d)\\w+",
- K: "",
- M: "(\\w+)",
- S: "(\\d\\d|\\d)",
- U: "(.+)",
- W: "(\\d\\d|\\d)",
- Y: "(\\d{4})",
- Z: "(.+)",
- d: "(\\d\\d|\\d)",
- h: "(\\d\\d|\\d)",
- i: "(\\d\\d|\\d)",
- j: "(\\d\\d|\\d)",
- l: "(\\w+)",
- m: "(\\d\\d|\\d)",
- n: "(\\d\\d|\\d)",
- s: "(\\d\\d|\\d)",
- w: "(\\d\\d|\\d)",
- y: "(\\d{2})",
-};
-var formats = {
- Z: function (date) { return date.toISOString(); },
- D: function (date, locale, options) {
- return locale.weekdays.shorthand[formats.w(date, locale, options)];
- },
- F: function (date, locale, options) {
- return monthToStr(formats.n(date, locale, options) - 1, false, locale);
- },
- G: function (date, locale, options) {
- return pad(formats.h(date, locale, options));
- },
- H: function (date) { return pad(date.getHours()); },
- J: function (date, locale) {
- return locale.ordinal !== undefined
- ? date.getDate() + locale.ordinal(date.getDate())
- : date.getDate();
- },
- K: function (date, locale) { return locale.amPM[int(date.getHours() > 11)]; },
- M: function (date, locale) {
- return monthToStr(date.getMonth(), true, locale);
- },
- S: function (date) { return pad(date.getSeconds()); },
- U: function (date) { return date.getTime() / 1000; },
- W: function (date, _, options) {
- return options.getWeek(date);
- },
- Y: function (date) { return date.getFullYear(); },
- d: function (date) { return pad(date.getDate()); },
- h: function (date) { return (date.getHours() % 12 ? date.getHours() % 12 : 12); },
- i: function (date) { return pad(date.getMinutes()); },
- j: function (date) { return date.getDate(); },
- l: function (date, locale) {
- return locale.weekdays.longhand[date.getDay()];
- },
- m: function (date) { return pad(date.getMonth() + 1); },
- n: function (date) { return date.getMonth() + 1; },
- s: function (date) { return date.getSeconds(); },
- w: function (date) { return date.getDay(); },
- y: function (date) { return String(date.getFullYear()).substring(2); },
+var do_nothing = function () { return undefined; };
+var revFormat = {
+ D: do_nothing,
+ F: function (dateObj, monthName, locale) {
+ dateObj.setMonth(locale.months.longhand.indexOf(monthName));
+ },
+ G: function (dateObj, hour) {
+ dateObj.setHours(parseFloat(hour));
+ },
+ H: function (dateObj, hour) {
+ dateObj.setHours(parseFloat(hour));
+ },
+ J: function (dateObj, day) {
+ dateObj.setDate(parseFloat(day));
+ },
+ K: function (dateObj, amPM, locale) {
+ dateObj.setHours(dateObj.getHours() % 12 +
+ 12 * int(new RegExp(locale.amPM[1], "i").test(amPM)));
+ },
+ M: function (dateObj, shortMonth, locale) {
+ dateObj.setMonth(locale.months.shorthand.indexOf(shortMonth));
+ },
+ S: function (dateObj, seconds) {
+ dateObj.setSeconds(parseFloat(seconds));
+ },
+ U: function (_, unixSeconds) { return new Date(parseFloat(unixSeconds) * 1000); },
+ W: function (dateObj, weekNum) {
+ var weekNumber = parseInt(weekNum);
+ return new Date(dateObj.getFullYear(), 0, 2 + (weekNumber - 1) * 7, 0, 0, 0, 0);
+ },
+ Y: function (dateObj, year) {
+ dateObj.setFullYear(parseFloat(year));
+ },
+ Z: function (_, ISODate) { return new Date(ISODate); },
+ d: function (dateObj, day) {
+ dateObj.setDate(parseFloat(day));
+ },
+ h: function (dateObj, hour) {
+ dateObj.setHours(parseFloat(hour));
+ },
+ i: function (dateObj, minutes) {
+ dateObj.setMinutes(parseFloat(minutes));
+ },
+ j: function (dateObj, day) {
+ dateObj.setDate(parseFloat(day));
+ },
+ l: do_nothing,
+ m: function (dateObj, month) {
+ dateObj.setMonth(parseFloat(month) - 1);
+ },
+ n: function (dateObj, month) {
+ dateObj.setMonth(parseFloat(month) - 1);
+ },
+ s: function (dateObj, seconds) {
+ dateObj.setSeconds(parseFloat(seconds));
+ },
+ w: do_nothing,
+ y: function (dateObj, year) {
+ dateObj.setFullYear(2000 + parseFloat(year));
+ },
+};
+var tokenRegex = {
+ D: "(\\w+)",
+ F: "(\\w+)",
+ G: "(\\d\\d|\\d)",
+ H: "(\\d\\d|\\d)",
+ J: "(\\d\\d|\\d)\\w+",
+ K: "",
+ M: "(\\w+)",
+ S: "(\\d\\d|\\d)",
+ U: "(.+)",
+ W: "(\\d\\d|\\d)",
+ Y: "(\\d{4})",
+ Z: "(.+)",
+ d: "(\\d\\d|\\d)",
+ h: "(\\d\\d|\\d)",
+ i: "(\\d\\d|\\d)",
+ j: "(\\d\\d|\\d)",
+ l: "(\\w+)",
+ m: "(\\d\\d|\\d)",
+ n: "(\\d\\d|\\d)",
+ s: "(\\d\\d|\\d)",
+ w: "(\\d\\d|\\d)",
+ y: "(\\d{2})",
+};
+var formats = {
+ Z: function (date) { return date.toISOString(); },
+ D: function (date, locale, options) {
+ return locale.weekdays.shorthand[formats.w(date, locale, options)];
+ },
+ F: function (date, locale, options) {
+ return monthToStr(formats.n(date, locale, options) - 1, false, locale);
+ },
+ G: function (date, locale, options) {
+ return pad(formats.h(date, locale, options));
+ },
+ H: function (date) { return pad(date.getHours()); },
+ J: function (date, locale) {
+ return locale.ordinal !== undefined
+ ? date.getDate() + locale.ordinal(date.getDate())
+ : date.getDate();
+ },
+ K: function (date, locale) { return locale.amPM[int(date.getHours() > 11)]; },
+ M: function (date, locale) {
+ return monthToStr(date.getMonth(), true, locale);
+ },
+ S: function (date) { return pad(date.getSeconds()); },
+ U: function (date) { return date.getTime() / 1000; },
+ W: function (date, _, options) {
+ return options.getWeek(date);
+ },
+ Y: function (date) { return date.getFullYear(); },
+ d: function (date) { return pad(date.getDate()); },
+ h: function (date) { return (date.getHours() % 12 ? date.getHours() % 12 : 12); },
+ i: function (date) { return pad(date.getMinutes()); },
+ j: function (date) { return date.getDate(); },
+ l: function (date, locale) {
+ return locale.weekdays.longhand[date.getDay()];
+ },
+ m: function (date) { return pad(date.getMonth() + 1); },
+ n: function (date) { return date.getMonth() + 1; },
+ s: function (date) { return date.getSeconds(); },
+ w: function (date) { return date.getDay(); },
+ y: function (date) { return String(date.getFullYear()).substring(2); },
};
-var english = {
- weekdays: {
- shorthand: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
- longhand: [
- "Sunday",
- "Monday",
- "Tuesday",
- "Wednesday",
- "Thursday",
- "Friday",
- "Saturday",
- ],
- },
- months: {
- shorthand: [
- "Jan",
- "Feb",
- "Mar",
- "Apr",
- "May",
- "Jun",
- "Jul",
- "Aug",
- "Sep",
- "Oct",
- "Nov",
- "Dec",
- ],
- longhand: [
- "January",
- "February",
- "March",
- "April",
- "May",
- "June",
- "July",
- "August",
- "September",
- "October",
- "November",
- "December",
- ],
- },
- daysInMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],
- firstDayOfWeek: 0,
- ordinal: function (nth) {
- var s = nth % 100;
- if (s > 3 && s < 21)
- return "th";
- switch (s % 10) {
- case 1:
- return "st";
- case 2:
- return "nd";
- case 3:
- return "rd";
- default:
- return "th";
- }
- },
- rangeSeparator: " to ",
- weekAbbreviation: "Wk",
- scrollTitle: "Scroll to increment",
- toggleTitle: "Click to toggle",
- amPM: ["AM", "PM"],
+var english = {
+ weekdays: {
+ shorthand: ["Sun", "Mon", "Tue", "Wed", "Thu", "Fri", "Sat"],
+ longhand: [
+ "Sunday",
+ "Monday",
+ "Tuesday",
+ "Wednesday",
+ "Thursday",
+ "Friday",
+ "Saturday",
+ ],
+ },
+ months: {
+ shorthand: [
+ "Jan",
+ "Feb",
+ "Mar",
+ "Apr",
+ "May",
+ "Jun",
+ "Jul",
+ "Aug",
+ "Sep",
+ "Oct",
+ "Nov",
+ "Dec",
+ ],
+ longhand: [
+ "January",
+ "February",
+ "March",
+ "April",
+ "May",
+ "June",
+ "July",
+ "August",
+ "September",
+ "October",
+ "November",
+ "December",
+ ],
+ },
+ daysInMonth: [31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31],
+ firstDayOfWeek: 0,
+ ordinal: function (nth) {
+ var s = nth % 100;
+ if (s > 3 && s < 21)
+ return "th";
+ switch (s % 10) {
+ case 1:
+ return "st";
+ case 2:
+ return "nd";
+ case 3:
+ return "rd";
+ default:
+ return "th";
+ }
+ },
+ rangeSeparator: " to ",
+ weekAbbreviation: "Wk",
+ scrollTitle: "Scroll to increment",
+ toggleTitle: "Click to toggle",
+ amPM: ["AM", "PM"],
};
-var createDateFormatter = function (_a) {
- var _b = _a.config, config = _b === void 0 ? defaults : _b, _c = _a.l10n, l10n = _c === void 0 ? english : _c;
- return function (dateObj, frmt, overrideLocale) {
- if (config.formatDate !== undefined)
- return config.formatDate(dateObj, frmt);
- var locale = overrideLocale || l10n;
- return frmt
- .split("")
- .map(function (c, i, arr) {
- return formats[c] && arr[i - 1] !== "\\"
- ? formats[c](dateObj, locale, config)
- : c !== "\\" ? c : "";
- })
- .join("");
- };
-};
-var createDateParser = function (_a) {
- var _b = _a.config, config = _b === void 0 ? defaults : _b, _c = _a.l10n, l10n = _c === void 0 ? english : _c;
- return function (date, givenFormat, timeless) {
- if (date !== 0 && !date)
- return undefined;
- var parsedDate;
- var date_orig = date;
- if (date instanceof Date)
- parsedDate = new Date(date.getTime());
- else if (typeof date !== "string" &&
- date.toFixed !== undefined)
- parsedDate = new Date(date);
- else if (typeof date === "string") {
- var format = givenFormat || (config || defaults).dateFormat;
- var datestr = String(date).trim();
- if (datestr === "today") {
- parsedDate = new Date();
- timeless = true;
- }
- else if (/Z$/.test(datestr) ||
- /GMT$/.test(datestr))
- parsedDate = new Date(date);
- else if (config && config.parseDate)
- parsedDate = config.parseDate(date, format);
- else {
- parsedDate =
- !config || !config.noCalendar
- ? new Date(new Date().getFullYear(), 0, 1, 0, 0, 0, 0)
- : new Date(new Date().setHours(0, 0, 0, 0));
- var matched = void 0, ops = [];
- for (var i = 0, matchIndex = 0, regexStr = ""; i < format.length; i++) {
- var token = format[i];
- var isBackSlash = token === "\\";
- var escaped = format[i - 1] === "\\" || isBackSlash;
- if (tokenRegex[token] && !escaped) {
- regexStr += tokenRegex[token];
- var match = new RegExp(regexStr).exec(date);
- if (match && (matched = true)) {
- ops[token !== "Y" ? "push" : "unshift"]({
- fn: revFormat[token],
- val: match[++matchIndex],
- });
- }
- }
- else if (!isBackSlash)
- regexStr += ".";
- ops.forEach(function (_a) {
- var fn = _a.fn, val = _a.val;
- return (parsedDate = fn(parsedDate, val, l10n) || parsedDate);
- });
- }
- parsedDate = matched ? parsedDate : undefined;
- }
- }
- if (!(parsedDate instanceof Date)) {
- config.errorHandler(new Error("Invalid date provided: " + date_orig));
- return undefined;
- }
- if (timeless === true)
- parsedDate.setHours(0, 0, 0, 0);
- return parsedDate;
- };
-};
-function compareDates(date1, date2, timeless) {
- if (timeless === void 0) { timeless = true; }
- if (timeless !== false) {
- return (new Date(date1.getTime()).setHours(0, 0, 0, 0) -
- new Date(date2.getTime()).setHours(0, 0, 0, 0));
- }
- return date1.getTime() - date2.getTime();
-}
-
-var monthToStr = function (monthNumber, shorthand, locale) { return locale.months[shorthand ? "shorthand" : "longhand"][monthNumber]; };
-var getWeek = function (givenDate) {
- var date = new Date(givenDate.getTime());
- date.setHours(0, 0, 0, 0);
- date.setDate(date.getDate() + 3 - (date.getDay() + 6) % 7);
- var week1 = new Date(date.getFullYear(), 0, 4);
- return (1 +
- Math.round(((date.getTime() - week1.getTime()) / 86400000 -
- 3 +
- (week1.getDay() + 6) % 7) /
- 7));
-};
-var duration = {
- DAY: 86400000,
+var createDateFormatter = function (_a) {
+ var _b = _a.config, config = _b === void 0 ? defaults : _b, _c = _a.l10n, l10n = _c === void 0 ? english : _c;
+ return function (dateObj, frmt, overrideLocale) {
+ if (config.formatDate !== undefined)
+ return config.formatDate(dateObj, frmt);
+ var locale = overrideLocale || l10n;
+ return frmt
+ .split("")
+ .map(function (c, i, arr) {
+ return formats[c] && arr[i - 1] !== "\\"
+ ? formats[c](dateObj, locale, config)
+ : c !== "\\" ? c : "";
+ })
+ .join("");
+ };
+};
+var createDateParser = function (_a) {
+ var _b = _a.config, config = _b === void 0 ? defaults : _b, _c = _a.l10n, l10n = _c === void 0 ? english : _c;
+ return function (date, givenFormat, timeless) {
+ if (date !== 0 && !date)
+ return undefined;
+ var parsedDate;
+ var date_orig = date;
+ if (date instanceof Date)
+ parsedDate = new Date(date.getTime());
+ else if (typeof date !== "string" &&
+ date.toFixed !== undefined)
+ parsedDate = new Date(date);
+ else if (typeof date === "string") {
+ var format = givenFormat || (config || defaults).dateFormat;
+ var datestr = String(date).trim();
+ if (datestr === "today") {
+ parsedDate = new Date();
+ timeless = true;
+ }
+ else if (/Z$/.test(datestr) ||
+ /GMT$/.test(datestr))
+ parsedDate = new Date(date);
+ else if (config && config.parseDate)
+ parsedDate = config.parseDate(date, format);
+ else {
+ parsedDate =
+ !config || !config.noCalendar
+ ? new Date(new Date().getFullYear(), 0, 1, 0, 0, 0, 0)
+ : new Date(new Date().setHours(0, 0, 0, 0));
+ var matched = void 0, ops = [];
+ for (var i = 0, matchIndex = 0, regexStr = ""; i < format.length; i++) {
+ var token = format[i];
+ var isBackSlash = token === "\\";
+ var escaped = format[i - 1] === "\\" || isBackSlash;
+ if (tokenRegex[token] && !escaped) {
+ regexStr += tokenRegex[token];
+ var match = new RegExp(regexStr).exec(date);
+ if (match && (matched = true)) {
+ ops[token !== "Y" ? "push" : "unshift"]({
+ fn: revFormat[token],
+ val: match[++matchIndex],
+ });
+ }
+ }
+ else if (!isBackSlash)
+ regexStr += ".";
+ ops.forEach(function (_a) {
+ var fn = _a.fn, val = _a.val;
+ return (parsedDate = fn(parsedDate, val, l10n) || parsedDate);
+ });
+ }
+ parsedDate = matched ? parsedDate : undefined;
+ }
+ }
+ if (!(parsedDate instanceof Date)) {
+ config.errorHandler(new Error("Invalid date provided: " + date_orig));
+ return undefined;
+ }
+ if (timeless === true)
+ parsedDate.setHours(0, 0, 0, 0);
+ return parsedDate;
+ };
+};
+function compareDates(date1, date2, timeless) {
+ if (timeless === void 0) { timeless = true; }
+ if (timeless !== false) {
+ return (new Date(date1.getTime()).setHours(0, 0, 0, 0) -
+ new Date(date2.getTime()).setHours(0, 0, 0, 0));
+ }
+ return date1.getTime() - date2.getTime();
+}
+
+var monthToStr = function (monthNumber, shorthand, locale) { return locale.months[shorthand ? "shorthand" : "longhand"][monthNumber]; };
+var getWeek = function (givenDate) {
+ var date = new Date(givenDate.getTime());
+ date.setHours(0, 0, 0, 0);
+ date.setDate(date.getDate() + 3 - (date.getDay() + 6) % 7);
+ var week1 = new Date(date.getFullYear(), 0, 4);
+ return (1 +
+ Math.round(((date.getTime() - week1.getTime()) / 86400000 -
+ 3 +
+ (week1.getDay() + 6) % 7) /
+ 7));
+};
+var duration = {
+ DAY: 86400000,
};
-var defaults = {
- _disable: [],
- _enable: [],
- allowInput: false,
- altFormat: "F j, Y",
- altInput: false,
- altInputClass: "form-control input",
- animate: typeof window === "object" &&
- window.navigator.userAgent.indexOf("MSIE") === -1,
- ariaDateFormat: "F j, Y",
- clickOpens: true,
- closeOnSelect: true,
- conjunction: ", ",
- dateFormat: "Y-m-d",
- defaultHour: 12,
- defaultMinute: 0,
- defaultSeconds: 0,
- disable: [],
- disableMobile: false,
- enable: [],
- enableSeconds: false,
- enableTime: false,
- errorHandler: console.warn,
- getWeek: getWeek,
- hourIncrement: 1,
- ignoredFocusElements: [],
- inline: false,
- locale: "default",
- minuteIncrement: 5,
- mode: "single",
- nextArrow: "",
- noCalendar: false,
- onChange: [],
- onClose: [],
- onDayCreate: [],
- onDestroy: [],
- onKeyDown: [],
- onMonthChange: [],
- onOpen: [],
- onParseConfig: [],
- onReady: [],
- onValueUpdate: [],
- onYearChange: [],
- onPreCalendarPosition: [],
- plugins: [],
- position: "auto",
- positionElement: undefined,
- prevArrow: "",
- shorthandCurrentMonth: false,
- static: false,
- time_24hr: false,
- weekNumbers: false,
- wrap: false,
+var defaults = {
+ _disable: [],
+ _enable: [],
+ allowInput: false,
+ altFormat: "F j, Y",
+ altInput: false,
+ altInputClass: "form-control input",
+ animate: typeof window === "object" &&
+ window.navigator.userAgent.indexOf("MSIE") === -1,
+ ariaDateFormat: "F j, Y",
+ clickOpens: true,
+ closeOnSelect: true,
+ conjunction: ", ",
+ dateFormat: "Y-m-d",
+ defaultHour: 12,
+ defaultMinute: 0,
+ defaultSeconds: 0,
+ disable: [],
+ disableMobile: false,
+ enable: [],
+ enableSeconds: false,
+ enableTime: false,
+ errorHandler: console.warn,
+ getWeek: getWeek,
+ hourIncrement: 1,
+ ignoredFocusElements: [],
+ inline: false,
+ locale: "default",
+ minuteIncrement: 5,
+ mode: "single",
+ nextArrow: "",
+ noCalendar: false,
+ onChange: [],
+ onClose: [],
+ onDayCreate: [],
+ onDestroy: [],
+ onKeyDown: [],
+ onMonthChange: [],
+ onOpen: [],
+ onParseConfig: [],
+ onReady: [],
+ onValueUpdate: [],
+ onYearChange: [],
+ onPreCalendarPosition: [],
+ plugins: [],
+ position: "auto",
+ positionElement: undefined,
+ prevArrow: "",
+ shorthandCurrentMonth: false,
+ static: false,
+ time_24hr: false,
+ weekNumbers: false,
+ wrap: false,
};
-function toggleClass(elem, className, bool) {
- if (bool === true)
- return elem.classList.add(className);
- elem.classList.remove(className);
-}
-function createElement(tag, className, content) {
- var e = window.document.createElement(tag);
- className = className || "";
- content = content || "";
- e.className = className;
- if (content !== undefined)
- e.textContent = content;
- return e;
-}
-function clearNode(node) {
- while (node.firstChild)
- node.removeChild(node.firstChild);
-}
-function findParent(node, condition) {
- if (condition(node))
- return node;
- else if (node.parentNode)
- return findParent(node.parentNode, condition);
- return undefined;
-}
-function createNumberInput(inputClassName, opts) {
- var wrapper = createElement("div", "numInputWrapper"), numInput = createElement("input", "numInput " + inputClassName), arrowUp = createElement("span", "arrowUp"), arrowDown = createElement("span", "arrowDown");
- numInput.type = "text";
- numInput.pattern = "\\d*";
- if (opts !== undefined)
- for (var key in opts)
- numInput.setAttribute(key, opts[key]);
- wrapper.appendChild(numInput);
- wrapper.appendChild(arrowUp);
- wrapper.appendChild(arrowDown);
- return wrapper;
+function toggleClass(elem, className, bool) {
+ if (bool === true)
+ return elem.classList.add(className);
+ elem.classList.remove(className);
+}
+function createElement(tag, className, content) {
+ var e = window.document.createElement(tag);
+ className = className || "";
+ content = content || "";
+ e.className = className;
+ if (content !== undefined)
+ e.textContent = content;
+ return e;
+}
+function clearNode(node) {
+ while (node.firstChild)
+ node.removeChild(node.firstChild);
+}
+function findParent(node, condition) {
+ if (condition(node))
+ return node;
+ else if (node.parentNode)
+ return findParent(node.parentNode, condition);
+ return undefined;
+}
+function createNumberInput(inputClassName, opts) {
+ var wrapper = createElement("div", "numInputWrapper"), numInput = createElement("input", "numInput " + inputClassName), arrowUp = createElement("span", "arrowUp"), arrowDown = createElement("span", "arrowDown");
+ numInput.type = "text";
+ numInput.pattern = "\\d*";
+ if (opts !== undefined)
+ for (var key in opts)
+ numInput.setAttribute(key, opts[key]);
+ wrapper.appendChild(numInput);
+ wrapper.appendChild(arrowUp);
+ wrapper.appendChild(arrowDown);
+ return wrapper;
}
-if (typeof Object.assign !== "function") {
- Object.assign = function (target) {
- var args = [];
- for (var _i = 1; _i < arguments.length; _i++) {
- args[_i - 1] = arguments[_i];
- }
- if (!target) {
- throw TypeError("Cannot convert undefined or null to object");
- }
- var _loop_1 = function (source) {
- if (source) {
- Object.keys(source).forEach(function (key) { return (target[key] = source[key]); });
- }
- };
- for (var _a = 0, args_1 = args; _a < args_1.length; _a++) {
- var source = args_1[_a];
- _loop_1(source);
- }
- return target;
- };
+if (typeof Object.assign !== "function") {
+ Object.assign = function (target) {
+ var args = [];
+ for (var _i = 1; _i < arguments.length; _i++) {
+ args[_i - 1] = arguments[_i];
+ }
+ if (!target) {
+ throw TypeError("Cannot convert undefined or null to object");
+ }
+ var _loop_1 = function (source) {
+ if (source) {
+ Object.keys(source).forEach(function (key) { return (target[key] = source[key]); });
+ }
+ };
+ for (var _a = 0, args_1 = args; _a < args_1.length; _a++) {
+ var source = args_1[_a];
+ _loop_1(source);
+ }
+ return target;
+ };
}
-var DEBOUNCED_CHANGE_MS = 300;
-function FlatpickrInstance(element, instanceConfig) {
- var self = {
- config: __assign({}, flatpickr.defaultConfig),
- l10n: english,
- };
- self.parseDate = createDateParser({ config: self.config, l10n: self.l10n });
- self._handlers = [];
- self._bind = bind;
- self._setHoursFromDate = setHoursFromDate;
- self.changeMonth = changeMonth;
- self.changeYear = changeYear;
- self.clear = clear;
- self.close = close;
- self._createElement = createElement;
- self.destroy = destroy;
- self.isEnabled = isEnabled;
- self.jumpToDate = jumpToDate;
- self.open = open;
- self.redraw = redraw;
- self.set = set;
- self.setDate = setDate;
- self.toggle = toggle;
- function setupHelperFunctions() {
- self.utils = {
- getDaysInMonth: function (month, yr) {
- if (month === void 0) { month = self.currentMonth; }
- if (yr === void 0) { yr = self.currentYear; }
- if (month === 1 && ((yr % 4 === 0 && yr % 100 !== 0) || yr % 400 === 0))
- return 29;
- return self.l10n.daysInMonth[month];
- },
- };
- }
- function init() {
- self.element = self.input = element;
- self.isOpen = false;
- parseConfig();
- setupLocale();
- setupInputs();
- setupDates();
- setupHelperFunctions();
- if (!self.isMobile)
- build();
- bindEvents();
- if (self.selectedDates.length || self.config.noCalendar) {
- if (self.config.enableTime) {
- setHoursFromDate(self.config.noCalendar
- ? self.latestSelectedDateObj || self.config.minDate
- : undefined);
- }
- updateValue(false);
- }
- self.showTimeInput =
- self.selectedDates.length > 0 || self.config.noCalendar;
- if (self.weekWrapper !== undefined && self.daysContainer !== undefined) {
- self.calendarContainer.style.visibility = "hidden";
- self.calendarContainer.style.display = "block";
- self.calendarContainer.style.width =
- self.daysContainer.offsetWidth + self.weekWrapper.offsetWidth + "px";
- self.calendarContainer.style.visibility = "visible";
- self.calendarContainer.style.display = null;
- }
- var isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);
- if (!self.isMobile && isSafari) {
- positionCalendar();
- }
- triggerEvent("onReady");
- }
- function bindToInstance(fn) {
- return fn.bind(self);
- }
- function updateTime(e) {
- if (self.config.noCalendar && self.selectedDates.length === 0) {
- self.setDate(self.config.minDate !== undefined
- ? new Date(self.config.minDate.getTime())
- : new Date().setHours(self.config.defaultHour, self.config.defaultMinute, self.config.defaultSeconds, 0), false);
- setHoursFromInputs();
- updateValue();
- }
- timeWrapper(e);
- if (self.selectedDates.length === 0)
- return;
- if (e.type !== "input") {
- setHoursFromInputs();
- updateValue();
- }
- else {
- setTimeout(function () {
- setHoursFromInputs();
- updateValue();
- }, DEBOUNCED_CHANGE_MS);
- }
- }
- function ampm2military(hour, amPM) {
- return hour % 12 + 12 * int(amPM === self.l10n.amPM[1]);
- }
- function military2ampm(hour) {
- switch (hour % 24) {
- case 0:
- case 12:
- return 12;
- default:
- return hour % 12;
- }
- }
- function setHoursFromInputs() {
- if (self.hourElement === undefined || self.minuteElement === undefined)
- return;
- var hours = (parseInt(self.hourElement.value.slice(-2), 10) || 0) % 24, minutes = (parseInt(self.minuteElement.value, 10) || 0) % 60, seconds = self.secondElement !== undefined
- ? (parseInt(self.secondElement.value, 10) || 0) % 60
- : 0;
- if (self.amPM !== undefined)
- hours = ampm2military(hours, self.amPM.textContent);
- var limitMinHours = self.config.minTime !== undefined ||
- (self.config.minDate &&
- self.minDateHasTime &&
- self.latestSelectedDateObj &&
- compareDates(self.latestSelectedDateObj, self.config.minDate, true) ===
- 0);
- var limitMaxHours = self.config.maxTime !== undefined ||
- (self.config.maxDate &&
- self.maxDateHasTime &&
- self.latestSelectedDateObj &&
- compareDates(self.latestSelectedDateObj, self.config.maxDate, true) ===
- 0);
- if (limitMaxHours) {
- var maxTime = self.config.maxTime !== undefined
- ? self.config.maxTime
- : self.config.maxDate;
- hours = Math.min(hours, maxTime.getHours());
- if (hours === maxTime.getHours())
- minutes = Math.min(minutes, maxTime.getMinutes());
- }
- if (limitMinHours) {
- var minTime = self.config.minTime !== undefined
- ? self.config.minTime
- : self.config.minDate;
- hours = Math.max(hours, minTime.getHours());
- if (hours === minTime.getHours())
- minutes = Math.max(minutes, minTime.getMinutes());
- }
- setHours(hours, minutes, seconds);
- }
- function setHoursFromDate(dateObj) {
- var date = dateObj || self.latestSelectedDateObj;
- if (date)
- setHours(date.getHours(), date.getMinutes(), date.getSeconds());
- }
- function setHours(hours, minutes, seconds) {
- if (self.latestSelectedDateObj !== undefined) {
- self.latestSelectedDateObj.setHours(hours % 24, minutes, seconds || 0, 0);
- }
- if (!self.hourElement || !self.minuteElement || self.isMobile)
- return;
- self.hourElement.value = pad(!self.config.time_24hr
- ? (12 + hours) % 12 + 12 * int(hours % 12 === 0)
- : hours);
- self.minuteElement.value = pad(minutes);
- if (self.amPM !== undefined)
- self.amPM.textContent = self.l10n.amPM[int(hours >= 12)];
- if (self.secondElement !== undefined)
- self.secondElement.value = pad(seconds);
- }
- function onYearInput(event) {
- var year = parseInt(event.target.value) + (event.delta || 0);
- if (year.toString().length === 4 || event.key === "Enter") {
- self.currentYearElement.blur();
- if (!/[^\d]/.test(year.toString()))
- changeYear(year);
- }
- }
- function bind(element, event, handler, options) {
- if (event instanceof Array)
- return event.forEach(function (ev) { return bind(element, ev, handler, options); });
- if (element instanceof Array)
- return element.forEach(function (el) { return bind(el, event, handler, options); });
- element.addEventListener(event, handler, options);
- self._handlers.push({ element: element, event: event, handler: handler });
- }
- function onClick(handler) {
- return function (evt) {
- evt.which === 1 && handler(evt);
- };
- }
- function triggerChange() {
- triggerEvent("onChange");
- }
- function bindEvents() {
- if (self.config.wrap) {
- ["open", "close", "toggle", "clear"].forEach(function (evt) {
- Array.prototype.forEach.call(self.element.querySelectorAll("[data-" + evt + "]"), function (el) {
- return bind(el, "click", self[evt]);
- });
- });
- }
- if (self.isMobile) {
- setupMobile();
- return;
- }
- var debouncedResize = debounce(onResize, 50);
- self._debouncedChange = debounce(triggerChange, DEBOUNCED_CHANGE_MS);
- if (self.daysContainer && !/iPhone|iPad|iPod/i.test(navigator.userAgent))
- bind(self.daysContainer, "mouseover", function (e) {
- if (self.config.mode === "range")
- onMouseOver(e.target);
- });
- bind(window.document.body, "keydown", onKeyDown);
- if (!self.config.static)
- bind(self._input, "keydown", onKeyDown);
- if (!self.config.inline && !self.config.static)
- bind(window, "resize", debouncedResize);
- if (window.ontouchstart !== undefined)
- bind(window.document, "touchstart", documentClick);
- bind(window.document, "mousedown", onClick(documentClick));
- bind(window.document, "focus", documentClick, { capture: true });
- if (self.config.clickOpens === true) {
- bind(self._input, "focus", self.open);
- bind(self._input, "mousedown", onClick(self.open));
- }
- if (self.daysContainer !== undefined) {
- bind(self.monthNav, "mousedown", onClick(onMonthNavClick));
- bind(self.monthNav, ["keyup", "increment"], onYearInput);
- bind(self.daysContainer, "mousedown", onClick(selectDate));
- }
- if (self.timeContainer !== undefined &&
- self.minuteElement !== undefined &&
- self.hourElement !== undefined) {
- var selText = function (e) {
- return e.target.select();
- };
- bind(self.timeContainer, ["input", "increment"], updateTime);
- bind(self.timeContainer, "mousedown", onClick(timeIncrement));
- bind(self.timeContainer, ["input", "increment"], self._debouncedChange, {
- passive: true,
- });
- bind([self.hourElement, self.minuteElement], ["focus", "click"], selText);
- if (self.secondElement !== undefined)
- bind(self.secondElement, "focus", function () { return self.secondElement && self.secondElement.select(); });
- if (self.amPM !== undefined) {
- bind(self.amPM, "mousedown", onClick(function (e) {
- updateTime(e);
- triggerChange();
- }));
- }
- }
- }
- function jumpToDate(jumpDate) {
- var jumpTo = jumpDate !== undefined
- ? self.parseDate(jumpDate)
- : self.latestSelectedDateObj ||
- (self.config.minDate && self.config.minDate > self.now
- ? self.config.minDate
- : self.config.maxDate && self.config.maxDate < self.now
- ? self.config.maxDate
- : self.now);
- try {
- if (jumpTo !== undefined) {
- self.currentYear = jumpTo.getFullYear();
- self.currentMonth = jumpTo.getMonth();
- }
- }
- catch (e) {
- e.message = "Invalid date supplied: " + jumpTo;
- self.config.errorHandler(e);
- }
- self.redraw();
- }
- function timeIncrement(e) {
- if (~e.target.className.indexOf("arrow"))
- incrementNumInput(e, e.target.classList.contains("arrowUp") ? 1 : -1);
- }
- function incrementNumInput(e, delta, inputElem) {
- var target = e && e.target;
- var input = inputElem ||
- (target && target.parentNode && target.parentNode.firstChild);
- var event = createEvent("increment");
- event.delta = delta;
- input && input.dispatchEvent(event);
- }
- function build() {
- var fragment = window.document.createDocumentFragment();
- self.calendarContainer = createElement("div", "flatpickr-calendar");
- self.calendarContainer.tabIndex = -1;
- if (!self.config.noCalendar) {
- fragment.appendChild(buildMonthNav());
- self.innerContainer = createElement("div", "flatpickr-innerContainer");
- if (self.config.weekNumbers) {
- var _a = buildWeeks(), weekWrapper = _a.weekWrapper, weekNumbers = _a.weekNumbers;
- self.innerContainer.appendChild(weekWrapper);
- self.weekNumbers = weekNumbers;
- self.weekWrapper = weekWrapper;
- }
- self.rContainer = createElement("div", "flatpickr-rContainer");
- self.rContainer.appendChild(buildWeekdays());
- if (!self.daysContainer) {
- self.daysContainer = createElement("div", "flatpickr-days");
- self.daysContainer.tabIndex = -1;
- }
- buildDays();
- self.rContainer.appendChild(self.daysContainer);
- self.innerContainer.appendChild(self.rContainer);
- fragment.appendChild(self.innerContainer);
- }
- if (self.config.enableTime) {
- fragment.appendChild(buildTime());
- }
- toggleClass(self.calendarContainer, "rangeMode", self.config.mode === "range");
- toggleClass(self.calendarContainer, "animate", self.config.animate);
- self.calendarContainer.appendChild(fragment);
- var customAppend = self.config.appendTo !== undefined && self.config.appendTo.nodeType;
- if (self.config.inline || self.config.static) {
- self.calendarContainer.classList.add(self.config.inline ? "inline" : "static");
- if (self.config.inline) {
- if (!customAppend && self.element.parentNode)
- self.element.parentNode.insertBefore(self.calendarContainer, self._input.nextSibling);
- else if (self.config.appendTo !== undefined)
- self.config.appendTo.appendChild(self.calendarContainer);
- }
- if (self.config.static) {
- var wrapper = createElement("div", "flatpickr-wrapper");
- if (self.element.parentNode)
- self.element.parentNode.insertBefore(wrapper, self.element);
- wrapper.appendChild(self.element);
- if (self.altInput)
- wrapper.appendChild(self.altInput);
- wrapper.appendChild(self.calendarContainer);
- }
- }
- if (!self.config.static && !self.config.inline)
- (self.config.appendTo !== undefined
- ? self.config.appendTo
- : window.document.body).appendChild(self.calendarContainer);
- }
- function createDay(className, date, dayNumber, i) {
- var dateIsEnabled = isEnabled(date, true), dayElement = createElement("span", "flatpickr-day " + className, date.getDate().toString());
- dayElement.dateObj = date;
- dayElement.$i = i;
- dayElement.setAttribute("aria-label", self.formatDate(date, self.config.ariaDateFormat));
- if (compareDates(date, self.now) === 0) {
- self.todayDateElem = dayElement;
- dayElement.classList.add("today");
- }
- if (dateIsEnabled) {
- dayElement.tabIndex = -1;
- if (isDateSelected(date)) {
- dayElement.classList.add("selected");
- self.selectedDateElem = dayElement;
- if (self.config.mode === "range") {
- toggleClass(dayElement, "startRange", self.selectedDates[0] &&
- compareDates(date, self.selectedDates[0]) === 0);
- toggleClass(dayElement, "endRange", self.selectedDates[1] &&
- compareDates(date, self.selectedDates[1]) === 0);
- }
- }
- }
- else {
- dayElement.classList.add("disabled");
- if (self.selectedDates[0] &&
- self.minRangeDate &&
- date > self.minRangeDate &&
- date < self.selectedDates[0])
- self.minRangeDate = date;
- else if (self.selectedDates[0] &&
- self.maxRangeDate &&
- date < self.maxRangeDate &&
- date > self.selectedDates[0])
- self.maxRangeDate = date;
- }
- if (self.config.mode === "range") {
- if (isDateInRange(date) && !isDateSelected(date))
- dayElement.classList.add("inRange");
- if (self.selectedDates.length === 1 &&
- self.minRangeDate !== undefined &&
- self.maxRangeDate !== undefined &&
- (date < self.minRangeDate || date > self.maxRangeDate))
- dayElement.classList.add("notAllowed");
- }
- if (self.weekNumbers &&
- className !== "prevMonthDay" &&
- dayNumber % 7 === 1) {
- self.weekNumbers.insertAdjacentHTML("beforeend", "" + self.config.getWeek(date) + "");
- }
- triggerEvent("onDayCreate", dayElement);
- return dayElement;
- }
- function focusOnDay(currentIndex, offset) {
- var newIndex = currentIndex + offset || 0, targetNode = (currentIndex !== undefined
- ? self.days.childNodes[newIndex]
- : self.selectedDateElem ||
- self.todayDateElem ||
- self.days.childNodes[0]);
- var focus = function () {
- targetNode = targetNode || self.days.childNodes[newIndex];
- targetNode.focus();
- if (self.config.mode === "range")
- onMouseOver(targetNode);
- };
- if (targetNode === undefined && offset !== 0) {
- if (offset > 0) {
- self.changeMonth(1, true, true);
- newIndex = newIndex % 42;
- }
- else if (offset < 0) {
- self.changeMonth(-1, true, true);
- newIndex += 42;
- }
- }
- focus();
- }
- function buildDays() {
- if (self.daysContainer === undefined) {
- return;
- }
- var firstOfMonth = (new Date(self.currentYear, self.currentMonth, 1).getDay() -
- self.l10n.firstDayOfWeek +
- 7) %
- 7, isRangeMode = self.config.mode === "range";
- var prevMonthDays = self.utils.getDaysInMonth((self.currentMonth - 1 + 12) % 12);
- var daysInMonth = self.utils.getDaysInMonth(), days = window.document.createDocumentFragment();
- var dayNumber = prevMonthDays + 1 - firstOfMonth, dayIndex = 0;
- if (self.weekNumbers && self.weekNumbers.firstChild)
- self.weekNumbers.textContent = "";
- if (isRangeMode) {
- self.minRangeDate = new Date(self.currentYear, self.currentMonth - 1, dayNumber);
- self.maxRangeDate = new Date(self.currentYear, self.currentMonth + 1, (42 - firstOfMonth) % daysInMonth);
- }
- for (; dayNumber <= prevMonthDays; dayNumber++, dayIndex++) {
- days.appendChild(createDay("prevMonthDay", new Date(self.currentYear, self.currentMonth - 1, dayNumber), dayNumber, dayIndex));
- }
- for (dayNumber = 1; dayNumber <= daysInMonth; dayNumber++, dayIndex++) {
- days.appendChild(createDay("", new Date(self.currentYear, self.currentMonth, dayNumber), dayNumber, dayIndex));
- }
- for (var dayNum = daysInMonth + 1; dayNum <= 42 - firstOfMonth; dayNum++, dayIndex++) {
- days.appendChild(createDay("nextMonthDay", new Date(self.currentYear, self.currentMonth + 1, dayNum % daysInMonth), dayNum, dayIndex));
- }
- if (isRangeMode && self.selectedDates.length === 1 && days.childNodes[0]) {
- self._hidePrevMonthArrow =
- self._hidePrevMonthArrow ||
- (!!self.minRangeDate &&
- self.minRangeDate > days.childNodes[0].dateObj);
- self._hideNextMonthArrow =
- self._hideNextMonthArrow ||
- (!!self.maxRangeDate &&
- self.maxRangeDate <
- new Date(self.currentYear, self.currentMonth + 1, 1));
- }
- else
- updateNavigationCurrentMonth();
- var dayContainer = createElement("div", "dayContainer");
- dayContainer.appendChild(days);
- clearNode(self.daysContainer);
- self.daysContainer.insertBefore(dayContainer, self.daysContainer.firstChild);
- self.days = self.daysContainer.firstChild;
- }
- function buildMonthNav() {
- var monthNavFragment = window.document.createDocumentFragment();
- self.monthNav = createElement("div", "flatpickr-month");
- self.prevMonthNav = createElement("span", "flatpickr-prev-month");
- self.prevMonthNav.innerHTML = self.config.prevArrow;
- self.currentMonthElement = createElement("span", "cur-month");
- var yearInput = createNumberInput("cur-year", { tabindex: "-1" });
- self.currentYearElement = yearInput.childNodes[0];
- if (self.config.minDate)
- self.currentYearElement.setAttribute("data-min", self.config.minDate.getFullYear().toString());
- if (self.config.maxDate) {
- self.currentYearElement.setAttribute("data-max", self.config.maxDate.getFullYear().toString());
- self.currentYearElement.disabled =
- !!self.config.minDate &&
- self.config.minDate.getFullYear() === self.config.maxDate.getFullYear();
- }
- self.nextMonthNav = createElement("span", "flatpickr-next-month");
- self.nextMonthNav.innerHTML = self.config.nextArrow;
- self.navigationCurrentMonth = createElement("div", "flatpickr-current-month");
- self.navigationCurrentMonth.appendChild(self.currentMonthElement);
- self.navigationCurrentMonth.appendChild(yearInput);
- monthNavFragment.appendChild(self.prevMonthNav);
- monthNavFragment.appendChild(self.navigationCurrentMonth);
- monthNavFragment.appendChild(self.nextMonthNav);
- self.monthNav.appendChild(monthNavFragment);
- Object.defineProperty(self, "_hidePrevMonthArrow", {
- get: function () { return self.__hidePrevMonthArrow; },
- set: function (bool) {
- if (self.__hidePrevMonthArrow !== bool)
- self.prevMonthNav.style.display = bool ? "none" : "block";
- self.__hidePrevMonthArrow = bool;
- },
- });
- Object.defineProperty(self, "_hideNextMonthArrow", {
- get: function () { return self.__hideNextMonthArrow; },
- set: function (bool) {
- if (self.__hideNextMonthArrow !== bool)
- self.nextMonthNav.style.display = bool ? "none" : "block";
- self.__hideNextMonthArrow = bool;
- },
- });
- updateNavigationCurrentMonth();
- return self.monthNav;
- }
- function buildTime() {
- self.calendarContainer.classList.add("hasTime");
- if (self.config.noCalendar)
- self.calendarContainer.classList.add("noCalendar");
- self.timeContainer = createElement("div", "flatpickr-time");
- self.timeContainer.tabIndex = -1;
- var separator = createElement("span", "flatpickr-time-separator", ":");
- var hourInput = createNumberInput("flatpickr-hour");
- self.hourElement = hourInput.childNodes[0];
- var minuteInput = createNumberInput("flatpickr-minute");
- self.minuteElement = minuteInput.childNodes[0];
- self.hourElement.tabIndex = self.minuteElement.tabIndex = -1;
- self.hourElement.value = pad(self.latestSelectedDateObj
- ? self.latestSelectedDateObj.getHours()
- : self.config.time_24hr
- ? self.config.defaultHour
- : military2ampm(self.config.defaultHour));
- self.minuteElement.value = pad(self.latestSelectedDateObj
- ? self.latestSelectedDateObj.getMinutes()
- : self.config.defaultMinute);
- self.hourElement.setAttribute("data-step", self.config.hourIncrement.toString());
- self.minuteElement.setAttribute("data-step", self.config.minuteIncrement.toString());
- self.hourElement.setAttribute("data-min", self.config.time_24hr ? "0" : "1");
- self.hourElement.setAttribute("data-max", self.config.time_24hr ? "23" : "12");
- self.minuteElement.setAttribute("data-min", "0");
- self.minuteElement.setAttribute("data-max", "59");
- self.timeContainer.appendChild(hourInput);
- self.timeContainer.appendChild(separator);
- self.timeContainer.appendChild(minuteInput);
- if (self.config.time_24hr)
- self.timeContainer.classList.add("time24hr");
- if (self.config.enableSeconds) {
- self.timeContainer.classList.add("hasSeconds");
- var secondInput = createNumberInput("flatpickr-second");
- self.secondElement = secondInput.childNodes[0];
- self.secondElement.value = pad(self.latestSelectedDateObj
- ? self.latestSelectedDateObj.getSeconds()
- : self.config.defaultSeconds);
- self.secondElement.setAttribute("data-step", self.minuteElement.getAttribute("data-step"));
- self.secondElement.setAttribute("data-min", self.minuteElement.getAttribute("data-min"));
- self.secondElement.setAttribute("data-max", self.minuteElement.getAttribute("data-max"));
- self.timeContainer.appendChild(createElement("span", "flatpickr-time-separator", ":"));
- self.timeContainer.appendChild(secondInput);
- }
- if (!self.config.time_24hr) {
- self.amPM = createElement("span", "flatpickr-am-pm", self.l10n.amPM[int((self.latestSelectedDateObj
- ? self.hourElement.value
- : self.config.defaultHour) > 11)]);
- self.amPM.title = self.l10n.toggleTitle;
- self.amPM.tabIndex = -1;
- self.timeContainer.appendChild(self.amPM);
- }
- return self.timeContainer;
- }
- function buildWeekdays() {
- if (!self.weekdayContainer)
- self.weekdayContainer = createElement("div", "flatpickr-weekdays");
- var firstDayOfWeek = self.l10n.firstDayOfWeek;
- var weekdays = self.l10n.weekdays.shorthand.slice();
- if (firstDayOfWeek > 0 && firstDayOfWeek < weekdays.length) {
- weekdays = weekdays.splice(firstDayOfWeek, weekdays.length).concat(weekdays.splice(0, firstDayOfWeek));
- }
- self.weekdayContainer.innerHTML = "\n \n " + weekdays.join("") + "\n \n ";
- return self.weekdayContainer;
- }
- function buildWeeks() {
- self.calendarContainer.classList.add("hasWeeks");
- var weekWrapper = createElement("div", "flatpickr-weekwrapper");
- weekWrapper.appendChild(createElement("span", "flatpickr-weekday", self.l10n.weekAbbreviation));
- var weekNumbers = createElement("div", "flatpickr-weeks");
- weekWrapper.appendChild(weekNumbers);
- return {
- weekWrapper: weekWrapper,
- weekNumbers: weekNumbers,
- };
- }
- function changeMonth(value, is_offset, from_keyboard) {
- if (is_offset === void 0) { is_offset = true; }
- if (from_keyboard === void 0) { from_keyboard = false; }
- var delta = is_offset ? value : value - self.currentMonth;
- if ((delta < 0 && self._hidePrevMonthArrow) ||
- (delta > 0 && self._hideNextMonthArrow))
- return;
- self.currentMonth += delta;
- if (self.currentMonth < 0 || self.currentMonth > 11) {
- self.currentYear += self.currentMonth > 11 ? 1 : -1;
- self.currentMonth = (self.currentMonth + 12) % 12;
- triggerEvent("onYearChange");
- }
- buildDays();
- triggerEvent("onMonthChange");
- updateNavigationCurrentMonth();
- if (from_keyboard &&
- document.activeElement &&
- document.activeElement.$i) {
- var index = document.activeElement.$i;
- focusOnDay(index, 0);
- }
- }
- function clear(triggerChangeEvent) {
- if (triggerChangeEvent === void 0) { triggerChangeEvent = true; }
- self.input.value = "";
- if (self.altInput)
- self.altInput.value = "";
- if (self.mobileInput)
- self.mobileInput.value = "";
- self.selectedDates = [];
- self.latestSelectedDateObj = undefined;
- self.showTimeInput = false;
- if (self.config.enableTime) {
- if (self.config.minDate !== undefined)
- setHoursFromDate(self.config.minDate);
- else
- setHours(self.config.defaultHour, self.config.defaultMinute, self.config.defaultSeconds);
- }
- self.redraw();
- if (triggerChangeEvent)
- triggerEvent("onChange");
- }
- function close() {
- self.isOpen = false;
- if (!self.isMobile) {
- self.calendarContainer.classList.remove("open");
- self._input.classList.remove("active");
- }
- triggerEvent("onClose");
- }
- function destroy() {
- if (self.config !== undefined)
- triggerEvent("onDestroy");
- for (var i = self._handlers.length; i--;) {
- var h = self._handlers[i];
- h.element.removeEventListener(h.event, h.handler);
- }
- self._handlers = [];
- if (self.mobileInput) {
- if (self.mobileInput.parentNode)
- self.mobileInput.parentNode.removeChild(self.mobileInput);
- self.mobileInput = undefined;
- }
- else if (self.calendarContainer && self.calendarContainer.parentNode)
- self.calendarContainer.parentNode.removeChild(self.calendarContainer);
- if (self.altInput) {
- self.input.type = "text";
- if (self.altInput.parentNode)
- self.altInput.parentNode.removeChild(self.altInput);
- delete self.altInput;
- }
- if (self.input) {
- self.input.type = self.input._type;
- self.input.classList.remove("flatpickr-input");
- self.input.removeAttribute("readonly");
- self.input.value = "";
- }
- [
- "_showTimeInput",
- "latestSelectedDateObj",
- "_hideNextMonthArrow",
- "_hidePrevMonthArrow",
- "__hideNextMonthArrow",
- "__hidePrevMonthArrow",
- "isMobile",
- "isOpen",
- "selectedDateElem",
- "minDateHasTime",
- "maxDateHasTime",
- "days",
- "daysContainer",
- "_input",
- "_positionElement",
- "innerContainer",
- "rContainer",
- "monthNav",
- "todayDateElem",
- "calendarContainer",
- "weekdayContainer",
- "prevMonthNav",
- "nextMonthNav",
- "currentMonthElement",
- "currentYearElement",
- "navigationCurrentMonth",
- "selectedDateElem",
- "config",
- ].forEach(function (k) {
- try {
- delete self[k];
- }
- catch (_) { }
- });
- }
- function isCalendarElem(elem) {
- if (self.config.appendTo && self.config.appendTo.contains(elem))
- return true;
- return self.calendarContainer.contains(elem);
- }
- function documentClick(e) {
- if (self.isOpen && !self.config.inline) {
- var isCalendarElement = isCalendarElem(e.target);
- var isInput = e.target === self.input ||
- e.target === self.altInput ||
- self.element.contains(e.target) ||
- (e.path &&
- e.path.indexOf &&
- (~e.path.indexOf(self.input) ||
- ~e.path.indexOf(self.altInput)));
- var lostFocus = e.type === "blur"
- ? isInput &&
- e.relatedTarget &&
- !isCalendarElem(e.relatedTarget)
- : !isInput && !isCalendarElement;
- var isIgnored = !self.config.ignoredFocusElements.some(function (elem) {
- return elem.contains(e.target);
- });
- if (lostFocus && isIgnored) {
- self.close();
- if (self.config.mode === "range" && self.selectedDates.length === 1) {
- self.clear(false);
- self.redraw();
- }
- }
- }
- }
- function changeYear(newYear) {
- if (!newYear ||
- (self.currentYearElement.getAttribute("data-min") &&
- newYear <
- parseInt(self.currentYearElement.getAttribute("data-min"))) ||
- (self.currentYearElement.getAttribute("data-max") &&
- newYear >
- parseInt(self.currentYearElement.getAttribute("data-max"))))
- return;
- var newYearNum = newYear, isNewYear = self.currentYear !== newYearNum;
- self.currentYear = newYearNum || self.currentYear;
- if (self.config.maxDate &&
- self.currentYear === self.config.maxDate.getFullYear()) {
- self.currentMonth = Math.min(self.config.maxDate.getMonth(), self.currentMonth);
- }
- else if (self.config.minDate &&
- self.currentYear === self.config.minDate.getFullYear()) {
- self.currentMonth = Math.max(self.config.minDate.getMonth(), self.currentMonth);
- }
- if (isNewYear) {
- self.redraw();
- triggerEvent("onYearChange");
- }
- }
- function isEnabled(date, timeless) {
- if (timeless === void 0) { timeless = true; }
- var dateToCheck = self.parseDate(date, undefined, timeless);
- if ((self.config.minDate &&
- dateToCheck &&
- compareDates(dateToCheck, self.config.minDate, timeless !== undefined ? timeless : !self.minDateHasTime) < 0) ||
- (self.config.maxDate &&
- dateToCheck &&
- compareDates(dateToCheck, self.config.maxDate, timeless !== undefined ? timeless : !self.maxDateHasTime) > 0))
- return false;
- if (!self.config.enable.length && !self.config.disable.length)
- return true;
- if (dateToCheck === undefined)
- return false;
- var bool = self.config.enable.length > 0, array = bool ? self.config.enable : self.config.disable;
- for (var i = 0, d = void 0; i < array.length; i++) {
- d = array[i];
- if (typeof d === "function" &&
- d(dateToCheck))
- return bool;
- else if (d instanceof Date &&
- dateToCheck !== undefined &&
- d.getTime() === dateToCheck.getTime())
- return bool;
- else if (typeof d === "string" && dateToCheck !== undefined) {
- var parsed = self.parseDate(d, undefined, true);
- return parsed && parsed.getTime() === dateToCheck.getTime()
- ? bool
- : !bool;
- }
- else if (typeof d === "object" &&
- dateToCheck !== undefined &&
- d.from &&
- d.to &&
- dateToCheck.getTime() >= d.from.getTime() &&
- dateToCheck.getTime() <= d.to.getTime())
- return bool;
- }
- return !bool;
- }
- function onKeyDown(e) {
- var isInput = e.target === self._input;
- var calendarElem = isCalendarElem(e.target);
- var allowInput = self.config.allowInput;
- var allowKeydown = self.isOpen && (!allowInput || !isInput);
- var allowInlineKeydown = self.config.inline && isInput && !allowInput;
- if (e.keyCode === 13 && isInput) {
- if (allowInput) {
- self.setDate(self._input.value, true, e.target === self.altInput
- ? self.config.altFormat
- : self.config.dateFormat);
- return e.target.blur();
- }
- else
- self.open();
- }
- else if (calendarElem || allowKeydown || allowInlineKeydown) {
- var isTimeObj = !!self.timeContainer &&
- self.timeContainer.contains(e.target);
- switch (e.keyCode) {
- case 13:
- if (isTimeObj)
- updateValue();
- else
- selectDate(e);
- break;
- case 27:
- e.preventDefault();
- self.close();
- break;
- case 8:
- case 46:
- if (isInput && !self.config.allowInput)
- self.clear();
- break;
- case 37:
- case 39:
- if (!isTimeObj) {
- e.preventDefault();
- if (self.daysContainer) {
- var delta_1 = e.keyCode === 39 ? 1 : -1;
- if (!e.ctrlKey)
- focusOnDay(e.target.$i, delta_1);
- else
- changeMonth(delta_1, true, true);
- }
- }
- else if (self.hourElement)
- self.hourElement.focus();
- break;
- case 38:
- case 40:
- e.preventDefault();
- var delta = e.keyCode === 40 ? 1 : -1;
- if (self.daysContainer && e.target.$i !== undefined) {
- if (e.ctrlKey) {
- changeYear(self.currentYear - delta);
- focusOnDay(e.target.$i, 0);
- }
- else if (!isTimeObj)
- focusOnDay(e.target.$i, delta * 7);
- }
- else if (self.config.enableTime) {
- if (!isTimeObj && self.hourElement)
- self.hourElement.focus();
- updateTime(e);
- self._debouncedChange();
- }
- break;
- case 9:
- if (e.target === self.hourElement) {
- e.preventDefault();
- self.minuteElement.select();
- }
- else if (e.target === self.minuteElement &&
- (self.secondElement || self.amPM)) {
- e.preventDefault();
- if (self.secondElement !== undefined)
- self.secondElement.focus();
- else if (self.amPM !== undefined)
- self.amPM.focus();
- }
- else if (e.target === self.secondElement && self.amPM) {
- e.preventDefault();
- self.amPM.focus();
- }
- break;
- default:
- break;
- }
- switch (e.key) {
- case self.l10n.amPM[0].charAt(0):
- if (self.amPM !== undefined && e.target === self.amPM) {
- self.amPM.textContent = self.l10n.amPM[0];
- setHoursFromInputs();
- updateValue();
- }
- break;
- case self.l10n.amPM[1].charAt(0):
- if (self.amPM !== undefined && e.target === self.amPM) {
- self.amPM.textContent = self.l10n.amPM[1];
- setHoursFromInputs();
- updateValue();
- }
- break;
- default:
- break;
- }
- triggerEvent("onKeyDown", e);
- }
- }
- function onMouseOver(elem) {
- if (self.selectedDates.length !== 1 ||
- !elem.classList.contains("flatpickr-day") ||
- elem.classList.contains("disabled") ||
- self.minRangeDate === undefined ||
- self.maxRangeDate === undefined)
- return;
- var hoverDate = elem.dateObj, initialDate = self.parseDate(self.selectedDates[0], undefined, true), rangeStartDate = Math.min(hoverDate.getTime(), self.selectedDates[0].getTime()), rangeEndDate = Math.max(hoverDate.getTime(), self.selectedDates[0].getTime()), containsDisabled = false;
- for (var t = rangeStartDate; t < rangeEndDate; t += duration.DAY) {
- if (!isEnabled(new Date(t))) {
- containsDisabled = true;
- break;
- }
- }
- var _loop_1 = function (i, date) {
- var timestamp = date.getTime();
- var outOfRange = timestamp < self.minRangeDate.getTime() ||
- timestamp > self.maxRangeDate.getTime(), dayElem = self.days.childNodes[i];
- if (outOfRange) {
- dayElem.classList.add("notAllowed");
- ["inRange", "startRange", "endRange"].forEach(function (c) {
- dayElem.classList.remove(c);
- });
- return "continue";
- }
- else if (containsDisabled && !outOfRange)
- return "continue";
- ["startRange", "inRange", "endRange", "notAllowed"].forEach(function (c) {
- dayElem.classList.remove(c);
- });
- var minRangeDate = Math.max(self.minRangeDate.getTime(), rangeStartDate), maxRangeDate = Math.min(self.maxRangeDate.getTime(), rangeEndDate);
- elem.classList.add(hoverDate < self.selectedDates[0] ? "startRange" : "endRange");
- if (initialDate < hoverDate && timestamp === initialDate.getTime())
- dayElem.classList.add("startRange");
- else if (initialDate > hoverDate && timestamp === initialDate.getTime())
- dayElem.classList.add("endRange");
- if (timestamp >= minRangeDate && timestamp <= maxRangeDate)
- dayElem.classList.add("inRange");
- };
- for (var i = 0, date = self.days.childNodes[i].dateObj; i < 42; i++, date =
- self.days.childNodes[i] &&
- self.days.childNodes[i].dateObj) {
- _loop_1(i, date);
- }
- }
- function onResize() {
- if (self.isOpen && !self.config.static && !self.config.inline)
- positionCalendar();
- }
- function open(e, positionElement) {
- if (positionElement === void 0) { positionElement = self._input; }
- if (self.isMobile) {
- if (e) {
- e.preventDefault();
- e.target && e.target.blur();
- }
- setTimeout(function () {
- self.mobileInput !== undefined && self.mobileInput.click();
- }, 0);
- triggerEvent("onOpen");
- return;
- }
- if (self._input.disabled || self.config.inline)
- return;
- var wasOpen = self.isOpen;
- self.isOpen = true;
- if (!wasOpen) {
- self.calendarContainer.classList.add("open");
- self._input.classList.add("active");
- triggerEvent("onOpen");
- positionCalendar(positionElement);
- }
- }
- function minMaxDateSetter(type) {
- return function (date) {
- var dateObj = (self.config["_" + type + "Date"] = self.parseDate(date, self.config.dateFormat));
- var inverseDateObj = self.config["_" + (type === "min" ? "max" : "min") + "Date"];
- if (dateObj !== undefined) {
- self[type === "min" ? "minDateHasTime" : "maxDateHasTime"] =
- dateObj.getHours() > 0 ||
- dateObj.getMinutes() > 0 ||
- dateObj.getSeconds() > 0;
- }
- if (self.selectedDates) {
- self.selectedDates = self.selectedDates.filter(function (d) { return isEnabled(d); });
- if (!self.selectedDates.length && type === "min")
- setHoursFromDate(dateObj);
- updateValue();
- }
- if (self.daysContainer) {
- redraw();
- if (dateObj !== undefined)
- self.currentYearElement[type] = dateObj.getFullYear().toString();
- else
- self.currentYearElement.removeAttribute(type);
- self.currentYearElement.disabled =
- !!inverseDateObj &&
- dateObj !== undefined &&
- inverseDateObj.getFullYear() === dateObj.getFullYear();
- }
- };
- }
- function parseConfig() {
- var boolOpts = [
- "wrap",
- "weekNumbers",
- "allowInput",
- "clickOpens",
- "time_24hr",
- "enableTime",
- "noCalendar",
- "altInput",
- "shorthandCurrentMonth",
- "inline",
- "static",
- "enableSeconds",
- "disableMobile",
- ];
- var hooks = [
- "onChange",
- "onClose",
- "onDayCreate",
- "onDestroy",
- "onKeyDown",
- "onMonthChange",
- "onOpen",
- "onParseConfig",
- "onReady",
- "onValueUpdate",
- "onYearChange",
- "onPreCalendarPosition",
- ];
- var userConfig = __assign({}, instanceConfig, JSON.parse(JSON.stringify(element.dataset || {})));
- var formats$$1 = {};
- self.config.parseDate = userConfig.parseDate;
- self.config.formatDate = userConfig.formatDate;
- Object.defineProperty(self.config, "enable", {
- get: function () { return self.config._enable || []; },
- set: function (dates) {
- self.config._enable = parseDateRules(dates);
- },
- });
- Object.defineProperty(self.config, "disable", {
- get: function () { return self.config._disable || []; },
- set: function (dates) {
- self.config._disable = parseDateRules(dates);
- },
- });
- if (!userConfig.dateFormat && userConfig.enableTime) {
- formats$$1.dateFormat = userConfig.noCalendar
- ? "H:i" + (userConfig.enableSeconds ? ":S" : "")
- : flatpickr.defaultConfig.dateFormat +
- " H:i" +
- (userConfig.enableSeconds ? ":S" : "");
- }
- if (userConfig.altInput && userConfig.enableTime && !userConfig.altFormat) {
- formats$$1.altFormat = userConfig.noCalendar
- ? "h:i" + (userConfig.enableSeconds ? ":S K" : " K")
- : flatpickr.defaultConfig.altFormat +
- (" h:i" + (userConfig.enableSeconds ? ":S" : "") + " K");
- }
- Object.defineProperty(self.config, "minDate", {
- get: function () { return self.config._minDate; },
- set: minMaxDateSetter("min"),
- });
- Object.defineProperty(self.config, "maxDate", {
- get: function () { return self.config._maxDate; },
- set: minMaxDateSetter("max"),
- });
- var minMaxTimeSetter = function (type) { return function (val) {
- self.config[type === "min" ? "_minTime" : "_maxTime"] = self.parseDate(val, "H:i");
- }; };
- Object.defineProperty(self.config, "minTime", {
- get: function () { return self.config._minTime; },
- set: minMaxTimeSetter("min"),
- });
- Object.defineProperty(self.config, "maxTime", {
- get: function () { return self.config._maxTime; },
- set: minMaxTimeSetter("max"),
- });
- Object.assign(self.config, formats$$1, userConfig);
- for (var i = 0; i < boolOpts.length; i++)
- self.config[boolOpts[i]] =
- self.config[boolOpts[i]] === true ||
- self.config[boolOpts[i]] === "true";
- for (var i = hooks.length; i--;) {
- if (self.config[hooks[i]] !== undefined) {
- self.config[hooks[i]] = arrayify(self.config[hooks[i]] || []).map(bindToInstance);
- }
- }
- for (var i = 0; i < self.config.plugins.length; i++) {
- var pluginConf = self.config.plugins[i](self) || {};
- for (var key in pluginConf) {
- if (~hooks.indexOf(key)) {
- self.config[key] = arrayify(pluginConf[key])
- .map(bindToInstance)
- .concat(self.config[key]);
- }
- else if (typeof userConfig[key] === "undefined")
- self.config[key] = pluginConf[key];
- }
- }
- self.isMobile =
- !self.config.disableMobile &&
- !self.config.inline &&
- self.config.mode === "single" &&
- !self.config.disable.length &&
- !self.config.enable.length &&
- !self.config.weekNumbers &&
- /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
- triggerEvent("onParseConfig");
- }
- function setupLocale() {
- if (typeof self.config.locale !== "object" &&
- typeof flatpickr.l10ns[self.config.locale] === "undefined")
- self.config.errorHandler(new Error("flatpickr: invalid locale " + self.config.locale));
- self.l10n = __assign({}, flatpickr.l10ns.default, (typeof self.config.locale === "object"
- ? self.config.locale
- : self.config.locale !== "default"
- ? flatpickr.l10ns[self.config.locale]
- : undefined));
- tokenRegex.K = "(" + self.l10n.amPM[0] + "|" + self.l10n.amPM[1] + "|" + self.l10n.amPM[0].toLowerCase() + "|" + self.l10n.amPM[1].toLowerCase() + ")";
- self.formatDate = createDateFormatter(self);
- }
- function positionCalendar(customPositionElement) {
- if (self.calendarContainer === undefined)
- return;
- triggerEvent("onPreCalendarPosition");
- var positionElement = customPositionElement || self._positionElement;
- var calendarHeight = Array.prototype.reduce.call(self.calendarContainer.children, function (acc, child) { return acc + child.offsetHeight; }, 0), calendarWidth = self.calendarContainer.offsetWidth, configPos = self.config.position, inputBounds = positionElement.getBoundingClientRect(), distanceFromBottom = window.innerHeight - inputBounds.bottom, showOnTop = configPos === "above" ||
- (configPos !== "below" &&
- distanceFromBottom < calendarHeight &&
- inputBounds.top > calendarHeight);
- var top = window.pageYOffset +
- inputBounds.top +
- (!showOnTop ? positionElement.offsetHeight + 2 : -calendarHeight - 2);
- toggleClass(self.calendarContainer, "arrowTop", !showOnTop);
- toggleClass(self.calendarContainer, "arrowBottom", showOnTop);
- if (self.config.inline)
- return;
- var left = window.pageXOffset + inputBounds.left;
- var right = window.document.body.offsetWidth - inputBounds.right;
- var rightMost = left + calendarWidth > window.document.body.offsetWidth;
- toggleClass(self.calendarContainer, "rightMost", rightMost);
- if (self.config.static)
- return;
- self.calendarContainer.style.top = top + "px";
- if (!rightMost) {
- self.calendarContainer.style.left = left + "px";
- self.calendarContainer.style.right = "auto";
- }
- else {
- self.calendarContainer.style.left = "auto";
- self.calendarContainer.style.right = right + "px";
- }
- }
- function redraw() {
- if (self.config.noCalendar || self.isMobile)
- return;
- buildWeekdays();
- updateNavigationCurrentMonth();
- buildDays();
- }
- function focusAndClose() {
- self._input.focus();
- if (window.navigator.userAgent.indexOf("MSIE") !== -1 ||
- navigator.msMaxTouchPoints !== undefined) {
- setTimeout(self.close, 0);
- }
- else {
- self.close();
- }
- }
- function selectDate(e) {
- e.preventDefault();
- e.stopPropagation();
- var isSelectable = function (day) {
- return day.classList &&
- day.classList.contains("flatpickr-day") &&
- !day.classList.contains("disabled") &&
- !day.classList.contains("notAllowed");
- };
- var t = findParent(e.target, isSelectable);
- if (t === undefined)
- return;
- var target = t;
- var selectedDate = (self.latestSelectedDateObj = new Date(target.dateObj.getTime()));
- var shouldChangeMonth = selectedDate.getMonth() !== self.currentMonth &&
- self.config.mode !== "range";
- self.selectedDateElem = target;
- if (self.config.mode === "single")
- self.selectedDates = [selectedDate];
- else if (self.config.mode === "multiple") {
- var selectedIndex = isDateSelected(selectedDate);
- if (selectedIndex)
- self.selectedDates.splice(parseInt(selectedIndex), 1);
- else
- self.selectedDates.push(selectedDate);
- }
- else if (self.config.mode === "range") {
- if (self.selectedDates.length === 2)
- self.clear();
- self.selectedDates.push(selectedDate);
- if (compareDates(selectedDate, self.selectedDates[0], true) !== 0)
- self.selectedDates.sort(function (a, b) { return a.getTime() - b.getTime(); });
- }
- setHoursFromInputs();
- if (shouldChangeMonth) {
- var isNewYear = self.currentYear !== selectedDate.getFullYear();
- self.currentYear = selectedDate.getFullYear();
- self.currentMonth = selectedDate.getMonth();
- if (isNewYear)
- triggerEvent("onYearChange");
- triggerEvent("onMonthChange");
- }
- buildDays();
- if (self.config.minDate &&
- self.minDateHasTime &&
- self.config.enableTime &&
- compareDates(selectedDate, self.config.minDate) === 0)
- setHoursFromDate(self.config.minDate);
- updateValue();
- if (self.config.enableTime)
- setTimeout(function () { return (self.showTimeInput = true); }, 50);
- if (self.config.mode === "range") {
- if (self.selectedDates.length === 1) {
- onMouseOver(target);
- self._hidePrevMonthArrow =
- self._hidePrevMonthArrow ||
- (self.minRangeDate !== undefined &&
- self.minRangeDate >
- self.days.childNodes[0].dateObj);
- self._hideNextMonthArrow =
- self._hideNextMonthArrow ||
- (self.maxRangeDate !== undefined &&
- self.maxRangeDate <
- new Date(self.currentYear, self.currentMonth + 1, 1));
- }
- else
- updateNavigationCurrentMonth();
- }
- if (!shouldChangeMonth)
- focusOnDay(target.$i, 0);
- else
- self.selectedDateElem && self.selectedDateElem.focus();
- if (self.hourElement !== undefined)
- setTimeout(function () { return self.hourElement !== undefined && self.hourElement.select(); }, 451);
- if (self.config.closeOnSelect) {
- var single = self.config.mode === "single" && !self.config.enableTime;
- var range = self.config.mode === "range" &&
- self.selectedDates.length === 2 &&
- !self.config.enableTime;
- if (single || range) {
- focusAndClose();
- }
- }
- triggerChange();
- }
- var CALLBACKS = {
- locale: [setupLocale],
- };
- function set(option, value) {
- if (option !== null && typeof option === "object")
- Object.assign(self.config, option);
- else {
- self.config[option] = value;
- if (CALLBACKS[option] !== undefined)
- CALLBACKS[option].forEach(function (x) { return x(); });
- }
- self.redraw();
- jumpToDate();
- }
- function setSelectedDate(inputDate, format) {
- var dates = [];
- if (inputDate instanceof Array)
- dates = inputDate.map(function (d) { return self.parseDate(d, format); });
- else if (inputDate instanceof Date || typeof inputDate === "number")
- dates = [self.parseDate(inputDate, format)];
- else if (typeof inputDate === "string") {
- switch (self.config.mode) {
- case "single":
- dates = [self.parseDate(inputDate, format)];
- break;
- case "multiple":
- dates = inputDate
- .split(self.config.conjunction)
- .map(function (date) { return self.parseDate(date, format); });
- break;
- case "range":
- dates = inputDate
- .split(self.l10n.rangeSeparator)
- .map(function (date) { return self.parseDate(date, format); });
- break;
- default:
- break;
- }
- }
- else
- self.config.errorHandler(new Error("Invalid date supplied: " + JSON.stringify(inputDate)));
- self.selectedDates = dates.filter(function (d) { return d instanceof Date && isEnabled(d, false); });
- if (self.config.mode === "range")
- self.selectedDates.sort(function (a, b) { return a.getTime() - b.getTime(); });
- }
- function setDate(date, triggerChange, format) {
- if (triggerChange === void 0) { triggerChange = false; }
- if (format === void 0) { format = self.config.dateFormat; }
- if (date !== 0 && !date)
- return self.clear(triggerChange);
- setSelectedDate(date, format);
- self.showTimeInput = self.selectedDates.length > 0;
- self.latestSelectedDateObj = self.selectedDates[0];
- self.redraw();
- jumpToDate();
- setHoursFromDate();
- updateValue(triggerChange);
- if (triggerChange)
- triggerEvent("onChange");
- }
- function parseDateRules(arr) {
- return arr
- .map(function (rule) {
- if (typeof rule === "string" ||
- typeof rule === "number" ||
- rule instanceof Date) {
- return self.parseDate(rule, undefined, true);
- }
- else if (rule &&
- typeof rule === "object" &&
- rule.from &&
- rule.to)
- return {
- from: self.parseDate(rule.from, undefined),
- to: self.parseDate(rule.to, undefined),
- };
- return rule;
- })
- .filter(function (x) { return x; });
- }
- function setupDates() {
- self.selectedDates = [];
- self.now = new Date();
- var preloadedDate = self.config.defaultDate || self.input.value;
- if (preloadedDate)
- setSelectedDate(preloadedDate, self.config.dateFormat);
- var initialDate = self.selectedDates.length
- ? self.selectedDates[0]
- : self.config.minDate &&
- self.config.minDate.getTime() > self.now.getTime()
- ? self.config.minDate
- : self.config.maxDate &&
- self.config.maxDate.getTime() < self.now.getTime()
- ? self.config.maxDate
- : self.now;
- self.currentYear = initialDate.getFullYear();
- self.currentMonth = initialDate.getMonth();
- if (self.selectedDates.length)
- self.latestSelectedDateObj = self.selectedDates[0];
- if (self.config.minTime !== undefined)
- self.config.minTime = self.parseDate(self.config.minTime, "H:i");
- if (self.config.maxTime !== undefined)
- self.config.maxTime = self.parseDate(self.config.maxTime, "H:i");
- self.minDateHasTime =
- !!self.config.minDate &&
- (self.config.minDate.getHours() > 0 ||
- self.config.minDate.getMinutes() > 0 ||
- self.config.minDate.getSeconds() > 0);
- self.maxDateHasTime =
- !!self.config.maxDate &&
- (self.config.maxDate.getHours() > 0 ||
- self.config.maxDate.getMinutes() > 0 ||
- self.config.maxDate.getSeconds() > 0);
- Object.defineProperty(self, "showTimeInput", {
- get: function () { return self._showTimeInput; },
- set: function (bool) {
- self._showTimeInput = bool;
- if (self.calendarContainer)
- toggleClass(self.calendarContainer, "showTimeInput", bool);
- self.isOpen && positionCalendar();
- },
- });
- }
- function setupInputs() {
- self.input = self.config.wrap
- ? element.querySelector("[data-input]")
- : element;
- if (!self.input) {
- self.config.errorHandler(new Error("Invalid input element specified"));
- return;
- }
- self.input._type = self.input.type;
- self.input.type = "text";
- self.input.classList.add("flatpickr-input");
- self._input = self.input;
- if (self.config.altInput) {
- self.altInput = createElement(self.input.nodeName, self.input.className + " " + self.config.altInputClass);
- self._input = self.altInput;
- self.altInput.placeholder = self.input.placeholder;
- self.altInput.disabled = self.input.disabled;
- self.altInput.required = self.input.required;
- self.altInput.tabIndex = self.input.tabIndex;
- self.altInput.type = "text";
- self.input.type = "hidden";
- if (!self.config.static && self.input.parentNode)
- self.input.parentNode.insertBefore(self.altInput, self.input.nextSibling);
- }
- if (!self.config.allowInput)
- self._input.setAttribute("readonly", "readonly");
- self._positionElement = self.config.positionElement || self._input;
- }
- function setupMobile() {
- var inputType = self.config.enableTime
- ? self.config.noCalendar ? "time" : "datetime-local"
- : "date";
- self.mobileInput = createElement("input", self.input.className + " flatpickr-mobile");
- self.mobileInput.step = self.input.getAttribute("step") || "any";
- self.mobileInput.tabIndex = 1;
- self.mobileInput.type = inputType;
- self.mobileInput.disabled = self.input.disabled;
- self.mobileInput.required = self.input.required;
- self.mobileInput.placeholder = self.input.placeholder;
- self.mobileFormatStr =
- inputType === "datetime-local"
- ? "Y-m-d\\TH:i:S"
- : inputType === "date" ? "Y-m-d" : "H:i:S";
- if (self.selectedDates.length) {
- self.mobileInput.defaultValue = self.mobileInput.value = self.formatDate(self.selectedDates[0], self.mobileFormatStr);
- }
- if (self.config.minDate)
- self.mobileInput.min = self.formatDate(self.config.minDate, "Y-m-d");
- if (self.config.maxDate)
- self.mobileInput.max = self.formatDate(self.config.maxDate, "Y-m-d");
- self.input.type = "hidden";
- if (self.altInput !== undefined)
- self.altInput.type = "hidden";
- try {
- if (self.input.parentNode)
- self.input.parentNode.insertBefore(self.mobileInput, self.input.nextSibling);
- }
- catch (_a) { }
- bind(self.mobileInput, "change", function (e) {
- self.setDate(e.target.value, false, self.mobileFormatStr);
- triggerEvent("onChange");
- triggerEvent("onClose");
- });
- }
- function toggle() {
- if (self.isOpen)
- return self.close();
- self.open();
- }
- function triggerEvent(event, data) {
- var hooks = self.config[event];
- if (hooks !== undefined && hooks.length > 0) {
- for (var i = 0; hooks[i] && i < hooks.length; i++)
- hooks[i](self.selectedDates, self.input.value, self, data);
- }
- if (event === "onChange") {
- self.input.dispatchEvent(createEvent("change"));
- self.input.dispatchEvent(createEvent("input"));
- }
- }
- function createEvent(name) {
- var e = document.createEvent("Event");
- e.initEvent(name, true, true);
- return e;
- }
- function isDateSelected(date) {
- for (var i = 0; i < self.selectedDates.length; i++) {
- if (compareDates(self.selectedDates[i], date) === 0)
- return "" + i;
- }
- return false;
- }
- function isDateInRange(date) {
- if (self.config.mode !== "range" || self.selectedDates.length < 2)
- return false;
- return (compareDates(date, self.selectedDates[0]) >= 0 &&
- compareDates(date, self.selectedDates[1]) <= 0);
- }
- function updateNavigationCurrentMonth() {
- if (self.config.noCalendar || self.isMobile || !self.monthNav)
- return;
- self.currentMonthElement.textContent =
- monthToStr(self.currentMonth, self.config.shorthandCurrentMonth, self.l10n) + " ";
- self.currentYearElement.value = self.currentYear.toString();
- self._hidePrevMonthArrow =
- self.config.minDate !== undefined &&
- (self.currentYear === self.config.minDate.getFullYear()
- ? self.currentMonth <= self.config.minDate.getMonth()
- : self.currentYear < self.config.minDate.getFullYear());
- self._hideNextMonthArrow =
- self.config.maxDate !== undefined &&
- (self.currentYear === self.config.maxDate.getFullYear()
- ? self.currentMonth + 1 > self.config.maxDate.getMonth()
- : self.currentYear > self.config.maxDate.getFullYear());
- }
- function updateValue(triggerChange) {
- if (triggerChange === void 0) { triggerChange = true; }
- if (!self.selectedDates.length)
- return self.clear(triggerChange);
- if (self.mobileInput !== undefined && self.mobileFormatStr) {
- self.mobileInput.value =
- self.latestSelectedDateObj !== undefined
- ? self.formatDate(self.latestSelectedDateObj, self.mobileFormatStr)
- : "";
- }
- var joinChar = self.config.mode !== "range"
- ? self.config.conjunction
- : self.l10n.rangeSeparator;
- self.input.value = self.selectedDates
- .map(function (dObj) { return self.formatDate(dObj, self.config.dateFormat); })
- .join(joinChar);
- if (self.altInput !== undefined) {
- self.altInput.value = self.selectedDates
- .map(function (dObj) { return self.formatDate(dObj, self.config.altFormat); })
- .join(joinChar);
- }
- if (triggerChange !== false)
- triggerEvent("onValueUpdate");
- }
- function onMonthNavClick(e) {
- e.preventDefault();
- var isPrevMonth = self.prevMonthNav.contains(e.target);
- var isNextMonth = self.nextMonthNav.contains(e.target);
- if (isPrevMonth || isNextMonth) {
- changeMonth(isPrevMonth ? -1 : 1);
- }
- else if (e.target === self.currentYearElement) {
- self.currentYearElement.select();
- }
- else if (e.target.className === "arrowUp") {
- self.changeYear(self.currentYear + 1);
- }
- else if (e.target.className === "arrowDown") {
- self.changeYear(self.currentYear - 1);
- }
- }
- function timeWrapper(e) {
- e.preventDefault();
- var isKeyDown = e.type === "keydown", input = e.target;
- if (self.amPM !== undefined && e.target === self.amPM) {
- self.amPM.textContent =
- self.l10n.amPM[int(self.amPM.textContent === self.l10n.amPM[0])];
- }
- var min = parseFloat(input.getAttribute("data-min")), max = parseFloat(input.getAttribute("data-max")), step = parseFloat(input.getAttribute("data-step")), curValue = parseInt(input.value, 10), delta = e.delta ||
- (isKeyDown ? (e.which === 38 ? 1 : -1) : 0);
- var newValue = curValue + step * delta;
- if (typeof input.value !== "undefined" && input.value.length === 2) {
- var isHourElem = input === self.hourElement, isMinuteElem = input === self.minuteElement;
- if (newValue < min) {
- newValue =
- max +
- newValue +
- int(!isHourElem) +
- (int(isHourElem) && int(!self.amPM));
- if (isMinuteElem)
- incrementNumInput(undefined, -1, self.hourElement);
- }
- else if (newValue > max) {
- newValue =
- input === self.hourElement ? newValue - max - int(!self.amPM) : min;
- if (isMinuteElem)
- incrementNumInput(undefined, 1, self.hourElement);
- }
- if (self.amPM &&
- isHourElem &&
- (step === 1
- ? newValue + curValue === 23
- : Math.abs(newValue - curValue) > step)) {
- self.amPM.textContent =
- self.l10n.amPM[int(self.amPM.textContent === self.l10n.amPM[0])];
- }
- input.value = pad(newValue);
- }
- }
- init();
- return self;
-}
-function _flatpickr(nodeList, config) {
- var nodes = Array.prototype.slice.call(nodeList);
- var instances = [];
- for (var i = 0; i < nodes.length; i++) {
- var node = nodes[i];
- try {
- if (node.getAttribute("data-fp-omit") !== null)
- continue;
- if (node._flatpickr !== undefined) {
- node._flatpickr.destroy();
- node._flatpickr = undefined;
- }
- node._flatpickr = FlatpickrInstance(node, config || {});
- instances.push(node._flatpickr);
- }
- catch (e) {
- console.error(e);
- }
- }
- return instances.length === 1 ? instances[0] : instances;
-}
-if (typeof HTMLElement !== "undefined") {
- HTMLCollection.prototype.flatpickr = NodeList.prototype.flatpickr = function (config) {
- return _flatpickr(this, config);
- };
- HTMLElement.prototype.flatpickr = function (config) {
- return _flatpickr([this], config);
- };
-}
-var flatpickr;
-flatpickr = function (selector, config) {
- if (selector instanceof NodeList)
- return _flatpickr(selector, config);
- else if (typeof selector === "string")
- return _flatpickr(window.document.querySelectorAll(selector), config);
- return _flatpickr([selector], config);
-};
-if (typeof window === "object")
- window.flatpickr = flatpickr;
-flatpickr.defaultConfig = defaults;
-flatpickr.l10ns = {
- en: __assign({}, english),
- default: __assign({}, english),
-};
-flatpickr.localize = function (l10n) {
- flatpickr.l10ns.default = __assign({}, flatpickr.l10ns.default, l10n);
-};
-flatpickr.setDefaults = function (config) {
- flatpickr.defaultConfig = __assign({}, flatpickr.defaultConfig, config);
-};
-flatpickr.parseDate = createDateParser({});
-flatpickr.formatDate = createDateFormatter({});
-flatpickr.compareDates = compareDates;
-if (typeof jQuery !== "undefined") {
- jQuery.fn.flatpickr = function (config) {
- return _flatpickr(this, config);
- };
-}
-Date.prototype.fp_incr = function (days) {
- return new Date(this.getFullYear(), this.getMonth(), this.getDate() + (typeof days === "string" ? parseInt(days, 10) : days));
-};
+var DEBOUNCED_CHANGE_MS = 300;
+function FlatpickrInstance(element, instanceConfig) {
+ var self = {
+ config: __assign({}, flatpickr.defaultConfig),
+ l10n: english,
+ };
+ self.parseDate = createDateParser({ config: self.config, l10n: self.l10n });
+ self._handlers = [];
+ self._bind = bind;
+ self._setHoursFromDate = setHoursFromDate;
+ self.changeMonth = changeMonth;
+ self.changeYear = changeYear;
+ self.clear = clear;
+ self.close = close;
+ self._createElement = createElement;
+ self.destroy = destroy;
+ self.isEnabled = isEnabled;
+ self.jumpToDate = jumpToDate;
+ self.open = open;
+ self.redraw = redraw;
+ self.set = set;
+ self.setDate = setDate;
+ self.toggle = toggle;
+ function setupHelperFunctions() {
+ self.utils = {
+ getDaysInMonth: function (month, yr) {
+ if (month === void 0) { month = self.currentMonth; }
+ if (yr === void 0) { yr = self.currentYear; }
+ if (month === 1 && ((yr % 4 === 0 && yr % 100 !== 0) || yr % 400 === 0))
+ return 29;
+ return self.l10n.daysInMonth[month];
+ },
+ };
+ }
+ function init() {
+ self.element = self.input = element;
+ self.isOpen = false;
+ parseConfig();
+ setupLocale();
+ setupInputs();
+ setupDates();
+ setupHelperFunctions();
+ if (!self.isMobile)
+ build();
+ bindEvents();
+ if (self.selectedDates.length || self.config.noCalendar) {
+ if (self.config.enableTime) {
+ setHoursFromDate(self.config.noCalendar
+ ? self.latestSelectedDateObj || self.config.minDate
+ : undefined);
+ }
+ updateValue(false);
+ }
+ self.showTimeInput =
+ self.selectedDates.length > 0 || self.config.noCalendar;
+ if (self.weekWrapper !== undefined && self.daysContainer !== undefined) {
+ self.calendarContainer.style.visibility = "hidden";
+ self.calendarContainer.style.display = "block";
+ self.calendarContainer.style.width =
+ self.daysContainer.offsetWidth + self.weekWrapper.offsetWidth + "px";
+ self.calendarContainer.style.visibility = "visible";
+ self.calendarContainer.style.display = null;
+ }
+ var isSafari = /^((?!chrome|android).)*safari/i.test(navigator.userAgent);
+ if (!self.isMobile && isSafari) {
+ positionCalendar();
+ }
+ triggerEvent("onReady");
+ }
+ function bindToInstance(fn) {
+ return fn.bind(self);
+ }
+ function updateTime(e) {
+ if (self.config.noCalendar && self.selectedDates.length === 0) {
+ self.setDate(self.config.minDate !== undefined
+ ? new Date(self.config.minDate.getTime())
+ : new Date().setHours(self.config.defaultHour, self.config.defaultMinute, self.config.defaultSeconds, 0), false);
+ setHoursFromInputs();
+ updateValue();
+ }
+ timeWrapper(e);
+ if (self.selectedDates.length === 0)
+ return;
+ if (e.type !== "input") {
+ setHoursFromInputs();
+ updateValue();
+ }
+ else {
+ setTimeout(function () {
+ setHoursFromInputs();
+ updateValue();
+ }, DEBOUNCED_CHANGE_MS);
+ }
+ }
+ function ampm2military(hour, amPM) {
+ return hour % 12 + 12 * int(amPM === self.l10n.amPM[1]);
+ }
+ function military2ampm(hour) {
+ switch (hour % 24) {
+ case 0:
+ case 12:
+ return 12;
+ default:
+ return hour % 12;
+ }
+ }
+ function setHoursFromInputs() {
+ if (self.hourElement === undefined || self.minuteElement === undefined)
+ return;
+ var hours = (parseInt(self.hourElement.value.slice(-2), 10) || 0) % 24, minutes = (parseInt(self.minuteElement.value, 10) || 0) % 60, seconds = self.secondElement !== undefined
+ ? (parseInt(self.secondElement.value, 10) || 0) % 60
+ : 0;
+ if (self.amPM !== undefined)
+ hours = ampm2military(hours, self.amPM.textContent);
+ var limitMinHours = self.config.minTime !== undefined ||
+ (self.config.minDate &&
+ self.minDateHasTime &&
+ self.latestSelectedDateObj &&
+ compareDates(self.latestSelectedDateObj, self.config.minDate, true) ===
+ 0);
+ var limitMaxHours = self.config.maxTime !== undefined ||
+ (self.config.maxDate &&
+ self.maxDateHasTime &&
+ self.latestSelectedDateObj &&
+ compareDates(self.latestSelectedDateObj, self.config.maxDate, true) ===
+ 0);
+ if (limitMaxHours) {
+ var maxTime = self.config.maxTime !== undefined
+ ? self.config.maxTime
+ : self.config.maxDate;
+ hours = Math.min(hours, maxTime.getHours());
+ if (hours === maxTime.getHours())
+ minutes = Math.min(minutes, maxTime.getMinutes());
+ }
+ if (limitMinHours) {
+ var minTime = self.config.minTime !== undefined
+ ? self.config.minTime
+ : self.config.minDate;
+ hours = Math.max(hours, minTime.getHours());
+ if (hours === minTime.getHours())
+ minutes = Math.max(minutes, minTime.getMinutes());
+ }
+ setHours(hours, minutes, seconds);
+ }
+ function setHoursFromDate(dateObj) {
+ var date = dateObj || self.latestSelectedDateObj;
+ if (date)
+ setHours(date.getHours(), date.getMinutes(), date.getSeconds());
+ }
+ function setHours(hours, minutes, seconds) {
+ if (self.latestSelectedDateObj !== undefined) {
+ self.latestSelectedDateObj.setHours(hours % 24, minutes, seconds || 0, 0);
+ }
+ if (!self.hourElement || !self.minuteElement || self.isMobile)
+ return;
+ self.hourElement.value = pad(!self.config.time_24hr
+ ? (12 + hours) % 12 + 12 * int(hours % 12 === 0)
+ : hours);
+ self.minuteElement.value = pad(minutes);
+ if (self.amPM !== undefined)
+ self.amPM.textContent = self.l10n.amPM[int(hours >= 12)];
+ if (self.secondElement !== undefined)
+ self.secondElement.value = pad(seconds);
+ }
+ function onYearInput(event) {
+ var year = parseInt(event.target.value) + (event.delta || 0);
+ if (year.toString().length === 4 || event.key === "Enter") {
+ self.currentYearElement.blur();
+ if (!/[^\d]/.test(year.toString()))
+ changeYear(year);
+ }
+ }
+ function bind(element, event, handler, options) {
+ if (event instanceof Array)
+ return event.forEach(function (ev) { return bind(element, ev, handler, options); });
+ if (element instanceof Array)
+ return element.forEach(function (el) { return bind(el, event, handler, options); });
+ element.addEventListener(event, handler, options);
+ self._handlers.push({ element: element, event: event, handler: handler });
+ }
+ function onClick(handler) {
+ return function (evt) {
+ evt.which === 1 && handler(evt);
+ };
+ }
+ function triggerChange() {
+ triggerEvent("onChange");
+ }
+ function bindEvents() {
+ if (self.config.wrap) {
+ ["open", "close", "toggle", "clear"].forEach(function (evt) {
+ Array.prototype.forEach.call(self.element.querySelectorAll("[data-" + evt + "]"), function (el) {
+ return bind(el, "click", self[evt]);
+ });
+ });
+ }
+ if (self.isMobile) {
+ setupMobile();
+ return;
+ }
+ var debouncedResize = debounce(onResize, 50);
+ self._debouncedChange = debounce(triggerChange, DEBOUNCED_CHANGE_MS);
+ if (self.daysContainer && !/iPhone|iPad|iPod/i.test(navigator.userAgent))
+ bind(self.daysContainer, "mouseover", function (e) {
+ if (self.config.mode === "range")
+ onMouseOver(e.target);
+ });
+ bind(window.document.body, "keydown", onKeyDown);
+ if (!self.config.static)
+ bind(self._input, "keydown", onKeyDown);
+ if (!self.config.inline && !self.config.static)
+ bind(window, "resize", debouncedResize);
+ if (window.ontouchstart !== undefined)
+ bind(window.document, "touchstart", documentClick);
+ bind(window.document, "mousedown", onClick(documentClick));
+ bind(window.document, "focus", documentClick, { capture: true });
+ if (self.config.clickOpens === true) {
+ bind(self._input, "focus", self.open);
+ bind(self._input, "mousedown", onClick(self.open));
+ }
+ if (self.daysContainer !== undefined) {
+ bind(self.monthNav, "mousedown", onClick(onMonthNavClick));
+ bind(self.monthNav, ["keyup", "increment"], onYearInput);
+ bind(self.daysContainer, "mousedown", onClick(selectDate));
+ }
+ if (self.timeContainer !== undefined &&
+ self.minuteElement !== undefined &&
+ self.hourElement !== undefined) {
+ var selText = function (e) {
+ return e.target.select();
+ };
+ bind(self.timeContainer, ["input", "increment"], updateTime);
+ bind(self.timeContainer, "mousedown", onClick(timeIncrement));
+ bind(self.timeContainer, ["input", "increment"], self._debouncedChange, {
+ passive: true,
+ });
+ bind([self.hourElement, self.minuteElement], ["focus", "click"], selText);
+ if (self.secondElement !== undefined)
+ bind(self.secondElement, "focus", function () { return self.secondElement && self.secondElement.select(); });
+ if (self.amPM !== undefined) {
+ bind(self.amPM, "mousedown", onClick(function (e) {
+ updateTime(e);
+ triggerChange();
+ }));
+ }
+ }
+ }
+ function jumpToDate(jumpDate) {
+ var jumpTo = jumpDate !== undefined
+ ? self.parseDate(jumpDate)
+ : self.latestSelectedDateObj ||
+ (self.config.minDate && self.config.minDate > self.now
+ ? self.config.minDate
+ : self.config.maxDate && self.config.maxDate < self.now
+ ? self.config.maxDate
+ : self.now);
+ try {
+ if (jumpTo !== undefined) {
+ self.currentYear = jumpTo.getFullYear();
+ self.currentMonth = jumpTo.getMonth();
+ }
+ }
+ catch (e) {
+ e.message = "Invalid date supplied: " + jumpTo;
+ self.config.errorHandler(e);
+ }
+ self.redraw();
+ }
+ function timeIncrement(e) {
+ if (~e.target.className.indexOf("arrow"))
+ incrementNumInput(e, e.target.classList.contains("arrowUp") ? 1 : -1);
+ }
+ function incrementNumInput(e, delta, inputElem) {
+ var target = e && e.target;
+ var input = inputElem ||
+ (target && target.parentNode && target.parentNode.firstChild);
+ var event = createEvent("increment");
+ event.delta = delta;
+ input && input.dispatchEvent(event);
+ }
+ function build() {
+ var fragment = window.document.createDocumentFragment();
+ self.calendarContainer = createElement("div", "flatpickr-calendar");
+ self.calendarContainer.tabIndex = -1;
+ if (!self.config.noCalendar) {
+ fragment.appendChild(buildMonthNav());
+ self.innerContainer = createElement("div", "flatpickr-innerContainer");
+ if (self.config.weekNumbers) {
+ var _a = buildWeeks(), weekWrapper = _a.weekWrapper, weekNumbers = _a.weekNumbers;
+ self.innerContainer.appendChild(weekWrapper);
+ self.weekNumbers = weekNumbers;
+ self.weekWrapper = weekWrapper;
+ }
+ self.rContainer = createElement("div", "flatpickr-rContainer");
+ self.rContainer.appendChild(buildWeekdays());
+ if (!self.daysContainer) {
+ self.daysContainer = createElement("div", "flatpickr-days");
+ self.daysContainer.tabIndex = -1;
+ }
+ buildDays();
+ self.rContainer.appendChild(self.daysContainer);
+ self.innerContainer.appendChild(self.rContainer);
+ fragment.appendChild(self.innerContainer);
+ }
+ if (self.config.enableTime) {
+ fragment.appendChild(buildTime());
+ }
+ toggleClass(self.calendarContainer, "rangeMode", self.config.mode === "range");
+ toggleClass(self.calendarContainer, "animate", self.config.animate);
+ self.calendarContainer.appendChild(fragment);
+ var customAppend = self.config.appendTo !== undefined && self.config.appendTo.nodeType;
+ if (self.config.inline || self.config.static) {
+ self.calendarContainer.classList.add(self.config.inline ? "inline" : "static");
+ if (self.config.inline) {
+ if (!customAppend && self.element.parentNode)
+ self.element.parentNode.insertBefore(self.calendarContainer, self._input.nextSibling);
+ else if (self.config.appendTo !== undefined)
+ self.config.appendTo.appendChild(self.calendarContainer);
+ }
+ if (self.config.static) {
+ var wrapper = createElement("div", "flatpickr-wrapper");
+ if (self.element.parentNode)
+ self.element.parentNode.insertBefore(wrapper, self.element);
+ wrapper.appendChild(self.element);
+ if (self.altInput)
+ wrapper.appendChild(self.altInput);
+ wrapper.appendChild(self.calendarContainer);
+ }
+ }
+ if (!self.config.static && !self.config.inline)
+ (self.config.appendTo !== undefined
+ ? self.config.appendTo
+ : window.document.body).appendChild(self.calendarContainer);
+ }
+ function createDay(className, date, dayNumber, i) {
+ var dateIsEnabled = isEnabled(date, true), dayElement = createElement("span", "flatpickr-day " + className, date.getDate().toString());
+ dayElement.dateObj = date;
+ dayElement.$i = i;
+ dayElement.setAttribute("aria-label", self.formatDate(date, self.config.ariaDateFormat));
+ if (compareDates(date, self.now) === 0) {
+ self.todayDateElem = dayElement;
+ dayElement.classList.add("today");
+ }
+ if (dateIsEnabled) {
+ dayElement.tabIndex = -1;
+ if (isDateSelected(date)) {
+ dayElement.classList.add("selected");
+ self.selectedDateElem = dayElement;
+ if (self.config.mode === "range") {
+ toggleClass(dayElement, "startRange", self.selectedDates[0] &&
+ compareDates(date, self.selectedDates[0]) === 0);
+ toggleClass(dayElement, "endRange", self.selectedDates[1] &&
+ compareDates(date, self.selectedDates[1]) === 0);
+ }
+ }
+ }
+ else {
+ dayElement.classList.add("disabled");
+ if (self.selectedDates[0] &&
+ self.minRangeDate &&
+ date > self.minRangeDate &&
+ date < self.selectedDates[0])
+ self.minRangeDate = date;
+ else if (self.selectedDates[0] &&
+ self.maxRangeDate &&
+ date < self.maxRangeDate &&
+ date > self.selectedDates[0])
+ self.maxRangeDate = date;
+ }
+ if (self.config.mode === "range") {
+ if (isDateInRange(date) && !isDateSelected(date))
+ dayElement.classList.add("inRange");
+ if (self.selectedDates.length === 1 &&
+ self.minRangeDate !== undefined &&
+ self.maxRangeDate !== undefined &&
+ (date < self.minRangeDate || date > self.maxRangeDate))
+ dayElement.classList.add("notAllowed");
+ }
+ if (self.weekNumbers &&
+ className !== "prevMonthDay" &&
+ dayNumber % 7 === 1) {
+ self.weekNumbers.insertAdjacentHTML("beforeend", "" + self.config.getWeek(date) + "");
+ }
+ triggerEvent("onDayCreate", dayElement);
+ return dayElement;
+ }
+ function focusOnDay(currentIndex, offset) {
+ var newIndex = currentIndex + offset || 0, targetNode = (currentIndex !== undefined
+ ? self.days.childNodes[newIndex]
+ : self.selectedDateElem ||
+ self.todayDateElem ||
+ self.days.childNodes[0]);
+ var focus = function () {
+ targetNode = targetNode || self.days.childNodes[newIndex];
+ targetNode.focus();
+ if (self.config.mode === "range")
+ onMouseOver(targetNode);
+ };
+ if (targetNode === undefined && offset !== 0) {
+ if (offset > 0) {
+ self.changeMonth(1, true, true);
+ newIndex = newIndex % 42;
+ }
+ else if (offset < 0) {
+ self.changeMonth(-1, true, true);
+ newIndex += 42;
+ }
+ }
+ focus();
+ }
+ function buildDays() {
+ if (self.daysContainer === undefined) {
+ return;
+ }
+ var firstOfMonth = (new Date(self.currentYear, self.currentMonth, 1).getDay() -
+ self.l10n.firstDayOfWeek +
+ 7) %
+ 7, isRangeMode = self.config.mode === "range";
+ var prevMonthDays = self.utils.getDaysInMonth((self.currentMonth - 1 + 12) % 12);
+ var daysInMonth = self.utils.getDaysInMonth(), days = window.document.createDocumentFragment();
+ var dayNumber = prevMonthDays + 1 - firstOfMonth, dayIndex = 0;
+ if (self.weekNumbers && self.weekNumbers.firstChild)
+ self.weekNumbers.textContent = "";
+ if (isRangeMode) {
+ self.minRangeDate = new Date(self.currentYear, self.currentMonth - 1, dayNumber);
+ self.maxRangeDate = new Date(self.currentYear, self.currentMonth + 1, (42 - firstOfMonth) % daysInMonth);
+ }
+ for (; dayNumber <= prevMonthDays; dayNumber++, dayIndex++) {
+ days.appendChild(createDay("prevMonthDay", new Date(self.currentYear, self.currentMonth - 1, dayNumber), dayNumber, dayIndex));
+ }
+ for (dayNumber = 1; dayNumber <= daysInMonth; dayNumber++, dayIndex++) {
+ days.appendChild(createDay("", new Date(self.currentYear, self.currentMonth, dayNumber), dayNumber, dayIndex));
+ }
+ for (var dayNum = daysInMonth + 1; dayNum <= 42 - firstOfMonth; dayNum++, dayIndex++) {
+ days.appendChild(createDay("nextMonthDay", new Date(self.currentYear, self.currentMonth + 1, dayNum % daysInMonth), dayNum, dayIndex));
+ }
+ if (isRangeMode && self.selectedDates.length === 1 && days.childNodes[0]) {
+ self._hidePrevMonthArrow =
+ self._hidePrevMonthArrow ||
+ (!!self.minRangeDate &&
+ self.minRangeDate > days.childNodes[0].dateObj);
+ self._hideNextMonthArrow =
+ self._hideNextMonthArrow ||
+ (!!self.maxRangeDate &&
+ self.maxRangeDate <
+ new Date(self.currentYear, self.currentMonth + 1, 1));
+ }
+ else
+ updateNavigationCurrentMonth();
+ var dayContainer = createElement("div", "dayContainer");
+ dayContainer.appendChild(days);
+ clearNode(self.daysContainer);
+ self.daysContainer.insertBefore(dayContainer, self.daysContainer.firstChild);
+ self.days = self.daysContainer.firstChild;
+ }
+ function buildMonthNav() {
+ var monthNavFragment = window.document.createDocumentFragment();
+ self.monthNav = createElement("div", "flatpickr-month");
+ self.prevMonthNav = createElement("span", "flatpickr-prev-month");
+ self.prevMonthNav.innerHTML = self.config.prevArrow;
+ self.currentMonthElement = createElement("span", "cur-month");
+ var yearInput = createNumberInput("cur-year", { tabindex: "-1" });
+ self.currentYearElement = yearInput.childNodes[0];
+ if (self.config.minDate)
+ self.currentYearElement.setAttribute("data-min", self.config.minDate.getFullYear().toString());
+ if (self.config.maxDate) {
+ self.currentYearElement.setAttribute("data-max", self.config.maxDate.getFullYear().toString());
+ self.currentYearElement.disabled =
+ !!self.config.minDate &&
+ self.config.minDate.getFullYear() === self.config.maxDate.getFullYear();
+ }
+ self.nextMonthNav = createElement("span", "flatpickr-next-month");
+ self.nextMonthNav.innerHTML = self.config.nextArrow;
+ self.navigationCurrentMonth = createElement("div", "flatpickr-current-month");
+ self.navigationCurrentMonth.appendChild(self.currentMonthElement);
+ self.navigationCurrentMonth.appendChild(yearInput);
+ monthNavFragment.appendChild(self.prevMonthNav);
+ monthNavFragment.appendChild(self.navigationCurrentMonth);
+ monthNavFragment.appendChild(self.nextMonthNav);
+ self.monthNav.appendChild(monthNavFragment);
+ Object.defineProperty(self, "_hidePrevMonthArrow", {
+ get: function () { return self.__hidePrevMonthArrow; },
+ set: function (bool) {
+ if (self.__hidePrevMonthArrow !== bool)
+ self.prevMonthNav.style.display = bool ? "none" : "block";
+ self.__hidePrevMonthArrow = bool;
+ },
+ });
+ Object.defineProperty(self, "_hideNextMonthArrow", {
+ get: function () { return self.__hideNextMonthArrow; },
+ set: function (bool) {
+ if (self.__hideNextMonthArrow !== bool)
+ self.nextMonthNav.style.display = bool ? "none" : "block";
+ self.__hideNextMonthArrow = bool;
+ },
+ });
+ updateNavigationCurrentMonth();
+ return self.monthNav;
+ }
+ function buildTime() {
+ self.calendarContainer.classList.add("hasTime");
+ if (self.config.noCalendar)
+ self.calendarContainer.classList.add("noCalendar");
+ self.timeContainer = createElement("div", "flatpickr-time");
+ self.timeContainer.tabIndex = -1;
+ var separator = createElement("span", "flatpickr-time-separator", ":");
+ var hourInput = createNumberInput("flatpickr-hour");
+ self.hourElement = hourInput.childNodes[0];
+ var minuteInput = createNumberInput("flatpickr-minute");
+ self.minuteElement = minuteInput.childNodes[0];
+ self.hourElement.tabIndex = self.minuteElement.tabIndex = -1;
+ self.hourElement.value = pad(self.latestSelectedDateObj
+ ? self.latestSelectedDateObj.getHours()
+ : self.config.time_24hr
+ ? self.config.defaultHour
+ : military2ampm(self.config.defaultHour));
+ self.minuteElement.value = pad(self.latestSelectedDateObj
+ ? self.latestSelectedDateObj.getMinutes()
+ : self.config.defaultMinute);
+ self.hourElement.setAttribute("data-step", self.config.hourIncrement.toString());
+ self.minuteElement.setAttribute("data-step", self.config.minuteIncrement.toString());
+ self.hourElement.setAttribute("data-min", self.config.time_24hr ? "0" : "1");
+ self.hourElement.setAttribute("data-max", self.config.time_24hr ? "23" : "12");
+ self.minuteElement.setAttribute("data-min", "0");
+ self.minuteElement.setAttribute("data-max", "59");
+ self.timeContainer.appendChild(hourInput);
+ self.timeContainer.appendChild(separator);
+ self.timeContainer.appendChild(minuteInput);
+ if (self.config.time_24hr)
+ self.timeContainer.classList.add("time24hr");
+ if (self.config.enableSeconds) {
+ self.timeContainer.classList.add("hasSeconds");
+ var secondInput = createNumberInput("flatpickr-second");
+ self.secondElement = secondInput.childNodes[0];
+ self.secondElement.value = pad(self.latestSelectedDateObj
+ ? self.latestSelectedDateObj.getSeconds()
+ : self.config.defaultSeconds);
+ self.secondElement.setAttribute("data-step", self.minuteElement.getAttribute("data-step"));
+ self.secondElement.setAttribute("data-min", self.minuteElement.getAttribute("data-min"));
+ self.secondElement.setAttribute("data-max", self.minuteElement.getAttribute("data-max"));
+ self.timeContainer.appendChild(createElement("span", "flatpickr-time-separator", ":"));
+ self.timeContainer.appendChild(secondInput);
+ }
+ if (!self.config.time_24hr) {
+ self.amPM = createElement("span", "flatpickr-am-pm", self.l10n.amPM[int((self.latestSelectedDateObj
+ ? self.hourElement.value
+ : self.config.defaultHour) > 11)]);
+ self.amPM.title = self.l10n.toggleTitle;
+ self.amPM.tabIndex = -1;
+ self.timeContainer.appendChild(self.amPM);
+ }
+ return self.timeContainer;
+ }
+ function buildWeekdays() {
+ if (!self.weekdayContainer)
+ self.weekdayContainer = createElement("div", "flatpickr-weekdays");
+ var firstDayOfWeek = self.l10n.firstDayOfWeek;
+ var weekdays = self.l10n.weekdays.shorthand.slice();
+ if (firstDayOfWeek > 0 && firstDayOfWeek < weekdays.length) {
+ weekdays = weekdays.splice(firstDayOfWeek, weekdays.length).concat(weekdays.splice(0, firstDayOfWeek));
+ }
+ self.weekdayContainer.innerHTML = "\n \n " + weekdays.join("") + "\n \n ";
+ return self.weekdayContainer;
+ }
+ function buildWeeks() {
+ self.calendarContainer.classList.add("hasWeeks");
+ var weekWrapper = createElement("div", "flatpickr-weekwrapper");
+ weekWrapper.appendChild(createElement("span", "flatpickr-weekday", self.l10n.weekAbbreviation));
+ var weekNumbers = createElement("div", "flatpickr-weeks");
+ weekWrapper.appendChild(weekNumbers);
+ return {
+ weekWrapper: weekWrapper,
+ weekNumbers: weekNumbers,
+ };
+ }
+ function changeMonth(value, is_offset, from_keyboard) {
+ if (is_offset === void 0) { is_offset = true; }
+ if (from_keyboard === void 0) { from_keyboard = false; }
+ var delta = is_offset ? value : value - self.currentMonth;
+ if ((delta < 0 && self._hidePrevMonthArrow) ||
+ (delta > 0 && self._hideNextMonthArrow))
+ return;
+ self.currentMonth += delta;
+ if (self.currentMonth < 0 || self.currentMonth > 11) {
+ self.currentYear += self.currentMonth > 11 ? 1 : -1;
+ self.currentMonth = (self.currentMonth + 12) % 12;
+ triggerEvent("onYearChange");
+ }
+ buildDays();
+ triggerEvent("onMonthChange");
+ updateNavigationCurrentMonth();
+ if (from_keyboard &&
+ document.activeElement &&
+ document.activeElement.$i) {
+ var index = document.activeElement.$i;
+ focusOnDay(index, 0);
+ }
+ }
+ function clear(triggerChangeEvent) {
+ if (triggerChangeEvent === void 0) { triggerChangeEvent = true; }
+ self.input.value = "";
+ if (self.altInput)
+ self.altInput.value = "";
+ if (self.mobileInput)
+ self.mobileInput.value = "";
+ self.selectedDates = [];
+ self.latestSelectedDateObj = undefined;
+ self.showTimeInput = false;
+ if (self.config.enableTime) {
+ if (self.config.minDate !== undefined)
+ setHoursFromDate(self.config.minDate);
+ else
+ setHours(self.config.defaultHour, self.config.defaultMinute, self.config.defaultSeconds);
+ }
+ self.redraw();
+ if (triggerChangeEvent)
+ triggerEvent("onChange");
+ }
+ function close() {
+ self.isOpen = false;
+ if (!self.isMobile) {
+ self.calendarContainer.classList.remove("open");
+ self._input.classList.remove("active");
+ }
+ triggerEvent("onClose");
+ }
+ function destroy() {
+ if (self.config !== undefined)
+ triggerEvent("onDestroy");
+ for (var i = self._handlers.length; i--;) {
+ var h = self._handlers[i];
+ h.element.removeEventListener(h.event, h.handler);
+ }
+ self._handlers = [];
+ if (self.mobileInput) {
+ if (self.mobileInput.parentNode)
+ self.mobileInput.parentNode.removeChild(self.mobileInput);
+ self.mobileInput = undefined;
+ }
+ else if (self.calendarContainer && self.calendarContainer.parentNode)
+ self.calendarContainer.parentNode.removeChild(self.calendarContainer);
+ if (self.altInput) {
+ self.input.type = "text";
+ if (self.altInput.parentNode)
+ self.altInput.parentNode.removeChild(self.altInput);
+ delete self.altInput;
+ }
+ if (self.input) {
+ self.input.type = self.input._type;
+ self.input.classList.remove("flatpickr-input");
+ self.input.removeAttribute("readonly");
+ self.input.value = "";
+ }
+ [
+ "_showTimeInput",
+ "latestSelectedDateObj",
+ "_hideNextMonthArrow",
+ "_hidePrevMonthArrow",
+ "__hideNextMonthArrow",
+ "__hidePrevMonthArrow",
+ "isMobile",
+ "isOpen",
+ "selectedDateElem",
+ "minDateHasTime",
+ "maxDateHasTime",
+ "days",
+ "daysContainer",
+ "_input",
+ "_positionElement",
+ "innerContainer",
+ "rContainer",
+ "monthNav",
+ "todayDateElem",
+ "calendarContainer",
+ "weekdayContainer",
+ "prevMonthNav",
+ "nextMonthNav",
+ "currentMonthElement",
+ "currentYearElement",
+ "navigationCurrentMonth",
+ "selectedDateElem",
+ "config",
+ ].forEach(function (k) {
+ try {
+ delete self[k];
+ }
+ catch (_) { }
+ });
+ }
+ function isCalendarElem(elem) {
+ if (self.config.appendTo && self.config.appendTo.contains(elem))
+ return true;
+ return self.calendarContainer.contains(elem);
+ }
+ function documentClick(e) {
+ if (self.isOpen && !self.config.inline) {
+ var isCalendarElement = isCalendarElem(e.target);
+ var isInput = e.target === self.input ||
+ e.target === self.altInput ||
+ self.element.contains(e.target) ||
+ (e.path &&
+ e.path.indexOf &&
+ (~e.path.indexOf(self.input) ||
+ ~e.path.indexOf(self.altInput)));
+ var lostFocus = e.type === "blur"
+ ? isInput &&
+ e.relatedTarget &&
+ !isCalendarElem(e.relatedTarget)
+ : !isInput && !isCalendarElement;
+ var isIgnored = !self.config.ignoredFocusElements.some(function (elem) {
+ return elem.contains(e.target);
+ });
+ if (lostFocus && isIgnored) {
+ self.close();
+ if (self.config.mode === "range" && self.selectedDates.length === 1) {
+ self.clear(false);
+ self.redraw();
+ }
+ }
+ }
+ }
+ function changeYear(newYear) {
+ if (!newYear ||
+ (self.currentYearElement.getAttribute("data-min") &&
+ newYear <
+ parseInt(self.currentYearElement.getAttribute("data-min"))) ||
+ (self.currentYearElement.getAttribute("data-max") &&
+ newYear >
+ parseInt(self.currentYearElement.getAttribute("data-max"))))
+ return;
+ var newYearNum = newYear, isNewYear = self.currentYear !== newYearNum;
+ self.currentYear = newYearNum || self.currentYear;
+ if (self.config.maxDate &&
+ self.currentYear === self.config.maxDate.getFullYear()) {
+ self.currentMonth = Math.min(self.config.maxDate.getMonth(), self.currentMonth);
+ }
+ else if (self.config.minDate &&
+ self.currentYear === self.config.minDate.getFullYear()) {
+ self.currentMonth = Math.max(self.config.minDate.getMonth(), self.currentMonth);
+ }
+ if (isNewYear) {
+ self.redraw();
+ triggerEvent("onYearChange");
+ }
+ }
+ function isEnabled(date, timeless) {
+ if (timeless === void 0) { timeless = true; }
+ var dateToCheck = self.parseDate(date, undefined, timeless);
+ if ((self.config.minDate &&
+ dateToCheck &&
+ compareDates(dateToCheck, self.config.minDate, timeless !== undefined ? timeless : !self.minDateHasTime) < 0) ||
+ (self.config.maxDate &&
+ dateToCheck &&
+ compareDates(dateToCheck, self.config.maxDate, timeless !== undefined ? timeless : !self.maxDateHasTime) > 0))
+ return false;
+ if (!self.config.enable.length && !self.config.disable.length)
+ return true;
+ if (dateToCheck === undefined)
+ return false;
+ var bool = self.config.enable.length > 0, array = bool ? self.config.enable : self.config.disable;
+ for (var i = 0, d = void 0; i < array.length; i++) {
+ d = array[i];
+ if (typeof d === "function" &&
+ d(dateToCheck))
+ return bool;
+ else if (d instanceof Date &&
+ dateToCheck !== undefined &&
+ d.getTime() === dateToCheck.getTime())
+ return bool;
+ else if (typeof d === "string" && dateToCheck !== undefined) {
+ var parsed = self.parseDate(d, undefined, true);
+ return parsed && parsed.getTime() === dateToCheck.getTime()
+ ? bool
+ : !bool;
+ }
+ else if (typeof d === "object" &&
+ dateToCheck !== undefined &&
+ d.from &&
+ d.to &&
+ dateToCheck.getTime() >= d.from.getTime() &&
+ dateToCheck.getTime() <= d.to.getTime())
+ return bool;
+ }
+ return !bool;
+ }
+ function onKeyDown(e) {
+ var isInput = e.target === self._input;
+ var calendarElem = isCalendarElem(e.target);
+ var allowInput = self.config.allowInput;
+ var allowKeydown = self.isOpen && (!allowInput || !isInput);
+ var allowInlineKeydown = self.config.inline && isInput && !allowInput;
+ if (e.keyCode === 13 && isInput) {
+ if (allowInput) {
+ self.setDate(self._input.value, true, e.target === self.altInput
+ ? self.config.altFormat
+ : self.config.dateFormat);
+ return e.target.blur();
+ }
+ else
+ self.open();
+ }
+ else if (calendarElem || allowKeydown || allowInlineKeydown) {
+ var isTimeObj = !!self.timeContainer &&
+ self.timeContainer.contains(e.target);
+ switch (e.keyCode) {
+ case 13:
+ if (isTimeObj)
+ updateValue();
+ else
+ selectDate(e);
+ break;
+ case 27:
+ e.preventDefault();
+ self.close();
+ break;
+ case 8:
+ case 46:
+ if (isInput && !self.config.allowInput)
+ self.clear();
+ break;
+ case 37:
+ case 39:
+ if (!isTimeObj) {
+ e.preventDefault();
+ if (self.daysContainer) {
+ var delta_1 = e.keyCode === 39 ? 1 : -1;
+ if (!e.ctrlKey)
+ focusOnDay(e.target.$i, delta_1);
+ else
+ changeMonth(delta_1, true, true);
+ }
+ }
+ else if (self.hourElement)
+ self.hourElement.focus();
+ break;
+ case 38:
+ case 40:
+ e.preventDefault();
+ var delta = e.keyCode === 40 ? 1 : -1;
+ if (self.daysContainer && e.target.$i !== undefined) {
+ if (e.ctrlKey) {
+ changeYear(self.currentYear - delta);
+ focusOnDay(e.target.$i, 0);
+ }
+ else if (!isTimeObj)
+ focusOnDay(e.target.$i, delta * 7);
+ }
+ else if (self.config.enableTime) {
+ if (!isTimeObj && self.hourElement)
+ self.hourElement.focus();
+ updateTime(e);
+ self._debouncedChange();
+ }
+ break;
+ case 9:
+ if (e.target === self.hourElement) {
+ e.preventDefault();
+ self.minuteElement.select();
+ }
+ else if (e.target === self.minuteElement &&
+ (self.secondElement || self.amPM)) {
+ e.preventDefault();
+ if (self.secondElement !== undefined)
+ self.secondElement.focus();
+ else if (self.amPM !== undefined)
+ self.amPM.focus();
+ }
+ else if (e.target === self.secondElement && self.amPM) {
+ e.preventDefault();
+ self.amPM.focus();
+ }
+ break;
+ default:
+ break;
+ }
+ switch (e.key) {
+ case self.l10n.amPM[0].charAt(0):
+ if (self.amPM !== undefined && e.target === self.amPM) {
+ self.amPM.textContent = self.l10n.amPM[0];
+ setHoursFromInputs();
+ updateValue();
+ }
+ break;
+ case self.l10n.amPM[1].charAt(0):
+ if (self.amPM !== undefined && e.target === self.amPM) {
+ self.amPM.textContent = self.l10n.amPM[1];
+ setHoursFromInputs();
+ updateValue();
+ }
+ break;
+ default:
+ break;
+ }
+ triggerEvent("onKeyDown", e);
+ }
+ }
+ function onMouseOver(elem) {
+ if (self.selectedDates.length !== 1 ||
+ !elem.classList.contains("flatpickr-day") ||
+ elem.classList.contains("disabled") ||
+ self.minRangeDate === undefined ||
+ self.maxRangeDate === undefined)
+ return;
+ var hoverDate = elem.dateObj, initialDate = self.parseDate(self.selectedDates[0], undefined, true), rangeStartDate = Math.min(hoverDate.getTime(), self.selectedDates[0].getTime()), rangeEndDate = Math.max(hoverDate.getTime(), self.selectedDates[0].getTime()), containsDisabled = false;
+ for (var t = rangeStartDate; t < rangeEndDate; t += duration.DAY) {
+ if (!isEnabled(new Date(t))) {
+ containsDisabled = true;
+ break;
+ }
+ }
+ var _loop_1 = function (i, date) {
+ var timestamp = date.getTime();
+ var outOfRange = timestamp < self.minRangeDate.getTime() ||
+ timestamp > self.maxRangeDate.getTime(), dayElem = self.days.childNodes[i];
+ if (outOfRange) {
+ dayElem.classList.add("notAllowed");
+ ["inRange", "startRange", "endRange"].forEach(function (c) {
+ dayElem.classList.remove(c);
+ });
+ return "continue";
+ }
+ else if (containsDisabled && !outOfRange)
+ return "continue";
+ ["startRange", "inRange", "endRange", "notAllowed"].forEach(function (c) {
+ dayElem.classList.remove(c);
+ });
+ var minRangeDate = Math.max(self.minRangeDate.getTime(), rangeStartDate), maxRangeDate = Math.min(self.maxRangeDate.getTime(), rangeEndDate);
+ elem.classList.add(hoverDate < self.selectedDates[0] ? "startRange" : "endRange");
+ if (initialDate < hoverDate && timestamp === initialDate.getTime())
+ dayElem.classList.add("startRange");
+ else if (initialDate > hoverDate && timestamp === initialDate.getTime())
+ dayElem.classList.add("endRange");
+ if (timestamp >= minRangeDate && timestamp <= maxRangeDate)
+ dayElem.classList.add("inRange");
+ };
+ for (var i = 0, date = self.days.childNodes[i].dateObj; i < 42; i++, date =
+ self.days.childNodes[i] &&
+ self.days.childNodes[i].dateObj) {
+ _loop_1(i, date);
+ }
+ }
+ function onResize() {
+ if (self.isOpen && !self.config.static && !self.config.inline)
+ positionCalendar();
+ }
+ function open(e, positionElement) {
+ if (positionElement === void 0) { positionElement = self._input; }
+ if (self.isMobile) {
+ if (e) {
+ e.preventDefault();
+ e.target && e.target.blur();
+ }
+ setTimeout(function () {
+ self.mobileInput !== undefined && self.mobileInput.click();
+ }, 0);
+ triggerEvent("onOpen");
+ return;
+ }
+ if (self._input.disabled || self.config.inline)
+ return;
+ var wasOpen = self.isOpen;
+ self.isOpen = true;
+ if (!wasOpen) {
+ self.calendarContainer.classList.add("open");
+ self._input.classList.add("active");
+ triggerEvent("onOpen");
+ positionCalendar(positionElement);
+ }
+ }
+ function minMaxDateSetter(type) {
+ return function (date) {
+ var dateObj = (self.config["_" + type + "Date"] = self.parseDate(date, self.config.dateFormat));
+ var inverseDateObj = self.config["_" + (type === "min" ? "max" : "min") + "Date"];
+ if (dateObj !== undefined) {
+ self[type === "min" ? "minDateHasTime" : "maxDateHasTime"] =
+ dateObj.getHours() > 0 ||
+ dateObj.getMinutes() > 0 ||
+ dateObj.getSeconds() > 0;
+ }
+ if (self.selectedDates) {
+ self.selectedDates = self.selectedDates.filter(function (d) { return isEnabled(d); });
+ if (!self.selectedDates.length && type === "min")
+ setHoursFromDate(dateObj);
+ updateValue();
+ }
+ if (self.daysContainer) {
+ redraw();
+ if (dateObj !== undefined)
+ self.currentYearElement[type] = dateObj.getFullYear().toString();
+ else
+ self.currentYearElement.removeAttribute(type);
+ self.currentYearElement.disabled =
+ !!inverseDateObj &&
+ dateObj !== undefined &&
+ inverseDateObj.getFullYear() === dateObj.getFullYear();
+ }
+ };
+ }
+ function parseConfig() {
+ var boolOpts = [
+ "wrap",
+ "weekNumbers",
+ "allowInput",
+ "clickOpens",
+ "time_24hr",
+ "enableTime",
+ "noCalendar",
+ "altInput",
+ "shorthandCurrentMonth",
+ "inline",
+ "static",
+ "enableSeconds",
+ "disableMobile",
+ ];
+ var hooks = [
+ "onChange",
+ "onClose",
+ "onDayCreate",
+ "onDestroy",
+ "onKeyDown",
+ "onMonthChange",
+ "onOpen",
+ "onParseConfig",
+ "onReady",
+ "onValueUpdate",
+ "onYearChange",
+ "onPreCalendarPosition",
+ ];
+ var userConfig = __assign({}, instanceConfig, JSON.parse(JSON.stringify(element.dataset || {})));
+ var formats$$1 = {};
+ self.config.parseDate = userConfig.parseDate;
+ self.config.formatDate = userConfig.formatDate;
+ Object.defineProperty(self.config, "enable", {
+ get: function () { return self.config._enable || []; },
+ set: function (dates) {
+ self.config._enable = parseDateRules(dates);
+ },
+ });
+ Object.defineProperty(self.config, "disable", {
+ get: function () { return self.config._disable || []; },
+ set: function (dates) {
+ self.config._disable = parseDateRules(dates);
+ },
+ });
+ if (!userConfig.dateFormat && userConfig.enableTime) {
+ formats$$1.dateFormat = userConfig.noCalendar
+ ? "H:i" + (userConfig.enableSeconds ? ":S" : "")
+ : flatpickr.defaultConfig.dateFormat +
+ " H:i" +
+ (userConfig.enableSeconds ? ":S" : "");
+ }
+ if (userConfig.altInput && userConfig.enableTime && !userConfig.altFormat) {
+ formats$$1.altFormat = userConfig.noCalendar
+ ? "h:i" + (userConfig.enableSeconds ? ":S K" : " K")
+ : flatpickr.defaultConfig.altFormat +
+ (" h:i" + (userConfig.enableSeconds ? ":S" : "") + " K");
+ }
+ Object.defineProperty(self.config, "minDate", {
+ get: function () { return self.config._minDate; },
+ set: minMaxDateSetter("min"),
+ });
+ Object.defineProperty(self.config, "maxDate", {
+ get: function () { return self.config._maxDate; },
+ set: minMaxDateSetter("max"),
+ });
+ var minMaxTimeSetter = function (type) { return function (val) {
+ self.config[type === "min" ? "_minTime" : "_maxTime"] = self.parseDate(val, "H:i");
+ }; };
+ Object.defineProperty(self.config, "minTime", {
+ get: function () { return self.config._minTime; },
+ set: minMaxTimeSetter("min"),
+ });
+ Object.defineProperty(self.config, "maxTime", {
+ get: function () { return self.config._maxTime; },
+ set: minMaxTimeSetter("max"),
+ });
+ Object.assign(self.config, formats$$1, userConfig);
+ for (var i = 0; i < boolOpts.length; i++)
+ self.config[boolOpts[i]] =
+ self.config[boolOpts[i]] === true ||
+ self.config[boolOpts[i]] === "true";
+ for (var i = hooks.length; i--;) {
+ if (self.config[hooks[i]] !== undefined) {
+ self.config[hooks[i]] = arrayify(self.config[hooks[i]] || []).map(bindToInstance);
+ }
+ }
+ for (var i = 0; i < self.config.plugins.length; i++) {
+ var pluginConf = self.config.plugins[i](self) || {};
+ for (var key in pluginConf) {
+ if (~hooks.indexOf(key)) {
+ self.config[key] = arrayify(pluginConf[key])
+ .map(bindToInstance)
+ .concat(self.config[key]);
+ }
+ else if (typeof userConfig[key] === "undefined")
+ self.config[key] = pluginConf[key];
+ }
+ }
+ self.isMobile =
+ !self.config.disableMobile &&
+ !self.config.inline &&
+ self.config.mode === "single" &&
+ !self.config.disable.length &&
+ !self.config.enable.length &&
+ !self.config.weekNumbers &&
+ /Android|webOS|iPhone|iPad|iPod|BlackBerry|IEMobile|Opera Mini/i.test(navigator.userAgent);
+ triggerEvent("onParseConfig");
+ }
+ function setupLocale() {
+ if (typeof self.config.locale !== "object" &&
+ typeof flatpickr.l10ns[self.config.locale] === "undefined")
+ self.config.errorHandler(new Error("flatpickr: invalid locale " + self.config.locale));
+ self.l10n = __assign({}, flatpickr.l10ns.default, (typeof self.config.locale === "object"
+ ? self.config.locale
+ : self.config.locale !== "default"
+ ? flatpickr.l10ns[self.config.locale]
+ : undefined));
+ tokenRegex.K = "(" + self.l10n.amPM[0] + "|" + self.l10n.amPM[1] + "|" + self.l10n.amPM[0].toLowerCase() + "|" + self.l10n.amPM[1].toLowerCase() + ")";
+ self.formatDate = createDateFormatter(self);
+ }
+ function positionCalendar(customPositionElement) {
+ if (self.calendarContainer === undefined)
+ return;
+ triggerEvent("onPreCalendarPosition");
+ var positionElement = customPositionElement || self._positionElement;
+ var calendarHeight = Array.prototype.reduce.call(self.calendarContainer.children, function (acc, child) { return acc + child.offsetHeight; }, 0), calendarWidth = self.calendarContainer.offsetWidth, configPos = self.config.position, inputBounds = positionElement.getBoundingClientRect(), distanceFromBottom = window.innerHeight - inputBounds.bottom, showOnTop = configPos === "above" ||
+ (configPos !== "below" &&
+ distanceFromBottom < calendarHeight &&
+ inputBounds.top > calendarHeight);
+ var top = window.pageYOffset +
+ inputBounds.top +
+ (!showOnTop ? positionElement.offsetHeight + 2 : -calendarHeight - 2);
+ toggleClass(self.calendarContainer, "arrowTop", !showOnTop);
+ toggleClass(self.calendarContainer, "arrowBottom", showOnTop);
+ if (self.config.inline)
+ return;
+ var left = window.pageXOffset + inputBounds.left;
+ var right = window.document.body.offsetWidth - inputBounds.right;
+ var rightMost = left + calendarWidth > window.document.body.offsetWidth;
+ toggleClass(self.calendarContainer, "rightMost", rightMost);
+ if (self.config.static)
+ return;
+ self.calendarContainer.style.top = top + "px";
+ if (!rightMost) {
+ self.calendarContainer.style.left = left + "px";
+ self.calendarContainer.style.right = "auto";
+ }
+ else {
+ self.calendarContainer.style.left = "auto";
+ self.calendarContainer.style.right = right + "px";
+ }
+ }
+ function redraw() {
+ if (self.config.noCalendar || self.isMobile)
+ return;
+ buildWeekdays();
+ updateNavigationCurrentMonth();
+ buildDays();
+ }
+ function focusAndClose() {
+ self._input.focus();
+ if (window.navigator.userAgent.indexOf("MSIE") !== -1 ||
+ navigator.msMaxTouchPoints !== undefined) {
+ setTimeout(self.close, 0);
+ }
+ else {
+ self.close();
+ }
+ }
+ function selectDate(e) {
+ e.preventDefault();
+ e.stopPropagation();
+ var isSelectable = function (day) {
+ return day.classList &&
+ day.classList.contains("flatpickr-day") &&
+ !day.classList.contains("disabled") &&
+ !day.classList.contains("notAllowed");
+ };
+ var t = findParent(e.target, isSelectable);
+ if (t === undefined)
+ return;
+ var target = t;
+ var selectedDate = (self.latestSelectedDateObj = new Date(target.dateObj.getTime()));
+ var shouldChangeMonth = selectedDate.getMonth() !== self.currentMonth &&
+ self.config.mode !== "range";
+ self.selectedDateElem = target;
+ if (self.config.mode === "single")
+ self.selectedDates = [selectedDate];
+ else if (self.config.mode === "multiple") {
+ var selectedIndex = isDateSelected(selectedDate);
+ if (selectedIndex)
+ self.selectedDates.splice(parseInt(selectedIndex), 1);
+ else
+ self.selectedDates.push(selectedDate);
+ }
+ else if (self.config.mode === "range") {
+ if (self.selectedDates.length === 2)
+ self.clear();
+ self.selectedDates.push(selectedDate);
+ if (compareDates(selectedDate, self.selectedDates[0], true) !== 0)
+ self.selectedDates.sort(function (a, b) { return a.getTime() - b.getTime(); });
+ }
+ setHoursFromInputs();
+ if (shouldChangeMonth) {
+ var isNewYear = self.currentYear !== selectedDate.getFullYear();
+ self.currentYear = selectedDate.getFullYear();
+ self.currentMonth = selectedDate.getMonth();
+ if (isNewYear)
+ triggerEvent("onYearChange");
+ triggerEvent("onMonthChange");
+ }
+ buildDays();
+ if (self.config.minDate &&
+ self.minDateHasTime &&
+ self.config.enableTime &&
+ compareDates(selectedDate, self.config.minDate) === 0)
+ setHoursFromDate(self.config.minDate);
+ updateValue();
+ if (self.config.enableTime)
+ setTimeout(function () { return (self.showTimeInput = true); }, 50);
+ if (self.config.mode === "range") {
+ if (self.selectedDates.length === 1) {
+ onMouseOver(target);
+ self._hidePrevMonthArrow =
+ self._hidePrevMonthArrow ||
+ (self.minRangeDate !== undefined &&
+ self.minRangeDate >
+ self.days.childNodes[0].dateObj);
+ self._hideNextMonthArrow =
+ self._hideNextMonthArrow ||
+ (self.maxRangeDate !== undefined &&
+ self.maxRangeDate <
+ new Date(self.currentYear, self.currentMonth + 1, 1));
+ }
+ else
+ updateNavigationCurrentMonth();
+ }
+ if (!shouldChangeMonth)
+ focusOnDay(target.$i, 0);
+ else
+ self.selectedDateElem && self.selectedDateElem.focus();
+ if (self.hourElement !== undefined)
+ setTimeout(function () { return self.hourElement !== undefined && self.hourElement.select(); }, 451);
+ if (self.config.closeOnSelect) {
+ var single = self.config.mode === "single" && !self.config.enableTime;
+ var range = self.config.mode === "range" &&
+ self.selectedDates.length === 2 &&
+ !self.config.enableTime;
+ if (single || range) {
+ focusAndClose();
+ }
+ }
+ triggerChange();
+ }
+ var CALLBACKS = {
+ locale: [setupLocale],
+ };
+ function set(option, value) {
+ if (option !== null && typeof option === "object")
+ Object.assign(self.config, option);
+ else {
+ self.config[option] = value;
+ if (CALLBACKS[option] !== undefined)
+ CALLBACKS[option].forEach(function (x) { return x(); });
+ }
+ self.redraw();
+ jumpToDate();
+ }
+ function setSelectedDate(inputDate, format) {
+ var dates = [];
+ if (inputDate instanceof Array)
+ dates = inputDate.map(function (d) { return self.parseDate(d, format); });
+ else if (inputDate instanceof Date || typeof inputDate === "number")
+ dates = [self.parseDate(inputDate, format)];
+ else if (typeof inputDate === "string") {
+ switch (self.config.mode) {
+ case "single":
+ dates = [self.parseDate(inputDate, format)];
+ break;
+ case "multiple":
+ dates = inputDate
+ .split(self.config.conjunction)
+ .map(function (date) { return self.parseDate(date, format); });
+ break;
+ case "range":
+ dates = inputDate
+ .split(self.l10n.rangeSeparator)
+ .map(function (date) { return self.parseDate(date, format); });
+ break;
+ default:
+ break;
+ }
+ }
+ else
+ self.config.errorHandler(new Error("Invalid date supplied: " + JSON.stringify(inputDate)));
+ self.selectedDates = dates.filter(function (d) { return d instanceof Date && isEnabled(d, false); });
+ if (self.config.mode === "range")
+ self.selectedDates.sort(function (a, b) { return a.getTime() - b.getTime(); });
+ }
+ function setDate(date, triggerChange, format) {
+ if (triggerChange === void 0) { triggerChange = false; }
+ if (format === void 0) { format = self.config.dateFormat; }
+ if (date !== 0 && !date)
+ return self.clear(triggerChange);
+ setSelectedDate(date, format);
+ self.showTimeInput = self.selectedDates.length > 0;
+ self.latestSelectedDateObj = self.selectedDates[0];
+ self.redraw();
+ jumpToDate();
+ setHoursFromDate();
+ updateValue(triggerChange);
+ if (triggerChange)
+ triggerEvent("onChange");
+ }
+ function parseDateRules(arr) {
+ return arr
+ .map(function (rule) {
+ if (typeof rule === "string" ||
+ typeof rule === "number" ||
+ rule instanceof Date) {
+ return self.parseDate(rule, undefined, true);
+ }
+ else if (rule &&
+ typeof rule === "object" &&
+ rule.from &&
+ rule.to)
+ return {
+ from: self.parseDate(rule.from, undefined),
+ to: self.parseDate(rule.to, undefined),
+ };
+ return rule;
+ })
+ .filter(function (x) { return x; });
+ }
+ function setupDates() {
+ self.selectedDates = [];
+ self.now = new Date();
+ var preloadedDate = self.config.defaultDate || self.input.value;
+ if (preloadedDate)
+ setSelectedDate(preloadedDate, self.config.dateFormat);
+ var initialDate = self.selectedDates.length
+ ? self.selectedDates[0]
+ : self.config.minDate &&
+ self.config.minDate.getTime() > self.now.getTime()
+ ? self.config.minDate
+ : self.config.maxDate &&
+ self.config.maxDate.getTime() < self.now.getTime()
+ ? self.config.maxDate
+ : self.now;
+ self.currentYear = initialDate.getFullYear();
+ self.currentMonth = initialDate.getMonth();
+ if (self.selectedDates.length)
+ self.latestSelectedDateObj = self.selectedDates[0];
+ if (self.config.minTime !== undefined)
+ self.config.minTime = self.parseDate(self.config.minTime, "H:i");
+ if (self.config.maxTime !== undefined)
+ self.config.maxTime = self.parseDate(self.config.maxTime, "H:i");
+ self.minDateHasTime =
+ !!self.config.minDate &&
+ (self.config.minDate.getHours() > 0 ||
+ self.config.minDate.getMinutes() > 0 ||
+ self.config.minDate.getSeconds() > 0);
+ self.maxDateHasTime =
+ !!self.config.maxDate &&
+ (self.config.maxDate.getHours() > 0 ||
+ self.config.maxDate.getMinutes() > 0 ||
+ self.config.maxDate.getSeconds() > 0);
+ Object.defineProperty(self, "showTimeInput", {
+ get: function () { return self._showTimeInput; },
+ set: function (bool) {
+ self._showTimeInput = bool;
+ if (self.calendarContainer)
+ toggleClass(self.calendarContainer, "showTimeInput", bool);
+ self.isOpen && positionCalendar();
+ },
+ });
+ }
+ function setupInputs() {
+ self.input = self.config.wrap
+ ? element.querySelector("[data-input]")
+ : element;
+ if (!self.input) {
+ self.config.errorHandler(new Error("Invalid input element specified"));
+ return;
+ }
+ self.input._type = self.input.type;
+ self.input.type = "text";
+ self.input.classList.add("flatpickr-input");
+ self._input = self.input;
+ if (self.config.altInput) {
+ self.altInput = createElement(self.input.nodeName, self.input.className + " " + self.config.altInputClass);
+ self._input = self.altInput;
+ self.altInput.placeholder = self.input.placeholder;
+ self.altInput.disabled = self.input.disabled;
+ self.altInput.required = self.input.required;
+ self.altInput.tabIndex = self.input.tabIndex;
+ self.altInput.type = "text";
+ self.input.type = "hidden";
+ if (!self.config.static && self.input.parentNode)
+ self.input.parentNode.insertBefore(self.altInput, self.input.nextSibling);
+ }
+ if (!self.config.allowInput)
+ self._input.setAttribute("readonly", "readonly");
+ self._positionElement = self.config.positionElement || self._input;
+ }
+ function setupMobile() {
+ var inputType = self.config.enableTime
+ ? self.config.noCalendar ? "time" : "datetime-local"
+ : "date";
+ self.mobileInput = createElement("input", self.input.className + " flatpickr-mobile");
+ self.mobileInput.step = self.input.getAttribute("step") || "any";
+ self.mobileInput.tabIndex = 1;
+ self.mobileInput.type = inputType;
+ self.mobileInput.disabled = self.input.disabled;
+ self.mobileInput.required = self.input.required;
+ self.mobileInput.placeholder = self.input.placeholder;
+ self.mobileFormatStr =
+ inputType === "datetime-local"
+ ? "Y-m-d\\TH:i:S"
+ : inputType === "date" ? "Y-m-d" : "H:i:S";
+ if (self.selectedDates.length) {
+ self.mobileInput.defaultValue = self.mobileInput.value = self.formatDate(self.selectedDates[0], self.mobileFormatStr);
+ }
+ if (self.config.minDate)
+ self.mobileInput.min = self.formatDate(self.config.minDate, "Y-m-d");
+ if (self.config.maxDate)
+ self.mobileInput.max = self.formatDate(self.config.maxDate, "Y-m-d");
+ self.input.type = "hidden";
+ if (self.altInput !== undefined)
+ self.altInput.type = "hidden";
+ try {
+ if (self.input.parentNode)
+ self.input.parentNode.insertBefore(self.mobileInput, self.input.nextSibling);
+ }
+ catch (_a) { }
+ bind(self.mobileInput, "change", function (e) {
+ self.setDate(e.target.value, false, self.mobileFormatStr);
+ triggerEvent("onChange");
+ triggerEvent("onClose");
+ });
+ }
+ function toggle() {
+ if (self.isOpen)
+ return self.close();
+ self.open();
+ }
+ function triggerEvent(event, data) {
+ var hooks = self.config[event];
+ if (hooks !== undefined && hooks.length > 0) {
+ for (var i = 0; hooks[i] && i < hooks.length; i++)
+ hooks[i](self.selectedDates, self.input.value, self, data);
+ }
+ if (event === "onChange") {
+ self.input.dispatchEvent(createEvent("change"));
+ self.input.dispatchEvent(createEvent("input"));
+ }
+ }
+ function createEvent(name) {
+ var e = document.createEvent("Event");
+ e.initEvent(name, true, true);
+ return e;
+ }
+ function isDateSelected(date) {
+ for (var i = 0; i < self.selectedDates.length; i++) {
+ if (compareDates(self.selectedDates[i], date) === 0)
+ return "" + i;
+ }
+ return false;
+ }
+ function isDateInRange(date) {
+ if (self.config.mode !== "range" || self.selectedDates.length < 2)
+ return false;
+ return (compareDates(date, self.selectedDates[0]) >= 0 &&
+ compareDates(date, self.selectedDates[1]) <= 0);
+ }
+ function updateNavigationCurrentMonth() {
+ if (self.config.noCalendar || self.isMobile || !self.monthNav)
+ return;
+ self.currentMonthElement.textContent =
+ monthToStr(self.currentMonth, self.config.shorthandCurrentMonth, self.l10n) + " ";
+ self.currentYearElement.value = self.currentYear.toString();
+ self._hidePrevMonthArrow =
+ self.config.minDate !== undefined &&
+ (self.currentYear === self.config.minDate.getFullYear()
+ ? self.currentMonth <= self.config.minDate.getMonth()
+ : self.currentYear < self.config.minDate.getFullYear());
+ self._hideNextMonthArrow =
+ self.config.maxDate !== undefined &&
+ (self.currentYear === self.config.maxDate.getFullYear()
+ ? self.currentMonth + 1 > self.config.maxDate.getMonth()
+ : self.currentYear > self.config.maxDate.getFullYear());
+ }
+ function updateValue(triggerChange) {
+ if (triggerChange === void 0) { triggerChange = true; }
+ if (!self.selectedDates.length)
+ return self.clear(triggerChange);
+ if (self.mobileInput !== undefined && self.mobileFormatStr) {
+ self.mobileInput.value =
+ self.latestSelectedDateObj !== undefined
+ ? self.formatDate(self.latestSelectedDateObj, self.mobileFormatStr)
+ : "";
+ }
+ var joinChar = self.config.mode !== "range"
+ ? self.config.conjunction
+ : self.l10n.rangeSeparator;
+ self.input.value = self.selectedDates
+ .map(function (dObj) { return self.formatDate(dObj, self.config.dateFormat); })
+ .join(joinChar);
+ if (self.altInput !== undefined) {
+ self.altInput.value = self.selectedDates
+ .map(function (dObj) { return self.formatDate(dObj, self.config.altFormat); })
+ .join(joinChar);
+ }
+ if (triggerChange !== false)
+ triggerEvent("onValueUpdate");
+ }
+ function onMonthNavClick(e) {
+ e.preventDefault();
+ var isPrevMonth = self.prevMonthNav.contains(e.target);
+ var isNextMonth = self.nextMonthNav.contains(e.target);
+ if (isPrevMonth || isNextMonth) {
+ changeMonth(isPrevMonth ? -1 : 1);
+ }
+ else if (e.target === self.currentYearElement) {
+ self.currentYearElement.select();
+ }
+ else if (e.target.className === "arrowUp") {
+ self.changeYear(self.currentYear + 1);
+ }
+ else if (e.target.className === "arrowDown") {
+ self.changeYear(self.currentYear - 1);
+ }
+ }
+ function timeWrapper(e) {
+ e.preventDefault();
+ var isKeyDown = e.type === "keydown", input = e.target;
+ if (self.amPM !== undefined && e.target === self.amPM) {
+ self.amPM.textContent =
+ self.l10n.amPM[int(self.amPM.textContent === self.l10n.amPM[0])];
+ }
+ var min = parseFloat(input.getAttribute("data-min")), max = parseFloat(input.getAttribute("data-max")), step = parseFloat(input.getAttribute("data-step")), curValue = parseInt(input.value, 10), delta = e.delta ||
+ (isKeyDown ? (e.which === 38 ? 1 : -1) : 0);
+ var newValue = curValue + step * delta;
+ if (typeof input.value !== "undefined" && input.value.length === 2) {
+ var isHourElem = input === self.hourElement, isMinuteElem = input === self.minuteElement;
+ if (newValue < min) {
+ newValue =
+ max +
+ newValue +
+ int(!isHourElem) +
+ (int(isHourElem) && int(!self.amPM));
+ if (isMinuteElem)
+ incrementNumInput(undefined, -1, self.hourElement);
+ }
+ else if (newValue > max) {
+ newValue =
+ input === self.hourElement ? newValue - max - int(!self.amPM) : min;
+ if (isMinuteElem)
+ incrementNumInput(undefined, 1, self.hourElement);
+ }
+ if (self.amPM &&
+ isHourElem &&
+ (step === 1
+ ? newValue + curValue === 23
+ : Math.abs(newValue - curValue) > step)) {
+ self.amPM.textContent =
+ self.l10n.amPM[int(self.amPM.textContent === self.l10n.amPM[0])];
+ }
+ input.value = pad(newValue);
+ }
+ }
+ init();
+ return self;
+}
+function _flatpickr(nodeList, config) {
+ var nodes = Array.prototype.slice.call(nodeList);
+ var instances = [];
+ for (var i = 0; i < nodes.length; i++) {
+ var node = nodes[i];
+ try {
+ if (node.getAttribute("data-fp-omit") !== null)
+ continue;
+ if (node._flatpickr !== undefined) {
+ node._flatpickr.destroy();
+ node._flatpickr = undefined;
+ }
+ node._flatpickr = FlatpickrInstance(node, config || {});
+ instances.push(node._flatpickr);
+ }
+ catch (e) {
+ console.error(e);
+ }
+ }
+ return instances.length === 1 ? instances[0] : instances;
+}
+if (typeof HTMLElement !== "undefined") {
+ HTMLCollection.prototype.flatpickr = NodeList.prototype.flatpickr = function (config) {
+ return _flatpickr(this, config);
+ };
+ HTMLElement.prototype.flatpickr = function (config) {
+ return _flatpickr([this], config);
+ };
+}
+var flatpickr;
+flatpickr = function (selector, config) {
+ if (selector instanceof NodeList)
+ return _flatpickr(selector, config);
+ else if (typeof selector === "string")
+ return _flatpickr(window.document.querySelectorAll(selector), config);
+ return _flatpickr([selector], config);
+};
+if (typeof window === "object")
+ window.flatpickr = flatpickr;
+flatpickr.defaultConfig = defaults;
+flatpickr.l10ns = {
+ en: __assign({}, english),
+ default: __assign({}, english),
+};
+flatpickr.localize = function (l10n) {
+ flatpickr.l10ns.default = __assign({}, flatpickr.l10ns.default, l10n);
+};
+flatpickr.setDefaults = function (config) {
+ flatpickr.defaultConfig = __assign({}, flatpickr.defaultConfig, config);
+};
+flatpickr.parseDate = createDateParser({});
+flatpickr.formatDate = createDateFormatter({});
+flatpickr.compareDates = compareDates;
+if (typeof jQuery !== "undefined") {
+ jQuery.fn.flatpickr = function (config) {
+ return _flatpickr(this, config);
+ };
+}
+Date.prototype.fp_incr = function (days) {
+ return new Date(this.getFullYear(), this.getMonth(), this.getDate() + (typeof days === "string" ? parseInt(days, 10) : days));
+};
var flatpickr$1 = flatpickr;
exports.default = flatpickr$1;
@@ -48152,9 +48184,6 @@ DataTable.__version__ = packageJson.version;
module.exports = DataTable;
});
-// eslint-disable-line
-
-
var modal = class Modal extends observable {
constructor({ title, body, primary, secondary }) {
super();
@@ -48607,9 +48636,6 @@ var formLayout = class FormLayout extends observable {
makeControls(fields, parent) {
for(let field of fields) {
if (!field.hidden && controls$1.getControlClass(field.fieldtype)) {
- if (this.inline) {
- field.inline = true;
- }
let control = controls$1.makeControl({field: field, form: this, parent: parent});
this.controlList.push(control);
this.controls[field.fieldname] = control;
@@ -54669,7 +54695,7 @@ module.exports = rawAsap;
function rawAsap(task) {
if (!queue.length) {
requestFlush();
-
+
}
// Equivalent to push, but avoids a function call.
queue[queue.length] = task;
@@ -54718,7 +54744,7 @@ function flush() {
}
queue.length = 0;
index = 0;
-
+
}
// `requestFlush` is implemented using a strategy based on data collected from
@@ -54879,27 +54905,27 @@ rawAsap.makeRequestCallFromTimer = makeRequestCallFromTimer;
/* 14 */
/***/ (function(module, exports) {
-var g;
-
-// This works in non-strict mode
-g = (function() {
- return this;
-})();
-
-try {
- // This works if eval is allowed (see CSP)
- g = g || Function("return this")() || (eval)("this");
-} catch(e) {
- // This works if the window reference is available
- if(typeof window === "object")
- g = window;
-}
-
-// g can still be undefined, but nothing to do about it...
-// We return undefined, instead of nothing here, so it's
-// easier to handle this case. if(!global) { ...}
-
-module.exports = g;
+var g;
+
+// This works in non-strict mode
+g = (function() {
+ return this;
+})();
+
+try {
+ // This works if eval is allowed (see CSP)
+ g = g || Function("return this")() || (eval)("this");
+} catch(e) {
+ // This works if the window reference is available
+ if(typeof window === "object")
+ g = window;
+}
+
+// g can still be undefined, but nothing to do about it...
+// We return undefined, instead of nothing here, so it's
+// easier to handle this case. if(!global) { ...}
+
+module.exports = g;
/***/ }),
@@ -54940,7 +54966,7 @@ var __WEBPACK_AMD_DEFINE_ARRAY__, __WEBPACK_AMD_DEFINE_RESULT__;// MIT license (
};
return makeCallback(0);
};
-
+
var _isArray = Array.isArray || function(maybeArray){
return Object.prototype.toString.call(maybeArray) === '[object Array]';
};
@@ -56784,7 +56810,7 @@ module.exports = installCompat;
/***/ })
/******/ ]);
});
-
+//# sourceMappingURL=nunjucks.js.map
});
unwrapExports(nunjucks);
@@ -56985,10 +57011,6 @@ var menu = class DeskMenu {
}
};
-// const Search = require('./search');
-
-
-
const views = {};
views.Form = formpage;
views.List = listpage;
@@ -57731,10 +57753,6 @@ var client = {
}
};
-// baseclass for report
-// `url` url for report
-// `getColumns` return columns
-
var reportpage = class ReportPage extends page {
constructor({title, filterFields}) {
super({title: title, hasRoute: true});
@@ -58633,6 +58651,215 @@ var TaxSummary = {
]
};
+var Address = {
+ "name": "Address",
+ "doctype": "DocType",
+ "isSingle": 0,
+ "titleField": "addressTitle",
+ "keywordFields": [
+ "addressTitle"
+ ],
+ pageSettings: {
+ hideTitle: true
+ },
+ "naming": "autoincrement",
+ "fields": [
+ {
+ "fieldname": "addressTitle",
+ "label": "Address Title",
+ "fieldtype": "Data",
+ "required": 1
+ },
+ {
+ "fieldname": "addressType",
+ "label": "Address Type",
+ "fieldtype": "Select",
+ "options": [
+ "Billing", "Shipping", "Office",
+ "Personal", "Plant", "Postal",
+ "Shop", "Subsidary", "Warehouse",
+ "Current", "Permanent", "Other"
+ ]
+ },
+ {
+ "fieldname": "addressLine1",
+ "label": "Address Line 1",
+ "fieldtype": "Data",
+ "required": 1
+ },
+ {
+ "fieldname": "addressLine2",
+ "label": "Address Line 2",
+ "fieldtype": "Data"
+ },
+ {
+ "fieldname": "city",
+ "label": "City / Town",
+ "fieldtype": "Data",
+ "required": 1
+ },
+ {
+ "fieldname": "county",
+ "label": "County",
+ "fieldtype": "Data"
+ },
+ {
+ "fieldname": "state",
+ "label": "State",
+ "fieldtype": "Data"
+ },
+ {
+ "fieldname": "country",
+ "label": "Country",
+ "fieldtype": "Data",
+ "required": 1
+ },
+ {
+ "fieldname": "postalCode",
+ "label": "Postal Code",
+ "fieldtype": "Data"
+ },
+ {
+ "fieldname": "emailAddress",
+ "label": "Email Address",
+ "fieldtype": "Data"
+ },
+ {
+ "fieldname": "phone",
+ "label": "Phone",
+ "fieldtype": "Data"
+ },
+ {
+ "fieldname": "fax",
+ "label": "Fax",
+ "fieldtype": "Data"
+ },
+ {
+ "fieldname": "isPreferredBilling",
+ "label": "Preferred Billing Address",
+ "fieldtype": "Check"
+ },
+ {
+ "fieldname": "isShippingBilling",
+ "label": "Preferred Shipping Address",
+ "fieldtype": "Check"
+ }
+ ],
+
+ events: {
+ validate: (doc) => {
+
+ }
+ },
+
+ listSettings: {
+ getFields(list) {
+ return ['addressTitle', 'addressType'];
+ },
+ getRowHTML(list, data) {
+ console.log(list, data);
+ return `${list.getNameHTML(data)} (${data.addressType})
`;
+ }
+ },
+
+ layout: [
+ // section 1
+ {
+ columns: [
+ {
+ fields: [ "addressTitle", "addressType", "addressLine1",
+ "addressLine2", "city", "county", "state", "country",
+ "postalCode"]
+ },
+ { fields: [ "emailAddress", "phone", "fax", "isPreferredBilling", "isShippingBilling" ] }
+ ]
+ }
+ ]
+};
+
+var Contact = {
+ "name": "Contact",
+ "doctype": "DocType",
+ "isSingle": 0,
+ "naming": "autoincrement",
+ "pageSettings": {
+ "hideTitle": true
+ },
+ "titleField": "fullName",
+ "keywordFields": [
+ "fullName"
+ ],
+ "titleField": "fullName",
+ "fields": [
+ {
+ "fieldname": "fullName",
+ "label": "Full Name",
+ "fieldtype": "Data",
+ "required": 1
+ },
+ {
+ "fieldname": "emailAddress",
+ "label": "Email Address",
+ "fieldtype": "Data"
+ },
+ {
+ "fieldname": "userId",
+ "label": "User ID",
+ "fieldtype": "Link",
+ "target": "User",
+ "hidden": 1
+ },
+ {
+ "fieldname": "status",
+ "label": "Status",
+ "fieldtype": "Select",
+ "options": ["Passive", "Open", "Replied"]
+ },
+ {
+ "fieldname": "gender",
+ "label": "Gender",
+ "fieldtype": "Select",
+ "options": ["Male", "Female", "Gender"]
+ },
+ {
+ "fieldname": "mobileNumber",
+ "label": "Mobile Number",
+ "fieldtype": "Data"
+ },
+ {
+ "fieldname": "phone",
+ "label": "Phone",
+ "fieldtype": "Data"
+ }
+ ],
+
+ events: {
+ validate: (doc) => {
+
+ }
+ },
+
+ listSettings: {
+ getFields(list) {
+ return ['fullName'];
+ },
+ getRowHTML(list, data) {
+ console.log(list, data);
+ return `${list.getNameHTML(data)}
`;
+ }
+ },
+
+ layout: [
+ // section 1
+ {
+ columns: [
+ { fields: [ "fullName", "emailAddress", "userId", "status" ] },
+ { fields: [ "postalCode", "gender", "phone", "mobileNumber" ] }
+ ]
+ }
+ ]
+};
+
var models$2 = {
models: {
Account: Account,
@@ -58651,7 +58878,9 @@ var models$2 = {
Tax: Tax,
TaxDetail: TaxDetail,
- TaxSummary: TaxSummary
+ TaxSummary: TaxSummary,
+ Address: Address,
+ Contact: Contact
}
};
@@ -58706,6 +58935,8 @@ var client$2 = {
frappejs.desk.menu.addItem('Items', '#list/Item');
frappejs.desk.menu.addItem('Customers', '#list/Customer');
frappejs.desk.menu.addItem('Invoice', '#list/Invoice');
+ frappejs.desk.menu.addItem('Address', "#list/Address");
+ frappejs.desk.menu.addItem('Contact', "#list/Contact");
frappejs.desk.menu.addItem('Settings', () => frappejs.desk.showFormModal('SystemSettings'));
frappejs.router.default = '#list/ToDo';
@@ -59154,7 +59385,6 @@ object-assign
@license MIT
*/
-/* eslint-disable no-unused-vars */
var getOwnPropertySymbols = Object.getOwnPropertySymbols;
var hasOwnProperty = Object.prototype.hasOwnProperty;
var propIsEnumerable = Object.prototype.propertyIsEnumerable;
@@ -59304,95 +59534,93 @@ var octicons = data$4;
const triangleRight = octicons["triangle-right"].toSVG({ "width": 5});
const triangleDown = octicons["triangle-down"].toSVG({ "width": 10});
const triangleLeft = octicons["triangle-left"].toSVG({ "width": 5});
+// const octiconPrimitiveDot = octicons["octicon-primitive-dot"].toSVG({ "width": 7});
var setup = class SetupWizard {
constructor({postSetup = () => {}}) {
this.slideList = [];
this.indicatorList = [];
- this.currentIndex = 0;
this.footerLinks = {};
+
+ this.currentIndex = 0;
this.data = {};
this.postSetup = postSetup;
+ this.make();
+
+ this.showSlide(this.currentIndex);
+ }
+
+ make() {
let body = document.querySelector('body');
-
- // container
this.container = frappejs.ui.add('form', 'setup-container container', body);
-
- // dots
this.$indicators = frappejs.ui.add('div', 'indicators vertical-margin align-center', this.container);
- // make form
+ this.makeSlides();
+ this.makeLinks();
+ }
+
+ makeSlides() {
config.forEach(config$$1 => {
this.formLayout = new formLayout(config$$1);
this.slideList.push(this.formLayout);
let form = this.formLayout.form;
-
- let title = document.createElement('h3');
- title.innerHTML = config$$1.title;
- title.classList.add('text-extra-muted');
- form.insertBefore(title, form.firstChild);
this.container.appendChild(form);
- let indicator = document.createElement('span');
- indicator.classList.add('indicator', 'gray');
- this.indicatorList.push(indicator);
- this.$indicators.appendChild(indicator);
- });
+ let title = frappejs.ui.create('h3', {
+ className: 'text-extra-muted',
+ innerHTML: config$$1.title
+ });
+ form.insertBefore(title, form.firstChild);
- // make links
+ let indicator = frappejs.ui.create('span', {
+ inside: this.$indicators,
+ className: 'indicator gray'
+ });
+ this.indicatorList.push(indicator);
+ });
+ }
+
+ makeLinks() {
this.linkArea = frappejs.ui.add('div', 'setup-link-area align-right', this.container);
- let links = [
- {
- label: 'Prev',
- name: 'prev',
- action: () => {
- this.prevSlide();
- }
- },
- {
- label: 'Next',
- name: 'next',
- action: () => {
- this.nextSlide();
- }
- },
- {
- label: 'Complete',
- name: 'complete',
- action: (data) => {
- this.postSetup();
- }
- }
- ];
// this.formLayout.on('change', () => {
// const show = this.doc._dirty && !this.doc.submitted;
// this.saveButton.classList.toggle('hide', !show);
// });
- links.map(link => {
+ this.getFooterLinks().map(link => {
let $link = utils$3.addLink(link.label, this.linkArea, () => {
+ this.buildData();
link.action(this.data);
});
this.footerLinks[link.name] = $link;
});
-
- this.showSlide(this.currentIndex);
}
- make() {
- //
+ buildData() {
+ this.data = {};
+ this.slideList.forEach(slide => {
+ Object.assign(this.data, slide.doc);
+ });
}
showSlide(index) {
utils$3.activate(this.container, this.slideList[index].form, 'form-body', 'active');
this.slideList[index].controlList[0].input.blur();
this.activateIndicator(index);
- this.setFooterLinks(index);
+ this.showFooterLinks(index);
this.currentIndex = index;
}
+ prevSlide() {
+ this.showSlide(this.currentIndex - 1);
+ }
+
+ nextSlide() {
+ this.showSlide(this.currentIndex + 1);
+ }
+
activateIndicator(index) {
this.indicatorList.forEach(indicator => {indicator.classList.add('gray');});
let indicator = this.indicatorList[index];
@@ -59402,39 +59630,49 @@ var setup = class SetupWizard {
indicator.classList.remove('gray');
}
- prevSlide() {
- this.showSlide(this.currentIndex - 1);
- }
-
- nextSlide() {
- this.showSlide(this.currentIndex + 1);
- }
-
- setFooterLinks(index) {
+ showFooterLinks(index) {
+ let mat = [1, 1, 0];
if(index === 0) {
- this.footerLinks.prev.classList.add('hide');
- this.footerLinks.next.classList.remove('hide');
- this.footerLinks.complete.classList.add('hide');
+ mat = [0, 1, 0];
} else if (index === this.slideList.length - 1) {
- this.footerLinks.prev.classList.remove('hide');
- this.footerLinks.next.classList.add('hide');
- this.footerLinks.complete.classList.remove('hide');
- } else {
- this.footerLinks.prev.classList.remove('hide');
- this.footerLinks.next.classList.remove('hide');
- this.footerLinks.complete.classList.add('hide');
+ mat = [1, 0, 1];
}
+ this.showHideLinks(mat);
+ }
+ showHideLinks(matrix = [1, 1, 0]) {
+ let linkNames = this.getFooterLinks().map(link => link.name);
+ matrix.forEach((value, i) => {
+ const fn = value ? 'remove' : 'add';
+ this.footerLinks[linkNames[i]].classList[fn]('hide');
+ });
+ }
+
+ getFooterLinks() {
+ return [
+ {
+ label: 'Prev', name: 'prev',
+ action: this.prevSlide.bind(this)
+ },
+ {
+ label: 'Next', name: 'next',
+ action: this.nextSlide.bind(this)
+ },
+ {
+ label: 'Complete', name: 'complete',
+ action: this.postSetup.bind(this)
+ }
+ ];
}
};
-// start server
client.start({
server: 'localhost:8000',
makeDesk: 0
}).then(() => {
new setup({
postSetup: async (data) => {
+ console.log(data);
client.makeDesk(3);
client$2.start();
diff --git a/www/index.js b/www/index.js
index 0c1e020b..7eff7896 100644
--- a/www/index.js
+++ b/www/index.js
@@ -9,6 +9,7 @@ client.start({
}).then(() => {
new SetupWizard({
postSetup: async (data) => {
+ console.log(data);
client.makeDesk(3);
appClient.start();