兰宝车间质量管理系统-前端
src/plugins/tab.ts
@@ -1,13 +1,16 @@
import { useTagsViewStore } from '@/store/modules/tagsView';
import router from '@/router';
import { TagView, RouteLocationRaw } from 'vue-router';
import { TagView, RouteLocationMatched } from 'vue-router';
export default {
  // 刷新当前tab页签
  async refreshPage(obj: TagView): Promise<void> {
  /**
   * 刷新当前tab页签
   * @param obj 标签对象
   */
  async refreshPage(obj?: TagView): Promise<void> {
    const { path, query, matched } = router.currentRoute.value;
    if (obj === undefined) {
      matched.forEach((m) => {
      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 };
@@ -15,16 +18,21 @@
        }
      });
    }
    // prettier-ignore
    await useTagsViewStore().delCachedView(obj)
    router.replace({
      path: '/redirect' + obj.path,
      query: obj.query
    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);
  closeOpenPage(obj: TagView): void {
    useTagsViewStore().delView(router.currentRoute.value as any);
    if (obj !== undefined) {
      router.push(obj);
    }
@@ -33,10 +41,10 @@
  async closePage(obj?: TagView): Promise<{ visitedViews: TagView[]; cachedViews: string[] } | any> {
    if (obj === undefined) {
      // prettier-ignore
      const { visitedViews } = await useTagsViewStore().delView(router.currentRoute.value) as any
      const latestView = visitedViews.slice(-1)[0]
      const { visitedViews } = await useTagsViewStore().delView(router.currentRoute.value as any)
      const latestView = visitedViews.slice(-1)[0];
      if (latestView) {
        return router.push(latestView.fullPath)
        return router.push(latestView.fullPath as any);
      }
      return router.push('/');
    }
@@ -47,22 +55,31 @@
    return useTagsViewStore().delAllViews();
  },
  // 关闭左侧tab页签
  closeLeftPage(obj: TagView) {
    return useTagsViewStore().delLeftTags(obj || router.currentRoute.value);
  closeLeftPage(obj?: TagView) {
    return useTagsViewStore().delLeftTags(obj || (router.currentRoute.value as any));
  },
  // 关闭右侧tab页签
  closeRightPage(obj: TagView) {
    return useTagsViewStore().delRightTags(obj || router.currentRoute.value);
  closeRightPage(obj?: TagView) {
    return useTagsViewStore().delRightTags(obj || (router.currentRoute.value as any));
  },
  // 关闭其他tab页签
  closeOtherPage(obj: TagView) {
    return useTagsViewStore().delOthersViews(obj || router.currentRoute.value);
  closeOtherPage(obj?: TagView) {
    return useTagsViewStore().delOthersViews(obj || (router.currentRoute.value as any));
  },
  // 打开tab页签
  openPage(url: RouteLocationRaw) {
    return router.push(url);
  /**
   * 打开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页签
  /**
   * 修改tab页签
   * @param obj 标签对象
   */
  updatePage(obj: TagView) {
    return useTagsViewStore().updateVisitedView(obj);
  }