58 lines
1.5 KiB
TypeScript
58 lines
1.5 KiB
TypeScript
import {
|
|
Ref,
|
|
ref,
|
|
inject,
|
|
onBeforeMount,
|
|
watch,
|
|
provide,
|
|
} from 'vue';
|
|
|
|
interface BlockRect {
|
|
height: number;
|
|
width: number;
|
|
left: number;
|
|
top: number;
|
|
}
|
|
|
|
export const SymBlockDimensions = Symbol('Schlechtenburg block dimensions');
|
|
export const SymEditorDimensions = Symbol('Schlechtenburg editor dimensions');
|
|
export const useResizeObserver = (el: Ref<null|HTMLElement>, symbol: symbol) => {
|
|
const dimensions: Ref<null|BlockRect> = ref(null);
|
|
provide(symbol, dimensions);
|
|
const triggerSizeCalculation = () => {
|
|
if (!el.value) {
|
|
return;
|
|
}
|
|
|
|
const clientRect = el.value.getBoundingClientRect();
|
|
dimensions.value = {
|
|
width: clientRect.width,
|
|
height: clientRect.height,
|
|
left: el.value.offsetLeft,
|
|
top: el.value.offsetTop,
|
|
};
|
|
};
|
|
|
|
onBeforeMount(() => {
|
|
const resizeObserver = new ResizeObserver(triggerSizeCalculation);
|
|
const mutationObserver = new MutationObserver(triggerSizeCalculation);
|
|
|
|
watch(el, () => {
|
|
if (!el.value) {
|
|
return;
|
|
}
|
|
resizeObserver.observe(el.value);
|
|
mutationObserver.observe(el.value, { attributes: true, childList: false, subtree: false });
|
|
});
|
|
})
|
|
|
|
return { triggerSizeCalculation, dimensions };
|
|
};
|
|
|
|
export function useBlockSizing() {
|
|
const editorDimensions: Ref<BlockRect|null> = inject(SymEditorDimensions, ref(null));
|
|
const blockDimensions: Ref<BlockRect|null> = inject(SymBlockDimensions, ref(null));
|
|
|
|
return { editorDimensions, blockDimensions };
|
|
}
|