2
This commit is contained in:
40
normal-admin/node_modules/element-plus/es/directives/repeat-click/index.mjs
generated
vendored
Normal file
40
normal-admin/node_modules/element-plus/es/directives/repeat-click/index.mjs
generated
vendored
Normal file
@@ -0,0 +1,40 @@
|
||||
import { isFunction } from '@vue/shared';
|
||||
|
||||
const REPEAT_INTERVAL = 100;
|
||||
const REPEAT_DELAY = 600;
|
||||
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;
|
||||
}
|
||||
};
|
||||
el.addEventListener("mousedown", (evt) => {
|
||||
if (evt.button !== 0)
|
||||
return;
|
||||
clear();
|
||||
handler();
|
||||
document.addEventListener("mouseup", () => clear(), {
|
||||
once: true
|
||||
});
|
||||
delayId = setTimeout(() => {
|
||||
intervalId = setInterval(() => {
|
||||
handler();
|
||||
}, interval);
|
||||
}, delay);
|
||||
});
|
||||
}
|
||||
};
|
||||
|
||||
export { REPEAT_DELAY, REPEAT_INTERVAL, vRepeatClick };
|
||||
//# sourceMappingURL=index.mjs.map
|
||||
Reference in New Issue
Block a user