mirror of
https://github.com/element-plus/element-plus.git
synced 2025-01-12 10:45:10 +08:00
60 lines
1.5 KiB
TypeScript
60 lines
1.5 KiB
TypeScript
|
/** @deprecated use `element.addEventListener` instead */
|
||
|
export const on = (
|
||
|
element: HTMLElement | Document | Window,
|
||
|
event: string,
|
||
|
handler: EventListenerOrEventListenerObject,
|
||
|
useCapture = false
|
||
|
): void => {
|
||
|
if (element && event && handler) {
|
||
|
element?.addEventListener(event, handler, useCapture)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** @deprecated use `element.addEventListener` instead */
|
||
|
export const off = (
|
||
|
element: HTMLElement | Document | Window,
|
||
|
event: string,
|
||
|
handler: EventListenerOrEventListenerObject,
|
||
|
useCapture = false
|
||
|
): void => {
|
||
|
if (element && event && handler) {
|
||
|
element?.removeEventListener(event, handler, useCapture)
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/** @deprecated use `element.addEventListener` instead */
|
||
|
export const once = (
|
||
|
el: HTMLElement,
|
||
|
event: string,
|
||
|
fn: EventListener
|
||
|
): void => {
|
||
|
const listener = function (this: any, ...args: any) {
|
||
|
if (fn) {
|
||
|
fn.apply(this, args)
|
||
|
}
|
||
|
off(el, event, listener)
|
||
|
}
|
||
|
on(el, event, listener)
|
||
|
}
|
||
|
|
||
|
export const composeEventHandlers = <E>(
|
||
|
theirsHandler?: (event: E) => boolean | void,
|
||
|
oursHandler?: (event: E) => void,
|
||
|
{ checkForDefaultPrevented = true } = {}
|
||
|
) => {
|
||
|
const handleEvent = (event: E) => {
|
||
|
const shouldPrevent = theirsHandler?.(event)
|
||
|
|
||
|
if (checkForDefaultPrevented === false || !shouldPrevent) {
|
||
|
return oursHandler?.(event)
|
||
|
}
|
||
|
}
|
||
|
return handleEvent
|
||
|
}
|
||
|
|
||
|
type WhenMouseHandler = (e: PointerEvent) => any
|
||
|
export const whenMouse = (handler: WhenMouseHandler): WhenMouseHandler => {
|
||
|
return (e: PointerEvent) =>
|
||
|
e.pointerType === 'mouse' ? handler(e) : undefined
|
||
|
}
|