CET-vue-3.0/src/views/system/category/index.vue

296 lines
8.8 KiB
Vue
Raw Normal View History

2022-03-10 09:47:29 +08:00
<template>
2022-06-10 10:44:44 +08:00
<div>
2022-03-10 09:47:29 +08:00
<!--引用表格-->
<BasicTable
@register="registerTable"
:rowSelection="rowSelection"
:expandedRowKeys="expandedRowKeys"
@expand="handleExpand"
@fetch-success="onFetchSuccess"
>
2022-03-10 09:47:29 +08:00
<!--插槽:table标题-->
<template #tableTitle>
2022-06-10 10:44:44 +08:00
<a-button type="primary" preIcon="ant-design:plus-outlined" @click="handleCreate"> 新增</a-button>
<a-button type="primary" preIcon="ant-design:export-outlined" @click="onExportXls"> 导出</a-button>
<j-upload-button type="primary" preIcon="ant-design:import-outlined" @click="onImportXls">导入</j-upload-button>
<a-dropdown v-if="selectedRowKeys.length > 0">
2022-03-10 09:47:29 +08:00
<template #overlay>
<a-menu>
<a-menu-item key="1" @click="batchHandleDelete">
<Icon icon="ant-design:delete-outlined"></Icon>
删除
</a-menu-item>
</a-menu>
</template>
2022-06-10 10:44:44 +08:00
<a-button
>批量操作
2022-03-10 09:47:29 +08:00
<Icon icon="ant-design:down-outlined"></Icon>
</a-button>
</a-dropdown>
</template>
<!--操作栏-->
<template #action="{ record }">
2022-06-10 10:44:44 +08:00
<TableAction :actions="getTableAction(record)" />
2022-03-10 09:47:29 +08:00
</template>
</BasicTable>
<!--字典弹窗-->
2022-06-10 10:44:44 +08:00
<CategoryModal @register="registerModal" @success="handleSuccess" />
2022-03-10 09:47:29 +08:00
</div>
</template>
<script lang="ts" name="system-category" setup>
//ts语法
2022-06-10 10:44:44 +08:00
import { ref, computed, unref, toRaw, nextTick } from 'vue';
import { BasicTable, useTable, TableAction } from '/src/components/Table';
import { useDrawer } from '/src/components/Drawer';
2022-03-10 09:47:29 +08:00
import CategoryModal from './components/CategoryModal.vue';
2022-06-10 10:44:44 +08:00
import { useModal } from '/src/components/Modal';
import { useMethods } from '/src/hooks/system/useMethods';
import { columns, searchFormSchema } from './category.data';
import { list, deleteCategory, batchDeleteCategory, getExportUrl, getImportUrl, getChildList, getChildListBatch } from './category.api';
2022-03-10 09:47:29 +08:00
import { useListPage } from '/@/hooks/system/useListPage';
const expandedRowKeys = ref([]);
2022-06-10 10:44:44 +08:00
const { handleExportXls, handleImportXls } = useMethods();
2022-03-10 09:47:29 +08:00
//字典model
2022-06-10 10:44:44 +08:00
const [registerModal, { openModal }] = useModal();
2022-03-10 09:47:29 +08:00
// 列表页面公共参数、方法
const { prefixCls, onExportXls, onImportXls, tableContext } = useListPage({
designScope: 'category-template',
tableProps: {
title: '分类字典',
api: list,
columns: columns,
actionColumn: {
width: 180,
},
formConfig: {
schemas: searchFormSchema,
},
},
exportConfig: {
2022-06-10 10:44:44 +08:00
name: '分类字典列表',
url: getExportUrl,
2022-03-10 09:47:29 +08:00
},
importConfig: {
2022-06-10 10:44:44 +08:00
url: getImportUrl,
},
});
2022-03-10 09:47:29 +08:00
//注册table数据
const [registerTable, { reload, collapseAll, updateTableDataRecord, findTableDataRecord, getDataSource }, { rowSelection, selectedRowKeys }] =
tableContext;
2022-03-10 09:47:29 +08:00
/**
* 新增事件
*/
function handleCreate() {
openModal(true, {
isUpdate: false,
});
}
/**
* 编辑事件
*/
async function handleEdit(record) {
openModal(true, {
record,
isUpdate: true,
});
}
/**
* 详情
*/
async function handleDetail(record) {
openModal(true, {
record,
isUpdate: true,
hideFooter: true,
});
}
/**
* 删除事件
*/
async function handleDelete(record) {
2022-06-10 10:44:44 +08:00
await deleteCategory({ id: record.id }, importSuccess);
2022-03-10 09:47:29 +08:00
}
/**
* 批量删除事件
*/
async function batchHandleDelete() {
2022-06-10 10:44:44 +08:00
const ids = selectedRowKeys.value.filter((item) => !item.includes('loading'));
await batchDeleteCategory({ ids: ids }, importSuccess);
2022-03-10 09:47:29 +08:00
}
/**
* 导入
*/
2022-06-10 10:44:44 +08:00
function importSuccess() {
//update-begin---author:wangshuai ---date:20220530 for[issues/54]树字典,勾选,然后批量删除,系统错误------------
(selectedRowKeys.value = []) && reload();
//update-end---author:wangshuai ---date:20220530 for[issues/54]树字典,勾选,然后批量删除,系统错误--------------
2022-03-10 09:47:29 +08:00
}
/**
* 添加下级
*/
function handleAddSub(record) {
openModal(true, {
record,
isUpdate: false,
});
}
/**
* 成功回调
*/
async function handleSuccess({ isUpdate,isSubAdd, values, expandedArr }) {
2022-03-10 09:47:29 +08:00
if (isUpdate) {
//编辑回调
updateTableDataRecord(values.id, values);
} else {
2022-06-10 10:44:44 +08:00
if (!values['pid']) {
//新增根节点
reload();
} else {
//新增子集
//update-begin-author:liusq---date:20230411--for: [issue/4550]分类字典数据量过多会造成数据查询时间过长---
if(isSubAdd){
await expandTreeNode(values.pid);
//update-end-author:liusq---date:20230411--for: [issue/4550]分类字典数据量过多会造成数据查询时间过长---
}else{
expandedRowKeys.value = [];
for (let key of unref(expandedArr)) {
await expandTreeNode(key);
}
2022-03-10 09:47:29 +08:00
}
2022-06-10 10:44:44 +08:00
}
2022-03-10 09:47:29 +08:00
}
}
/**
* 接口请求成功后回调
*/
function onFetchSuccess(result) {
2022-06-10 10:44:44 +08:00
getDataByResult(result.items) && loadDataByExpandedRows();
2022-03-10 09:47:29 +08:00
}
/**
* 根据已展开的行查询数据用于保存后刷新时异步加载子级的数据
*/
async function loadDataByExpandedRows() {
2022-06-10 10:44:44 +08:00
if (unref(expandedRowKeys).length > 0) {
const res = await getChildListBatch({ parentIds: unref(expandedRowKeys).join(',') });
if (res.success && res.result.records.length > 0) {
//已展开的数据批量子节点
let records = res.result.records;
const listMap = new Map();
for (let item of records) {
let pid = item['pid'];
if (unref(expandedRowKeys).includes(pid)) {
let mapList = listMap.get(pid);
if (mapList == null) {
mapList = [];
}
mapList.push(item);
listMap.set(pid, mapList);
}
}
let childrenMap = listMap;
let fn = (list) => {
if (list) {
list.forEach((data) => {
if (unref(expandedRowKeys).includes(data.id)) {
data.children = getDataByResult(childrenMap.get(data.id));
fn(data.children);
2022-03-10 09:47:29 +08:00
}
2022-06-10 10:44:44 +08:00
});
2022-03-10 09:47:29 +08:00
}
2022-06-10 10:44:44 +08:00
};
fn(getDataSource());
2022-03-10 09:47:29 +08:00
}
2022-06-10 10:44:44 +08:00
}
2022-03-10 09:47:29 +08:00
}
/**
* 处理数据集
*/
2022-06-10 10:44:44 +08:00
function getDataByResult(result) {
if (result && result.length > 0) {
return result.map((item) => {
//判断是否标记了带有子节点
if (item['hasChild'] == '1') {
let loadChild = { id: item.id + '_loadChild', name: 'loading...', isLoading: true };
item.children = [loadChild];
}
return item;
});
}
2022-03-10 09:47:29 +08:00
}
/**
*树节点展开合并
* */
async function handleExpand(expanded, record) {
// 判断是否是展开状态,展开状态(expanded)并且存在子集(children)并且未加载过(isLoading)的就去查询子节点数据
if (expanded) {
2022-06-10 10:44:44 +08:00
expandedRowKeys.value.push(record.id);
2022-03-10 09:47:29 +08:00
if (record.children.length > 0 && !!record.children[0].isLoading) {
2022-06-10 10:44:44 +08:00
let result = await getChildList({ pid: record.id });
2022-03-10 09:47:29 +08:00
if (result && result.length > 0) {
record.children = getDataByResult(result);
} else {
2022-06-10 10:44:44 +08:00
record.children = null;
record.hasChild = '0';
2022-03-10 09:47:29 +08:00
}
}
} else {
2022-06-10 10:44:44 +08:00
let keyIndex = expandedRowKeys.value.indexOf(record.id);
2022-03-10 09:47:29 +08:00
if (keyIndex >= 0) {
expandedRowKeys.value.splice(keyIndex, 1);
}
}
}
/**
*操作表格后处理树节点展开合并
* */
async function expandTreeNode(key) {
let record:any = findTableDataRecord(key);
//update-begin-author:liusq---date:20230411--for: [issue/4550]分类字典数据量过多会造成数据查询时间过长,显示“接口请求超时,请刷新页面重试!”---
if(!expandedRowKeys.value.includes(key)){
expandedRowKeys.value.push(key);
}
//update-end-author:liusq---date:20230411--for: [issue/4550]分类字典数据量过多会造成数据查询时间过长,显示“接口请求超时,请刷新页面重试!”---
2022-06-10 10:44:44 +08:00
let result = await getChildList({ pid: key });
if (result && result.length > 0) {
record.children = getDataByResult(result);
} else {
record.children = null;
record.hasChild = '0';
}
updateTableDataRecord(key, record);
2022-03-10 09:47:29 +08:00
}
/**
* 操作栏
*/
function getTableAction(record) {
return [
{
label: '编辑',
onClick: handleEdit.bind(null, record),
},
{
label: '删除',
popConfirm: {
title: '确定删除吗?',
confirm: handleDelete.bind(null, record),
},
},
{
label: '添加下级',
2022-06-10 10:44:44 +08:00
onClick: handleAddSub.bind(null, { pid: record.id }),
},
];
2022-03-10 09:47:29 +08:00
}
</script>
2022-06-10 10:44:44 +08:00
<style scoped></style>