feat(全局): table组件增加拖拽排序

This commit is contained in:
teukkk 2024-03-13 11:05:32 +08:00 committed by 刘瑞斌
parent c29e0490c1
commit e6c660aa32
2 changed files with 42 additions and 34 deletions

View File

@ -11,6 +11,7 @@
:expanded-keys="props.expandedKeys" :expanded-keys="props.expandedKeys"
:span-all="props.spanAll" :span-all="props.spanAll"
@expand="(rowKey, record) => emit('expand', record)" @expand="(rowKey, record) => emit('expand', record)"
@change="(data: TableData[], extra: TableChangeExtra, currentData: TableData[]) => handleDragChange(data, extra, currentData)"
@sorter-change="(dataIndex: string,direction: string) => handleSortChange(dataIndex, direction)" @sorter-change="(dataIndex: string,direction: string) => handleSortChange(dataIndex, direction)"
@cell-click="(record: TableData,column: TableColumnData,ev: Event) => emit('cell-click',record, column,ev)" @cell-click="(record: TableData,column: TableColumnData,ev: Event) => emit('cell-click',record, column,ev)"
> >
@ -264,6 +265,7 @@
import { useI18n } from '@/hooks/useI18n'; import { useI18n } from '@/hooks/useI18n';
import { useAppStore, useTableStore } from '@/store'; import { useAppStore, useTableStore } from '@/store';
import { DragSortParams } from '@/models/common';
import { ColumnEditTypeEnum, SelectAllEnum, SpecialColumnEnum } from '@/enums/tableEnum'; import { ColumnEditTypeEnum, SelectAllEnum, SpecialColumnEnum } from '@/enums/tableEnum';
import type { import type {
@ -275,7 +277,7 @@
MsTableDataItem, MsTableDataItem,
MsTableProps, MsTableProps,
} from './type'; } from './type';
import type { TableColumnData, TableData } from '@arco-design/web-vue'; import type { TableChangeExtra, TableColumnData, TableData } from '@arco-design/web-vue';
import type { TableOperationColumn } from '@arco-design/web-vue/es/table/interface'; import type { TableOperationColumn } from '@arco-design/web-vue/es/table/interface';
const batchLeft = ref('10px'); const batchLeft = ref('10px');
@ -317,6 +319,7 @@
(e: 'rowNameChange', value: TableData, cb: (v: boolean) => void): void; (e: 'rowNameChange', value: TableData, cb: (v: boolean) => void): void;
(e: 'rowSelectChange', key: string): void; (e: 'rowSelectChange', key: string): void;
(e: 'selectAllChange', value: SelectAllEnum): void; (e: 'selectAllChange', value: SelectAllEnum): void;
(e: 'dragChange', value: DragSortParams): void;
(e: 'sorterChange', value: { [key: string]: string }): void; (e: 'sorterChange', value: { [key: string]: string }): void;
(e: 'expand', record: TableData): void | Promise<any>; (e: 'expand', record: TableData): void | Promise<any>;
(e: 'cell-click', record: TableData, column: TableColumnData, ev: Event): void | Promise<any>; (e: 'cell-click', record: TableData, column: TableColumnData, ev: Event): void | Promise<any>;
@ -515,6 +518,34 @@
emit('sorterChange', sortOrder ? { [dataIndex]: sortOrder } : {}); emit('sorterChange', sortOrder ? { [dataIndex]: sortOrder } : {});
}; };
//
const handleDragChange = (data: TableData[], extra: TableChangeExtra, currentData: TableData[]) => {
if (!currentData || currentData.length === 1) {
return;
}
if (extra && extra.dragTarget?.id) {
const params: DragSortParams = {
projectId: appStore.currentProjectId,
targetId: '', // id
moveMode: 'BEFORE',
moveId: extra.dragTarget.id as string, // id
};
const index = currentData.findIndex((item: any) => item.key === extra.dragTarget?.id);
if (index > -1 && currentData[index + 1]) {
params.moveMode = 'BEFORE';
params.targetId = currentData[index + 1].raw.id;
} else if (index > -1 && !currentData[index + 1]) {
if (index > -1 && currentData[index - 1]) {
params.moveMode = 'AFTER';
params.targetId = currentData[index - 1].raw.id;
}
}
emit('dragChange', params);
}
};
// input // input
const handleEdit = (dataIndex: string, rowIndex: number, record: TableData) => { const handleEdit = (dataIndex: string, rowIndex: number, record: TableData) => {
editActiveKey.value = dataIndex + rowIndex; editActiveKey.value = dataIndex + rowIndex;

View File

@ -24,7 +24,7 @@
v-on="propsEvent" v-on="propsEvent"
@selected-change="handleTableSelect" @selected-change="handleTableSelect"
@batch-action="handleTableBatch" @batch-action="handleTableBatch"
@change="changeHandler" @drag-change="handleDragChange"
> >
<template #num="{ record }"> <template #num="{ record }">
<MsButton type="text">{{ record.num }}</MsButton> <MsButton type="text">{{ record.num }}</MsButton>
@ -226,7 +226,7 @@
</template> </template>
<script setup lang="ts"> <script setup lang="ts">
import { FormInstance, Message, TableChangeExtra, TableData } from '@arco-design/web-vue'; import { FormInstance, Message } from '@arco-design/web-vue';
import MsButton from '@/components/pure/ms-button/index.vue'; import MsButton from '@/components/pure/ms-button/index.vue';
import MsBaseTable from '@/components/pure/ms-table/base-table.vue'; import MsBaseTable from '@/components/pure/ms-table/base-table.vue';
@ -518,37 +518,14 @@
} }
// //
async function changeHandler(data: TableData[], extra: TableChangeExtra, currentData: TableData[]) { async function handleDragChange(params: DragSortParams) {
if (!currentData || currentData.length === 1) { try {
return; await dragSort(params);
} Message.success(t('caseManagement.featureCase.sortSuccess'));
loadCaseList();
if (extra && extra.dragTarget?.id) { } catch (error) {
const params: DragSortParams = { // eslint-disable-next-line no-console
projectId: appStore.currentProjectId, console.log(error);
targetId: '', // id
moveMode: 'BEFORE',
moveId: extra.dragTarget.id as string, // id
};
const index = currentData.findIndex((item: any) => item.key === extra.dragTarget?.id);
if (index > -1 && currentData[index + 1]) {
params.moveMode = 'BEFORE';
params.targetId = currentData[index + 1].raw.id;
} else if (index > -1 && !currentData[index + 1]) {
if (index > -1 && currentData[index - 1]) {
params.moveMode = 'AFTER';
params.targetId = currentData[index - 1].raw.id;
}
}
try {
await dragSort(params);
Message.success(t('caseManagement.featureCase.sortSuccess'));
loadCaseList();
} catch (error) {
// eslint-disable-next-line no-console
console.log(error);
}
} }
} }