raise-common-lib-new 0.0.21 → 0.0.22

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -86,6 +86,8 @@ export class MultiTabComponent {
86
86
  }, 50);
87
87
  }
88
88
  ngOnDestroy() {
89
+ this.tabList = []; // 清空 tab 列表
90
+ this.selectedTab = 0; // 重置选中的 tab 索引
89
91
  this.subscriptions.forEach((sub) => sub.unsubscribe());
90
92
  }
91
93
  setEllipsisTitle(title) {
@@ -264,4 +266,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
264
266
  type: HostListener,
265
267
  args: ["window:resize", ["$event"]]
266
268
  }] } });
267
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.component.js","sourceRoot":"","sources":["../../../../../../projects/raise-common-lib/src/lib/layout/multi-tab/index.component.ts","../../../../../../projects/raise-common-lib/src/lib/layout/multi-tab/index.component.html"],"names":[],"mappings":"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","sourcesContent":["// 组件类\r\nimport {\r\n\tAfterViewInit,\r\n\tChangeDetectorRef,\r\n\tComponent,\r\n\tEventEmitter,\r\n\tHostListener,\r\n\tInput,\r\n\tOnDestroy,\r\n\tOnInit,\r\n\tOutput,\r\n} from \"@angular/core\";\r\nimport {\r\n\tActivatedRoute,\r\n\tNavigationEnd,\r\n\tRouter,\r\n\tRouterOutlet,\r\n} from \"@angular/router\";\r\nimport { filter } from \"rxjs/operators\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { RouteReuseStrategy } from \"@angular/router\";\r\nimport { CommonFunctionService } from \"../../service/common-function.service\";\r\nimport { DrawerService } from \"../../service/drawer.service\";\r\nimport { KeepAliveService } from \"../../service/keep-alive.service\";\r\n\r\n@Component({\r\n\tselector: \"rs-multi-tab\",\r\n\ttemplateUrl: \"./index.component.html\",\r\n\tstyleUrls: [\"./index.component.scss\"],\r\n})\r\nexport class MultiTabComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\tconstructor(\r\n\t\tpublic router: Router,\r\n\t\tpublic cf: CommonFunctionService,\r\n\t\tpublic activatedRoute: ActivatedRoute,\r\n\t\tprivate ref: ChangeDetectorRef,\r\n\t\tprivate drawer: DrawerService,\r\n\t\tprivate routeReuseStrategy: RouteReuseStrategy\r\n\t) {\r\n\t\tthis.keepAlive = this.routeReuseStrategy as KeepAliveService;\r\n\t}\r\n\tkeepAlive: KeepAliveService;\r\n\t@Input() singleReuseUrls: string[] = []; //只能单个缓存的url\r\n\t@Input() noGenerateTabUrls: string[] = []; //不生成tab的url\r\n\t@Output() onRefreshTab = new EventEmitter();\r\n\r\n\tprivate subscriptions: Subscription[] = [];\r\n\tTAB_WIDTH = 164;\r\n\tGAP_NORMAL = 54;\r\n\tGAP_SMALL = 30;\r\n\ttextGap; // 文本与边框的总间距\r\n\tfoo: RouterOutlet;\r\n\tcomRef: any;\r\n\ttabList = [];\r\n\tselectedTab: number = 0;\r\n\tmaxTabs: number = 10;\r\n\tscreenWidth: number = window.innerWidth; // 初始化屏幕宽度\r\n\t@HostListener(\"window:resize\", [\"$event\"])\r\n\tonResize(event) {\r\n\t\tthis.screenWidth = window.innerWidth; // 更新屏幕宽度\r\n\t\tthis.setEllipsisTitle();\r\n\t}\r\n\r\n\tngOnInit() {\r\n\t\tthis.initTab();\r\n\t\t// 解决刷新页面后，选中的 tab 丢失问题\r\n\t\tconst isExistIdx = this.tabList.findIndex(\r\n\t\t\t(ele) =>\r\n\t\t\t\tthis.urlWithoutQuery(ele.url) ===\r\n\t\t\t\tthis.urlWithoutQuery(this.router.url)\r\n\t\t);\r\n\t\tif (isExistIdx !== -1) {\r\n\t\t\tthis.selectedTab = isExistIdx;\r\n\t\t}\r\n\r\n\t\tthis.subscriptions.push(\r\n\t\t\tthis.router.events\r\n\t\t\t\t.pipe(filter((event) => event instanceof NavigationEnd))\r\n\t\t\t\t.subscribe(() => {\r\n\t\t\t\t\tconst navigation = this.router.getCurrentNavigation(); // 获取当前导航\r\n\t\t\t\t\tif (navigation) {\r\n\t\t\t\t\t\tconst tooltipElements =\r\n\t\t\t\t\t\t\tdocument.querySelectorAll(\".e-popup-open\");\r\n\t\t\t\t\t\t// 删除tooltips\r\n\t\t\t\t\t\ttooltipElements.forEach((element) => {\r\n\t\t\t\t\t\t\tconst htmlElement = element as HTMLElement;\r\n\t\t\t\t\t\t\thtmlElement.style.display = \"none\";\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tconst state = navigation.extras.state; // 获取传递的 state\r\n\t\t\t\t\t\tconst skipLocationChange =\r\n\t\t\t\t\t\t\tnavigation.extras.skipLocationChange; // 获取是否跳过 location change\r\n\t\t\t\t\t\tconst currentRoute =\r\n\t\t\t\t\t\t\tthis.router.routerState.root.firstChild;\r\n\t\t\t\t\t\tconst navigationInfo = JSON.parse(\r\n\t\t\t\t\t\t\tsessionStorage.getItem(\"navigationInfo\") || \"{}\"\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tlet title =\r\n\t\t\t\t\t\t\t(state && state.title) ||\r\n\t\t\t\t\t\t\tnavigationInfo.title ||\r\n\t\t\t\t\t\t\tnavigationInfo.subTitle ||\r\n\t\t\t\t\t\t\tnavigationInfo.name;\r\n\r\n\t\t\t\t\t\tlet noReused = (state && state.noReused) || false; // 当前tab不复用，新开一个tab,当有已经存在的tab时候也是新开\r\n\t\t\t\t\t\tif (currentRoute && !skipLocationChange) {\r\n\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\tthis.noGenerateTabUrls.includes(\r\n\t\t\t\t\t\t\t\t\tthis.urlWithoutQuery(this.router.url)\r\n\t\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\treturn; // 排除不生成tab的url\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tthis.setTab(\r\n\t\t\t\t\t\t\t\tthis.router.url,\r\n\t\t\t\t\t\t\t\tcurrentRoute.snapshot.routeConfig.path,\r\n\t\t\t\t\t\t\t\ttitle,\r\n\t\t\t\t\t\t\t\tnoReused\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t);\r\n\t}\r\n\tngAfterViewInit() {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.setEllipsisTitle();\r\n\t\t}, 50);\r\n\t}\r\n\tngOnDestroy() {\r\n\t\tthis.subscriptions.forEach((sub) => sub.unsubscribe());\r\n\t}\r\n\r\n\tsetEllipsisTitle(title?) {\r\n\t\tthis.textGap = this.GAP_NORMAL;\r\n\t\tif (this.screenWidth <= 1100) {\r\n\t\t\tthis.textGap = this.GAP_SMALL;\r\n\t\t}\r\n\t\tlet { allWidth, leftWidth, rightWidth } = this.calcTabWidth();\r\n\t\tlet width = Math.floor(\r\n\t\t\t(allWidth - rightWidth) / (this.tabList && this.tabList.length)\r\n\t\t);\r\n\t\tif (title) {\r\n\t\t\treturn this.cf.setMiddleEllipsis(\r\n\t\t\t\ttitle,\r\n\t\t\t\twidth > this.TAB_WIDTH\r\n\t\t\t\t\t? this.TAB_WIDTH - this.textGap\r\n\t\t\t\t\t: width - this.textGap,\r\n\t\t\t\t12\r\n\t\t\t);\r\n\t\t} else {\r\n\t\t\tthis.tabList.forEach((ele, idx) => {\r\n\t\t\t\tele.displayTitle = this.cf.setMiddleEllipsis(\r\n\t\t\t\t\tele.title,\r\n\t\t\t\t\twidth > this.TAB_WIDTH\r\n\t\t\t\t\t\t? this.TAB_WIDTH - this.textGap\r\n\t\t\t\t\t\t: width - this.textGap,\r\n\t\t\t\t\t12\r\n\t\t\t\t);\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tcalcTabWidth() {\r\n\t\tconst wrap = document.querySelector(\".rs-multi-tab\");\r\n\t\tconst ulElement = document.querySelector(\".rs-multi-tab > ul\");\r\n\t\tconst refreshTabDiv = document.querySelector(\r\n\t\t\t\".rs-multi-tab .refresh-tab\"\r\n\t\t);\r\n\t\tlet allWidth;\r\n\t\tlet leftWidth;\r\n\t\tlet rightWidth;\r\n\t\tif (wrap && ulElement) {\r\n\t\t\t// 获取元素的位置信息\r\n\t\t\tconst wrapRect = wrap.getBoundingClientRect();\r\n\t\t\tconst ulRect = ulElement.getBoundingClientRect();\r\n\t\t\tconst refreshTabRect =\r\n\t\t\t\trefreshTabDiv && refreshTabDiv.getBoundingClientRect();\r\n\t\t\tallWidth = wrapRect.width;\r\n\t\t\tleftWidth = ulRect.width;\r\n\t\t\trightWidth = (refreshTabRect && refreshTabRect.width) || 100;\r\n\t\t}\r\n\t\treturn {\r\n\t\t\tallWidth,\r\n\t\t\tleftWidth,\r\n\t\t\trightWidth,\r\n\t\t};\r\n\t}\r\n\tinitTab() {\r\n\t\tlet TabCache = JSON.parse(sessionStorage.getItem(\"TabCache\"));\r\n\t\tthis.tabList = TabCache || [];\r\n\t\tif (this.tabList.length === 0) {\r\n\t\t\tconst title = sessionStorage.getItem(\"firstTabTitle\");\r\n\t\t\tif (title) {\r\n\t\t\t\tsessionStorage.removeItem(\"firstTabTitle\");\r\n\t\t\t\tconst url = this.router.url;\r\n\t\t\t\tthis.addTab(url, title);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tcloseTab(idx, isExternal?) {\r\n\t\tconst tab = this.tabList[idx];\r\n\t\tthis.tabList = this.tabList.filter((ele) => ele.url !== tab.url);\r\n\t\tthis.clearCache(this.urlWithoutQuery(tab.url));\r\n\t\tif (!isExternal && this.selectedTab === idx) {\r\n\t\t\tconst targetIdx = Math.max(0, idx - 1);\r\n\t\t\tthis.changeTab(this.tabList[targetIdx], targetIdx);\r\n\t\t}\r\n\t\tif (idx < this.selectedTab) {\r\n\t\t\tthis.selectedTab = this.selectedTab - 1; // 如果关闭的tab在当前选中的tab之前，选中tab索引减1\r\n\t\t}\r\n\t\tthis.setEllipsisTitle();\r\n\t\tsessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n\t\tthis.ref.markForCheck();\r\n\t}\r\n\r\n\tchangeTab(tab, idx) {\r\n\t\tthis.router.navigateByUrl(tab.url);\r\n\t\tif (tab.navigationInfo) {\r\n\t\t\tsessionStorage.setItem(\r\n\t\t\t\t\"navigationInfo\",\r\n\t\t\t\tJSON.stringify(tab.navigationInfo)\r\n\t\t\t);\r\n\t\t}\r\n\t\tif (tab.fromUrl) {\r\n\t\t\tsessionStorage.setItem(\"fromUrl\", tab.fromUrl);\r\n\t\t}\r\n\t\tif (tab.permissions) {\r\n\t\t\tsessionStorage.setItem(\r\n\t\t\t\t\"permissions\",\r\n\t\t\t\tJSON.stringify(tab.permissions)\r\n\t\t\t);\r\n\t\t}\r\n\t\tthis.selectedTab = idx;\r\n\t\tthis.ref.markForCheck();\r\n\t}\r\n\r\n\taddTab(url, title) {\r\n\t\tif (this.tabList.length >= this.maxTabs) {\r\n\t\t\tthis.closeTab(1); // 删除第二个，第一个固定\r\n\t\t}\r\n\t\tconst localPermissions =\r\n\t\t\tsessionStorage.getItem(\"permissions\") ||\r\n\t\t\tlocalStorage.getItem(\"permissions\");\r\n\t\tconst navigationInfo = JSON.parse(\r\n\t\t\tsessionStorage.getItem(\"navigationInfo\")\r\n\t\t);\r\n\t\tconst fromUrl = sessionStorage.getItem(\"fromUrl\");\r\n\t\tconst permissions = JSON.parse(localPermissions);\r\n\r\n\t\tthis.tabList.push({\r\n\t\t\turl: url,\r\n\t\t\ttitle: title || \"default\",\r\n\t\t\tdisplayTitle: title,\r\n\t\t\tnavigationInfo: navigationInfo,\r\n\t\t\tpermissions: permissions,\r\n\t\t\tfromUrl: fromUrl,\r\n\t\t});\r\n\t\tthis.selectedTab = this.tabList.length - 1;\r\n\t\tthis.setEllipsisTitle();\r\n\t\tsessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n\t\tthis.ref.markForCheck();\r\n\t}\r\n\r\n\tpublic setTab(url, pureUrl, title, noReused) {\r\n\t\tconst isExistIdx = this.tabList.findIndex(\r\n\t\t\t(ele) => this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(url)\r\n\t\t);\r\n\t\tif (isExistIdx === -1) {\r\n\t\t\tconst singleIdx = this.singleReuseUrls.findIndex(\r\n\t\t\t\t(ele) => ele === pureUrl\r\n\t\t\t);\r\n\t\t\tif (singleIdx !== -1) {\r\n\t\t\t\tthis.tabList = this.tabList.filter(\r\n\t\t\t\t\t(ele) => !ele.url.includes(this.singleReuseUrls[singleIdx])\r\n\t\t\t\t);\r\n\t\t\t\tthis.keepAlive.clearCache(url);\r\n\t\t\t\tthis.drawer.deleteCache(url);\r\n\t\t\t}\r\n\t\t\tthis.addTab(url, title);\r\n\t\t} else {\r\n\t\t\tconst targetTabUrl = this.tabList[isExistIdx].url;\r\n\t\t\tif (targetTabUrl !== url || noReused) {\r\n\t\t\t\t// 当缓存一致时候，但是url不一致，重新按照新的url生成tab\r\n\t\t\t\tthis.closeTab(isExistIdx, true);\r\n\t\t\t\tthis.addTab(url, title);\r\n\t\t\t} else {\r\n\t\t\t\tthis.changeTab(this.tabList[isExistIdx], isExistIdx);\r\n\t\t\t}\r\n\t\t\tthis.ref.markForCheck();\r\n\t\t}\r\n\t}\r\n\ttimer = null;\r\n\trefreshTab() {\r\n\t\tconst loadingIcon = document.getElementById(\"loadingIcon\");\r\n\t\tloadingIcon.classList.add(\"refresh-tab-loading\");\r\n\t\tif (this.timer) {\r\n\t\t\tclearInterval(this.timer);\r\n\t\t}\r\n\t\t// 模拟加载过程，1秒后移除动画\r\n\t\tthis.timer = setTimeout(() => {\r\n\t\t\tloadingIcon.classList.remove(\"refresh-tab-loading\");\r\n\t\t\tthis.timer = null;\r\n\t\t}, 1500);\r\n\t\t// this.keepAlive.clearCache(this.tabList[this.selectedTab].url);\r\n\t\t// this.drawer.deleteCache(this.tabList[this.selectedTab].url);\r\n\t\tconst currentUrl = this.router.url; // 获取当前 URL\r\n\t\tthis.onRefreshTab.emit(currentUrl);\r\n\t\t// this.router.navigateByUrl(\"/\", { skipLocationChange: true }).then(() => {\r\n\t\t//   this.router.navigateByUrl(currentUrl); // 重新导航到当前 URL\r\n\t\t// });\r\n\t}\r\n\r\n\tclearCache(url) {\r\n\t\tthis.keepAlive.clearCache(url); // 调用自定义策略的清除缓存方法\r\n\t\tthis.drawer.deleteCache(url);\r\n\t}\r\n\r\n\tcleanAllCache() {\r\n\t\tthis.ngOnDestroy();\r\n\t\tthis.keepAlive.clearAllCache(); // 调用自定义策略的清除缓存方法\r\n\t}\r\n\r\n\tprivate urlWithoutQuery(url) {\r\n\t\treturn url.split(\"?\")[0];\r\n\t}\r\n}\r\n","<div class=\"rs-multi-tab\" [ngClass]=\"{ 'b-line': tabList.length > 0 }\">\r\n\t<ul>\r\n\t\t<ng-container *ngFor=\"let tab of tabList; let i = index\">\r\n\t\t\t<li\r\n\t\t\t\t[ngClass]=\"selectedTab === i ? 'isSelect' : 'notSelect'\"\r\n\t\t\t\t(click)=\"changeTab(tab, i)\"\r\n\t\t\t>\r\n\t\t\t\t<ejs-tooltip\r\n\t\t\t\t\tid=\"notSelectTooltip\"\r\n\t\t\t\t\t[showTipPointer]=\"false\"\r\n\t\t\t\t\t[openDelay]=\"500\"\r\n\t\t\t\t\t*ngIf=\"tab.displayTitle !== tab.title; else originText\"\r\n\t\t\t\t\tstyle=\"height: 27px\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<ng-template #content>\r\n\t\t\t\t\t\t<div class=\"tooltip-content\">\r\n\t\t\t\t\t\t\t{{ tab.title }}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t\t<span class=\"tabTitle\">{{ tab.displayTitle }}</span>\r\n\t\t\t\t</ejs-tooltip>\r\n\t\t\t\t<ng-template #originText>\r\n\t\t\t\t\t<span class=\"tabTitle\">\r\n\t\t\t\t\t\t{{ tab.displayTitle }}\r\n\t\t\t\t\t</span>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<span\r\n\t\t\t\t\tclass=\"img-block\"\r\n\t\t\t\t\t*ngIf=\"selectedTab !== i && i !== 0\"\r\n\t\t\t\t></span>\r\n\t\t\t\t<img\r\n\t\t\t\t\t*ngIf=\"i !== 0\"\r\n\t\t\t\t\tsrc=\"../../../assets/img/close-url.svg\"\r\n\t\t\t\t\t(click)=\"closeTab(i)\"\r\n\t\t\t\t/>\r\n\t\t\t</li>\r\n\t\t</ng-container>\r\n\t</ul>\r\n\t<div class=\"refresh-tab\" (click)=\"refreshTab()\" *ngIf=\"tabList.length > 0\">\r\n\t\t<ejs-tooltip\r\n\t\t\tid=\"notSelectTooltip\"\r\n\t\t\tcssClass=\"notSelectTooltip\"\r\n\t\t\t[showTipPointer]=\"false\"\r\n\t\t\t[openDelay]=\"500\"\r\n\t\t\tstyle=\"height: 27px\"\r\n\t\t>\r\n\t\t\t<ng-template #content>\r\n\t\t\t\t<div class=\"tooltip-content\">Refresh Current Tab</div>\r\n\t\t\t</ng-template>\r\n\t\t\t<img\r\n\t\t\t\tid=\"loadingIcon\"\r\n\t\t\t\talt\r\n\t\t\t\tclass=\"refresh-btn\"\r\n\t\t\t\tsrc=\"../../../assets/img/desktop-refresh-btn.svg\"\r\n\t\t\t/>\r\n\t\t</ejs-tooltip>\r\n\t</div>\r\n</div>\r\n"]}
269
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.component.js","sourceRoot":"","sources":["../../../../../../projects/raise-common-lib/src/lib/layout/multi-tab/index.component.ts","../../../../../../projects/raise-common-lib/src/lib/layout/multi-tab/index.component.html"],"names":[],"mappings":"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","sourcesContent":["// 组件类\r\nimport {\r\n\tAfterViewInit,\r\n\tChangeDetectorRef,\r\n\tComponent,\r\n\tEventEmitter,\r\n\tHostListener,\r\n\tInput,\r\n\tOnDestroy,\r\n\tOnInit,\r\n\tOutput,\r\n} from \"@angular/core\";\r\nimport {\r\n\tActivatedRoute,\r\n\tNavigationEnd,\r\n\tRouter,\r\n\tRouterOutlet,\r\n} from \"@angular/router\";\r\nimport { filter } from \"rxjs/operators\";\r\nimport { Subscription } from \"rxjs\";\r\nimport { RouteReuseStrategy } from \"@angular/router\";\r\nimport { CommonFunctionService } from \"../../service/common-function.service\";\r\nimport { DrawerService } from \"../../service/drawer.service\";\r\nimport { KeepAliveService } from \"../../service/keep-alive.service\";\r\n\r\n@Component({\r\n\tselector: \"rs-multi-tab\",\r\n\ttemplateUrl: \"./index.component.html\",\r\n\tstyleUrls: [\"./index.component.scss\"],\r\n})\r\nexport class MultiTabComponent implements OnInit, AfterViewInit, OnDestroy {\r\n\tconstructor(\r\n\t\tpublic router: Router,\r\n\t\tpublic cf: CommonFunctionService,\r\n\t\tpublic activatedRoute: ActivatedRoute,\r\n\t\tprivate ref: ChangeDetectorRef,\r\n\t\tprivate drawer: DrawerService,\r\n\t\tprivate routeReuseStrategy: RouteReuseStrategy\r\n\t) {\r\n\t\tthis.keepAlive = this.routeReuseStrategy as KeepAliveService;\r\n\t}\r\n\tkeepAlive: KeepAliveService;\r\n\t@Input() singleReuseUrls: string[] = []; //只能单个缓存的url\r\n\t@Input() noGenerateTabUrls: string[] = []; //不生成tab的url\r\n\t@Output() onRefreshTab = new EventEmitter();\r\n\r\n\tprivate subscriptions: Subscription[] = [];\r\n\tTAB_WIDTH = 164;\r\n\tGAP_NORMAL = 54;\r\n\tGAP_SMALL = 30;\r\n\ttextGap; // 文本与边框的总间距\r\n\tfoo: RouterOutlet;\r\n\tcomRef: any;\r\n\ttabList = [];\r\n\tselectedTab: number = 0;\r\n\tmaxTabs: number = 10;\r\n\tscreenWidth: number = window.innerWidth; // 初始化屏幕宽度\r\n\t@HostListener(\"window:resize\", [\"$event\"])\r\n\tonResize(event) {\r\n\t\tthis.screenWidth = window.innerWidth; // 更新屏幕宽度\r\n\t\tthis.setEllipsisTitle();\r\n\t}\r\n\r\n\tngOnInit() {\r\n\t\tthis.initTab();\r\n\t\t// 解决刷新页面后，选中的 tab 丢失问题\r\n\t\tconst isExistIdx = this.tabList.findIndex(\r\n\t\t\t(ele) =>\r\n\t\t\t\tthis.urlWithoutQuery(ele.url) ===\r\n\t\t\t\tthis.urlWithoutQuery(this.router.url)\r\n\t\t);\r\n\t\tif (isExistIdx !== -1) {\r\n\t\t\tthis.selectedTab = isExistIdx;\r\n\t\t}\r\n\r\n\t\tthis.subscriptions.push(\r\n\t\t\tthis.router.events\r\n\t\t\t\t.pipe(filter((event) => event instanceof NavigationEnd))\r\n\t\t\t\t.subscribe(() => {\r\n\t\t\t\t\tconst navigation = this.router.getCurrentNavigation(); // 获取当前导航\r\n\t\t\t\t\tif (navigation) {\r\n\t\t\t\t\t\tconst tooltipElements =\r\n\t\t\t\t\t\t\tdocument.querySelectorAll(\".e-popup-open\");\r\n\t\t\t\t\t\t// 删除tooltips\r\n\t\t\t\t\t\ttooltipElements.forEach((element) => {\r\n\t\t\t\t\t\t\tconst htmlElement = element as HTMLElement;\r\n\t\t\t\t\t\t\thtmlElement.style.display = \"none\";\r\n\t\t\t\t\t\t});\r\n\t\t\t\t\t\tconst state = navigation.extras.state; // 获取传递的 state\r\n\t\t\t\t\t\tconst skipLocationChange =\r\n\t\t\t\t\t\t\tnavigation.extras.skipLocationChange; // 获取是否跳过 location change\r\n\t\t\t\t\t\tconst currentRoute =\r\n\t\t\t\t\t\t\tthis.router.routerState.root.firstChild;\r\n\t\t\t\t\t\tconst navigationInfo = JSON.parse(\r\n\t\t\t\t\t\t\tsessionStorage.getItem(\"navigationInfo\") || \"{}\"\r\n\t\t\t\t\t\t);\r\n\t\t\t\t\t\tlet title =\r\n\t\t\t\t\t\t\t(state && state.title) ||\r\n\t\t\t\t\t\t\tnavigationInfo.title ||\r\n\t\t\t\t\t\t\tnavigationInfo.subTitle ||\r\n\t\t\t\t\t\t\tnavigationInfo.name;\r\n\r\n\t\t\t\t\t\tlet noReused = (state && state.noReused) || false; // 当前tab不复用，新开一个tab,当有已经存在的tab时候也是新开\r\n\t\t\t\t\t\tif (currentRoute && !skipLocationChange) {\r\n\t\t\t\t\t\t\tif (\r\n\t\t\t\t\t\t\t\tthis.noGenerateTabUrls.includes(\r\n\t\t\t\t\t\t\t\t\tthis.urlWithoutQuery(this.router.url)\r\n\t\t\t\t\t\t\t\t)\r\n\t\t\t\t\t\t\t) {\r\n\t\t\t\t\t\t\t\treturn; // 排除不生成tab的url\r\n\t\t\t\t\t\t\t}\r\n\t\t\t\t\t\t\tthis.setTab(\r\n\t\t\t\t\t\t\t\tthis.router.url,\r\n\t\t\t\t\t\t\t\tcurrentRoute.snapshot.routeConfig.path,\r\n\t\t\t\t\t\t\t\ttitle,\r\n\t\t\t\t\t\t\t\tnoReused\r\n\t\t\t\t\t\t\t);\r\n\t\t\t\t\t\t}\r\n\t\t\t\t\t}\r\n\t\t\t\t})\r\n\t\t);\r\n\t}\r\n\tngAfterViewInit() {\r\n\t\tsetTimeout(() => {\r\n\t\t\tthis.setEllipsisTitle();\r\n\t\t}, 50);\r\n\t}\r\n\tngOnDestroy() {\r\n\t\tthis.tabList = []; // 清空 tab 列表\r\n\t\tthis.selectedTab = 0; // 重置选中的 tab 索引\r\n\t\tthis.subscriptions.forEach((sub) => sub.unsubscribe());\r\n\t}\r\n\r\n\tsetEllipsisTitle(title?) {\r\n\t\tthis.textGap = this.GAP_NORMAL;\r\n\t\tif (this.screenWidth <= 1100) {\r\n\t\t\tthis.textGap = this.GAP_SMALL;\r\n\t\t}\r\n\t\tlet { allWidth, leftWidth, rightWidth } = this.calcTabWidth();\r\n\t\tlet width = Math.floor(\r\n\t\t\t(allWidth - rightWidth) / (this.tabList && this.tabList.length)\r\n\t\t);\r\n\t\tif (title) {\r\n\t\t\treturn this.cf.setMiddleEllipsis(\r\n\t\t\t\ttitle,\r\n\t\t\t\twidth > this.TAB_WIDTH\r\n\t\t\t\t\t? this.TAB_WIDTH - this.textGap\r\n\t\t\t\t\t: width - this.textGap,\r\n\t\t\t\t12\r\n\t\t\t);\r\n\t\t} else {\r\n\t\t\tthis.tabList.forEach((ele, idx) => {\r\n\t\t\t\tele.displayTitle = this.cf.setMiddleEllipsis(\r\n\t\t\t\t\tele.title,\r\n\t\t\t\t\twidth > this.TAB_WIDTH\r\n\t\t\t\t\t\t? this.TAB_WIDTH - this.textGap\r\n\t\t\t\t\t\t: width - this.textGap,\r\n\t\t\t\t\t12\r\n\t\t\t\t);\r\n\t\t\t});\r\n\t\t}\r\n\t}\r\n\r\n\tcalcTabWidth() {\r\n\t\tconst wrap = document.querySelector(\".rs-multi-tab\");\r\n\t\tconst ulElement = document.querySelector(\".rs-multi-tab > ul\");\r\n\t\tconst refreshTabDiv = document.querySelector(\r\n\t\t\t\".rs-multi-tab .refresh-tab\"\r\n\t\t);\r\n\t\tlet allWidth;\r\n\t\tlet leftWidth;\r\n\t\tlet rightWidth;\r\n\t\tif (wrap && ulElement) {\r\n\t\t\t// 获取元素的位置信息\r\n\t\t\tconst wrapRect = wrap.getBoundingClientRect();\r\n\t\t\tconst ulRect = ulElement.getBoundingClientRect();\r\n\t\t\tconst refreshTabRect =\r\n\t\t\t\trefreshTabDiv && refreshTabDiv.getBoundingClientRect();\r\n\t\t\tallWidth = wrapRect.width;\r\n\t\t\tleftWidth = ulRect.width;\r\n\t\t\trightWidth = (refreshTabRect && refreshTabRect.width) || 100;\r\n\t\t}\r\n\t\treturn {\r\n\t\t\tallWidth,\r\n\t\t\tleftWidth,\r\n\t\t\trightWidth,\r\n\t\t};\r\n\t}\r\n\tinitTab() {\r\n\t\tlet TabCache = JSON.parse(sessionStorage.getItem(\"TabCache\"));\r\n\t\tthis.tabList = TabCache || [];\r\n\t\tif (this.tabList.length === 0) {\r\n\t\t\tconst title = sessionStorage.getItem(\"firstTabTitle\");\r\n\t\t\tif (title) {\r\n\t\t\t\tsessionStorage.removeItem(\"firstTabTitle\");\r\n\t\t\t\tconst url = this.router.url;\r\n\t\t\t\tthis.addTab(url, title);\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\r\n\tcloseTab(idx, isExternal?) {\r\n\t\tconst tab = this.tabList[idx];\r\n\t\tthis.tabList = this.tabList.filter((ele) => ele.url !== tab.url);\r\n\t\tthis.clearCache(this.urlWithoutQuery(tab.url));\r\n\t\tif (!isExternal && this.selectedTab === idx) {\r\n\t\t\tconst targetIdx = Math.max(0, idx - 1);\r\n\t\t\tthis.changeTab(this.tabList[targetIdx], targetIdx);\r\n\t\t}\r\n\t\tif (idx < this.selectedTab) {\r\n\t\t\tthis.selectedTab = this.selectedTab - 1; // 如果关闭的tab在当前选中的tab之前，选中tab索引减1\r\n\t\t}\r\n\t\tthis.setEllipsisTitle();\r\n\t\tsessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n\t\tthis.ref.markForCheck();\r\n\t}\r\n\r\n\tchangeTab(tab, idx) {\r\n\t\tthis.router.navigateByUrl(tab.url);\r\n\t\tif (tab.navigationInfo) {\r\n\t\t\tsessionStorage.setItem(\r\n\t\t\t\t\"navigationInfo\",\r\n\t\t\t\tJSON.stringify(tab.navigationInfo)\r\n\t\t\t);\r\n\t\t}\r\n\t\tif (tab.fromUrl) {\r\n\t\t\tsessionStorage.setItem(\"fromUrl\", tab.fromUrl);\r\n\t\t}\r\n\t\tif (tab.permissions) {\r\n\t\t\tsessionStorage.setItem(\r\n\t\t\t\t\"permissions\",\r\n\t\t\t\tJSON.stringify(tab.permissions)\r\n\t\t\t);\r\n\t\t}\r\n\t\tthis.selectedTab = idx;\r\n\t\tthis.ref.markForCheck();\r\n\t}\r\n\r\n\taddTab(url, title) {\r\n\t\tif (this.tabList.length >= this.maxTabs) {\r\n\t\t\tthis.closeTab(1); // 删除第二个，第一个固定\r\n\t\t}\r\n\t\tconst localPermissions =\r\n\t\t\tsessionStorage.getItem(\"permissions\") ||\r\n\t\t\tlocalStorage.getItem(\"permissions\");\r\n\t\tconst navigationInfo = JSON.parse(\r\n\t\t\tsessionStorage.getItem(\"navigationInfo\")\r\n\t\t);\r\n\t\tconst fromUrl = sessionStorage.getItem(\"fromUrl\");\r\n\t\tconst permissions = JSON.parse(localPermissions);\r\n\r\n\t\tthis.tabList.push({\r\n\t\t\turl: url,\r\n\t\t\ttitle: title || \"default\",\r\n\t\t\tdisplayTitle: title,\r\n\t\t\tnavigationInfo: navigationInfo,\r\n\t\t\tpermissions: permissions,\r\n\t\t\tfromUrl: fromUrl,\r\n\t\t});\r\n\t\tthis.selectedTab = this.tabList.length - 1;\r\n\t\tthis.setEllipsisTitle();\r\n\t\tsessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n\t\tthis.ref.markForCheck();\r\n\t}\r\n\r\n\tpublic setTab(url, pureUrl, title, noReused) {\r\n\t\tconst isExistIdx = this.tabList.findIndex(\r\n\t\t\t(ele) => this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(url)\r\n\t\t);\r\n\t\tif (isExistIdx === -1) {\r\n\t\t\tconst singleIdx = this.singleReuseUrls.findIndex(\r\n\t\t\t\t(ele) => ele === pureUrl\r\n\t\t\t);\r\n\t\t\tif (singleIdx !== -1) {\r\n\t\t\t\tthis.tabList = this.tabList.filter(\r\n\t\t\t\t\t(ele) => !ele.url.includes(this.singleReuseUrls[singleIdx])\r\n\t\t\t\t);\r\n\t\t\t\tthis.keepAlive.clearCache(url);\r\n\t\t\t\tthis.drawer.deleteCache(url);\r\n\t\t\t}\r\n\t\t\tthis.addTab(url, title);\r\n\t\t} else {\r\n\t\t\tconst targetTabUrl = this.tabList[isExistIdx].url;\r\n\t\t\tif (targetTabUrl !== url || noReused) {\r\n\t\t\t\t// 当缓存一致时候，但是url不一致，重新按照新的url生成tab\r\n\t\t\t\tthis.closeTab(isExistIdx, true);\r\n\t\t\t\tthis.addTab(url, title);\r\n\t\t\t} else {\r\n\t\t\t\tthis.changeTab(this.tabList[isExistIdx], isExistIdx);\r\n\t\t\t}\r\n\t\t\tthis.ref.markForCheck();\r\n\t\t}\r\n\t}\r\n\ttimer = null;\r\n\trefreshTab() {\r\n\t\tconst loadingIcon = document.getElementById(\"loadingIcon\");\r\n\t\tloadingIcon.classList.add(\"refresh-tab-loading\");\r\n\t\tif (this.timer) {\r\n\t\t\tclearInterval(this.timer);\r\n\t\t}\r\n\t\t// 模拟加载过程，1秒后移除动画\r\n\t\tthis.timer = setTimeout(() => {\r\n\t\t\tloadingIcon.classList.remove(\"refresh-tab-loading\");\r\n\t\t\tthis.timer = null;\r\n\t\t}, 1500);\r\n\t\t// this.keepAlive.clearCache(this.tabList[this.selectedTab].url);\r\n\t\t// this.drawer.deleteCache(this.tabList[this.selectedTab].url);\r\n\t\tconst currentUrl = this.router.url; // 获取当前 URL\r\n\t\tthis.onRefreshTab.emit(currentUrl);\r\n\t\t// this.router.navigateByUrl(\"/\", { skipLocationChange: true }).then(() => {\r\n\t\t//   this.router.navigateByUrl(currentUrl); // 重新导航到当前 URL\r\n\t\t// });\r\n\t}\r\n\r\n\tclearCache(url) {\r\n\t\tthis.keepAlive.clearCache(url); // 调用自定义策略的清除缓存方法\r\n\t\tthis.drawer.deleteCache(url);\r\n\t}\r\n\r\n\tcleanAllCache() {\r\n\t\tthis.ngOnDestroy();\r\n\t\tthis.keepAlive.clearAllCache(); // 调用自定义策略的清除缓存方法\r\n\t}\r\n\r\n\tprivate urlWithoutQuery(url) {\r\n\t\treturn url.split(\"?\")[0];\r\n\t}\r\n}\r\n","<div class=\"rs-multi-tab\" [ngClass]=\"{ 'b-line': tabList.length > 0 }\">\r\n\t<ul>\r\n\t\t<ng-container *ngFor=\"let tab of tabList; let i = index\">\r\n\t\t\t<li\r\n\t\t\t\t[ngClass]=\"selectedTab === i ? 'isSelect' : 'notSelect'\"\r\n\t\t\t\t(click)=\"changeTab(tab, i)\"\r\n\t\t\t>\r\n\t\t\t\t<ejs-tooltip\r\n\t\t\t\t\tid=\"notSelectTooltip\"\r\n\t\t\t\t\t[showTipPointer]=\"false\"\r\n\t\t\t\t\t[openDelay]=\"500\"\r\n\t\t\t\t\t*ngIf=\"tab.displayTitle !== tab.title; else originText\"\r\n\t\t\t\t\tstyle=\"height: 27px\"\r\n\t\t\t\t>\r\n\t\t\t\t\t<ng-template #content>\r\n\t\t\t\t\t\t<div class=\"tooltip-content\">\r\n\t\t\t\t\t\t\t{{ tab.title }}\r\n\t\t\t\t\t\t</div>\r\n\t\t\t\t\t</ng-template>\r\n\t\t\t\t\t<span class=\"tabTitle\">{{ tab.displayTitle }}</span>\r\n\t\t\t\t</ejs-tooltip>\r\n\t\t\t\t<ng-template #originText>\r\n\t\t\t\t\t<span class=\"tabTitle\">\r\n\t\t\t\t\t\t{{ tab.displayTitle }}\r\n\t\t\t\t\t</span>\r\n\t\t\t\t</ng-template>\r\n\t\t\t\t<span\r\n\t\t\t\t\tclass=\"img-block\"\r\n\t\t\t\t\t*ngIf=\"selectedTab !== i && i !== 0\"\r\n\t\t\t\t></span>\r\n\t\t\t\t<img\r\n\t\t\t\t\t*ngIf=\"i !== 0\"\r\n\t\t\t\t\tsrc=\"../../../assets/img/close-url.svg\"\r\n\t\t\t\t\t(click)=\"closeTab(i)\"\r\n\t\t\t\t/>\r\n\t\t\t</li>\r\n\t\t</ng-container>\r\n\t</ul>\r\n\t<div class=\"refresh-tab\" (click)=\"refreshTab()\" *ngIf=\"tabList.length > 0\">\r\n\t\t<ejs-tooltip\r\n\t\t\tid=\"notSelectTooltip\"\r\n\t\t\tcssClass=\"notSelectTooltip\"\r\n\t\t\t[showTipPointer]=\"false\"\r\n\t\t\t[openDelay]=\"500\"\r\n\t\t\tstyle=\"height: 27px\"\r\n\t\t>\r\n\t\t\t<ng-template #content>\r\n\t\t\t\t<div class=\"tooltip-content\">Refresh Current Tab</div>\r\n\t\t\t</ng-template>\r\n\t\t\t<img\r\n\t\t\t\tid=\"loadingIcon\"\r\n\t\t\t\talt\r\n\t\t\t\tclass=\"refresh-btn\"\r\n\t\t\t\tsrc=\"../../../assets/img/desktop-refresh-btn.svg\"\r\n\t\t\t/>\r\n\t\t</ejs-tooltip>\r\n\t</div>\r\n</div>\r\n"]}
@@ -1714,6 +1714,8 @@ class MultiTabComponent {
1714
1714
  }, 50);
1715
1715
  }
1716
1716
  ngOnDestroy() {
1717
+ this.tabList = []; // 清空 tab 列表
1718
+ this.selectedTab = 0; // 重置选中的 tab 索引
1717
1719
  this.subscriptions.forEach((sub) => sub.unsubscribe());
1718
1720
  }
1719
1721
  setEllipsisTitle(title) {