import { Instance } from "types/instance";
interface Config {
confirmIcon?: string;
confirmText?: string;
showAlways?: boolean;
theme?: string;
}
const defaultConfig: Config = {
confirmIcon:
"",
confirmText: "OK ",
showAlways: false,
theme: "light",
};
function confirmDatePlugin(pluginConfig: Config) {
const config = { ...defaultConfig, ...pluginConfig };
let confirmContainer: HTMLDivElement;
return function(fp: Instance) {
const hooks = {
onKeyDown(_: Date[], __: string, ___: Instance, e: KeyboardEvent) {
if (fp.config.enableTime && e.key === "Tab" && e.target === fp.amPM) {
e.preventDefault();
confirmContainer.focus();
} else if (e.key === "Enter" && e.target === confirmContainer)
fp.close();
},
onReady() {
if (fp.calendarContainer === undefined) return;
confirmContainer = fp._createElement(
"div",
`flatpickr-confirm ${config.showAlways
? "visible"
: ""} ${config.theme}Theme`,
config.confirmText
);
confirmContainer.tabIndex = -1;
confirmContainer.innerHTML += config.confirmIcon;
confirmContainer.addEventListener("click", fp.close);
fp.calendarContainer.appendChild(confirmContainer);
},
...!config.showAlways
? {
onChange: function(_: Date, dateStr: string) {
const showCondition =
fp.config.enableTime || fp.config.mode === "multiple";
if (dateStr && !fp.config.inline && showCondition)
return confirmContainer.classList.add("visible");
confirmContainer.classList.remove("visible");
},
}
: {},
};
return hooks;
};
}
export default confirmDatePlugin;