From e423d8afcf5b9666e166565d0509b621ebab17e7 Mon Sep 17 00:00:00 2001
From: 疯狂的狮子Li <15040126243@163.com>
Date: 星期一, 13 一月 2025 14:11:00 +0800
Subject: [PATCH] !172 合并 warmflow 功能分支 * update 优化 流程定义页面 点击复制之后跳转到未发布列表 * update 优化 流程定义页面 增加加载loading层 * fix: v-model处理有延迟 需要手动处理 * update 调整流程定义查询 * Merge remote-tracking branch 'origin/dev' into warm-flw-future * update 调整可驳回的节点 * update: 调整文案 * update: 激活/挂起改为switch操作 * update 优化 代码删除无用输出 * update 统一抄送人使用昵称展示 * update 调整分类接口 * update 统一业务id参数 * update 删除默认顶节点 * !168 优化流程分类 * update 恢复误删除代码 * update 优化流程分类 * update 修复 路由跳转未改全 * [update] * fix 修复一些问题 * update 重构流程分类表 * update 流程定义增加表单路径与编辑功能 修复一些其他bug * fix 修复 一些问题 * update 变量统一命名 * add 增加示例 * Merge branch 'warm-flw-future' of https://gitee.com/JavaLionLi/plus-ui… * update 调整办理人 * Merge remote-tracking branch 'origin/dev' into warm-flw-future * add 增加示例 * update 调整审批记录 添加流程导出 * remove 删除无用代码 * remove 删除无用代码 * [update] * [fix] * 流程干预删除委托 * 增加附件 * 附件修改 * 申请人查询修改 * 1.修改查询条件 * !167 fix 修复 import路径修改不全问题 * fix 修复 import路径修改不全问题 * !166 update 清除 ProcessPreview 引用 * update 清除 ProcessPreview 引用 * remove 删除 bpmn.js 设计器 * remove 删除 bpmn.js 设计器 * remove 删除 bpmn.js 设计器 * remove 删除 bpmn.js 设计器 * fix 修复 前端路径修改不全问题 * update 优化接口请求路径 * add 添加作废 * add 添加流程干预 * update 调整加签,减签 * update 调整加签,减签 * add 增加流程查看 * update 调整委托,转办 * update 调整流程变量显示 * update 调整办理人修改 * update 调整流程实例状态页面 * update 调整已办页面 * add 添加流程撤销 * update 调整任务,流程实例 ,流程定义页面 * Merge branch 'dev' into warm-flw-future * update 调整流程定义页面 * add 添加流程变量查看 * update 调整设计器路由名称 * update 调整办理人 * update 调整设计器uri * update 调整设计器请求uri 调整待办状态 * update 调整办理 驳回 终止等状态 * add 添加模型新增 * add 添加warm-ui设计器,删除无用代码 * Merge remote-tracking branch 'origin/dev' into warm-flw-future * add 添加流程设计 * update 调整驳回 * update 调整视图类型错误 * Merge branch 'warm-flw-future' of https://gitee.com/JavaLionLi/plus-ui… * 添加已办,未办 * Merge remote-tracking branch 'origin/dev' into warm-flw-future * update 调整流程实例,待办查询 * add 添加代办人,调整提交按钮校验 * update 调整流程定义查询 * add添加流程定义激活 挂起 * add 添加流程文件部署 调整流程发布 * update 优化 时间搜索组件统一 * Merge remote-tracking branch 'origin/dev' into warm-flw-future * fix 修复 用户管理编辑安全权限错误问题 * Merge remote-tracking branch 'origin/dev' into warm-flw-future * update 优化 类型报错问题 * update 优化 切换租户后刷新首页 * update 优化 实现表格行选中切换 * update 优化 使用 vueuse 重构 websocket 实现 * update 优化 使用 vueuse 重构 websocket 实现 * fix 修复 登出后重新登录 sse推送报错问题 * reset 回滚 代码修改 采用其他方案 * fix 修复 登出后重新登录 sse推送报错问题 * update 优化 删除无用代码 * update element-plus 2.7.5 => 2.7.8 * reset 回滚 错误修复 * update 优化 代码生成器编辑页禁用缓存 防止同步后页面不更新问题 * fix 修复 代码生成同步点击取消报错问题 * 初始化添加warm-flow

---
 src/plugins/tab.ts |  153 ++++++++++++++++++++++++++++++--------------------
 1 files changed, 92 insertions(+), 61 deletions(-)

diff --git a/src/plugins/tab.ts b/src/plugins/tab.ts
index ad6f1c3..4b44dc6 100644
--- a/src/plugins/tab.ts
+++ b/src/plugins/tab.ts
@@ -1,65 +1,96 @@
-import { useTagsViewStore } from '@/store/modules/tagsView';
 import router from '@/router';
