chore: split function for easy maintain, understand and using (#2945)

This commit is contained in:
Cao Duc Anh 2023-08-03 15:28:34 +07:00 committed by GitHub
parent a065de4fbc
commit 0bd98b3c27
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23

View File

@ -53,22 +53,7 @@ export function useTableScroll(
let footerEl: HTMLElement | null; let footerEl: HTMLElement | null;
let bodyEl: HTMLElement | null; let bodyEl: HTMLElement | null;
async function calcTableHeight() { function handleScrollBar(bodyEl: HTMLElement, tableEl: Element) {
const { resizeHeightOffset, pagination, maxHeight, isCanResizeParent, useSearchForm } =
unref(propsRef);
const tableData = unref(getDataSourceRef);
const table = unref(tableElRef);
if (!table) return;
const tableEl: Element = table.$el;
if (!tableEl) return;
if (!bodyEl) {
bodyEl = tableEl.querySelector('.ant-table-body');
if (!bodyEl) return;
}
const hasScrollBarY = bodyEl.scrollHeight > bodyEl.clientHeight; const hasScrollBarY = bodyEl.scrollHeight > bodyEl.clientHeight;
const hasScrollBarX = bodyEl.scrollWidth > bodyEl.clientWidth; const hasScrollBarX = bodyEl.scrollWidth > bodyEl.clientWidth;
@ -85,20 +70,10 @@ export function useTableScroll(
} else { } else {
!tableEl.classList.contains('hide-scrollbar-x') && tableEl.classList.add('hide-scrollbar-x'); !tableEl.classList.contains('hide-scrollbar-x') && tableEl.classList.add('hide-scrollbar-x');
} }
}
bodyEl!.style.height = 'unset'; function caclPaginationHeight(tableEl: Element): number {
const { pagination } = unref(propsRef);
if (!unref(getCanResize) || !unref(tableData) || tableData.length === 0) return;
await nextTick();
// Add a delay to get the correct bottomIncludeBody paginationHeight footerHeight headerHeight
const headEl = tableEl.querySelector('.ant-table-thead ');
if (!headEl) return;
// Table height from bottom height-custom offset
let paddingHeight = 32;
// Pager height // Pager height
let paginationHeight = 2; let paginationHeight = 2;
if (!isBoolean(pagination)) { if (!isBoolean(pagination)) {
@ -113,7 +88,11 @@ export function useTableScroll(
} else { } else {
paginationHeight = -8; paginationHeight = -8;
} }
return paginationHeight;
}
function caclFooterHeight(tableEl: Element): number {
const { pagination } = unref(propsRef);
let footerHeight = 0; let footerHeight = 0;
if (!isBoolean(pagination)) { if (!isBoolean(pagination)) {
if (!footerEl) { if (!footerEl) {
@ -123,12 +102,21 @@ export function useTableScroll(
footerHeight += offsetHeight || 0; footerHeight += offsetHeight || 0;
} }
} }
return footerHeight;
}
function calcHeaderHeight(headEl: Element): number {
let headerHeight = 0; let headerHeight = 0;
if (headEl) { if (headEl) {
headerHeight = (headEl as HTMLElement).offsetHeight; headerHeight = (headEl as HTMLElement).offsetHeight;
} }
return headerHeight;
}
function calcBottomAndPaddingHeight(tableEl: Element, headEl: Element) {
const { pagination, isCanResizeParent, useSearchForm } = unref(propsRef);
// Table height from bottom height-custom offset
let paddingHeight = 30;
let bottomIncludeBody = 0; let bottomIncludeBody = 0;
if (unref(wrapRef) && isCanResizeParent) { if (unref(wrapRef) && isCanResizeParent) {
const tablePadding = 12; const tablePadding = 12;
@ -158,6 +146,45 @@ export function useTableScroll(
bottomIncludeBody = getViewportOffset(headEl).bottomIncludeBody; bottomIncludeBody = getViewportOffset(headEl).bottomIncludeBody;
} }
return {
paddingHeight,
bottomIncludeBody,
};
}
async function calcTableHeight() {
const { resizeHeightOffset, maxHeight } = unref(propsRef);
const tableData = unref(getDataSourceRef);
const table = unref(tableElRef);
if (!table) return;
const tableEl: Element = table.$el;
if (!tableEl) return;
if (!bodyEl) {
bodyEl = tableEl.querySelector('.ant-table-body');
if (!bodyEl) return;
}
handleScrollBar(bodyEl, tableEl);
bodyEl!.style.height = 'unset';
if (!unref(getCanResize) || !unref(tableData) || tableData.length === 0) return;
await nextTick();
// Add a delay to get the correct bottomIncludeBody paginationHeight footerHeight headerHeight
const headEl = tableEl.querySelector('.ant-table-thead ');
if (!headEl) return;
const paginationHeight = caclPaginationHeight(tableEl);
const footerHeight = caclFooterHeight(tableEl);
const headerHeight = calcHeaderHeight(headEl);
const { paddingHeight, bottomIncludeBody } = calcBottomAndPaddingHeight(tableEl, headEl);
let height = let height =
bottomIncludeBody - bottomIncludeBody -
(resizeHeightOffset || 0) - (resizeHeightOffset || 0) -