UNPKG

vuetify

Version:

Vue Material Component Framework

37 lines 1.14 kB
// Utilities import { onBeforeUnmount, readonly, ref, watch } from 'vue'; import { templateRef } from "../util/index.js"; import { IN_BROWSER } from "../util/globals.js"; // Types export function useResizeObserver(callback) { let box = arguments.length > 1 && arguments[1] !== undefined ? arguments[1] : 'content'; const resizeRef = templateRef(); const contentRect = ref(); if (IN_BROWSER) { const observer = new ResizeObserver(entries => { callback?.(entries, observer); if (!entries.length) return; if (box === 'content') { contentRect.value = entries[0].contentRect; } else { contentRect.value = entries[0].target.getBoundingClientRect(); } }); onBeforeUnmount(() => { observer.disconnect(); }); watch(() => resizeRef.el, (newValue, oldValue) => { if (oldValue) { observer.unobserve(oldValue); contentRect.value = undefined; } if (newValue) observer.observe(newValue); }, { flush: 'post' }); } return { resizeRef, contentRect: readonly(contentRect) }; } //# sourceMappingURL=resizeObserver.js.map