refactor: 完善ColumnSetting的操作逻辑 (#2745)

This commit is contained in:
GauharChan 2023-04-30 22:52:42 +08:00 committed by GitHub
parent 6e716c5607
commit b97d588392
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 75 additions and 36 deletions

View File

@ -184,6 +184,7 @@
getViewColumns, getViewColumns,
getColumns, getColumns,
setCacheColumnsByField, setCacheColumnsByField,
setCacheColumns,
setColumns, setColumns,
getColumnsRef, getColumnsRef,
getCacheColumns, getCacheColumns,
@ -323,6 +324,7 @@
getSize: () => { getSize: () => {
return unref(getBindValues).size as SizeType; return unref(getBindValues).size as SizeType;
}, },
setCacheColumns,
}; };
createTableContext({ ...tableAction, wrapRef, getBindValues }); createTableContext({ ...tableAction, wrapRef, getBindValues });

View File

@ -99,7 +99,7 @@
</Tooltip> </Tooltip>
</template> </template>
<script lang="ts"> <script lang="ts">
import type { BasicColumn, ColumnChangeParam } from '../../types/table'; import type { BasicColumn, BasicTableProps, ColumnChangeParam } from '../../types/table';
import { import {
defineComponent, defineComponent,
ref, ref,
@ -159,6 +159,10 @@
const defaultRowSelection = omit(table.getRowSelection(), 'selectedRowKeys'); const defaultRowSelection = omit(table.getRowSelection(), 'selectedRowKeys');
let inited = false; let inited = false;
// setColums
let isSetColumnsFromThis = false;
// setProps
let isSetPropsFromThis = false;
const cachePlainOptions = ref<Options[]>([]); const cachePlainOptions = ref<Options[]>([]);
const plainOptions = ref<Options[] | any>([]); const plainOptions = ref<Options[] | any>([]);
@ -172,7 +176,8 @@
checkedList: [], checkedList: [],
defaultCheckList: [], defaultCheckList: [],
}); });
/** 缓存初始化props */
let cacheTableProps: Partial<BasicTableProps<any>> = {};
const checkIndex = ref(false); const checkIndex = ref(false);
const checkSelect = ref(false); const checkSelect = ref(false);
@ -185,7 +190,9 @@
watchEffect(() => { watchEffect(() => {
const columns = table.getColumns(); const columns = table.getColumns();
setTimeout(() => { setTimeout(() => {
if (columns.length && !state.isInit) { if (isSetColumnsFromThis) {
isSetColumnsFromThis = false;
} else if (columns.length) {
init(); init();
} }
}, 0); }, 0);
@ -193,6 +200,11 @@
watchEffect(() => { watchEffect(() => {
const values = unref(getValues); const values = unref(getValues);
if (isSetPropsFromThis) {
isSetPropsFromThis = false;
} else {
cacheTableProps = cloneDeep(values);
}
checkIndex.value = !!values.showIndexColumn; checkIndex.value = !!values.showIndexColumn;
checkSelect.value = !!values.rowSelection; checkSelect.value = !!values.rowSelection;
}); });
@ -209,8 +221,17 @@
return ret; return ret;
} }
function init() { async function init(isReset = false) {
const columns = getColumns(); // Sortablejsbugel appendchildNodechildNode
//
plainOptions.value = [];
const columnListEl = unref(columnListRef);
if (columnListEl && (columnListEl as any).$el) {
const el = (columnListEl as any).$el as Element;
Array.from(el.children).forEach((item) => el.removeChild(item));
}
await nextTick();
const columns = isReset ? cloneDeep(cachePlainOptions.value) : getColumns();
const checkList = table const checkList = table
.getColumns({ ignoreAction: true, ignoreIndex: true }) .getColumns({ ignoreAction: true, ignoreIndex: true })
@ -221,31 +242,25 @@
return item.dataIndex || item.title; return item.dataIndex || item.title;
}) })
.filter(Boolean) as string[]; .filter(Boolean) as string[];
if (!plainOptions.value.length) {
plainOptions.value = columns; plainOptions.value = columns;
plainSortOptions.value = columns; plainSortOptions.value = columns;
cachePlainOptions.value = columns; //
table.setCacheColumns?.(columns);
!isReset && (cachePlainOptions.value = cloneDeep(columns));
state.defaultCheckList = checkList; state.defaultCheckList = checkList;
} else {
// const fixedColumns = columns.filter((item) =>
// Reflect.has(item, 'fixed')
// ) as BasicColumn[];
unref(plainOptions).forEach((item: BasicColumn) => {
const findItem = columns.find((col: BasicColumn) => col.dataIndex === item.dataIndex);
if (findItem) {
item.fixed = findItem.fixed;
}
});
}
state.isInit = true;
state.checkedList = checkList; state.checkedList = checkList;
//
state.checkAll = checkList.length === columns.length;
inited = false;
handleVisibleChange();
} }
// checkAll change // checkAll change
function onCheckAllChange(e: CheckboxChangeEvent) { function onCheckAllChange(e: CheckboxChangeEvent) {
const checkList = plainOptions.value.map((item) => item.value); const checkList = plainSortOptions.value.map((item) => item.value);
plainSortOptions.value.forEach(
(item) => ((item as BasicColumn).defaultHidden = !e.target.checked),
);
if (e.target.checked) { if (e.target.checked) {
state.checkedList = checkList; state.checkedList = checkList;
setColumns(checkList); setColumns(checkList);
@ -270,6 +285,9 @@
checkedList.sort((prev, next) => { checkedList.sort((prev, next) => {
return sortList.indexOf(prev) - sortList.indexOf(next); return sortList.indexOf(prev) - sortList.indexOf(next);
}); });
unref(plainSortOptions).forEach((item) => {
(item as BasicColumn).defaultHidden = !checkedList.includes(item.value);
});
setColumns(checkedList); setColumns(checkedList);
} }
@ -277,11 +295,14 @@
let sortableOrder: string[] = []; let sortableOrder: string[] = [];
// reset columns // reset columns
function reset() { function reset() {
state.checkedList = [...state.defaultCheckList]; setColumns(cachePlainOptions.value);
state.checkAll = true; init(true);
plainOptions.value = unref(cachePlainOptions); checkIndex.value = !!cacheTableProps.showIndexColumn;
plainSortOptions.value = unref(cachePlainOptions); checkSelect.value = !!cacheTableProps.rowSelection;
setColumns(table.getCacheColumns()); table.setProps({
showIndexColumn: checkIndex.value,
rowSelection: checkSelect.value ? defaultRowSelection : undefined,
});
sortable.sort(sortableOrder); sortable.sort(sortableOrder);
} }
@ -316,12 +337,7 @@
} }
plainSortOptions.value = columns; plainSortOptions.value = columns;
setColumns(columns.filter((item) => state.checkedList.includes(item.value)));
setColumns(
columns
.map((col: Options) => col.value)
.filter((value: string) => state.checkedList.includes(value)),
);
}, },
}); });
// order // order
@ -332,6 +348,8 @@
// Control whether the serial number column is displayed // Control whether the serial number column is displayed
function handleIndexCheckChange(e: CheckboxChangeEvent) { function handleIndexCheckChange(e: CheckboxChangeEvent) {
isSetPropsFromThis = true;
isSetColumnsFromThis = true;
table.setProps({ table.setProps({
showIndexColumn: e.target.checked, showIndexColumn: e.target.checked,
}); });
@ -339,6 +357,8 @@
// Control whether the check box is displayed // Control whether the check box is displayed
function handleSelectCheckChange(e: CheckboxChangeEvent) { function handleSelectCheckChange(e: CheckboxChangeEvent) {
isSetPropsFromThis = true;
isSetColumnsFromThis = true;
table.setProps({ table.setProps({
rowSelection: e.target.checked ? defaultRowSelection : undefined, rowSelection: e.target.checked ? defaultRowSelection : undefined,
}); });
@ -360,11 +380,14 @@
if (isFixed && !item.width) { if (isFixed && !item.width) {
item.width = 100; item.width = 100;
} }
updateSortOption(item);
table.setCacheColumnsByField?.(item.dataIndex as string, { fixed: isFixed }); table.setCacheColumnsByField?.(item.dataIndex as string, { fixed: isFixed });
setColumns(columns); setColumns(columns);
} }
function setColumns(columns: BasicColumn[] | string[]) { function setColumns(columns: BasicColumn[] | string[]) {
isSetPropsFromThis = true;
isSetColumnsFromThis = true;
table.setColumns(columns); table.setColumns(columns);
const data: ColumnChangeParam[] = unref(plainSortOptions).map((col) => { const data: ColumnChangeParam[] = unref(plainSortOptions).map((col) => {
const visible = const visible =
@ -384,6 +407,14 @@
: getParentContainer(); : getParentContainer();
} }
function updateSortOption(column: BasicColumn) {
plainSortOptions.value.forEach((item) => {
if (item.value === column.dataIndex) {
Object.assign(item, column);
}
});
}
return { return {
t, t,
...toRefs(state), ...toRefs(state),

View File

@ -260,6 +260,10 @@ export function useColumns(
function getCacheColumns() { function getCacheColumns() {
return cacheColumns; return cacheColumns;
} }
function setCacheColumns(columns: BasicColumn[]) {
if (!isArray(columns)) return;
cacheColumns = columns.filter((item) => !item.flag);
}
return { return {
getColumnsRef, getColumnsRef,
@ -268,6 +272,7 @@ export function useColumns(
setColumns, setColumns,
getViewColumns, getViewColumns,
setCacheColumnsByField, setCacheColumnsByField,
setCacheColumns,
}; };
} }

View File

@ -116,6 +116,7 @@ export interface TableActionType {
setShowPagination: (show: boolean) => Promise<void>; setShowPagination: (show: boolean) => Promise<void>;
getShowPagination: () => boolean; getShowPagination: () => boolean;
setCacheColumnsByField?: (dataIndex: string | undefined, value: BasicColumn) => void; setCacheColumnsByField?: (dataIndex: string | undefined, value: BasicColumn) => void;
setCacheColumns?: (columns: BasicColumn[]) => void;
} }
export interface FetchSetting { export interface FetchSetting {