tab.ts 2.6 KB

1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253545556575859606162636465666768697071727374757677787980818283848586
  1. import { useTagsViewStore } from '@/store/modules/tagsView';
  2. import router from '@/router';
  3. import { TagView, RouteLocationRaw } from 'vue-router';
  4. export default {
  5. /**
  6. * 刷新当前tab页签
  7. * @param obj 标签对象
  8. */
  9. async refreshPage(obj?: TagView): Promise<void> {
  10. const { path, query, matched } = router.currentRoute.value;
  11. if (obj === undefined) {
  12. matched.forEach((m) => {
  13. if (m.components && m.components.default && m.components.default.name) {
  14. if (!['Layout', 'ParentView'].includes(m.components.default.name)) {
  15. obj = { name: m.components.default.name, path: path, query: query };
  16. }
  17. }
  18. });
  19. }
  20. let query1: undefined | {} = {};
  21. let path1: undefined | string = '';
  22. if (obj) {
  23. query1 = obj.query;
  24. path1 = obj.path;
  25. }
  26. await useTagsViewStore().delCachedView(obj);
  27. await router.replace({
  28. path: '/redirect' + path1,
  29. query: query1
  30. });
  31. },
  32. // 关闭当前tab页签,打开新页签
  33. closeOpenPage(obj: RouteLocationRaw): void {
  34. useTagsViewStore().delView(router.currentRoute.value);
  35. if (obj !== undefined) {
  36. router.push(obj);
  37. }
  38. },
  39. // 关闭指定tab页签
  40. async closePage(obj?: TagView): Promise<{ visitedViews: TagView[]; cachedViews: string[] } | any> {
  41. if (obj === undefined) {
  42. // prettier-ignore
  43. const { visitedViews } = await useTagsViewStore().delView(router.currentRoute.value) as any
  44. const latestView = visitedViews.slice(-1)[0];
  45. if (latestView) {
  46. return router.push(latestView.fullPath);
  47. }
  48. return router.push('/');
  49. }
  50. return useTagsViewStore().delView(obj);
  51. },
  52. // 关闭所有tab页签
  53. closeAllPage() {
  54. return useTagsViewStore().delAllViews();
  55. },
  56. // 关闭左侧tab页签
  57. closeLeftPage(obj?: TagView) {
  58. return useTagsViewStore().delLeftTags(obj || router.currentRoute.value);
  59. },
  60. // 关闭右侧tab页签
  61. closeRightPage(obj?: TagView) {
  62. return useTagsViewStore().delRightTags(obj || router.currentRoute.value);
  63. },
  64. // 关闭其他tab页签
  65. closeOtherPage(obj?: TagView) {
  66. return useTagsViewStore().delOthersViews(obj || router.currentRoute.value);
  67. },
  68. /**
  69. * 打开tab页签
  70. * @param url 路由地址
  71. * @param title 标题
  72. * @param query 参数
  73. */
  74. openPage(url: string, title?: string, query?: any) {
  75. const obj = { path: url, query: { ...query, title } };
  76. return router.push(obj);
  77. },
  78. /**
  79. * 修改tab页签
  80. * @param obj 标签对象
  81. */
  82. updatePage(obj: TagView) {
  83. return useTagsViewStore().updateVisitedView(obj);
  84. }
  85. };