@element-plus-next/vue-hooks
Version:
Vue hooks for Element Plus.
33 lines (28 loc) • 1 kB
text/typescript
import { onBeforeUnmount, onMounted } from 'vue'
import { isClient } from '@element-plus-next/utils'
import { EVENT_CODE } from '@element-plus-next/constants'
let registeredEscapeHandlers: ((e: KeyboardEvent) => void)[] = []
const cachedHandler = (e: Event) => {
const event = e as KeyboardEvent
if (event.key === EVENT_CODE.esc) {
registeredEscapeHandlers.forEach((registeredHandler) =>
registeredHandler(event)
)
}
}
export const useEscapeKeydown = (handler: (e: KeyboardEvent) => void) => {
onMounted(() => {
if (registeredEscapeHandlers.length === 0) {
document.addEventListener('keydown', cachedHandler)
}
if (isClient) registeredEscapeHandlers.push(handler)
})
onBeforeUnmount(() => {
registeredEscapeHandlers = registeredEscapeHandlers.filter(
(registeredHandler) => registeredHandler !== handler
)
if (registeredEscapeHandlers.length === 0) {
if (isClient) document.removeEventListener('keydown', cachedHandler)
}
})
}