@formio/js 5.1.0-dev.6211.5d30602 → 5.1.0-dev.6214.89da41f

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -5325,7 +5325,7 @@ eval("\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\n// A
5325
5325
  /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
5326
5326
 
5327
5327
  "use strict";
5328
- eval("\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nconst lodash_1 = __importDefault(__webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\"));\nconst moment_1 = __importDefault(__webpack_require__(/*! moment */ \"./node_modules/moment/moment.js\"));\nconst vanilla_text_mask_1 = __importDefault(__webpack_require__(/*! @formio/vanilla-text-mask */ \"./node_modules/@formio/vanilla-text-mask/dist/vanillaTextMask.js\"));\nconst EventEmitter_1 = __importDefault(__webpack_require__(/*! ./EventEmitter */ \"./lib/cjs/EventEmitter.js\"));\nconst Formio_1 = __webpack_require__(/*! ./Formio */ \"./lib/cjs/Formio.js\");\nconst utils_1 = __importDefault(__webpack_require__(/*! ./utils */ \"./lib/cjs/utils/index.js\"));\nconst core_1 = __webpack_require__(/*! @formio/core */ \"./node_modules/@formio/core/lib/index.js\");\nconst en_1 = __importDefault(__webpack_require__(/*! ./translations/en */ \"./lib/cjs/translations/en.js\"));\n/**\n * The root component for all elements within the Form.io renderer.\n */\nclass Element {\n constructor(options) {\n var _a;\n /**\n * The options for this component.\n * @type {{}}\n */\n this.options = Object.assign({\n language: 'en',\n highlightErrors: true,\n componentErrorClass: 'formio-error-wrapper',\n componentWarningClass: 'formio-warning-wrapper',\n row: '',\n namespace: 'formio'\n }, options || {});\n /**\n * The ID of this component. This value is auto-generated when the component is created, but\n * can also be provided from the component.id value passed into the constructor.\n * @type {string}\n */\n this.id = utils_1.default.getRandomComponentId();\n /**\n * An array of event handlers so that the destry command can deregister them.\n * @type {Array}\n */\n this.eventHandlers = [];\n // Use the i18next that is passed in, otherwise use the global version.\n this.options.i18n = this.options.i18n || {};\n if ((_a = this.options) === null || _a === void 0 ? void 0 : _a.language) {\n this.options.i18n.language = this.options.language;\n }\n this.options.i18next = this.i18next = this.options.i18next || core_1.I18n.init(Object.assign({ en: en_1.default }, this.options.i18n));\n /**\n * An instance of the EventEmitter class to handle the emitting and registration of events.\n * @type {EventEmitter}\n */\n this.events = (options && options.events) ? options.events : new EventEmitter_1.default();\n this.defaultMask = null;\n /**\n * Conditional to show or hide helplinks in editForm\n * @type {*|boolean}\n */\n this.helplinks = (this.options.helplinks === 'false') ? false : (this.options.helplinks || 'https://help.form.io');\n }\n /**\n * Register for a new event within this component.\n * @example\n * let component = new BaseComponent({\n * type: 'textfield',\n * label: 'First Name',\n * key: 'firstName'\n * });\n * component.on('componentChange', (changed) => {\n * console.log('this element is changed.');\n * });\n * @param {string} event - The event you wish to register the handler for.\n * @param {Function} cb - The callback handler to handle this event.\n * @param {boolean} [internal] - This is an internal event handler.\n * @param {boolean} [once] - This event should only fire once.\n * @returns {EventEmitter | void} - The event emitter instance.\n */\n on(event, cb, internal, once = false) {\n if (!this.events) {\n return;\n }\n const type = `${this.options.namespace}.${event}`;\n // Store the component id in the handler so that we can determine which events are for this component.\n cb.id = this.id;\n cb.key = this.key;\n cb.internal = internal;\n // Register for this event.\n return this.events[once ? 'once' : 'on'](type, cb);\n }\n /**\n * Register for a new single-fire event within this component.\n * @param {string} event - The event you wish to register the handler for.\n * @param {Function} cb - The callback handler to handle this event.\n * @param {boolean} internal - This is an internal event handler.\n * @returns {EventEmitter} - The event emitter instance.\n */\n once(event, cb, internal) {\n return this.on(event, cb, internal, true);\n }\n /**\n * Allow catching any event.\n * @param {Function} cb - The callback handler to handle this event.\n * @returns {EventEmitter | void} - The event emitter instance.\n */\n onAny(cb) {\n if (!this.events) {\n return;\n }\n return this.events.onAny(cb);\n }\n /**\n * Removes the listener that will be fired when any event is emitted.\n * @param {Function} cb - The callback handler to handle this event.\n * @returns {EventEmitter | void} - The event emitter instance.\n */\n offAny(cb) {\n if (!this.events) {\n return;\n }\n return this.events.offAny(cb);\n }\n /**\n * Removes a listener for a certain event. Not passing the 2nd arg will remove all listeners for that event.\n * @param {string} event - The event you wish to register the handler for.\n * @param {Function | undefined} cb - The callback handler to handle this event.\n */\n off(event, cb) {\n if (!this.events) {\n return;\n }\n const type = `${this.options.namespace}.${event}`;\n this.events.listeners(type).forEach((listener) => {\n // Ensure the listener is for this element\n if (!listener || listener.id !== this.id) {\n return;\n }\n // If there is a given callback, only deal with the match\n if (cb && cb !== listener) {\n return;\n }\n this.events.off(type, listener);\n });\n }\n /**\n * Emit a new event.\n * @param {string} event - The event to emit.\n * @param {object} data - The data to emit with the handler.\n */\n emit(event, ...data) {\n if (this.events) {\n this.events.emit(`${this.options.namespace}.${event}`, ...data);\n }\n }\n /**\n * Check if the component has an event handler set up for the event.\n * @param {string} event - The event name.\n * @returns {boolean} - TRUE if the event is registered, FALSE otherwise.\n */\n hasEventHandler(event) {\n if (!this.events) {\n return false;\n }\n const type = `${this.options.namespace}.${event}`;\n return this.events.listeners(type).some((listener) => {\n if (!listener) {\n return false;\n }\n return listener.id === this.id || listener.key === this.key;\n });\n }\n /**\n * Wrapper method to add an event listener to an HTML element.\n * @param {HtmlElement} obj - The DOM element to add the event to.\n * @param {string} type - The event name to add.\n * @param {Function} func - The callback function to be executed when the listener is triggered.\n * @param {boolean} persistent - If this listener should persist beyond \"destroy\" commands.\n * @param {boolean} capture - If this listener should be executed in the capture phase.\n * @returns {void | this} - The instance of the element.\n */\n addEventListener(obj, type, func, persistent, capture) {\n if (!obj) {\n return;\n }\n if (!persistent) {\n this.eventHandlers.push({ id: this.id, obj, type, func });\n }\n if ('addEventListener' in obj) {\n obj.addEventListener(type, func, !!capture);\n }\n else if ('attachEvent' in obj) {\n obj.attachEvent(`on${type}`, func);\n }\n return this;\n }\n /**\n * Remove an event listener from the object.\n * @param {HTMLElement} obj - The DOM element to remove the event from.\n * @param {string} type - The event name to remove.\n * @param {Function} func - The callback function to remove.\n * @returns {this | void} - The instance of the element.\n */\n removeEventListener(obj, type, func = null) {\n const indexes = [];\n if (!obj) {\n return;\n }\n this.eventHandlers.forEach((handler, index) => {\n if ((handler.id === this.id)\n && obj.removeEventListener\n && (handler.type === type)\n && (!func || handler.func === func)) {\n obj.removeEventListener(type, handler.func);\n indexes.push(index);\n }\n });\n if (indexes.length) {\n lodash_1.default.pullAt(this.eventHandlers, indexes);\n }\n return this;\n }\n removeEventListeners() {\n this.eventHandlers.forEach(handler => {\n if ((this.id === handler.id) && handler.type && handler.obj && handler.obj.removeEventListener) {\n handler.obj.removeEventListener(handler.type, handler.func);\n }\n });\n this.eventHandlers = [];\n }\n removeAllEvents(includeExternal) {\n if (this.events) {\n lodash_1.default.each(this.events._events, (events, type) => {\n lodash_1.default.each(events, (listener) => {\n if (listener && (this.id === listener.id) && (includeExternal || listener.internal)) {\n this.events.off(type, listener);\n }\n });\n });\n }\n }\n teardown() {\n delete this.i18next;\n delete this.events;\n }\n /**\n * Removes all event listeners attached to this component.\n * @param {boolean} all - If all events should be removed, including external events.\n */\n destroy(all = false) {\n this.removeEventListeners();\n this.removeAllEvents();\n if (all) {\n this.teardown();\n }\n }\n /**\n * Append an HTML DOM element to a container.\n * @param {HTMLElement} element - The DOM element to append.\n * @param {HTMLElement} container - The DOM element that is the container of the element getting appended.\n * @returns {this} - The instance of the element.\n */\n appendTo(element, container) {\n container === null || container === void 0 ? void 0 : container.appendChild(element);\n return this;\n }\n /**\n * Prepend an HTML DOM element to a container.\n * @param {HTMLElement} element - The DOM element to prepend.\n * @param {HTMLElement} container - The DOM element that is the container of the element getting prepended.\n * @returns {this} - The instance of the element.\n */\n prependTo(element, container) {\n if (container) {\n if (container.firstChild) {\n try {\n container.insertBefore(element, container.firstChild);\n }\n catch (err) {\n console.warn(err);\n container.appendChild(element);\n }\n }\n else {\n container.appendChild(element);\n }\n }\n return this;\n }\n /**\n * Removes an HTML DOM element from its bounding container.\n * @param {HTMLElement} element - The element to remove.\n * @param {HTMLElement} container - The DOM element that is the container of the element to remove.\n * @returns {this} - The instance of the element.\n */\n removeChildFrom(element, container) {\n if (container && container.contains(element)) {\n try {\n container.removeChild(element);\n }\n catch (err) {\n console.warn(err);\n }\n }\n return this;\n }\n /**\n * Alias for document.createElement.\n * @param {string} type - The type of element to create\n * @param {object} attr - The element attributes to add to the created element.\n * @param {Various} children - Child elements. Can be a DOM Element, string or array of both.\n * @returns {HTMLElement} - The created element.\n */\n ce(type, attr, children = null) {\n // console.warn('Call to deprecated this.ce(). Dom elements should be created with templates, not manually with ce.');\n // Create the element.\n const element = document.createElement(type);\n // Add attributes.\n if (attr) {\n this.attr(element, attr);\n }\n // Append the children.\n this.appendChild(element, children);\n return element;\n }\n /**\n * Append different types of children.\n * @param {HTMLElement} element - The element to append to.\n * @param {HTMLElement} child - The child element to append.\n * @returns {this} - The instance of the element.\n */\n appendChild(element, child) {\n if (Array.isArray(child)) {\n child.forEach((oneChild) => this.appendChild(element, oneChild));\n }\n else if (child instanceof HTMLElement || child instanceof Text) {\n element.appendChild(child);\n }\n else if (child) {\n element.appendChild(this.text(child.toString()));\n }\n return this;\n }\n /**\n * Creates a new input mask placeholder.\n * @param {HTMLElement} mask - The input mask.\n * @returns {string} - The placeholder that will exist within the input as they type.\n */\n maskPlaceholder(mask) {\n return mask.map((char) => (char instanceof RegExp) ? this.placeholderChar : char).join('');\n }\n /**\n * Get the placeholder character for the input mask.\n * @returns {string} - The placeholder character.\n */\n get placeholderChar() {\n var _a;\n return ((_a = this.component) === null || _a === void 0 ? void 0 : _a.inputMaskPlaceholderChar) || '_';\n }\n /**\n * Sets the input mask for an input.\n * @param {HTMLElement} input - The html input to apply the mask to.\n * @param {string} inputMask - The input mask to add to this input.\n * @param {boolean} usePlaceholder - Set the mask placeholder on the input.\n */\n setInputMask(input, inputMask, usePlaceholder) {\n if (input && inputMask) {\n const mask = utils_1.default.getInputMask(inputMask, this.placeholderChar);\n this.defaultMask = mask;\n try {\n //destroy previous mask\n if (input.mask) {\n input.mask.destroy();\n }\n input.mask = (0, vanilla_text_mask_1.default)({\n inputElement: input,\n mask,\n placeholderChar: this.placeholderChar,\n shadowRoot: this.root ? this.root.shadowRoot : null\n });\n }\n catch (e) {\n // Don't pass error up, to prevent form rejection.\n // Internal bug of vanilla-text-mask on iOS (`selectionEnd`);\n console.warn(e);\n }\n if (mask.numeric) {\n input.setAttribute('pattern', '\\\\d*');\n }\n if (usePlaceholder) {\n input.setAttribute('placeholder', this.maskPlaceholder(mask));\n }\n }\n }\n /**\n * Translate a text using the i18n system.\n * @param {string|Array<string>} text - The i18n identifier.\n * @param {any} data - contextual data object containing data, component, row, etc.\n * @param {...any} args - The arguments to pass to the i18n translation.\n * @returns {string} - The translated text.\n */\n t(text, data, ...args) {\n return this.i18next ? this.i18next.t(text, data, ...args) : text;\n }\n /**\n * Alias to create a text node.\n * @param {string} text - The text to create.\n * @returns {HtmlElement} - The created text node.\n */\n text(text) {\n return document.createTextNode(this.t(text));\n }\n /**\n * Adds an object of attributes onto an element.\n * @param {HtmlElement} element - The element to add the attributes to.\n * @param {object} attr - The attributes to add to the input element.\n */\n attr(element, attr) {\n if (!element) {\n return;\n }\n lodash_1.default.each(attr, (value, key) => {\n if (typeof value !== 'undefined') {\n if (key.indexOf('on') === 0) {\n // If this is an event, add a listener.\n this.addEventListener(element, key.substr(2).toLowerCase(), value);\n }\n else {\n // Otherwise it is just an attribute.\n element.setAttribute(key, value);\n }\n }\n });\n }\n /**\n * Determines if an element has a class.\n *\n * Taken from jQuery https://j11y.io/jquery/#v=1.5.0&fn=jQuery.fn.hasClass\n * @param {HTMLElement} element - The element to check for the class.\n * @param {string} className - The class to check for.\n * @returns {boolean} - TRUE if the element has the class, FALSE otherwise.\n */\n hasClass(element, className) {\n if (!element) {\n return false;\n }\n // Allow templates to intercept.\n className = ` ${className} `;\n return ((` ${element.className} `).replace(/[\\n\\t\\r]/g, ' ').indexOf(className) > -1);\n }\n /**\n * Adds a class to a DOM element.\n * @param {HTMLElement} element - The element to add a class to.\n * @param {string} className - The name of the class to add.\n * @returns {this} - The instance of the element.\n */\n addClass(element, className) {\n if (!element || !(element instanceof HTMLElement)) {\n return this;\n }\n // Allow templates to intercept.\n const classes = element.getAttribute('class');\n if (!(classes === null || classes === void 0 ? void 0 : classes.includes(className))) {\n element.setAttribute('class', `${classes} ${className}`);\n }\n return this;\n }\n /**\n * Remove a class from a DOM element.\n * @param {HTMLElement} element - The DOM element to remove the class from.\n * @param {string} className - The name of the class that is to be removed.\n * @returns {this} - The instance of the element.\n */\n removeClass(element, className) {\n if (!element || !className || !(element instanceof HTMLElement)) {\n return this;\n }\n // Allow templates to intercept.\n let cls = element.getAttribute('class');\n if (cls) {\n cls = cls.replace(new RegExp(` ${className}`, 'g'), '');\n element.setAttribute('class', cls);\n }\n return this;\n }\n /**\n * Empty's an HTML DOM element.\n * @param {HTMLElement} element - The element you wish to empty.\n */\n empty(element) {\n if (element) {\n while (element.firstChild) {\n element.removeChild(element.firstChild);\n }\n }\n }\n /**\n * Create an evaluation context for all script executions and interpolations.\n * @param {object} additional - Additional context to apply to the evaluation context.\n * @returns {*} - The evaluation context.\n */\n evalContext(additional) {\n var _a;\n return Object.assign({\n _: lodash_1.default,\n utils: utils_1.default,\n util: utils_1.default,\n user: Formio_1.Formio.getUser(),\n moment: moment_1.default,\n instance: this,\n self: this,\n token: Formio_1.Formio.getToken({\n decode: true\n }),\n options: this.options,\n config: this.root && this.root.form && this.root.form.config\n ? this.root.form.config\n : ((_a = this.options) === null || _a === void 0 ? void 0 : _a.formConfig)\n ? this.options.formConfig\n : {},\n }, additional, lodash_1.default.get(this.root, 'options.evalContext', {}));\n }\n /**\n * Performs an interpolation using the evaluation context of this component.\n * @param {string} string - The string to interpolate.\n * @param {object} data - The data to use in the interpolation.\n * @param {object} options - The options to pass to the interpolation.\n * @returns {XML|string|*|void} - The interpolated string.\n */\n interpolate(string, data, options = {}) {\n if (typeof string !== 'function' && (this.component.content || this.component.html)\n && !utils_1.default.Evaluator.templateSettings.interpolate.test(string)) {\n string = utils_1.default.translateHTMLTemplate(String(string), (value) => this.t(value));\n }\n if (this.component.filter === string && !this.options.building) {\n const evalContext = this.evalContext(data);\n evalContext.data = lodash_1.default.mapValues(evalContext.data, (val) => lodash_1.default.isString(val) ? encodeURIComponent(val) : val);\n return utils_1.default.Evaluator.interpolate(string, evalContext, options);\n }\n return utils_1.default.Evaluator.interpolate(string, this.evalContext(data), options);\n }\n /**\n * Performs an evaluation using the evaluation context of this component.\n * @param {string|Function|object} func - The function or string to evaluate.\n * @param {object} args - The arguments to pass to the evaluation.\n * @param {string} ret - The name of the variable within the evaluation context to return.\n * @param {boolean} interpolate - Determines if it should replace all {{ }} token references with actual data.\n * @param {import('@formio/core').EvaluatorOptions} options - The options to pass to the evaluation.\n * @returns {*} - The result of the evaluation.\n */\n evaluate(func, args, ret, interpolate, options = {}) {\n return utils_1.default.evaluate(func, this.evalContext(args), ret, interpolate, options);\n }\n /**\n * Allow for options to hook into the functionality of this renderer.\n * @returns {*} - The result of the hook function.\n */\n hook() {\n const name = arguments[0];\n if (this.options &&\n this.options.hooks &&\n this.options.hooks[name]) {\n return this.options.hooks[name].apply(this, Array.prototype.slice.call(arguments, 1));\n }\n else {\n // If this is an async hook instead of a sync.\n const fn = (typeof arguments[arguments.length - 1] === 'function') ? arguments[arguments.length - 1] : null;\n if (fn) {\n return fn(null, arguments[1]);\n }\n else {\n return arguments[1];\n }\n }\n }\n}\nexports[\"default\"] = Element;\n\n\n//# sourceURL=webpack://Formio/./lib/cjs/Element.js?");
5328
+ eval("\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nconst lodash_1 = __importDefault(__webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\"));\nconst moment_1 = __importDefault(__webpack_require__(/*! moment */ \"./node_modules/moment/moment.js\"));\nconst vanilla_text_mask_1 = __importDefault(__webpack_require__(/*! @formio/vanilla-text-mask */ \"./node_modules/@formio/vanilla-text-mask/dist/vanillaTextMask.js\"));\nconst EventEmitter_1 = __importDefault(__webpack_require__(/*! ./EventEmitter */ \"./lib/cjs/EventEmitter.js\"));\nconst Formio_1 = __webpack_require__(/*! ./Formio */ \"./lib/cjs/Formio.js\");\nconst utils_1 = __importDefault(__webpack_require__(/*! ./utils */ \"./lib/cjs/utils/index.js\"));\nconst core_1 = __webpack_require__(/*! @formio/core */ \"./node_modules/@formio/core/lib/index.js\");\nconst en_1 = __importDefault(__webpack_require__(/*! ./translations/en */ \"./lib/cjs/translations/en.js\"));\n/**\n * The root component for all elements within the Form.io renderer.\n */\nclass Element {\n constructor(options) {\n var _a;\n /**\n * The options for this component.\n * @type {{}}\n */\n this.options = Object.assign({\n language: 'en',\n highlightErrors: true,\n componentErrorClass: 'formio-error-wrapper',\n componentWarningClass: 'formio-warning-wrapper',\n row: '',\n namespace: 'formio'\n }, options || {});\n /**\n * The ID of this component. This value is auto-generated when the component is created, but\n * can also be provided from the component.id value passed into the constructor.\n * @type {string}\n */\n this.id = utils_1.default.getRandomComponentId();\n /**\n * An array of event handlers so that the destry command can deregister them.\n * @type {Array}\n */\n this.eventHandlers = [];\n // Use the i18next that is passed in, otherwise use the global version.\n this.options.i18n = this.options.i18n || {};\n if ((_a = this.options) === null || _a === void 0 ? void 0 : _a.language) {\n this.options.i18n.language = this.options.language;\n }\n this.options.i18next = this.i18next = this.options.i18next || core_1.I18n.init(Object.assign({ en: en_1.default }, this.options.i18n));\n /**\n * An instance of the EventEmitter class to handle the emitting and registration of events.\n * @type {EventEmitter}\n */\n this.events = (options && options.events) ? options.events : new EventEmitter_1.default();\n this.defaultMask = null;\n /**\n * Conditional to show or hide helplinks in editForm\n * @type {*|boolean}\n */\n this.helplinks = (this.options.helplinks === 'false') ? false : (this.options.helplinks || 'https://help.form.io');\n }\n /**\n * Register for a new event within this component.\n * @example\n * let component = new BaseComponent({\n * type: 'textfield',\n * label: 'First Name',\n * key: 'firstName'\n * });\n * component.on('componentChange', (changed) => {\n * console.log('this element is changed.');\n * });\n * @param {string} event - The event you wish to register the handler for.\n * @param {Function} cb - The callback handler to handle this event.\n * @param {boolean} [internal] - This is an internal event handler.\n * @param {boolean} [once] - This event should only fire once.\n * @returns {EventEmitter | void} - The event emitter instance.\n */\n on(event, cb, internal, once = false) {\n if (!this.events) {\n return;\n }\n const type = `${this.options.namespace}.${event}`;\n // Store the component id in the handler so that we can determine which events are for this component.\n cb.id = this.id;\n cb.key = this.key;\n cb.internal = internal;\n // Register for this event.\n return this.events[once ? 'once' : 'on'](type, cb);\n }\n /**\n * Register for a new single-fire event within this component.\n * @param {string} event - The event you wish to register the handler for.\n * @param {Function} cb - The callback handler to handle this event.\n * @param {boolean} internal - This is an internal event handler.\n * @returns {EventEmitter} - The event emitter instance.\n */\n once(event, cb, internal) {\n return this.on(event, cb, internal, true);\n }\n /**\n * Allow catching any event.\n * @param {Function} cb - The callback handler to handle this event.\n * @returns {EventEmitter | void} - The event emitter instance.\n */\n onAny(cb) {\n if (!this.events) {\n return;\n }\n return this.events.onAny(cb);\n }\n /**\n * Removes the listener that will be fired when any event is emitted.\n * @param {Function} cb - The callback handler to handle this event.\n * @returns {EventEmitter | void} - The event emitter instance.\n */\n offAny(cb) {\n if (!this.events) {\n return;\n }\n return this.events.offAny(cb);\n }\n /**\n * Removes a listener for a certain event. Not passing the 2nd arg will remove all listeners for that event.\n * @param {string} event - The event you wish to register the handler for.\n * @param {Function | undefined} cb - The callback handler to handle this event.\n */\n off(event, cb) {\n if (!this.events) {\n return;\n }\n const type = `${this.options.namespace}.${event}`;\n this.events.listeners(type).forEach((listener) => {\n // Ensure the listener is for this element\n if (!listener || listener.id !== this.id) {\n return;\n }\n // If there is a given callback, only deal with the match\n if (cb && cb !== listener) {\n return;\n }\n this.events.off(type, listener);\n });\n }\n /**\n * Emit a new event.\n * @param {string} event - The event to emit.\n * @param {object} data - The data to emit with the handler.\n */\n emit(event, ...data) {\n if (this.events) {\n this.events.emit(`${this.options.namespace}.${event}`, ...data);\n }\n }\n /**\n * Check if the component has an event handler set up for the event.\n * @param {string} event - The event name.\n * @returns {boolean} - TRUE if the event is registered, FALSE otherwise.\n */\n hasEventHandler(event) {\n if (!this.events) {\n return false;\n }\n const type = `${this.options.namespace}.${event}`;\n return this.events.listeners(type).some((listener) => {\n if (!listener) {\n return false;\n }\n return listener.id === this.id || listener.key === this.key;\n });\n }\n /**\n * Wrapper method to add an event listener to an HTML element.\n * @param {HtmlElement} obj - The DOM element to add the event to.\n * @param {string} type - The event name to add.\n * @param {Function} func - The callback function to be executed when the listener is triggered.\n * @param {boolean} persistent - If this listener should persist beyond \"destroy\" commands.\n * @param {boolean} capture - If this listener should be executed in the capture phase.\n * @returns {void | this} - The instance of the element.\n */\n addEventListener(obj, type, func, persistent, capture) {\n if (!obj) {\n return;\n }\n if (!persistent) {\n this.eventHandlers.push({ id: this.id, obj, type, func });\n }\n if ('addEventListener' in obj) {\n obj.addEventListener(type, func, !!capture);\n }\n else if ('attachEvent' in obj) {\n obj.attachEvent(`on${type}`, func);\n }\n return this;\n }\n /**\n * Remove an event listener from the object.\n * @param {HTMLElement} obj - The DOM element to remove the event from.\n * @param {string} type - The event name to remove.\n * @param {Function} func - The callback function to remove.\n * @returns {this | void} - The instance of the element.\n */\n removeEventListener(obj, type, func = null) {\n const indexes = [];\n if (!obj) {\n return;\n }\n this.eventHandlers.forEach((handler, index) => {\n if ((handler.id === this.id)\n && obj.removeEventListener\n && (handler.type === type)\n && (!func || handler.func === func)) {\n obj.removeEventListener(type, handler.func);\n indexes.push(index);\n }\n });\n if (indexes.length) {\n lodash_1.default.pullAt(this.eventHandlers, indexes);\n }\n return this;\n }\n removeEventListeners() {\n this.eventHandlers.forEach(handler => {\n if ((this.id === handler.id) && handler.type && handler.obj && handler.obj.removeEventListener) {\n handler.obj.removeEventListener(handler.type, handler.func);\n }\n });\n this.eventHandlers = [];\n }\n removeAllEvents(includeExternal) {\n if (this.events) {\n lodash_1.default.each(this.events._events, (events, type) => {\n lodash_1.default.each(events, (listener) => {\n if (listener && (this.id === listener.id) && (includeExternal || listener.internal)) {\n this.events.off(type, listener);\n }\n });\n });\n }\n }\n teardown() {\n delete this.i18next;\n delete this.events;\n }\n /**\n * Removes all event listeners attached to this component.\n * @param {boolean} all - If all events should be removed, including external events.\n */\n destroy(all = false) {\n this.removeEventListeners();\n this.removeAllEvents();\n if (all) {\n this.teardown();\n }\n }\n /**\n * Append an HTML DOM element to a container.\n * @param {HTMLElement} element - The DOM element to append.\n * @param {HTMLElement} container - The DOM element that is the container of the element getting appended.\n * @returns {this} - The instance of the element.\n */\n appendTo(element, container) {\n container === null || container === void 0 ? void 0 : container.appendChild(element);\n return this;\n }\n /**\n * Prepend an HTML DOM element to a container.\n * @param {HTMLElement} element - The DOM element to prepend.\n * @param {HTMLElement} container - The DOM element that is the container of the element getting prepended.\n * @returns {this} - The instance of the element.\n */\n prependTo(element, container) {\n if (container) {\n if (container.firstChild) {\n try {\n container.insertBefore(element, container.firstChild);\n }\n catch (err) {\n console.warn(err);\n container.appendChild(element);\n }\n }\n else {\n container.appendChild(element);\n }\n }\n return this;\n }\n /**\n * Removes an HTML DOM element from its bounding container.\n * @param {HTMLElement} element - The element to remove.\n * @param {HTMLElement} container - The DOM element that is the container of the element to remove.\n * @returns {this} - The instance of the element.\n */\n removeChildFrom(element, container) {\n if (container && container.contains(element)) {\n try {\n container.removeChild(element);\n }\n catch (err) {\n console.warn(err);\n }\n }\n return this;\n }\n /**\n * Alias for document.createElement.\n * @param {string} type - The type of element to create\n * @param {object} attr - The element attributes to add to the created element.\n * @param {Various} children - Child elements. Can be a DOM Element, string or array of both.\n * @returns {HTMLElement} - The created element.\n */\n ce(type, attr, children = null) {\n // console.warn('Call to deprecated this.ce(). Dom elements should be created with templates, not manually with ce.');\n // Create the element.\n const element = document.createElement(type);\n // Add attributes.\n if (attr) {\n this.attr(element, attr);\n }\n // Append the children.\n this.appendChild(element, children);\n return element;\n }\n /**\n * Append different types of children.\n * @param {HTMLElement} element - The element to append to.\n * @param {HTMLElement} child - The child element to append.\n * @returns {this} - The instance of the element.\n */\n appendChild(element, child) {\n if (Array.isArray(child)) {\n child.forEach((oneChild) => this.appendChild(element, oneChild));\n }\n else if (child instanceof HTMLElement || child instanceof Text) {\n element.appendChild(child);\n }\n else if (child) {\n element.appendChild(this.text(child.toString()));\n }\n return this;\n }\n /**\n * Creates a new input mask placeholder.\n * @param {HTMLElement} mask - The input mask.\n * @returns {string} - The placeholder that will exist within the input as they type.\n */\n maskPlaceholder(mask) {\n return mask.map((char) => (char instanceof RegExp) ? this.placeholderChar : char).join('');\n }\n /**\n * Get the placeholder character for the input mask.\n * @returns {string} - The placeholder character.\n */\n get placeholderChar() {\n var _a;\n return ((_a = this.component) === null || _a === void 0 ? void 0 : _a.inputMaskPlaceholderChar) || '_';\n }\n /**\n * Sets the input mask for an input.\n * @param {HTMLElement} input - The html input to apply the mask to.\n * @param {string} inputMask - The input mask to add to this input.\n * @param {boolean} usePlaceholder - Set the mask placeholder on the input.\n */\n setInputMask(input, inputMask, usePlaceholder) {\n if (input && inputMask) {\n const mask = utils_1.default.getInputMask(inputMask, this.placeholderChar);\n this.defaultMask = mask;\n try {\n //destroy previous mask\n if (input.mask) {\n input.mask.destroy();\n }\n input.mask = (0, vanilla_text_mask_1.default)({\n inputElement: input,\n mask,\n placeholderChar: this.placeholderChar,\n shadowRoot: this.root ? this.root.shadowRoot : null\n });\n }\n catch (e) {\n // Don't pass error up, to prevent form rejection.\n // Internal bug of vanilla-text-mask on iOS (`selectionEnd`);\n console.warn(e);\n }\n if (mask.numeric) {\n input.setAttribute('pattern', '\\\\d*');\n }\n if (usePlaceholder) {\n input.setAttribute('placeholder', this.maskPlaceholder(mask));\n }\n }\n }\n /**\n * Translate a text using the i18n system.\n * @param {string|Array<string>} text - The i18n identifier.\n * @param {any} data - contextual data object containing data, component, row, etc.\n * @param {...any} args - The arguments to pass to the i18n translation.\n * @returns {string} - The translated text.\n */\n t(text, data, ...args) {\n return this.i18next ? this.i18next.t(text, data, ...args) : text;\n }\n /**\n * Alias to create a text node.\n * @param {string} text - The text to create.\n * @returns {HtmlElement} - The created text node.\n */\n text(text) {\n return document.createTextNode(this.t(text));\n }\n /**\n * Adds an object of attributes onto an element.\n * @param {HtmlElement} element - The element to add the attributes to.\n * @param {object} attr - The attributes to add to the input element.\n */\n attr(element, attr) {\n if (!element) {\n return;\n }\n lodash_1.default.each(attr, (value, key) => {\n if (typeof value !== 'undefined') {\n if (key.indexOf('on') === 0) {\n // If this is an event, add a listener.\n this.addEventListener(element, key.substr(2).toLowerCase(), value);\n }\n else {\n // Otherwise it is just an attribute.\n element.setAttribute(key, value);\n }\n }\n });\n }\n /**\n * Determines if an element has a class.\n *\n * Taken from jQuery https://j11y.io/jquery/#v=1.5.0&fn=jQuery.fn.hasClass\n * @param {HTMLElement} element - The element to check for the class.\n * @param {string} className - The class to check for.\n * @returns {boolean} - TRUE if the element has the class, FALSE otherwise.\n */\n hasClass(element, className) {\n if (!element) {\n return false;\n }\n // Allow templates to intercept.\n className = ` ${className} `;\n return ((` ${element.className} `).replace(/[\\n\\t\\r]/g, ' ').indexOf(className) > -1);\n }\n /**\n * Adds a class to a DOM element.\n * @param {HTMLElement} element - The element to add a class to.\n * @param {string} className - The name of the class to add.\n * @returns {this} - The instance of the element.\n */\n addClass(element, className) {\n if (!element || !(element instanceof HTMLElement)) {\n return this;\n }\n // Allow templates to intercept.\n const classes = element.getAttribute('class');\n if (!(classes === null || classes === void 0 ? void 0 : classes.includes(className))) {\n element.setAttribute('class', `${classes} ${className}`);\n }\n return this;\n }\n /**\n * Remove a class from a DOM element.\n * @param {HTMLElement} element - The DOM element to remove the class from.\n * @param {string} className - The name of the class that is to be removed.\n * @returns {this} - The instance of the element.\n */\n removeClass(element, className) {\n if (!element || !className || !(element instanceof HTMLElement)) {\n return this;\n }\n // Allow templates to intercept.\n let cls = element.getAttribute('class');\n if (cls) {\n cls = cls.replace(new RegExp(` ${className}`, 'g'), '');\n element.setAttribute('class', cls);\n }\n return this;\n }\n /**\n * Empty's an HTML DOM element.\n * @param {HTMLElement} element - The element you wish to empty.\n */\n empty(element) {\n if (element) {\n while (element.firstChild) {\n element.removeChild(element.firstChild);\n }\n }\n }\n /**\n * Create an evaluation context for all script executions and interpolations.\n * @param {object} additional - Additional context to apply to the evaluation context.\n * @returns {*} - The evaluation context.\n */\n evalContext(additional) {\n var _a;\n return Object.assign({\n _: lodash_1.default,\n utils: utils_1.default,\n util: utils_1.default,\n user: Formio_1.Formio.getUser(),\n moment: moment_1.default,\n instance: this,\n self: this,\n token: Formio_1.Formio.getToken({\n decode: true\n }),\n options: this.options,\n config: this.root && this.root.form && this.root.form.config\n ? this.root.form.config\n : ((_a = this.options) === null || _a === void 0 ? void 0 : _a.formConfig)\n ? this.options.formConfig\n : {},\n }, additional, lodash_1.default.get(this.root, 'options.evalContext', {}));\n }\n /**\n * Performs an interpolation using the evaluation context of this component.\n * @param {string} string - The string to interpolate.\n * @param {object} data - The data to use in the interpolation.\n * @param {object} options - The options to pass to the interpolation.\n * @returns {XML|string|*|void} - The interpolated string.\n */\n interpolate(string, data, options = {}) {\n if (typeof string !== 'function' && (this.component.content || this.component.html)\n && !utils_1.default.Evaluator.templateSettings.interpolate.test(string)) {\n string = utils_1.default.translateHTMLTemplate(String(string), (value) => this.t(value));\n }\n if (this.component.filter === string && !this.options.building) {\n const evalContext = this.evalContext(data);\n evalContext.data = lodash_1.default.mapValues(evalContext.data, (val) => lodash_1.default.isString(val) ? encodeURIComponent(val) : val);\n return utils_1.default.interpolate(string, evalContext, options);\n }\n return utils_1.default.interpolate(string, this.evalContext(data), options);\n }\n /**\n * Performs an evaluation using the evaluation context of this component.\n * @param {string|Function|object} func - The function or string to evaluate.\n * @param {object} args - The arguments to pass to the evaluation.\n * @param {string} ret - The name of the variable within the evaluation context to return.\n * @param {boolean} interpolate - Determines if it should replace all {{ }} token references with actual data.\n * @param {import('@formio/core').EvaluatorOptions} options - The options to pass to the evaluation.\n * @returns {*} - The result of the evaluation.\n */\n evaluate(func, args, ret, interpolate, options = {}) {\n return utils_1.default.evaluate(func, this.evalContext(args), ret, interpolate, options);\n }\n /**\n * Allow for options to hook into the functionality of this renderer.\n * @returns {*} - The result of the hook function.\n */\n hook() {\n const name = arguments[0];\n if (this.options &&\n this.options.hooks &&\n this.options.hooks[name]) {\n return this.options.hooks[name].apply(this, Array.prototype.slice.call(arguments, 1));\n }\n else {\n // If this is an async hook instead of a sync.\n const fn = (typeof arguments[arguments.length - 1] === 'function') ? arguments[arguments.length - 1] : null;\n if (fn) {\n return fn(null, arguments[1]);\n }\n else {\n return arguments[1];\n }\n }\n }\n}\nexports[\"default\"] = Element;\n\n\n//# sourceURL=webpack://Formio/./lib/cjs/Element.js?");
5329
5329
 
5330
5330
  /***/ }),
