feat(全局): table组件增加拖拽排序
This commit is contained in:
parent
c29e0490c1
commit
e6c660aa32
|
@ -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;
|
||||||
|
|
|
@ -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);
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue