var __assign = (this && this.__assign) || function () { __assign = Object.assign || function(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; }; return __assign.apply(this, arguments); }; import { getEventTarget } from "../../utils/dom"; var defaultConfig = { confirmIcon: " ", confirmText: "OK ", showAlways: false, theme: "light", }; function confirmDatePlugin(pluginConfig) { var config = __assign(__assign({}, defaultConfig), pluginConfig); var confirmContainer; var confirmButtonCSSClass = "flatpickr-confirm"; return function (fp) { if (fp.config.noCalendar || fp.isMobile) return {}; return __assign({ onKeyDown: function (_, __, ___, e) { var eventTarget = getEventTarget(e); var isTargetLastFocusableElement = (!fp.config.time_24hr && eventTarget === fp.amPM) || (fp.config.time_24hr && ((fp.config.enableSeconds && eventTarget === fp.secondElement) || (!fp.config.enableSeconds && eventTarget === fp.minuteElement))); if (fp.config.enableTime && e.key === "Tab" && isTargetLastFocusableElement) { e.preventDefault(); confirmContainer.focus(); } else if (e.key === "Enter" && eventTarget === confirmContainer) fp.close(); }, onReady: function () { confirmContainer = fp._createElement("div", confirmButtonCSSClass + " " + (config.showAlways ? "visible" : "") + " " + config.theme + "Theme", config.confirmText); confirmContainer.tabIndex = -1; confirmContainer.innerHTML += config.confirmIcon; confirmContainer.addEventListener("click", fp.close); fp.calendarContainer.appendChild(confirmContainer); fp.loadedPlugins.push("confirmDate"); } }, (!config.showAlways ? { onChange: function (_, dateStr) { var showCondition = fp.config.enableTime || fp.config.mode === "multiple" || fp.loadedPlugins.indexOf("monthSelect") !== -1; var localConfirmContainer = fp.calendarContainer.querySelector("." + confirmButtonCSSClass); if (!localConfirmContainer) return; if (dateStr && !fp.config.inline && showCondition && localConfirmContainer) return localConfirmContainer.classList.add("visible"); localConfirmContainer.classList.remove("visible"); }, } : {})); }; } export default confirmDatePlugin;