5331
5331
 
@@ -8119,7 +8119,7 @@ eval("\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nexpo
8119
8119
  /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
8120
8120
 
8121
8121
  "use strict";
8122
- eval("\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nexports.registerEvaluator = exports.Evaluator = exports.Utils = void 0;\nconst utils = __importStar(__webpack_require__(/*! ./utils */ \"./lib/cjs/utils/utils.js\"));\nconst formUtils = __importStar(__webpack_require__(/*! ./formUtils */ \"./lib/cjs/utils/formUtils.js\"));\nconst Evaluator_1 = __webpack_require__(/*! ./Evaluator */ \"./lib/cjs/utils/Evaluator.js\");\nObject.defineProperty(exports, \"Evaluator\", ({ enumerable: true, get: function () { return Evaluator_1.Evaluator; } }));\nObject.defineProperty(exports, \"registerEvaluator\", ({ enumerable: true, get: function () { return Evaluator_1.registerEvaluator; } }));\nconst conditionOperators_1 = __importDefault(__webpack_require__(/*! ./conditionOperators */ \"./lib/cjs/utils/conditionOperators/index.js\"));\nconst lodash_1 = __importDefault(__webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\"));\nconst moment_1 = __importDefault(__webpack_require__(/*! moment */ \"./node_modules/moment/moment.js\"));\nconst FormioUtils = Object.assign(Object.assign(Object.assign({}, utils), formUtils), { Evaluator: Evaluator_1.Evaluator,\n interpolate: Evaluator_1.interpolate,\n ConditionOperators: conditionOperators_1.default,\n _: lodash_1.default,\n moment: moment_1.default });\nexports.Utils = FormioUtils;\nif (typeof __webpack_require__.g === 'object') {\n __webpack_require__.g.FormioUtils = FormioUtils;\n}\n__exportStar(__webpack_require__(/*! ./utils */ \"./lib/cjs/utils/utils.js\"), exports);\n__exportStar(__webpack_require__(/*! ./formUtils */ \"./lib/cjs/utils/formUtils.js\"), exports);\nexports[\"default\"] = FormioUtils;\n\n\n//# sourceURL=webpack://Formio/./lib/cjs/utils/index.js?");
8122
+ eval("\nvar __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n var desc = Object.getOwnPropertyDescriptor(m, k);\n if (!desc || (\"get\" in desc ? !m.__esModule : desc.writable || desc.configurable)) {\n desc = { enumerable: true, get: function() { return m[k]; } };\n }\n Object.defineProperty(o, k2, desc);\n}) : (function(o, m, k, k2) {\n if (k2 === undefined) k2 = k;\n o[k2] = m[k];\n}));\nvar __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\n}) : function(o, v) {\n o[\"default\"] = v;\n});\nvar __importStar = (this && this.__importStar) || function (mod) {\n if (mod && mod.__esModule) return mod;\n var result = {};\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\n __setModuleDefault(result, mod);\n return result;\n};\nvar __exportStar = (this && this.__exportStar) || function(m, exports) {\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(exports, p)) __createBinding(exports, m, p);\n};\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nexports.registerEvaluator = exports.Evaluator = exports.Utils = void 0;\nconst utils = __importStar(__webpack_require__(/*! ./utils */ \"./lib/cjs/utils/utils.js\"));\nconst formUtils = __importStar(__webpack_require__(/*! ./formUtils */ \"./lib/cjs/utils/formUtils.js\"));\nconst Evaluator_1 = __webpack_require__(/*! ./Evaluator */ \"./lib/cjs/utils/Evaluator.js\");\nObject.defineProperty(exports, \"Evaluator\", ({ enumerable: true, get: function () { return Evaluator_1.Evaluator; } }));\nObject.defineProperty(exports, \"registerEvaluator\", ({ enumerable: true, get: function () { return Evaluator_1.registerEvaluator; } }));\nconst conditionOperators_1 = __importDefault(__webpack_require__(/*! ./conditionOperators */ \"./lib/cjs/utils/conditionOperators/index.js\"));\nconst lodash_1 = __importDefault(__webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\"));\nconst moment_1 = __importDefault(__webpack_require__(/*! moment */ \"./node_modules/moment/moment.js\"));\nconst FormioUtils = Object.assign(Object.assign(Object.assign({}, utils), formUtils), { DefaultEvaluator: Evaluator_1.DefaultEvaluator,\n Evaluator: Evaluator_1.Evaluator,\n interpolate: Evaluator_1.interpolate,\n ConditionOperators: conditionOperators_1.default,\n _: lodash_1.default,\n moment: moment_1.default });\nexports.Utils = FormioUtils;\nif (typeof __webpack_require__.g === 'object') {\n __webpack_require__.g.FormioUtils = FormioUtils;\n}\n__exportStar(__webpack_require__(/*! ./utils */ \"./lib/cjs/utils/utils.js\"), exports);\n__exportStar(__webpack_require__(/*! ./formUtils */ \"./lib/cjs/utils/formUtils.js\"), exports);\nexports[\"default\"] = FormioUtils;\n\n\n//# sourceURL=webpack://Formio/./lib/cjs/utils/index.js?");
8123
8123
 
8124
8124
  /***/ }),
