123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286 |
- <template>
- <div class="device-manager-box">
- <!--引用表格-->
- <BasicTable
- @register="registerTable"
- :rowSelection="rowSelection"
- :expandedRowKeys="expandedRowKeys"
- @expand="handleExpand"
- @fetch-success="onFetchSuccess"
- >
- <!--插槽:table标题-->
- <template #tableTitle>
- <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">
- <template #overlay>
- <a-menu>
- <a-menu-item key="1" @click="batchHandleDelete">
- <Icon icon="ant-design:delete-outlined" />
- 删除
- </a-menu-item>
- </a-menu>
- </template>
- <a-button
- >批量操作
- <Icon icon="ant-design:down-outlined" />
- </a-button>
- </a-dropdown>
- </template>
- <!--操作栏-->
- <template #action="{ record }">
- <TableAction :actions="getTableAction(record)" />
- </template>
- </BasicTable>
- <!--字典弹窗-->
- <CategoryModal @register="registerModal" @success="handleSuccess" />
- </div>
- </template>
- <script lang="ts" name="system-category" setup>
- //ts语法
- import { ref, unref } from 'vue';
- import { BasicTable, TableAction } from '/@/components/Table';
- import CategoryModal from './components/CategoryModal.vue';
- import { useModal } from '/@/components/Modal';
- // import { useMethods } from '/@/hooks/system/useMethods';
- import { columns, searchFormSchema } from './category.data';
- import { list, deleteCategory, batchDeleteCategory, getExportUrl, getImportUrl, getChildList, getChildListBatch } from './category.api';
- import { useListPage } from '/@/hooks/system/useListPage';
- import { defHttp } from '/@/utils/http/axios';
- const expandedRowKeys = ref([]);
- // const { handleExportXls, handleImportXls } = useMethods();
- //字典model
- const [registerModal, { openModal }] = useModal();
- // 列表页面公共参数、方法
- const { prefixCls, onExportXls, onImportXls, tableContext } = useListPage({
- designScope: 'category-template',
- tableProps: {
- title: '设备分类',
- api: list,
- columns: columns,
- actionColumn: {
- width: 180,
- },
- formConfig: {
- schemas: searchFormSchema,
- },
- },
- exportConfig: {
- name: '设备分类列表',
- url: getExportUrl,
- },
- importConfig: {
- url: getImportUrl,
- },
- });
- //注册table数据
- const [registerTable, { reload, collapseAll, updateTableDataRecord, findTableDataRecord, getDataSource }, { rowSelection, selectedRowKeys }] =
- tableContext;
- /**
- * 新增事件
- */
- 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) {
- await deleteCategory({ id: record.id }, importSuccess);
- }
- /**
- * 批量删除事件
- */
- async function batchHandleDelete() {
- const ids = selectedRowKeys.value.filter((item) => !item.includes('loading'));
- await batchDeleteCategory({ ids: ids }, importSuccess);
- }
- /**
- * 导入
- */
- function importSuccess() {
- //update-begin---author:wangshuai ---date:20220530 for:[issues/54]树字典,勾选,然后批量删除,系统错误------------
- (selectedRowKeys.value = []) && reload();
- //update-end---author:wangshuai ---date:20220530 for:[issues/54]树字典,勾选,然后批量删除,系统错误--------------
- }
- /**
- * 添加下级
- */
- function handleAddSub(record) {
- openModal(true, {
- record,
- isUpdate: false,
- });
- }
- /**
- * 成功回调
- */
- async function handleSuccess({ isUpdate, values, expandedArr }) {
- if (isUpdate) {
- //编辑回调
- updateTableDataRecord(values.id, values);
- } else {
- if (!values['pid']) {
- //新增根节点
- reload();
- } else {
- //新增子集
- expandedRowKeys.value = [];
- for (let key of unref(expandedArr)) {
- await expandTreeNode(key);
- }
- }
- }
- }
- /**
- * 接口请求成功后回调
- */
- function onFetchSuccess(result) {
- getDataByResult(result.items) && loadDataByExpandedRows();
- }
- /**
- * 根据已展开的行查询数据(用于保存后刷新时异步加载子级的数据)
- */
- async function loadDataByExpandedRows() {
- 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);
- }
- });
- }
- };
- fn(getDataSource());
- }
- }
- }
- /**
- * 处理数据集
- */
- 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;
- });
- }
- }
- /**
- *树节点展开合并
- * */
- async function handleExpand(expanded, record) {
- // 判断是否是展开状态,展开状态(expanded)并且存在子集(children)并且未加载过(isLoading)的就去查询子节点数据
- if (expanded) {
- expandedRowKeys.value.push(record.id);
- if (record.children.length > 0 && !!record.children[0].isLoading) {
- let result = await defHttp.get({ url: `/sys/dict/getDictItems/${record.devicekind + 'kind'}` }, {}); //defHttp.get({ url: `/sys/dict/getDictItems/${record.devicekind + 'kind'}` }, {})
- if (result && result.length > 0) {
- record.children = getDataByResult(result);
- } else {
- record.children = null;
- record.hasChild = '0';
- }
- }
- } else {
- let keyIndex = expandedRowKeys.value.indexOf(record.id);
- if (keyIndex >= 0) {
- expandedRowKeys.value.splice(keyIndex, 1);
- }
- }
- }
- /**
- *操作表格后处理树节点展开合并
- * */
- async function expandTreeNode(key) {
- let record = findTableDataRecord(key);
- expandedRowKeys.value.push(key);
- 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);
- }
- /**
- * 操作栏
- */
- function getTableAction(record) {
- debugger;
- return [
- {
- label: '编辑',
- onClick: handleEdit.bind(null, record),
- },
- {
- label: '删除',
- popConfirm: {
- title: '确定删除吗?',
- confirm: handleDelete.bind(null, record),
- },
- },
- {
- label: '添加下级',
- onClick: handleAddSub.bind(null, { pid: record.id }),
- },
- ];
- }
- </script>
- <style scoped></style>
|