import { isFunction } from '@vue/shared'; const REPEAT_INTERVAL = 100; const REPEAT_DELAY = 600; const SCOPE = "_RepeatClick"; const vRepeatClick = { beforeMount(el, binding) { const value = binding.value; const { interval = REPEAT_INTERVAL, delay = REPEAT_DELAY } = isFunction(value) ? {} : value; let intervalId; let delayId; const handler = () => isFunction(value) ? value() : value.handler(); const clear = () => { if (delayId) { clearTimeout(delayId); delayId = void 0; } if (intervalId) { clearInterval(intervalId); intervalId = void 0; } }; const start = (evt) => { if (evt.button !== 0) return; clear(); handler(); document.addEventListener("mouseup", clear, { once: true }); delayId = setTimeout(() => { intervalId = setInterval(() => { handler(); }, interval); }, delay); }; el[SCOPE] = { start, clear }; el.addEventListener("mousedown", start); }, unmounted(el) { if (!el[SCOPE]) return; const { start, clear } = el[SCOPE]; if (start) { el.removeEventListener("mousedown", start); } if (clear) { clear(); document.removeEventListener("mouseup", clear); } el[SCOPE] = null; } }; export { REPEAT_DELAY, REPEAT_INTERVAL, vRepeatClick }; //# sourceMappingURL=index.mjs.map