8125
8125
 
@@ -8141,7 +8141,7 @@ eval("\nvar __importDefault = (this && this.__importDefault) || function (mod) {
8141
8141
  /***/ (function(__unused_webpack_module, exports, __webpack_require__) {
8142
8142
 
8143
8143
  "use strict";
8144
- eval("\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nconst moment_1 = __importDefault(__webpack_require__(/*! moment */ \"./node_modules/moment/moment.js\"));\nconst lodash_1 = __importDefault(__webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\"));\nconst Formio_1 = __webpack_require__(/*! ../Formio */ \"./lib/cjs/Formio.js\");\nconst InputWidget_1 = __importDefault(__webpack_require__(/*! ./InputWidget */ \"./lib/cjs/widgets/InputWidget.js\"));\nconst utils_1 = __webpack_require__(/*! ../utils */ \"./lib/cjs/utils/index.js\");\nconst DEFAULT_FORMAT = 'yyyy-MM-dd hh:mm a';\nconst ISO_8601_FORMAT = 'yyyy-MM-ddTHH:mm:ssZ';\nconst isIEBrowser = (0, utils_1.getBrowserInfo)().ie;\nclass CalendarWidget extends InputWidget_1.default {\n /* eslint-disable camelcase */\n static get defaultSettings() {\n return {\n type: 'calendar',\n altInput: true,\n allowInput: true,\n clickOpens: true,\n enableDate: true,\n enableTime: true,\n mode: 'single',\n noCalendar: false,\n format: DEFAULT_FORMAT,\n dateFormat: ISO_8601_FORMAT,\n useLocaleSettings: false,\n language: 'us-en',\n hourIncrement: 1,\n minuteIncrement: 5,\n time_24hr: false,\n saveAs: 'date',\n displayInTimezone: '',\n timezone: '',\n disable: [],\n minDate: '',\n maxDate: ''\n };\n }\n /* eslint-enable camelcase */\n constructor(settings, component, instance, index) {\n super(settings, component, instance, index);\n // Change the format to map to the settings.\n if (this.settings.noCalendar) {\n this.settings.format = this.settings.format.replace(/yyyy-MM-dd /g, '');\n }\n if (!this.settings.enableTime) {\n this.settings.format = this.settings.format.replace(/ hh:mm a$/g, '');\n }\n else if (this.settings.time_24hr) {\n this.settings.format = this.settings.format.replace(/hh:mm a$/g, 'HH:mm');\n }\n }\n attach(input) {\n var _a;\n const superAttach = super.attach(input);\n const dateFormatInfo = (0, utils_1.getLocaleDateFormatInfo)(this.settings.language);\n this.defaultFormat = {\n date: dateFormatInfo.dayFirst ? 'd/m/Y ' : 'm/d/Y ',\n time: 'G:i K'\n };\n this.closedOn = 0;\n this.valueFormat = (this.settings.saveAs === 'date') ? ISO_8601_FORMAT : this.settings.dateFormat || ISO_8601_FORMAT;\n this.valueMomentFormat = (0, utils_1.convertFormatToDayjs)(this.valueFormat);\n const isReadOnly = this.settings.readOnly;\n this.settings.minDate = isReadOnly ? null : (0, utils_1.getDateSetting)(this.settings.minDate);\n this.settings.maxDate = isReadOnly ? null : (0, utils_1.getDateSetting)(this.settings.maxDate);\n this.settings.disable = this.disabledDates;\n this.settings.disableWeekends ? this.settings.disable.push(this.disableWeekends) : '';\n this.settings.disableWeekdays ? this.settings.disable.push(this.disableWeekdays) : '';\n this.settings.disableFunction ? this.settings.disable.push(this.disableFunction) : '';\n this.settings.manualInputValue = '';\n this.settings.isManuallyOverriddenValue = false;\n this.settings.currentValue = '';\n this.settings.altFormat = (0, utils_1.convertFormatToFlatpickr)(this.settings.format);\n this.settings.dateFormat = (0, utils_1.convertFormatToFlatpickr)(this.settings.dateFormat);\n this.settings.position = 'auto center';\n this.settings.onChange = () => {\n if (this.settings.allowInput && this.settings.enableTime) {\n this.calendar._input.value = this.settings.isManuallyOverriddenValue ? this.settings.manualInputValue : this.calendar.altInput.value;\n }\n this.emit('update');\n };\n this.settings.onOpen = () => this.hook('onCalendarOpen');\n this.settings.onClose = () => {\n this.hook('onCalendarClose');\n this.closedOn = Date.now();\n if (this.settings.allowInput && this.settings.enableTime) {\n this.calendar._input.value = this.settings.isManuallyOverriddenValue ? this.settings.manualInputValue : this.calendar.altInput.value;\n this.emit('update');\n }\n if (this.calendar) {\n this.emit('blur');\n }\n };\n Formio_1.Formio.requireLibrary('flatpickr-css', 'flatpickr', [\n { type: 'styles', src: `${Formio_1.Formio.cdn['flatpickr']}/flatpickr.min.css` }\n ], true);\n if (this.component.shortcutButtons) {\n this.component.shortcutButtons = this.component.shortcutButtons.filter((btn) => btn.label && btn.onClick);\n }\n if ((_a = this.component.shortcutButtons) === null || _a === void 0 ? void 0 : _a.length) {\n Formio_1.Formio.requireLibrary('shortcut-buttons-flatpickr-css', 'ShortcutButtonsPlugin', [\n { type: 'styles', src: `${Formio_1.Formio.cdn['shortcut-buttons-flatpickr']}/themes/light.min.css` }\n ], true);\n }\n return superAttach\n .then(() => {\n var _a;\n if ((_a = this.component.shortcutButtons) === null || _a === void 0 ? void 0 : _a.length) {\n return Formio_1.Formio.requireLibrary('shortcut-buttons-flatpickr', 'ShortcutButtonsPlugin', `${Formio_1.Formio.cdn['shortcut-buttons-flatpickr']}/shortcut-buttons-flatpickr.min.js`, true);\n }\n })\n .then((ShortcutButtonsPlugin) => {\n return Formio_1.Formio.requireLibrary('flatpickr', 'flatpickr', `${Formio_1.Formio.cdn['flatpickr']}/flatpickr.min.js`, true)\n .then((Flatpickr) => {\n var _a;\n if (((_a = this.component.shortcutButtons) === null || _a === void 0 ? void 0 : _a.length) && ShortcutButtonsPlugin) {\n this.initShortcutButtonsPlugin(ShortcutButtonsPlugin);\n }\n this.settings.formatDate = this.getFlatpickrFormatDate(Flatpickr);\n if (this._input) {\n const { locale } = this.settings;\n if (locale && locale.length >= 2 && locale !== 'en') {\n return Formio_1.Formio.requireLibrary(`flatpickr-${locale}`, `flatpickr.l10ns.${locale}`, `${Formio_1.Formio.cdn['flatpickr']}/l10n/${locale}.js`, true)\n .catch(() => {\n // fallback to en if locale fails to load\n this.settings.locale = 'en';\n })\n .finally(() => {\n this.initFlatpickr(Flatpickr);\n });\n }\n else {\n this.initFlatpickr(Flatpickr);\n }\n }\n });\n })\n .catch((err) => {\n console.warn(err);\n });\n }\n get disableWeekends() {\n return function (date) {\n return (date.getDay() === 0 || date.getDay() === 6);\n };\n }\n get disableWeekdays() {\n return (date) => !this.disableWeekends(date);\n }\n get disableFunction() {\n return (date) => this.evaluate(`return ${this.settings.disableFunction}`, {\n date\n });\n }\n get timezone() {\n return this.componentInstance.getTimezone(this.settings);\n }\n get defaultSettings() {\n return CalendarWidget.defaultSettings;\n }\n addSuffix(suffix) {\n this.addEventListener(suffix, 'click', () => {\n setTimeout(() => {\n if (this.calendar) {\n if (!this.calendar.isOpen && ((Date.now() - this.closedOn) > 200)) {\n this.calendar.open();\n }\n else if (this.calendar.isOpen) {\n this.calendar.close();\n }\n }\n }, 0);\n });\n return suffix;\n }\n set disabled(disabled) {\n super.disabled = disabled;\n if (this.calendar) {\n if (disabled) {\n this.calendar._input.setAttribute('disabled', 'disabled');\n }\n else {\n this.calendar._input.removeAttribute('disabled');\n }\n this.calendar.close();\n this.calendar.redraw();\n }\n }\n get input() {\n return this.calendar ? this.calendar.altInput : null;\n }\n get disabledDates() {\n if (this.settings.disabledDates) {\n const disabledDates = this.settings.disabledDates.split(',');\n return disabledDates.map((item) => {\n const dateMask = /\\d{4}-\\d{2}-\\d{2}/g;\n const dates = item.match(dateMask);\n if (dates && dates.length) {\n return dates.length === 1 ? item.match(dateMask)[0] : {\n from: item.match(dateMask)[0],\n to: item.match(dateMask)[1],\n };\n }\n });\n }\n return [];\n }\n get localeFormat() {\n let format = '';\n if (this.settings.enableDate) {\n format += this.defaultFormat.date;\n }\n if (this.settings.enableTime) {\n format += this.defaultFormat.time;\n }\n return format;\n }\n get dateTimeFormat() {\n return this.settings.useLocaleSettings ? this.localeFormat : (0, utils_1.convertFormatToFlatpickr)(this.dateFormat);\n }\n get dateFormat() {\n return lodash_1.default.get(this.settings, 'format', DEFAULT_FORMAT);\n }\n /**\n * Return the date value as a string.\n * @param {string|Date} date - The date object or a date string that is momentjs compatible.\n * @param {string} format - The DateParser code format.\n * @param {boolean} [useTimezone] - If the timezone should be used.\n * @returns {string} - Returns the formatted date string.\n */\n getDateValue(date, format, useTimezone) {\n if (useTimezone) {\n return (0, utils_1.dayjsDate)(date, this.valueFormat, this.timezone).format((0, utils_1.convertFormatToDayjs)(format));\n }\n return (0, moment_1.default)(date).format((0, utils_1.convertFormatToDayjs)(format));\n }\n /**\n * Return the value of the selected date.\n * @returns {*} - The value of the selected date.\n */\n getValue() {\n // Standard output format.\n if (!this.calendar) {\n return super.getValue();\n }\n if (this.settings.isManuallyOverriddenValue) {\n return this.settings.manualInputValue;\n }\n // Get the selected dates from the calendar widget.\n const dates = this.calendar.selectedDates;\n if (!dates || !dates.length) {\n return super.getValue();\n }\n if (!(dates[0] instanceof Date)) {\n return 'Invalid Date';\n }\n return this.getDateValue(dates[0], this.valueFormat, (this.settings.saveAs === 'date'));\n }\n isValueISO8601(value) {\n return value && (typeof value === 'string') && value.match(/-[0-9]{2}T[0-9]{2}:/);\n }\n /**\n * Set the selected date value.\n * @param {*} value - The value to set.\n * @returns {void}\n */\n setValue(value) {\n const saveAsText = (this.settings.saveAs === 'text');\n if (!this.calendar) {\n value = value ? (0, utils_1.formatDate)(value, (0, utils_1.convertFormatToDayjs)(this.settings.format), this.timezone, (0, utils_1.convertFormatToDayjs)(this.valueMomentFormat)) : value;\n return super.setValue(value);\n }\n // If the component is a textfield that does not have timezone information included in the string value then skip\n // the timezone offset\n this.settings.skipOffset = this.component.type === 'textfield' && !(0, utils_1.hasEncodedTimezone)(value);\n if (value) {\n if (!saveAsText && this.settings.readOnly) {\n this.calendar.setDate((0, utils_1.dayjsDate)(value, this.valueFormat, this.timezone).format(), false);\n }\n else if (this.isValueISO8601(value)) {\n this.calendar.setDate(value, false);\n }\n else {\n this.calendar.setDate((0, moment_1.default)(value, this.valueMomentFormat).toDate(), false);\n }\n }\n else {\n this.calendar.clear(false);\n }\n }\n getValueAsString(value, format = '') {\n const inputFormat = format || this.dateFormat;\n const valueFormat = this.calendar ? this.valueFormat : this.settings.dateFormat;\n if (this.settings.saveAs === 'text' && this.componentInstance.parent && !this.settings.readOnly) {\n return (0, moment_1.default)(value, (0, utils_1.convertFormatToDayjs)(valueFormat)).format((0, utils_1.convertFormatToDayjs)(valueFormat));\n }\n return (0, utils_1.formatDate)(value, inputFormat, this.timezone, (0, utils_1.convertFormatToDayjs)(valueFormat));\n }\n setErrorClasses(hasErrors) {\n if (!this.input) {\n return;\n }\n if (hasErrors) {\n this.addClass(this.input, 'is-invalid');\n this.input.setAttribute('aria-invalid', 'true');\n }\n else {\n this.removeClass(this.input, 'is-invalid');\n this.input.setAttribute('aria-invalid', 'false');\n }\n }\n get validationValue() {\n const value = this.dataValue;\n if (typeof value === 'string') {\n return new Date(value);\n }\n return value.map(val => new Date(val));\n }\n isCalendarElement(element) {\n var _a, _b, _c, _d, _e;\n if (!element) {\n return true;\n }\n if ((_c = (_b = (_a = this.calendar) === null || _a === void 0 ? void 0 : _a.config) === null || _b === void 0 ? void 0 : _b.appendTo) === null || _c === void 0 ? void 0 : _c.contains(element)) {\n return true;\n }\n return (_e = (_d = this.calendar) === null || _d === void 0 ? void 0 : _d.calendarContainer) === null || _e === void 0 ? void 0 : _e.contains(element);\n }\n initFlatpickr(Flatpickr) {\n // Create a new flatpickr.\n this.calendar = new Flatpickr(this._input, Object.assign(Object.assign({}, this.settings), { disableMobile: true }));\n this.addEventListener(this.calendar.altInput, 'input', (event) => {\n if (this.settings.allowInput && this.settings.currentValue !== event.target.value) {\n if (event.target.mask) {\n event.target.mask.textMaskInputElement.update();\n }\n this.settings.manualInputValue = event.target.value;\n this._input.value = this.settings.manualInputValue;\n this.settings.isManuallyOverriddenValue = true;\n this.settings.currentValue = event.target.value;\n this.emit('update');\n }\n });\n if (this.calendar.daysContainer) {\n this.calendar.daysContainer.addEventListener('click', () => {\n this.settings.isManuallyOverriddenValue = false;\n this.calendar.updateValue(false);\n });\n }\n if (this.calendar.timeContainer) {\n this.calendar.timeContainer.addEventListener('click', () => {\n this.settings.isManuallyOverriddenValue = false;\n this.calendar.updateValue(false);\n });\n }\n // Move input attributes to altInput.\n const labelledbyIds = this.calendar.input.getAttribute('aria-labelledby');\n const isRequired = this.calendar.input.getAttribute('aria-required');\n this.calendar.altInput.id = this._input.id;\n this.calendar.altInput.setAttribute('aria-labelledby', labelledbyIds);\n this.calendar.altInput.setAttribute('aria-required', isRequired);\n this._input.removeAttribute('id');\n this._input.removeAttribute('aria-labelledby');\n this._input.removeAttribute('aria-required');\n const excludedFromMaskFormats = ['MMMM'];\n if (!this.settings.readOnly && !lodash_1.default.some(excludedFromMaskFormats, format => lodash_1.default.includes(this.settings.format, format))) {\n // Enforce the input mask of the format.\n this.setInputMask(this.calendar._input, (0, utils_1.convertFormatToMask)(this.settings.format));\n }\n // Fixes an issue with IE11 where value is set only after the second click\n // TODO: Remove when the issue is solved in the flatpickr library\n if (isIEBrowser) {\n // Remove the original blur listener, because value will be set to empty since relatedTarget is null in IE11\n const originalBlurListener = this.calendar._handlers.find(({ event, element }) => event === 'blur' && element === this.calendar._input);\n this.calendar._input.removeEventListener('blur', originalBlurListener.handler);\n // Add the same event listener as in the original library, but with workaround for IE11 issue\n this.addEventListener(this.calendar._input, 'blur', (event) => {\n const activeElement = this.settings.shadowRoot ? this.settings.shadowRoot.activeElement : document.activeElement;\n const relatedTarget = event.relatedTarget ? event.relatedTarget : activeElement;\n const isInput = event.target === this.calendar._input;\n if (isInput && !this.isCalendarElement(relatedTarget)) {\n this.calendar.setDate(this.calendar._input.value, true, event.target === this.calendar.altInput\n ? this.calendar.config.altFormat\n : this.calendar.config.dateFormat);\n }\n });\n }\n // Make sure we commit the value after a blur event occurs.\n this.addEventListener(this.calendar._input, 'blur', (event) => {\n var _a, _b, _c, _d;\n // If we have manually overridden the value then we shouldn't call setDate because this will fill the input mask\n if (this.settings.isManuallyOverriddenValue) {\n return;\n }\n const activeElement = this.settings.shadowRoot ? this.settings.shadowRoot.activeElement : document.activeElement;\n const relatedTarget = event.relatedTarget ? event.relatedTarget : activeElement;\n if (!(isIEBrowser && !relatedTarget) && !this.isCalendarElement(relatedTarget)) {\n const inputValue = this.calendar.input.value;\n const dateValue = inputValue ? (0, moment_1.default)(this.calendar.input.value, (0, utils_1.convertFormatToDayjs)(this.valueFormat)).toDate() : inputValue;\n this.calendar.setDate(dateValue, true, this.settings.altFormat);\n }\n else if (!this.calendar.input.value && this.calendar.config.noCalendar) {\n const value = (0, moment_1.default)({ hour: (_b = (_a = this.calendar) === null || _a === void 0 ? void 0 : _a.config) === null || _b === void 0 ? void 0 : _b.defaultHour, minute: (_d = (_c = this.calendar) === null || _c === void 0 ? void 0 : _c.config) === null || _d === void 0 ? void 0 : _d.defaultMinute }).toDate();\n this.calendar.setDate(value, true, this.settings.format);\n }\n });\n // FJS-1103: When hit the enter button, the field not saving the year correctly\n this.addEventListener(this.calendar.altInput, 'keydown', (event) => {\n if (event.keyCode === 13) {\n if (this.calendar.isOpen) {\n this.calendar.close();\n event.stopPropagation();\n }\n }\n });\n // If other fields are used to calculate disabled dates, we need to redraw calendar to refresh disabled dates\n if (this.settings.disableFunction && this.componentInstance && this.componentInstance.root) {\n this.componentInstance.root.on('change', (e) => {\n if (e.changed && this.calendar) {\n this.calendar.redraw();\n }\n });\n }\n // Restore the calendar value from the component value.\n this.setValue(this.componentValue);\n }\n initShortcutButtonsPlugin(ShortcutButtonsPlugin) {\n this.settings.plugins = [\n // eslint-disable-next-line new-cap\n ShortcutButtonsPlugin({\n button: this.component.shortcutButtons.map((btn) => ({ label: btn.label, attributes: btn.attribute })),\n onClick: (index) => {\n const getValue = this.component.shortcutButtons[index].onClick;\n const date = this.evaluate(getValue, { date: new Date() }, 'date');\n this.calendar.setDate(date, true);\n }\n })\n ];\n }\n get componentValue() {\n let compValue = this.componentInstance.dataValue;\n if (Array.isArray(compValue)) {\n compValue = compValue[this.valueIndex];\n }\n return compValue;\n }\n getFlatpickrFormatDate(Flatpickr) {\n return (date, format) => {\n // Only format this if this is the altFormat and the form is readOnly.\n if (this.settings.readOnly && (format === this.settings.altFormat)) {\n if (!this.settings.enableTime || this.settings.skipOffset) {\n return Flatpickr.formatDate(date, format);\n }\n const currentValue = new Date(this.getValue());\n if (currentValue.toString() === date.toString()) {\n return (0, utils_1.formatOffset)(Flatpickr.formatDate.bind(Flatpickr), new Date(this.componentValue), format, this.timezone);\n }\n return (0, utils_1.formatOffset)(Flatpickr.formatDate.bind(Flatpickr), date, format, this.timezone);\n }\n return Flatpickr.formatDate(date, format);\n };\n }\n destroy(all = false) {\n if (this.calendar) {\n this.calendar.destroy();\n }\n super.destroy(all);\n }\n}\nexports[\"default\"] = CalendarWidget;\n\n\n//# sourceURL=webpack://Formio/./lib/cjs/widgets/CalendarWidget.js?");
8144
+ eval("\nvar __importDefault = (this && this.__importDefault) || function (mod) {\n return (mod && mod.__esModule) ? mod : { \"default\": mod };\n};\nObject.defineProperty(exports, \"__esModule\", ({ value: true }));\nconst moment_1 = __importDefault(__webpack_require__(/*! moment */ \"./node_modules/moment/moment.js\"));\nconst lodash_1 = __importDefault(__webpack_require__(/*! lodash */ \"./node_modules/lodash/lodash.js\"));\nconst Formio_1 = __webpack_require__(/*! ../Formio */ \"./lib/cjs/Formio.js\");\nconst InputWidget_1 = __importDefault(__webpack_require__(/*! ./InputWidget */ \"./lib/cjs/widgets/InputWidget.js\"));\nconst utils_1 = __webpack_require__(/*! ../utils */ \"./lib/cjs/utils/index.js\");\nconst DEFAULT_FORMAT = 'yyyy-MM-dd hh:mm a';\nconst ISO_8601_FORMAT = 'yyyy-MM-ddTHH:mm:ssZ';\nconst isIEBrowser = (0, utils_1.getBrowserInfo)().ie;\nclass CalendarWidget extends InputWidget_1.default {\n /* eslint-disable camelcase */\n static get defaultSettings() {\n return {\n type: 'calendar',\n altInput: true,\n allowInput: true,\n clickOpens: true,\n enableDate: true,\n enableTime: true,\n mode: 'single',\n noCalendar: false,\n format: DEFAULT_FORMAT,\n dateFormat: ISO_8601_FORMAT,\n useLocaleSettings: false,\n language: 'us-en',\n hourIncrement: 1,\n minuteIncrement: 5,\n time_24hr: false,\n saveAs: 'date',\n displayInTimezone: '',\n timezone: '',\n disable: [],\n minDate: '',\n maxDate: ''\n };\n }\n /* eslint-enable camelcase */\n constructor(settings, component, instance, index) {\n super(settings, component, instance, index);\n // Change the format to map to the settings.\n if (this.settings.noCalendar) {\n this.settings.format = this.settings.format.replace(/yyyy-MM-dd /g, '');\n }\n if (!this.settings.enableTime) {\n this.settings.format = this.settings.format.replace(/ hh:mm a$/g, '');\n }\n else if (this.settings.time_24hr) {\n this.settings.format = this.settings.format.replace(/hh:mm a$/g, 'HH:mm');\n }\n }\n attach(input) {\n var _a;\n const superAttach = super.attach(input);\n const dateFormatInfo = (0, utils_1.getLocaleDateFormatInfo)(this.settings.language);\n this.defaultFormat = {\n date: dateFormatInfo.dayFirst ? 'd/m/Y ' : 'm/d/Y ',\n time: 'G:i K'\n };\n this.closedOn = 0;\n this.valueFormat = (this.settings.saveAs === 'date') ? ISO_8601_FORMAT : this.settings.dateFormat || ISO_8601_FORMAT;\n this.valueMomentFormat = (0, utils_1.convertFormatToDayjs)(this.valueFormat);\n const isReadOnly = this.settings.readOnly;\n this.settings.minDate = isReadOnly ? null : (0, utils_1.getDateSetting)(this.settings.minDate);\n this.settings.maxDate = isReadOnly ? null : (0, utils_1.getDateSetting)(this.settings.maxDate);\n this.settings.disable = this.disabledDates;\n this.settings.disableWeekends ? this.settings.disable.push(this.disableWeekends) : '';\n this.settings.disableWeekdays ? this.settings.disable.push(this.disableWeekdays) : '';\n this.settings.disableFunction ? this.settings.disable.push(this.disableFunction) : '';\n this.settings.manualInputValue = '';\n this.settings.isManuallyOverriddenValue = false;\n this.settings.currentValue = '';\n this.settings.altFormat = (0, utils_1.convertFormatToFlatpickr)(this.settings.format);\n this.settings.dateFormat = (0, utils_1.convertFormatToFlatpickr)(this.settings.dateFormat);\n this.settings.position = 'auto center';\n this.settings.onChange = () => {\n if (this.settings.allowInput && this.settings.enableTime) {\n this.calendar._input.value = this.settings.isManuallyOverriddenValue ? this.settings.manualInputValue : this.calendar.altInput.value;\n }\n this.emit('update');\n };\n this.settings.onOpen = () => this.hook('onCalendarOpen');\n this.settings.onClose = () => {\n this.hook('onCalendarClose');\n this.closedOn = Date.now();\n if (this.settings.allowInput && this.settings.enableTime) {\n this.calendar._input.value = this.settings.isManuallyOverriddenValue ? this.settings.manualInputValue : this.calendar.altInput.value;\n this.emit('update');\n }\n if (this.calendar) {\n this.emit('blur');\n }\n };\n Formio_1.Formio.requireLibrary('flatpickr-css', 'flatpickr', [\n { type: 'styles', src: `${Formio_1.Formio.cdn['flatpickr']}/flatpickr.min.css` }\n ], true);\n if (this.component.shortcutButtons) {\n this.component.shortcutButtons = this.component.shortcutButtons.filter((btn) => btn.label && btn.onClick);\n }\n if ((_a = this.component.shortcutButtons) === null || _a === void 0 ? void 0 : _a.length) {\n Formio_1.Formio.requireLibrary('shortcut-buttons-flatpickr-css', 'ShortcutButtonsPlugin', [\n { type: 'styles', src: `${Formio_1.Formio.cdn['shortcut-buttons-flatpickr']}/themes/light.min.css` }\n ], true);\n }\n return superAttach\n .then(() => {\n var _a;\n if ((_a = this.component.shortcutButtons) === null || _a === void 0 ? void 0 : _a.length) {\n return Formio_1.Formio.requireLibrary('shortcut-buttons-flatpickr', 'ShortcutButtonsPlugin', `${Formio_1.Formio.cdn['shortcut-buttons-flatpickr']}/shortcut-buttons-flatpickr.min.js`, true);\n }\n })\n .then((ShortcutButtonsPlugin) => {\n return Formio_1.Formio.requireLibrary('flatpickr', 'flatpickr', `${Formio_1.Formio.cdn['flatpickr']}/flatpickr.min.js`, true)\n .then((Flatpickr) => {\n var _a;\n if (((_a = this.component.shortcutButtons) === null || _a === void 0 ? void 0 : _a.length) && ShortcutButtonsPlugin) {\n this.initShortcutButtonsPlugin(ShortcutButtonsPlugin);\n }\n this.settings.formatDate = this.getFlatpickrFormatDate(Flatpickr);\n if (this._input) {\n const { locale } = this.settings;\n if (locale && locale.length >= 2 && locale !== 'en') {\n return Formio_1.Formio.requireLibrary(`flatpickr-${locale}`, `flatpickr.l10ns.${locale}`, `${Formio_1.Formio.cdn['flatpickr']}/l10n/${locale}.js`, true)\n .catch(() => {\n // fallback to en if locale fails to load\n this.settings.locale = 'en';\n })\n .finally(() => {\n this.initFlatpickr(Flatpickr);\n });\n }\n else {\n this.initFlatpickr(Flatpickr);\n }\n }\n });\n })\n .catch((err) => {\n console.warn(err);\n });\n }\n get disableWeekends() {\n return function (date) {\n return (date.getDay() === 0 || date.getDay() === 6);\n };\n }\n get disableWeekdays() {\n return (date) => !this.disableWeekends(date);\n }\n get disableFunction() {\n return (date) => this.evaluate(`return ${this.settings.disableFunction}`, {\n date\n });\n }\n get timezone() {\n return this.componentInstance.getTimezone(this.settings);\n }\n get defaultSettings() {\n return CalendarWidget.defaultSettings;\n }\n addSuffix(suffix) {\n this.addEventListener(suffix, 'click', () => {\n setTimeout(() => {\n if (this.calendar) {\n if (!this.calendar.isOpen && ((Date.now() - this.closedOn) > 200)) {\n this.calendar.open();\n }\n else if (this.calendar.isOpen) {\n this.calendar.close();\n }\n }\n }, 0);\n });\n return suffix;\n }\n set disabled(disabled) {\n super.disabled = disabled;\n if (this.calendar) {\n if (disabled) {\n this.calendar._input.setAttribute('disabled', 'disabled');\n }\n else {\n this.calendar._input.removeAttribute('disabled');\n }\n this.calendar.close();\n this.calendar.redraw();\n }\n }\n get input() {\n return this.calendar ? this.calendar.altInput : null;\n }\n get disabledDates() {\n if (this.settings.disabledDates) {\n const disabledDates = this.settings.disabledDates.split(',');\n return disabledDates.map((item) => {\n const dateMask = /\\d{4}-\\d{2}-\\d{2}/g;\n const dates = item.match(dateMask);\n if (dates && dates.length) {\n return dates.length === 1 ? item.match(dateMask)[0] : {\n from: item.match(dateMask)[0],\n to: item.match(dateMask)[1],\n };\n }\n });\n }\n return [];\n }\n get localeFormat() {\n let format = '';\n if (this.settings.enableDate) {\n format += this.defaultFormat.date;\n }\n if (this.settings.enableTime) {\n format += this.defaultFormat.time;\n }\n return format;\n }\n get dateTimeFormat() {\n return this.settings.useLocaleSettings ? this.localeFormat : (0, utils_1.convertFormatToFlatpickr)(this.dateFormat);\n }\n get dateFormat() {\n return lodash_1.default.get(this.settings, 'format', DEFAULT_FORMAT);\n }\n /**\n * Return the date value as a string.\n * @param {string|Date} date - The date object or a date string that is momentjs compatible.\n * @param {string} format - The DateParser code format.\n * @param {boolean} [useTimezone] - If the timezone should be used.\n * @returns {string} - Returns the formatted date string.\n */\n getDateValue(date, format, useTimezone) {\n if (useTimezone) {\n return (0, utils_1.dayjsDate)(date, this.valueFormat, this.timezone).format((0, utils_1.convertFormatToDayjs)(format));\n }\n return (0, moment_1.default)(date).format((0, utils_1.convertFormatToDayjs)(format));\n }\n /**\n * Return the value of the selected date.\n * @returns {*} - The value of the selected date.\n */\n getValue() {\n // Standard output format.\n if (!this.calendar) {\n return super.getValue();\n }\n // Get the selected dates from the calendar widget.\n const dates = this.calendar.selectedDates;\n if (!dates || !dates.length) {\n return super.getValue();\n }\n if (!(dates[0] instanceof Date)) {\n return 'Invalid Date';\n }\n return this.getDateValue(dates[0], this.valueFormat, (this.settings.saveAs === 'date'));\n }\n isValueISO8601(value) {\n return value && (typeof value === 'string') && value.match(/-[0-9]{2}T[0-9]{2}:/);\n }\n /**\n * Set the selected date value.\n * @param {*} value - The value to set.\n * @returns {void}\n */\n setValue(value) {\n const saveAsText = (this.settings.saveAs === 'text');\n if (!this.calendar) {\n value = value ? (0, utils_1.formatDate)(value, (0, utils_1.convertFormatToDayjs)(this.settings.format), this.timezone, (0, utils_1.convertFormatToDayjs)(this.valueMomentFormat)) : value;\n return super.setValue(value);\n }\n // If the component is a textfield that does not have timezone information included in the string value then skip\n // the timezone offset\n this.settings.skipOffset = this.component.type === 'textfield' && !(0, utils_1.hasEncodedTimezone)(value);\n if (value) {\n if (!saveAsText && this.settings.readOnly) {\n this.calendar.setDate((0, utils_1.dayjsDate)(value, this.valueFormat, this.timezone).format(), false);\n }\n else if (this.isValueISO8601(value)) {\n this.calendar.setDate(value, false);\n }\n else {\n this.calendar.setDate((0, moment_1.default)(value, this.valueMomentFormat).toDate(), false);\n }\n }\n else {\n this.calendar.clear(false);\n }\n }\n getValueAsString(value, format = '') {\n const inputFormat = format || this.dateFormat;\n const valueFormat = this.calendar ? this.valueFormat : this.settings.dateFormat;\n if (this.settings.saveAs === 'text' && this.componentInstance.parent && !this.settings.readOnly) {\n return (0, moment_1.default)(value, (0, utils_1.convertFormatToDayjs)(valueFormat)).format((0, utils_1.convertFormatToDayjs)(valueFormat));\n }\n return (0, utils_1.formatDate)(value, inputFormat, this.timezone, (0, utils_1.convertFormatToDayjs)(valueFormat));\n }\n setErrorClasses(hasErrors) {\n if (!this.input) {\n return;\n }\n if (hasErrors) {\n this.addClass(this.input, 'is-invalid');\n this.input.setAttribute('aria-invalid', 'true');\n }\n else {\n this.removeClass(this.input, 'is-invalid');\n this.input.setAttribute('aria-invalid', 'false');\n }\n }\n get validationValue() {\n const value = this.dataValue;\n if (typeof value === 'string') {\n return new Date(value);\n }\n return value.map(val => new Date(val));\n }\n isCalendarElement(element) {\n var _a, _b, _c, _d, _e;\n if (!element) {\n return true;\n }\n if ((_c = (_b = (_a = this.calendar) === null || _a === void 0 ? void 0 : _a.config) === null || _b === void 0 ? void 0 : _b.appendTo) === null || _c === void 0 ? void 0 : _c.contains(element)) {\n return true;\n }\n return (_e = (_d = this.calendar) === null || _d === void 0 ? void 0 : _d.calendarContainer) === null || _e === void 0 ? void 0 : _e.contains(element);\n }\n initFlatpickr(Flatpickr) {\n // Create a new flatpickr.\n this.calendar = new Flatpickr(this._input, Object.assign(Object.assign({}, this.settings), { disableMobile: true }));\n this.addEventListener(this.calendar.altInput, 'input', (event) => {\n if (this.settings.allowInput && this.settings.currentValue !== event.target.value) {\n if (event.target.mask) {\n event.target.mask.textMaskInputElement.update();\n }\n this.settings.manualInputValue = event.target.value;\n this._input.value = this.settings.manualInputValue;\n this.settings.isManuallyOverriddenValue = true;\n this.settings.currentValue = event.target.value;\n this.emit('update');\n }\n });\n if (this.calendar.daysContainer) {\n this.calendar.daysContainer.addEventListener('click', () => {\n this.settings.isManuallyOverriddenValue = false;\n this.calendar.updateValue(false);\n });\n }\n if (this.calendar.timeContainer) {\n this.calendar.timeContainer.addEventListener('click', () => {\n this.settings.isManuallyOverriddenValue = false;\n this.calendar.updateValue(false);\n });\n }\n const excludedFromMaskFormats = ['MMMM'];\n if (!this.settings.readOnly && !lodash_1.default.some(excludedFromMaskFormats, format => lodash_1.default.includes(this.settings.format, format))) {\n // Enforce the input mask of the format.\n this.setInputMask(this.calendar._input, (0, utils_1.convertFormatToMask)(this.settings.format));\n }\n // Fixes an issue with IE11 where value is set only after the second click\n // TODO: Remove when the issue is solved in the flatpickr library\n if (isIEBrowser) {\n // Remove the original blur listener, because value will be set to empty since relatedTarget is null in IE11\n const originalBlurListener = this.calendar._handlers.find(({ event, element }) => event === 'blur' && element === this.calendar._input);\n this.calendar._input.removeEventListener('blur', originalBlurListener.handler);\n // Add the same event listener as in the original library, but with workaround for IE11 issue\n this.addEventListener(this.calendar._input, 'blur', (event) => {\n const activeElement = this.settings.shadowRoot ? this.settings.shadowRoot.activeElement : document.activeElement;\n const relatedTarget = event.relatedTarget ? event.relatedTarget : activeElement;\n const isInput = event.target === this.calendar._input;\n if (isInput && !this.isCalendarElement(relatedTarget)) {\n this.calendar.setDate(this.calendar._input.value, true, event.target === this.calendar.altInput\n ? this.calendar.config.altFormat\n : this.calendar.config.dateFormat);\n }\n });\n }\n // Make sure we commit the value after a blur event occurs.\n this.addEventListener(this.calendar._input, 'blur', (event) => {\n var _a, _b, _c, _d;\n // If we have manually overridden the value then we shouldn't call setDate because this will fill the input mask\n if (this.settings.isManuallyOverriddenValue) {\n return;\n }\n const activeElement = this.settings.shadowRoot ? this.settings.shadowRoot.activeElement : document.activeElement;\n const relatedTarget = event.relatedTarget ? event.relatedTarget : activeElement;\n if (!(isIEBrowser && !relatedTarget) && !this.isCalendarElement(relatedTarget)) {\n const inputValue = this.calendar.input.value;\n const dateValue = inputValue ? (0, moment_1.default)(this.calendar.input.value, (0, utils_1.convertFormatToDayjs)(this.valueFormat)).toDate() : inputValue;\n this.calendar.setDate(dateValue, true, this.settings.altFormat);\n }\n else if (!this.calendar.input.value && this.calendar.config.noCalendar) {\n const value = (0, moment_1.default)({ hour: (_b = (_a = this.calendar) === null || _a === void 0 ? void 0 : _a.config) === null || _b === void 0 ? void 0 : _b.defaultHour, minute: (_d = (_c = this.calendar) === null || _c === void 0 ? void 0 : _c.config) === null || _d === void 0 ? void 0 : _d.defaultMinute }).toDate();\n this.calendar.setDate(value, true, this.settings.format);\n }\n });\n // FJS-1103: When hit the enter button, the field not saving the year correctly\n this.addEventListener(this.calendar.altInput, 'keydown', (event) => {\n if (event.keyCode === 13) {\n if (this.calendar.isOpen) {\n this.calendar.close();\n event.stopPropagation();\n }\n }\n });\n // If other fields are used to calculate disabled dates, we need to redraw calendar to refresh disabled dates\n if (this.settings.disableFunction && this.componentInstance && this.componentInstance.root) {\n this.componentInstance.root.on('change', (e) => {\n if (e.changed && this.calendar) {\n this.calendar.redraw();\n }\n });\n }\n // Restore the calendar value from the component value.\n this.setValue(this.componentValue);\n }\n initShortcutButtonsPlugin(ShortcutButtonsPlugin) {\n this.settings.plugins = [\n // eslint-disable-next-line new-cap\n ShortcutButtonsPlugin({\n button: this.component.shortcutButtons.map((btn) => ({ label: btn.label, attributes: btn.attribute })),\n onClick: (index) => {\n const getValue = this.component.shortcutButtons[index].onClick;\n const date = this.evaluate(getValue, { date: new Date() }, 'date');\n this.calendar.setDate(date, true);\n }\n })\n ];\n }\n get componentValue() {\n let compValue = this.componentInstance.dataValue;\n if (Array.isArray(compValue)) {\n compValue = compValue[this.valueIndex];\n }\n return compValue;\n }\n getFlatpickrFormatDate(Flatpickr) {\n return (date, format) => {\n // Only format this if this is the altFormat and the form is readOnly.\n if (this.settings.readOnly && (format === this.settings.altFormat)) {\n if (!this.settings.enableTime || this.settings.skipOffset) {\n return Flatpickr.formatDate(date, format);\n }\n const currentValue = new Date(this.getValue());\n if (currentValue.toString() === date.toString()) {\n return (0, utils_1.formatOffset)(Flatpickr.formatDate.bind(Flatpickr), new Date(this.componentValue), format, this.timezone);\n }\n return (0, utils_1.formatOffset)(Flatpickr.formatDate.bind(Flatpickr), date, format, this.timezone);\n }\n return Flatpickr.formatDate(date, format);\n };\n }\n destroy(all = false) {\n if (this.calendar) {\n this.calendar.destroy();\n }\n super.destroy(all);\n }\n}\nexports[\"default\"] = CalendarWidget;\n\n\n//# sourceURL=webpack://Formio/./lib/cjs/widgets/CalendarWidget.js?");
8145
8145
 
8146
8146
  /***/ }),
8147
8147