UNPKG

flatpickr

Version:

A lightweight, powerful javascript datetime picker

67 lines (56 loc) 2.12 kB
import { Instance } from "types/instance"; interface Config { confirmIcon?: string; confirmText?: string; showAlways?: boolean; theme?: string; } const defaultConfig: Config = { 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: 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<HTMLDivElement>( "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;