mirror of
https://github.com/element-plus/element-plus.git
synced 2025-01-12 10:45:10 +08:00
27 lines
717 B
TypeScript
27 lines
717 B
TypeScript
import { on, once } from '@element-plus/utils'
|
|
|
|
import type { DirectiveBinding, ObjectDirective } from 'vue'
|
|
|
|
export default {
|
|
beforeMount(el: HTMLElement, binding: DirectiveBinding) {
|
|
let interval = null
|
|
let startTime: number
|
|
const handler = () => binding.value && binding.value()
|
|
const clear = () => {
|
|
if (Date.now() - startTime < 100) {
|
|
handler()
|
|
}
|
|
clearInterval(interval)
|
|
interval = null
|
|
}
|
|
|
|
on(el, 'mousedown', (e: MouseEvent) => {
|
|
if ((e as any).button !== 0) return
|
|
startTime = Date.now()
|
|
once(document as any, 'mouseup', clear)
|
|
clearInterval(interval)
|
|
interval = setInterval(handler, 100)
|
|
})
|
|
},
|
|
} as ObjectDirective
|