UNPKG

element3

Version:

A Component Library for Vue3

70 lines (61 loc) 1.82 kB
import { onMounted, getCurrentInstance } from 'vue' import ResizeObserver from 'resize-observer-polyfill' const isServer = typeof window === 'undefined' /* istanbul ignore next */ const resizeHandler = function (entries) { for (const entry of entries) { const listeners = entry.target.__resizeListeners__ || [] if (listeners.length) { listeners.forEach((fn) => { fn() }) } } } export const useResizeEvent = () => { let element = null const addResizeListener = (fn) => { element.__resizeListeners__.push(fn) } const removeResizeListener = (fn) => { if (!element || !element.__resizeListeners__) return element.__resizeListeners__.splice( element.__resizeListeners__.indexOf(fn), 1 ) if (!element.__resizeListeners__.length) { element.__ro__.disconnect() } } onMounted(() => { element = getCurrentInstance().vnode.el if (isServer) return if (!element.__resizeListeners__) { element.__resizeListeners__ = [] element.__ro__ = new ResizeObserver(resizeHandler) element.__ro__.observe(element) } }) return { addResizeListener, removeResizeListener } } /* istanbul ignore next */ export const addResizeListener = function (element, fn) { if (isServer) return if (!element.__resizeListeners__) { element.__resizeListeners__ = [] element.__ro__ = new ResizeObserver(resizeHandler) element.__ro__.observe(element) } element.__resizeListeners__.push(fn) } /* istanbul ignore next */ export const removeResizeListener = function (element, fn) { if (!element || !element.__resizeListeners__) return element.__resizeListeners__.splice(element.__resizeListeners__.indexOf(fn), 1) if (!element.__resizeListeners__.length) { element.__ro__.disconnect() } }