69 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
			
		
		
	
	
			69 lines
		
	
	
		
			3.3 KiB
		
	
	
	
		
			JavaScript
		
	
	
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: "<svg version='1.1' xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' width='17' height='17' viewBox='0 0 17 17'> <g> </g> <path d='M15.418 1.774l-8.833 13.485-4.918-4.386 0.666-0.746 4.051 3.614 8.198-12.515 0.836 0.548z' fill='#000000' /> </svg>",
 | 
						|
    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;
 |