-import { TagView, RouteLocationRaw } from 'vue-router';
+import { RouteLocationMatched, RouteLocationNormalized, RouteLocationRaw } from 'vue-router';
+import useTagsViewStore from '@/store/modules/tagsView';
 
 export default {
-	// 鍒锋柊褰撳墠tab椤电
-	async refreshPage(obj: TagView): Promise<void> {
-		const { path, query, matched } = router.currentRoute.value;
-		if (obj === undefined) {
-			matched.forEach((m) => {
-				if (m.components && m.components.default && m.components.default.name) {
-					if (!['Layout', 'ParentView'].includes(m.components.default.name)) {
-						obj = { name: m.components.default.name, path: path, query: query };
-					}
-				}
-			});
-		}
-		// prettier-ignore
-		await useTagsViewStore().delCachedView(obj)
-		router.replace({
-			path: '/redirect' + obj.path,
-			query: obj.query
-		});
-	},
-	// 鍏抽棴褰撳墠tab椤电锛屾墦寮�鏂伴〉绛�
-	closeOpenPage(obj: RouteLocationRaw): void {
-		useTagsViewStore().delView(router.currentRoute.value);
-		if (obj !== undefined) {
-			router.push(obj);
-		}
-	},
-	// 鍏抽棴鎸囧畾tab椤电
-	async closePage(obj?: TagView): Promise<{ visitedViews: TagView[]; cachedViews: string[] } | any> {
-		if (obj === undefined) {
-			// prettier-ignore
-			const { lastPath } = await useTagsViewStore().delView(router.currentRoute.value) as any
-			return router.push(lastPath || '/index');
-		}
-		return useTagsViewStore().delView(obj);
-	},
-	// 鍏抽棴鎵�鏈塼ab椤电
-	closeAllPage() {
-		return useTagsViewStore().delAllViews();
-	},
-	// 鍏抽棴宸︿晶tab椤电
-	closeLeftPage(obj: TagView) {
-		return useTagsViewStore().delLeftTags(obj || router.currentRoute.value);
-	},
-	// 鍏抽棴鍙充晶tab椤电
-	closeRightPage(obj: TagView) {
-		return useTagsViewStore().delRightTags(obj || router.currentRoute.value);
-	},
-	// 鍏抽棴鍏朵粬tab椤电
-	closeOtherPage(obj: TagView) {
-		return useTagsViewStore().delOthersViews(obj || router.currentRoute.value);
-	},
-	// 鎵撳紑tab椤电
-	openPage(url: RouteLocationRaw) {
-		return router.push(url);
-	},
-	// 淇敼tab椤电
-	updatePage(obj: TagView) {
-		return useTagsViewStore().updateVisitedView(obj);
-	}
+  /**
+   * 鍒锋柊褰撳墠tab椤电
+   * @param obj 鏍囩瀵硅薄
+   */
+  async refreshPage(obj?: RouteLocationNormalized): Promise<void> {
+    const { path, query, matched } = router.currentRoute.value;
+    if (obj === undefined) {
+      matched.forEach((m: RouteLocationMatched) => {
+        if (m.components && m.components.default && m.components.default.name) {
+          if (!['Layout', 'ParentView'].includes(m.components.default.name)) {
+            obj = {
+              name: m.components.default.name,
+              path: path,
+              query: query,
+              matched: undefined,
+              fullPath: undefined,
+              hash: undefined,
+              params: undefined,
+              redirectedFrom: undefined,
+              meta: undefined
+            };
+          }
+        }
+      });
+    }
+    let query1: undefined | {} = {};
+    let path1: undefined | string = '';
+    if (obj) {
+      query1 = obj.query;
+      path1 = obj.path;
+    }
+    await useTagsViewStore().delCachedView(obj);
+    await router.replace({
+      path: '/redirect' + path1,
+      query: query1
+    });
+  },
+  // 鍏抽棴褰撳墠tab椤电锛屾墦寮�鏂伴〉绛�
+  closeOpenPage(obj: RouteLocationRaw): void {
+    useTagsViewStore().delView(router.currentRoute.value);
+    if (obj !== undefined) {
+      router.push(obj);
+    }
+  },
+  // 鍏抽棴鎸囧畾tab椤电
+  async closePage(obj?: RouteLocationNormalized): Promise<{ visitedViews: RouteLocationNormalized[]; cachedViews: string[] } | any> {
+    if (obj === undefined) {
+      // prettier-ignore
+      const { visitedViews } = await useTagsViewStore().delView(router.currentRoute.value)
+      const latestView = visitedViews.slice(-1)[0];
+      if (latestView) {
+        return router.push(latestView.fullPath);
+      }
+      return router.push('/');
+    }
+    return useTagsViewStore().delView(obj);
+  },
+  // 鍏抽棴鎵�鏈塼ab椤电
+  closeAllPage() {
+    return useTagsViewStore().delAllViews();
+  },
+  // 鍏抽棴宸︿晶tab椤电
+  closeLeftPage(obj?: RouteLocationNormalized) {
+    return useTagsViewStore().delLeftTags(obj || router.currentRoute.value);
+  },
+  // 鍏抽棴鍙充晶tab椤电
+  closeRightPage(obj?: RouteLocationNormalized) {
+    return useTagsViewStore().delRightTags(obj || router.currentRoute.value);
+  },
+  // 鍏抽棴鍏朵粬tab椤电
+  closeOtherPage(obj?: RouteLocationNormalized) {
+    return useTagsViewStore().delOthersViews(obj || router.currentRoute.value);
+  },
+  /**
+   * 鎵撳紑tab椤电
+   * @param url 璺敱鍦板潃
+   * @param title 鏍囬
+   * @param query 鍙傛暟
+   */
+  openPage(url: string, title?: string, query?: any) {
+    const obj = { path: url, query: { ...query, title } };
+    return router.push(obj);
+  },
+  /**
+   * 淇敼tab椤电
+   * @param obj 鏍囩瀵硅薄
+   */
+  updatePage(obj: RouteLocationNormalized) {
+    return useTagsViewStore().updateVisitedView(obj);
+  }
 };

--
Gitblit v1.9.3