feat: 表格批量操作支持跨页全选
This commit is contained in:
parent
be7d73ada4
commit
72eebe62e0
|
@ -1,6 +1,6 @@
|
||||||
export default {
|
export default {
|
||||||
msPagination: {
|
msPagination: {
|
||||||
total: '共 {total} 项数据',
|
total: '共 {total} 条',
|
||||||
current: '当前页数 {current}',
|
current: '当前页数 {current}',
|
||||||
countPerPage: '条/页',
|
countPerPage: '条/页',
|
||||||
pageSize: '每页条数',
|
pageSize: '每页条数',
|
||||||
|
|
|
@ -146,17 +146,18 @@
|
||||||
</a-table>
|
</a-table>
|
||||||
<div
|
<div
|
||||||
class="mt-[16px] flex h-[32px] w-[100%] flex-row flex-nowrap items-center justify-end px-0"
|
class="mt-[16px] flex h-[32px] w-[100%] flex-row flex-nowrap items-center justify-end px-0"
|
||||||
:class="{ 'batch-action': showBatchAction }"
|
:class="{ 'justify-between': showBatchAction }"
|
||||||
>
|
>
|
||||||
<batch-action
|
<batch-action
|
||||||
v-if="showBatchAction"
|
v-if="showBatchAction"
|
||||||
:select-row-count="selectCurrent"
|
:select-row-count="selectCurrent"
|
||||||
:action-config="props.actionConfig"
|
:action-config="props.actionConfig"
|
||||||
@batch-action="(item: BatchActionParams) => emit('batchAction', item)"
|
@batch-action="handleBatchAction"
|
||||||
@clear="emit('clearSelector')"
|
@clear="emit('clearSelector')"
|
||||||
/>
|
/>
|
||||||
<ms-pagination
|
<ms-pagination
|
||||||
v-if="attrs.showPagination"
|
v-if="attrs.showPagination"
|
||||||
|
v-show="props.selectorStatus !== SelectAllEnum.CURRENT"
|
||||||
size="small"
|
size="small"
|
||||||
v-bind="attrs.msPagination"
|
v-bind="attrs.msPagination"
|
||||||
hide-on-single-page
|
hide-on-single-page
|
||||||
|
@ -178,7 +179,14 @@
|
||||||
import ColumnSelector from './columnSelector.vue';
|
import ColumnSelector from './columnSelector.vue';
|
||||||
import MsIcon from '@/components/pure/ms-icon-font/index.vue';
|
import MsIcon from '@/components/pure/ms-icon-font/index.vue';
|
||||||
|
|
||||||
import type { MsTableProps, BatchActionParams, BatchActionConfig, MsTableColumn, MsPaginationI } from './type';
|
import type {
|
||||||
|
MsTableProps,
|
||||||
|
BatchActionParams,
|
||||||
|
BatchActionConfig,
|
||||||
|
MsTableColumn,
|
||||||
|
MsPaginationI,
|
||||||
|
BatchActionQueryParams,
|
||||||
|
} from './type';
|
||||||
import type { TableData } from '@arco-design/web-vue';
|
import type { TableData } from '@arco-design/web-vue';
|
||||||
import MsCheckbox from '../ms-checkbox/MsCheckbox.vue';
|
import MsCheckbox from '../ms-checkbox/MsCheckbox.vue';
|
||||||
|
|
||||||
|
@ -199,7 +207,7 @@
|
||||||
spanMethod?: (params: { record: TableData; rowIndex: number; columnIndex: number }) => void;
|
spanMethod?: (params: { record: TableData; rowIndex: number; columnIndex: number }) => void;
|
||||||
}>();
|
}>();
|
||||||
const emit = defineEmits<{
|
const emit = defineEmits<{
|
||||||
(e: 'batchAction', value: BatchActionParams): void;
|
(e: 'batchAction', value: BatchActionParams, queryParams: BatchActionQueryParams): void;
|
||||||
(e: 'pageChange', value: number): void;
|
(e: 'pageChange', value: number): void;
|
||||||
(e: 'pageSizeChange', value: number): void;
|
(e: 'pageSizeChange', value: number): void;
|
||||||
(e: 'rowNameChange', value: TableData): void;
|
(e: 'rowNameChange', value: TableData): void;
|
||||||
|
@ -213,10 +221,10 @@
|
||||||
// 全选按钮-总条数
|
// 全选按钮-总条数
|
||||||
const selectTotal = computed(() => {
|
const selectTotal = computed(() => {
|
||||||
const { selectorStatus } = props;
|
const { selectorStatus } = props;
|
||||||
if (selectorStatus === SelectAllEnum.ALL) {
|
if (selectorStatus === SelectAllEnum.CURRENT) {
|
||||||
return (attrs.msPagination as MsPaginationI)?.total || appStore.pageSize;
|
return (attrs.msPagination as MsPaginationI)?.pageSize || appStore.pageSize;
|
||||||
}
|
}
|
||||||
return (attrs.msPagination as MsPaginationI).pageSize || appStore.pageSize;
|
return (attrs.msPagination as MsPaginationI)?.total || appStore.pageSize;
|
||||||
});
|
});
|
||||||
|
|
||||||
// 全选按钮-当前的条数
|
// 全选按钮-当前的条数
|
||||||
|
@ -288,9 +296,22 @@
|
||||||
};
|
};
|
||||||
|
|
||||||
const showBatchAction = computed(() => {
|
const showBatchAction = computed(() => {
|
||||||
return selectCurrent.value > 0 && attrs.showSelectAll;
|
return selectCurrent.value > 0 && attrs.selectable;
|
||||||
});
|
});
|
||||||
|
|
||||||
|
const handleBatchAction = (value: BatchActionParams) => {
|
||||||
|
const { selectorStatus, selectedKeys, excludeKeys } = props;
|
||||||
|
const queryParams: BatchActionQueryParams = {
|
||||||
|
selectedIds: Array.from(selectedKeys),
|
||||||
|
excludeIds: Array.from(excludeKeys),
|
||||||
|
selectAll: selectorStatus === SelectAllEnum.ALL,
|
||||||
|
params: {
|
||||||
|
...(attrs.msPagination as MsPaginationI),
|
||||||
|
},
|
||||||
|
};
|
||||||
|
emit('batchAction', value, queryParams);
|
||||||
|
};
|
||||||
|
|
||||||
const handleEditInputEnter = (record: TableData) => {
|
const handleEditInputEnter = (record: TableData) => {
|
||||||
editActiveKey.value = '';
|
editActiveKey.value = '';
|
||||||
emit('rowNameChange', record);
|
emit('rowNameChange', record);
|
||||||
|
@ -365,9 +386,6 @@
|
||||||
<style lang="less" scoped>
|
<style lang="less" scoped>
|
||||||
.ms-base-table {
|
.ms-base-table {
|
||||||
position: relative;
|
position: relative;
|
||||||
.batch-action {
|
|
||||||
justify-content: flex-start;
|
|
||||||
}
|
|
||||||
.ms-table-edit-active {
|
.ms-table-edit-active {
|
||||||
color: rgb(var(--primary-5));
|
color: rgb(var(--primary-5));
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,16 +5,16 @@ export default {
|
||||||
enable: 'Enable',
|
enable: 'Enable',
|
||||||
disable: 'Disable',
|
disable: 'Disable',
|
||||||
batch: {
|
batch: {
|
||||||
title: '批量操作',
|
title: 'Batch Operation',
|
||||||
selected: '已选择 {count} 项',
|
selected: 'Selected {count} ',
|
||||||
export: '导出',
|
export: 'Export',
|
||||||
edit: '编辑',
|
edit: 'Edit',
|
||||||
delete: '删除',
|
delete: 'Delete',
|
||||||
moveTo: '移动到',
|
moveTo: 'Move To',
|
||||||
copyTo: '复制到',
|
copyTo: 'Copy To',
|
||||||
related: '关联需求',
|
related: 'Related Requirements',
|
||||||
generateDep: '生成依赖关系',
|
generateDep: 'Generate Dependency',
|
||||||
addPublic: '添加到公用用例库',
|
addPublic: 'Add to Public Case Library',
|
||||||
clear: 'clear',
|
clear: 'clear',
|
||||||
},
|
},
|
||||||
columnSetting: {
|
columnSetting: {
|
||||||
|
|
|
@ -6,7 +6,7 @@ export default {
|
||||||
disable: '禁用',
|
disable: '禁用',
|
||||||
batch: {
|
batch: {
|
||||||
title: '批量操作',
|
title: '批量操作',
|
||||||
selected: '已选择 {count} 项',
|
selected: '已选择 {count} 条',
|
||||||
export: '导出',
|
export: '导出',
|
||||||
edit: '编辑',
|
edit: '编辑',
|
||||||
delete: '删除',
|
delete: '删除',
|
||||||
|
|
|
@ -1,4 +1,5 @@
|
||||||
import { ColumnEditTypeEnum, SelectAllEnum } from '@/enums/tableEnum';
|
import { ColumnEditTypeEnum, SelectAllEnum } from '@/enums/tableEnum';
|
||||||
|
import { TableQueryParams } from '@/models/common';
|
||||||
import { TableColumnData, TableData, TableDraggable, TableChangeExtra } from '@arco-design/web-vue';
|
import { TableColumnData, TableData, TableDraggable, TableChangeExtra } from '@arco-design/web-vue';
|
||||||
|
|
||||||
export interface MsPaginationI {
|
export interface MsPaginationI {
|
||||||
|
@ -110,3 +111,10 @@ export interface SetPaginationPrams {
|
||||||
current: number;
|
current: number;
|
||||||
total?: number;
|
total?: number;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
export interface BatchActionQueryParams {
|
||||||
|
excludeIds?: string[]; // 排除的id
|
||||||
|
selectedIds?: string[]; // 选中的id
|
||||||
|
selectAll: boolean; // 是否跨页全选
|
||||||
|
params?: TableQueryParams; // 查询参数
|
||||||
|
}
|
||||||
|
|
|
@ -62,16 +62,6 @@ export default function useTableProps<T>(
|
||||||
|
|
||||||
// 属性组
|
// 属性组
|
||||||
const propsRes = ref<MsTableProps<T>>(defaultProps);
|
const propsRes = ref<MsTableProps<T>>(defaultProps);
|
||||||
const oldPagination = ref<Pagination>({
|
|
||||||
current: 1,
|
|
||||||
pageSize: appStore.pageSize,
|
|
||||||
total: 0,
|
|
||||||
showPageSize: appStore.showPageSize,
|
|
||||||
showTotal: appStore.showTotal,
|
|
||||||
showJumper: appStore.showJumper,
|
|
||||||
hideOnSinglePage: appStore.hideOnSinglePage,
|
|
||||||
simple: defaultProps.pageSimple,
|
|
||||||
} as Pagination);
|
|
||||||
|
|
||||||
// 排序
|
// 排序
|
||||||
const sortItem = ref<object>({});
|
const sortItem = ref<object>({});
|
||||||
|
|
|
@ -269,6 +269,7 @@
|
||||||
columns,
|
columns,
|
||||||
size: 'default',
|
size: 'default',
|
||||||
selectable: true,
|
selectable: true,
|
||||||
|
pageSimple: true,
|
||||||
},
|
},
|
||||||
(record) => ({
|
(record) => ({
|
||||||
...record,
|
...record,
|
||||||
|
|
Loading…
Reference in New Issue