2024-08-15 13:48:52 +00:00
|
|
|
import type { CSSProperties } from 'vue';
|
2024-08-16 14:20:18 +00:00
|
|
|
import { computed, onMounted, onUnmounted, ref } from 'vue';
|
2024-08-15 13:48:52 +00:00
|
|
|
|
|
|
|
import {
|
|
|
|
CSS_VARIABLE_LAYOUT_CONTENT_HEIGHT,
|
|
|
|
CSS_VARIABLE_LAYOUT_CONTENT_WIDTH,
|
2024-09-10 13:48:51 +00:00
|
|
|
} from '@vben-core/shared/constants';
|
|
|
|
import {
|
2024-08-15 13:48:52 +00:00
|
|
|
getElementVisibleRect,
|
|
|
|
type VisibleDomRect,
|
2024-09-10 13:48:51 +00:00
|
|
|
} from '@vben-core/shared/utils';
|
2024-08-15 13:48:52 +00:00
|
|
|
|
|
|
|
import { useCssVar, useDebounceFn } from '@vueuse/core';
|
|
|
|
|
|
|
|
/**
|
|
|
|
* @zh_CN content style
|
|
|
|
*/
|
|
|
|
function useContentStyle() {
|
2024-08-16 14:20:18 +00:00
|
|
|
let resizeObserver: null | ResizeObserver = null;
|
2024-08-15 13:48:52 +00:00
|
|
|
const contentElement = ref<HTMLDivElement | null>(null);
|
|
|
|
const visibleDomRect = ref<null | VisibleDomRect>(null);
|
|
|
|
const contentHeight = useCssVar(CSS_VARIABLE_LAYOUT_CONTENT_HEIGHT);
|
|
|
|
const contentWidth = useCssVar(CSS_VARIABLE_LAYOUT_CONTENT_WIDTH);
|
|
|
|
|
|
|
|
const overlayStyle = computed((): CSSProperties => {
|
|
|
|
const { height, left, top, width } = visibleDomRect.value ?? {};
|
|
|
|
return {
|
|
|
|
height: `${height}px`,
|
|
|
|
left: `${left}px`,
|
|
|
|
position: 'fixed',
|
|
|
|
top: `${top}px`,
|
|
|
|
width: `${width}px`,
|
2024-08-26 14:09:18 +00:00
|
|
|
zIndex: 150,
|
2024-08-15 13:48:52 +00:00
|
|
|
};
|
|
|
|
});
|
|
|
|
|
|
|
|
const debouncedCalcHeight = useDebounceFn(
|
|
|
|
(_entries: ResizeObserverEntry[]) => {
|
|
|
|
visibleDomRect.value = getElementVisibleRect(contentElement.value);
|
|
|
|
contentHeight.value = `${visibleDomRect.value.height}px`;
|
|
|
|
contentWidth.value = `${visibleDomRect.value.width}px`;
|
|
|
|
},
|
|
|
|
100,
|
|
|
|
);
|
|
|
|
|
|
|
|
onMounted(() => {
|
2024-08-16 14:20:18 +00:00
|
|
|
if (contentElement.value && !resizeObserver) {
|
|
|
|
resizeObserver = new ResizeObserver(debouncedCalcHeight);
|
|
|
|
resizeObserver.observe(contentElement.value);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
|
|
|
onUnmounted(() => {
|
|
|
|
resizeObserver?.disconnect();
|
|
|
|
resizeObserver = null;
|
2024-08-15 13:48:52 +00:00
|
|
|
});
|
|
|
|
|
|
|
|
return { contentElement, overlayStyle, visibleDomRect };
|
|
|
|
}
|
|
|
|
|
|
|
|
export { useContentStyle };
|