raise-common-lib-new 0.0.29 → 0.0.31
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.
- package/esm2022/lib/layout/main-container/index.component.mjs +38 -6
- package/esm2022/lib/layout/multi-tab/index.component.mjs +12 -2
- package/fesm2022/raise-common-lib-new.mjs +45 -5
- package/fesm2022/raise-common-lib-new.mjs.map +1 -1
- package/lib/layout/main-container/index.component.d.ts +9 -3
- package/lib/layout/multi-tab/index.component.d.ts +1 -0
- package/package.json +1 -1
|
@@ -1,6 +1,8 @@
|
|
|
1
1
|
// 组件类
|
|
2
|
-
import { Component, ContentChild, HostListener, Input, ViewChild, } from "@angular/core";
|
|
2
|
+
import { Component, ContentChild, EventEmitter, HostListener, Input, Output, ViewChild, } from "@angular/core";
|
|
3
3
|
import { RSHeaderComponent } from "../rs-header/index.component";
|
|
4
|
+
import { MultiTabComponent } from "../multi-tab/index.component";
|
|
5
|
+
import { debounce } from "lodash";
|
|
4
6
|
import * as i0 from "@angular/core";
|
|
5
7
|
import * as i1 from "../../service/drawer.service";
|
|
6
8
|
import * as i2 from "@angular/common";
|
|
@@ -8,12 +10,24 @@ import * as i3 from "../rs-footer/index.component";
|
|
|
8
10
|
import * as i4 from "../drawer/index.component";
|
|
9
11
|
export class MainContainerComponent {
|
|
10
12
|
globalDrawer;
|
|
13
|
+
elementRef;
|
|
11
14
|
headerRef;
|
|
15
|
+
multiTabRef;
|
|
12
16
|
drawer;
|
|
13
17
|
isCollapsed = false; // 接收输入属性
|
|
14
18
|
singleReuseUrls = []; //只能单个缓存的url
|
|
15
|
-
|
|
19
|
+
onWidthChange = new EventEmitter();
|
|
20
|
+
resizeObserver;
|
|
21
|
+
debouncedHandleResize;
|
|
22
|
+
constructor(globalDrawer, elementRef) {
|
|
16
23
|
this.globalDrawer = globalDrawer;
|
|
24
|
+
this.elementRef = elementRef;
|
|
25
|
+
this.debouncedHandleResize = debounce((width) => {
|
|
26
|
+
console.log("Debounced width change:", width);
|
|
27
|
+
// 在这里处理防抖后的宽度变化逻辑
|
|
28
|
+
this.multiTabRef && this.multiTabRef.setEllipsisTitle();
|
|
29
|
+
this.onWidthChange.emit(width);
|
|
30
|
+
}, 300);
|
|
17
31
|
}
|
|
18
32
|
ngOnInit() { }
|
|
19
33
|
onResize(event) {
|
|
@@ -30,6 +44,19 @@ export class MainContainerComponent {
|
|
|
30
44
|
}
|
|
31
45
|
ngAfterViewInit() {
|
|
32
46
|
this.globalDrawer.setDrawer(this.drawer); // 设置抽屉组件
|
|
47
|
+
const rightAside = this.elementRef.nativeElement.querySelector(".right-aside");
|
|
48
|
+
this.resizeObserver = new ResizeObserver((entries) => {
|
|
49
|
+
for (const entry of entries) {
|
|
50
|
+
const width = entry.contentRect.width;
|
|
51
|
+
this.debouncedHandleResize(width);
|
|
52
|
+
}
|
|
53
|
+
});
|
|
54
|
+
this.resizeObserver.observe(rightAside);
|
|
55
|
+
}
|
|
56
|
+
ngOnDestroy() {
|
|
57
|
+
if (this.resizeObserver) {
|
|
58
|
+
this.resizeObserver.disconnect();
|
|
59
|
+
}
|
|
33
60
|
}
|
|
34
61
|
onRightAsideClick() {
|
|
35
62
|
const screenWidth = window.innerWidth;
|
|
@@ -37,15 +64,18 @@ export class MainContainerComponent {
|
|
|
37
64
|
this.headerRef && this.headerRef.onToggleMenu();
|
|
38
65
|
}
|
|
39
66
|
}
|
|
40
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MainContainerComponent, deps: [{ token: i1.DrawerService }], target: i0.ɵɵFactoryTarget.Component });
|
|
41
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MainContainerComponent, selector: "rs-main-container", inputs: { isCollapsed: "isCollapsed", singleReuseUrls: "singleReuseUrls" }, host: { listeners: { "window:resize": "onResize($event)" } }, queries: [{ propertyName: "headerRef", first: true, predicate: RSHeaderComponent, descendants: true, static: true }], viewQueries: [{ propertyName: "drawer", first: true, predicate: ["drawer"], descendants: true }], ngImport: i0, template: "<div class=\"app-main-container\">\r\n <ng-content select=\"[headerSlot]\"></ng-content>\r\n <div class=\"main-page\">\r\n <div class=\"left-aside\">\r\n <ng-content select=\"[leftAsideSlot]\"></ng-content>\r\n </div>\r\n <div\r\n class=\"right-aside\"\r\n [ngClass]=\"{ isCollapsed: isCollapsed }\"\r\n (click)=\"onRightAsideClick()\"\r\n >\r\n <ng-content select=\"[multiTabSlot]\"></ng-content>\r\n <!-- <rs-multi-tab [singleReuseUrls]=\"singleReuseUrls\"></rs-multi-tab> -->\r\n <div class=\"router-content\">\r\n <rs-drawer #drawer>\r\n <ng-content select=\"[routerSlot]\"></ng-content>\r\n </rs-drawer>\r\n </div>\r\n <rs-footer></rs-footer>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".app-main-container{display:flex;flex-direction:column;height:100vh}.app-main-container .main-page{flex:1;height:0;display:flex;background-color:var(--rs-container-bg)}.app-main-container .left-aside{height:100%}.app-main-container .right-aside{width:0;flex:1;display:flex;flex-direction:column;padding-right:12px}.app-main-container .right-aside .router-content{flex:1;overflow:auto;max-width:1886px;width:100%;margin:0 auto}@media (max-width: 992px){.app-main-container .right-aside.isCollapsed{position:relative}.app-main-container .right-aside.isCollapsed:after{content:\" \";position:absolute;z-index:5;inset:0;background-color:#0003}}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.RSFooterComponent, selector: "rs-footer" }, { kind: "component", type: i4.DrawerComponent, selector: "rs-drawer" }] });
|
|
67
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MainContainerComponent, deps: [{ token: i1.DrawerService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
68
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MainContainerComponent, selector: "rs-main-container", inputs: { isCollapsed: "isCollapsed", singleReuseUrls: "singleReuseUrls" }, outputs: { onWidthChange: "onWidthChange" }, host: { listeners: { "window:resize": "onResize($event)" } }, queries: [{ propertyName: "headerRef", first: true, predicate: RSHeaderComponent, descendants: true, static: true }, { propertyName: "multiTabRef", first: true, predicate: MultiTabComponent, descendants: true, static: true }], viewQueries: [{ propertyName: "drawer", first: true, predicate: ["drawer"], descendants: true }], ngImport: i0, template: "<div class=\"app-main-container\">\r\n <ng-content select=\"[headerSlot]\"></ng-content>\r\n <div class=\"main-page\">\r\n <div class=\"left-aside\">\r\n <ng-content select=\"[leftAsideSlot]\"></ng-content>\r\n </div>\r\n <div\r\n class=\"right-aside\"\r\n [ngClass]=\"{ isCollapsed: isCollapsed }\"\r\n (click)=\"onRightAsideClick()\"\r\n >\r\n <ng-content select=\"[multiTabSlot]\"></ng-content>\r\n <!-- <rs-multi-tab [singleReuseUrls]=\"singleReuseUrls\"></rs-multi-tab> -->\r\n <div class=\"router-content\">\r\n <rs-drawer #drawer>\r\n <ng-content select=\"[routerSlot]\"></ng-content>\r\n </rs-drawer>\r\n </div>\r\n <rs-footer></rs-footer>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".app-main-container{display:flex;flex-direction:column;height:100vh}.app-main-container .main-page{flex:1;height:0;display:flex;background-color:var(--rs-container-bg)}.app-main-container .left-aside{height:100%}.app-main-container .right-aside{width:0;flex:1;display:flex;flex-direction:column;padding-right:12px}.app-main-container .right-aside .router-content{flex:1;overflow:auto;max-width:1886px;width:100%;margin:0 auto}@media (max-width: 992px){.app-main-container .right-aside.isCollapsed{position:relative}.app-main-container .right-aside.isCollapsed:after{content:\" \";position:absolute;z-index:5;inset:0;background-color:#0003}}\n"], dependencies: [{ kind: "directive", type: i2.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: i3.RSFooterComponent, selector: "rs-footer" }, { kind: "component", type: i4.DrawerComponent, selector: "rs-drawer" }] });
|
|
42
69
|
}
|
|
43
70
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MainContainerComponent, decorators: [{
|
|
44
71
|
type: Component,
|
|
45
72
|
args: [{ selector: "rs-main-container", template: "<div class=\"app-main-container\">\r\n <ng-content select=\"[headerSlot]\"></ng-content>\r\n <div class=\"main-page\">\r\n <div class=\"left-aside\">\r\n <ng-content select=\"[leftAsideSlot]\"></ng-content>\r\n </div>\r\n <div\r\n class=\"right-aside\"\r\n [ngClass]=\"{ isCollapsed: isCollapsed }\"\r\n (click)=\"onRightAsideClick()\"\r\n >\r\n <ng-content select=\"[multiTabSlot]\"></ng-content>\r\n <!-- <rs-multi-tab [singleReuseUrls]=\"singleReuseUrls\"></rs-multi-tab> -->\r\n <div class=\"router-content\">\r\n <rs-drawer #drawer>\r\n <ng-content select=\"[routerSlot]\"></ng-content>\r\n </rs-drawer>\r\n </div>\r\n <rs-footer></rs-footer>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".app-main-container{display:flex;flex-direction:column;height:100vh}.app-main-container .main-page{flex:1;height:0;display:flex;background-color:var(--rs-container-bg)}.app-main-container .left-aside{height:100%}.app-main-container .right-aside{width:0;flex:1;display:flex;flex-direction:column;padding-right:12px}.app-main-container .right-aside .router-content{flex:1;overflow:auto;max-width:1886px;width:100%;margin:0 auto}@media (max-width: 992px){.app-main-container .right-aside.isCollapsed{position:relative}.app-main-container .right-aside.isCollapsed:after{content:\" \";position:absolute;z-index:5;inset:0;background-color:#0003}}\n"] }]
|
|
46
|
-
}], ctorParameters: function () { return [{ type: i1.DrawerService }]; }, propDecorators: { headerRef: [{
|
|
73
|
+
}], ctorParameters: function () { return [{ type: i1.DrawerService }, { type: i0.ElementRef }]; }, propDecorators: { headerRef: [{
|
|
47
74
|
type: ContentChild,
|
|
48
75
|
args: [RSHeaderComponent, { static: true }]
|
|
76
|
+
}], multiTabRef: [{
|
|
77
|
+
type: ContentChild,
|
|
78
|
+
args: [MultiTabComponent, { static: true }]
|
|
49
79
|
}], drawer: [{
|
|
50
80
|
type: ViewChild,
|
|
51
81
|
args: ["drawer", { static: false }]
|
|
@@ -53,8 +83,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
53
83
|
type: Input
|
|
54
84
|
}], singleReuseUrls: [{
|
|
55
85
|
type: Input
|
|
86
|
+
}], onWidthChange: [{
|
|
87
|
+
type: Output
|
|
56
88
|
}], onResize: [{
|
|
57
89
|
type: HostListener,
|
|
58
90
|
args: ["window:resize", ["$event"]]
|
|
59
91
|
}] } });
|
|
60
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
92
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.component.js","sourceRoot":"","sources":["../../../../../../projects/raise-common-lib/src/lib/layout/main-container/index.component.ts","../../../../../../projects/raise-common-lib/src/lib/layout/main-container/index.component.html"],"names":[],"mappings":"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","sourcesContent":["// 组件类\r\nimport {\r\n  Component,\r\n  ContentChild,\r\n  ElementRef,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnInit,\r\n  Output,\r\n  ViewChild,\r\n} from \"@angular/core\";\r\nimport { RSHeaderComponent } from \"../rs-header/index.component\";\r\nimport { DrawerComponent } from \"../drawer/index.component\";\r\nimport { DrawerService } from \"../../service/drawer.service\";\r\nimport { MultiTabComponent } from \"../multi-tab/index.component\";\r\nimport { debounce } from \"lodash\";\r\n\r\n@Component({\r\n  selector: \"rs-main-container\",\r\n  templateUrl: \"./index.component.html\",\r\n  styleUrls: [\"./index.component.scss\"],\r\n})\r\nexport class MainContainerComponent implements OnInit {\r\n  @ContentChild(RSHeaderComponent, { static: true }) headerRef;\r\n  @ContentChild(MultiTabComponent, { static: true }) multiTabRef;\r\n\r\n  @ViewChild(\"drawer\", { static: false }) drawer: DrawerComponent;\r\n\r\n  @Input() isCollapsed: boolean = false; // 接收输入属性\r\n  @Input() singleReuseUrls: string[] = []; //只能单个缓存的url\r\n  @Output() onWidthChange = new EventEmitter();\r\n\r\n  private resizeObserver: ResizeObserver;\r\n  private debouncedHandleResize: (width: number) => void;\r\n  constructor(\r\n    private globalDrawer: DrawerService,\r\n    private elementRef: ElementRef\r\n  ) {\r\n    this.debouncedHandleResize = debounce((width: number) => {\r\n      console.log(\"Debounced width change:\", width);\r\n      // 在这里处理防抖后的宽度变化逻辑\r\n      this.multiTabRef && this.multiTabRef.setEllipsisTitle();\r\n      this.onWidthChange.emit(width);\r\n    }, 300);\r\n  }\r\n\r\n  ngOnInit() {}\r\n\r\n  @HostListener(\"window:resize\", [\"$event\"])\r\n  onResize(event) {\r\n    const screenWidth = window.innerWidth; // 更新屏幕宽度\r\n    if (screenWidth <= 992) {\r\n      this.headerRef && this.headerRef.onToggleMenu(false);\r\n    } else if (screenWidth < 1200) {\r\n      this.headerRef && this.headerRef.onToggleMenu(true);\r\n    } else {\r\n      this.headerRef && this.headerRef.onToggleMenu(false);\r\n    }\r\n  }\r\n\r\n  ngAfterViewInit() {\r\n    this.globalDrawer.setDrawer(this.drawer); // 设置抽屉组件\r\n    const rightAside =\r\n      this.elementRef.nativeElement.querySelector(\".right-aside\");\r\n    this.resizeObserver = new ResizeObserver((entries) => {\r\n      for (const entry of entries) {\r\n        const width = entry.contentRect.width;\r\n        this.debouncedHandleResize(width);\r\n      }\r\n    });\r\n    this.resizeObserver.observe(rightAside);\r\n  }\r\n  \r\n  ngOnDestroy() {\r\n    if (this.resizeObserver) {\r\n      this.resizeObserver.disconnect();\r\n    }\r\n  }\r\n\r\n  onRightAsideClick() {\r\n    const screenWidth = window.innerWidth;\r\n    if (screenWidth <= 992 && this.isCollapsed) {\r\n      this.headerRef && this.headerRef.onToggleMenu();\r\n    }\r\n  }\r\n}\r\n","<div class=\"app-main-container\">\r\n  <ng-content select=\"[headerSlot]\"></ng-content>\r\n  <div class=\"main-page\">\r\n    <div class=\"left-aside\">\r\n      <ng-content select=\"[leftAsideSlot]\"></ng-content>\r\n    </div>\r\n    <div\r\n      class=\"right-aside\"\r\n      [ngClass]=\"{ isCollapsed: isCollapsed }\"\r\n      (click)=\"onRightAsideClick()\"\r\n    >\r\n      <ng-content select=\"[multiTabSlot]\"></ng-content>\r\n      <!-- <rs-multi-tab [singleReuseUrls]=\"singleReuseUrls\"></rs-multi-tab> -->\r\n      <div class=\"router-content\">\r\n        <rs-drawer #drawer>\r\n          <ng-content select=\"[routerSlot]\"></ng-content>\r\n        </rs-drawer>\r\n      </div>\r\n      <rs-footer></rs-footer>\r\n    </div>\r\n  </div>\r\n</div>\r\n"]}
|
|
@@ -41,7 +41,7 @@ export class MultiTabComponent {
|
|
|
41
41
|
screenWidth = window.innerWidth; // 初始化屏幕宽度
|
|
42
42
|
onResize(event) {
|
|
43
43
|
this.screenWidth = window.innerWidth; // 更新屏幕宽度
|
|
44
|
-
this.setEllipsisTitle();
|
|
44
|
+
// this.setEllipsisTitle(); 在最外面容器调用
|
|
45
45
|
}
|
|
46
46
|
ngOnInit() {
|
|
47
47
|
this.initTab();
|
|
@@ -85,6 +85,8 @@ export class MultiTabComponent {
|
|
|
85
85
|
}, 50);
|
|
86
86
|
}
|
|
87
87
|
ngOnDestroy() {
|
|
88
|
+
this.tabList = []; // 清空 tab 列表
|
|
89
|
+
this.selectedTab = 0; // 重置选中的 tab 索引
|
|
88
90
|
this.subscriptions.forEach((sub) => sub.unsubscribe());
|
|
89
91
|
}
|
|
90
92
|
setEllipsisTitle(title) {
|
|
@@ -106,6 +108,8 @@ export class MultiTabComponent {
|
|
|
106
108
|
: width - this.textGap, 12);
|
|
107
109
|
});
|
|
108
110
|
}
|
|
111
|
+
this.ref.markForCheck();
|
|
112
|
+
this.ref.detectChanges();
|
|
109
113
|
}
|
|
110
114
|
calcTabWidth() {
|
|
111
115
|
const wrap = document.querySelector(".rs-multi-tab");
|
|
@@ -242,6 +246,12 @@ export class MultiTabComponent {
|
|
|
242
246
|
this.keepAlive.clearCache(url); // 调用自定义策略的清除缓存方法
|
|
243
247
|
this.drawer.deleteCache(url);
|
|
244
248
|
}
|
|
249
|
+
cleanAllCache() {
|
|
250
|
+
sessionStorage.removeItem("TabCache"); // 清除缓存
|
|
251
|
+
this.tabList = []; // 清空 tab 列表
|
|
252
|
+
this.selectedTab = 0; // 重置选中的 tab 索引
|
|
253
|
+
this.keepAlive.clearAllCache(); // 调用自定义策略的清除缓存方法
|
|
254
|
+
}
|
|
245
255
|
urlWithoutQuery(url) {
|
|
246
256
|
return url.split("?")[0];
|
|
247
257
|
}
|
|
@@ -261,4 +271,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
261
271
|
type: HostListener,
|
|
262
272
|
args: ["window:resize", ["$event"]]
|
|
263
273
|
}] } });
|
|
264
|
-
//# 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  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n} from \"@angular/core\";\r\nimport {\r\n  ActivatedRoute,\r\n  NavigationEnd,\r\n  Router,\r\n  RouterOutlet,\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  selector: \"rs-multi-tab\",\r\n  templateUrl: \"./index.component.html\",\r\n  styleUrls: [\"./index.component.scss\"],\r\n})\r\nexport class MultiTabComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  constructor(\r\n    public router: Router,\r\n    public cf: CommonFunctionService,\r\n    public activatedRoute: ActivatedRoute,\r\n    private ref: ChangeDetectorRef,\r\n    private drawer: DrawerService,\r\n    private routeReuseStrategy: RouteReuseStrategy\r\n  ) {\r\n    this.keepAlive = this.routeReuseStrategy as KeepAliveService;\r\n  }\r\n  keepAlive: KeepAliveService;\r\n  @Input() singleReuseUrls: string[] = []; //只能单个缓存的url\r\n  @Input() noGenerateTabUrls: string[] = []; //不生成tab的url\r\n  @Output() onRefreshTab = new EventEmitter();\r\n\r\n  private subscriptions: Subscription[] = [];\r\n  TAB_WIDTH = 164;\r\n  GAP_NORMAL = 54;\r\n  GAP_SMALL = 30;\r\n  textGap; // 文本与边框的总间距\r\n  foo: RouterOutlet;\r\n  comRef: any;\r\n  tabList = [];\r\n  selectedTab: number = 0;\r\n  maxTabs: number = 10;\r\n  screenWidth: number = window.innerWidth; // 初始化屏幕宽度\r\n  @HostListener(\"window:resize\", [\"$event\"])\r\n  onResize(event) {\r\n    this.screenWidth = window.innerWidth; // 更新屏幕宽度\r\n    this.setEllipsisTitle();\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.initTab();\r\n    // 解决刷新页面后，选中的 tab 丢失问题\r\n    const isExistIdx = this.tabList.findIndex(\r\n      (ele) =>\r\n        this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(this.router.url)\r\n    );\r\n    if (isExistIdx !== -1) {\r\n      this.selectedTab = isExistIdx;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.router.events\r\n        .pipe(filter((event) => event instanceof NavigationEnd))\r\n        .subscribe(() => {\r\n          const navigation = this.router.getCurrentNavigation(); // 获取当前导航\r\n          if (navigation) {\r\n            const tooltipElements = document.querySelectorAll(\".e-popup-open\");\r\n            // 删除tooltips\r\n            tooltipElements.forEach((element) => {\r\n              const htmlElement = element as HTMLElement;\r\n              htmlElement.style.display = \"none\";\r\n            });\r\n            const state = navigation.extras.state; // 获取传递的 state\r\n            const skipLocationChange = navigation.extras.skipLocationChange; // 获取是否跳过 location change\r\n            const currentRoute = this.router.routerState.root.firstChild;\r\n            const navigationInfo = JSON.parse(\r\n              sessionStorage.getItem(\"navigationInfo\") || \"{}\"\r\n            );\r\n            let title =\r\n              (state && state.title) ||\r\n              navigationInfo.title ||\r\n              navigationInfo.subTitle ||\r\n              navigationInfo.name;\r\n\r\n            let noReused = (state && state.noReused) || false; // 当前tab不复用，新开一个tab,当有已经存在的tab时候也是新开\r\n            if (currentRoute && !skipLocationChange) {\r\n              if (\r\n                this.noGenerateTabUrls.includes(\r\n                  this.urlWithoutQuery(this.router.url)\r\n                )\r\n              ) {\r\n                return; // 排除不生成tab的url\r\n              }\r\n              this.setTab(\r\n                this.router.url,\r\n                currentRoute.snapshot.routeConfig.path,\r\n                title,\r\n                noReused\r\n              );\r\n            }\r\n          }\r\n        })\r\n    );\r\n  }\r\n  ngAfterViewInit() {\r\n    setTimeout(() => {\r\n      this.setEllipsisTitle();\r\n    }, 50);\r\n  }\r\n  ngOnDestroy() {\r\n    this.subscriptions.forEach((sub) => sub.unsubscribe());\r\n  }\r\n\r\n  setEllipsisTitle(title?) {\r\n    this.textGap = this.GAP_NORMAL;\r\n    if (this.screenWidth <= 1100) {\r\n      this.textGap = this.GAP_SMALL;\r\n    }\r\n    let { allWidth, leftWidth, rightWidth } = this.calcTabWidth();\r\n    let width = Math.floor(\r\n      (allWidth - rightWidth) / (this.tabList && this.tabList.length)\r\n    );\r\n    if (title) {\r\n      return this.cf.setMiddleEllipsis(\r\n        title,\r\n        width > this.TAB_WIDTH\r\n          ? this.TAB_WIDTH - this.textGap\r\n          : width - this.textGap,\r\n        12\r\n      );\r\n    } else {\r\n      this.tabList.forEach((ele, idx) => {\r\n        ele.displayTitle = this.cf.setMiddleEllipsis(\r\n          ele.title,\r\n          width > this.TAB_WIDTH\r\n            ? this.TAB_WIDTH - this.textGap\r\n            : width - this.textGap,\r\n          12\r\n        );\r\n      });\r\n    }\r\n  }\r\n\r\n  calcTabWidth() {\r\n    const wrap = document.querySelector(\".rs-multi-tab\");\r\n    const ulElement = document.querySelector(\".rs-multi-tab > ul\");\r\n    const refreshTabDiv = document.querySelector(\".rs-multi-tab .refresh-tab\");\r\n    let allWidth;\r\n    let leftWidth;\r\n    let rightWidth;\r\n    if (wrap && ulElement) {\r\n      // 获取元素的位置信息\r\n      const wrapRect = wrap.getBoundingClientRect();\r\n      const ulRect = ulElement.getBoundingClientRect();\r\n      const refreshTabRect =\r\n        refreshTabDiv && refreshTabDiv.getBoundingClientRect();\r\n      allWidth = wrapRect.width;\r\n      leftWidth = ulRect.width;\r\n      rightWidth = (refreshTabRect && refreshTabRect.width) || 100;\r\n    }\r\n    return {\r\n      allWidth,\r\n      leftWidth,\r\n      rightWidth,\r\n    };\r\n  }\r\n  initTab() {\r\n    let TabCache = JSON.parse(sessionStorage.getItem(\"TabCache\"));\r\n    this.tabList = TabCache || [];\r\n    if (this.tabList.length === 0) {\r\n      const title = sessionStorage.getItem(\"firstTabTitle\");\r\n      if (title) {\r\n        sessionStorage.removeItem(\"firstTabTitle\");\r\n        const url = this.router.url;\r\n        this.addTab(url, title);\r\n      }\r\n    }\r\n  }\r\n\r\n  closeTab(idx, noChange?) {\r\n    const tab = this.tabList[idx];\r\n    this.tabList = this.tabList.filter((ele) => ele.url !== tab.url);\r\n    this.clearCache(this.urlWithoutQuery(tab.url));\r\n    if (!noChange && this.selectedTab === idx) {\r\n      const targetIdx = Math.max(0, idx - 1);\r\n      this.changeTab(this.tabList[targetIdx], targetIdx);\r\n    }\r\n    if (idx < this.selectedTab) {\r\n      this.selectedTab = this.selectedTab - 1; // 如果关闭的tab在当前选中的tab之前，选中tab索引减1\r\n    }\r\n    this.setEllipsisTitle();\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  changeTab(tab, idx) {\r\n    this.router.navigateByUrl(tab.url);\r\n    if (tab.navigationInfo) {\r\n      sessionStorage.setItem(\r\n        \"navigationInfo\",\r\n        JSON.stringify(tab.navigationInfo)\r\n      );\r\n    }\r\n    if (tab.fromInfo) {\r\n      sessionStorage.setItem(\"fromInfo\", JSON.stringify(tab.fromInfo));\r\n    }\r\n    if (tab.permissions) {\r\n      sessionStorage.setItem(\"permissions\", JSON.stringify(tab.permissions));\r\n    }\r\n    this.selectedTab = idx;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  addTab(url, title) {\r\n    if (this.tabList.length >= this.maxTabs) {\r\n      this.closeTab(1); // 删除第二个，第一个固定\r\n    }\r\n    const localPermissions =\r\n      sessionStorage.getItem(\"permissions\") ||\r\n      localStorage.getItem(\"permissions\");\r\n    const navigationInfo = JSON.parse(sessionStorage.getItem(\"navigationInfo\"));\r\n    const fromInfo = JSON.parse(sessionStorage.getItem(\"fromInfo\"));\r\n    const permissions = JSON.parse(localPermissions);\r\n\r\n    this.tabList.push({\r\n      url: url,\r\n      title: title || \"default\",\r\n      displayTitle: title,\r\n      navigationInfo: navigationInfo,\r\n      permissions: permissions,\r\n      fromInfo: fromInfo,\r\n    });\r\n    this.selectedTab = this.tabList.length - 1;\r\n    this.setEllipsisTitle();\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  public setTab(url, pureUrl, title, noReused) {\r\n    const isExistIdx = this.tabList.findIndex(\r\n      (ele) => this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(url)\r\n    );\r\n    if (isExistIdx === -1) {\r\n      const singleIdx = this.singleReuseUrls.findIndex(\r\n        (ele) => ele === pureUrl\r\n      );\r\n      if (singleIdx !== -1) {\r\n        this.tabList = this.tabList.filter(\r\n          (ele) => !ele.url.includes(this.singleReuseUrls[singleIdx])\r\n        );\r\n        this.keepAlive.clearCache(url);\r\n        this.drawer.deleteCache(url);\r\n      }\r\n      this.addTab(url, title);\r\n    } else {\r\n      const targetTabUrl = this.tabList[isExistIdx].url;\r\n      if (targetTabUrl !== url || noReused) {\r\n        // 当缓存一致时候，但是url不一致，重新按照新的url生成tab\r\n        this.closeTab(isExistIdx, true);\r\n        setTimeout(() => {\r\n          this.addTab(url, title);\r\n        }, 30);\r\n      } else {\r\n        this.changeTab(this.tabList[isExistIdx], isExistIdx);\r\n      }\r\n      this.ref.markForCheck();\r\n    }\r\n  }\r\n  timer = null;\r\n  refreshTab() {\r\n    const loadingIcon = document.getElementById(\"loadingIcon\");\r\n    loadingIcon.classList.add(\"refresh-tab-loading\");\r\n    if (this.timer) {\r\n      clearInterval(this.timer);\r\n    }\r\n    // 模拟加载过程，1秒后移除动画\r\n    this.timer = setTimeout(() => {\r\n      loadingIcon.classList.remove(\"refresh-tab-loading\");\r\n      this.timer = null;\r\n    }, 1500);\r\n    // this.keepAlive.clearCache(this.tabList[this.selectedTab].url);\r\n    // this.drawer.deleteCache(this.tabList[this.selectedTab].url);\r\n    const currentUrl = this.router.url; // 获取当前 URL\r\n    this.onRefreshTab.emit(currentUrl);\r\n    // this.router.navigateByUrl(\"/\", { skipLocationChange: true }).then(() => {\r\n    //   this.router.navigateByUrl(currentUrl); // 重新导航到当前 URL\r\n    // });\r\n  }\r\n\r\n  clearCache(url) {\r\n    this.keepAlive.clearCache(url); // 调用自定义策略的清除缓存方法\r\n    this.drawer.deleteCache(url);\r\n  }\r\n\r\n  private urlWithoutQuery(url) {\r\n    return url.split(\"?\")[0];\r\n  }\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"]}
|
|
274
|
+
//# 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  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  EventEmitter,\r\n  HostListener,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  Output,\r\n} from \"@angular/core\";\r\nimport {\r\n  ActivatedRoute,\r\n  NavigationEnd,\r\n  Router,\r\n  RouterOutlet,\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  selector: \"rs-multi-tab\",\r\n  templateUrl: \"./index.component.html\",\r\n  styleUrls: [\"./index.component.scss\"],\r\n})\r\nexport class MultiTabComponent implements OnInit, AfterViewInit, OnDestroy {\r\n  constructor(\r\n    public router: Router,\r\n    public cf: CommonFunctionService,\r\n    public activatedRoute: ActivatedRoute,\r\n    private ref: ChangeDetectorRef,\r\n    private drawer: DrawerService,\r\n    private routeReuseStrategy: RouteReuseStrategy\r\n  ) {\r\n    this.keepAlive = this.routeReuseStrategy as KeepAliveService;\r\n  }\r\n  keepAlive: KeepAliveService;\r\n  @Input() singleReuseUrls: string[] = []; //只能单个缓存的url\r\n  @Input() noGenerateTabUrls: string[] = []; //不生成tab的url\r\n  @Output() onRefreshTab = new EventEmitter();\r\n\r\n  private subscriptions: Subscription[] = [];\r\n  TAB_WIDTH = 164;\r\n  GAP_NORMAL = 54;\r\n  GAP_SMALL = 30;\r\n  textGap; // 文本与边框的总间距\r\n  foo: RouterOutlet;\r\n  comRef: any;\r\n  tabList = [];\r\n  selectedTab: number = 0;\r\n  maxTabs: number = 10;\r\n  screenWidth: number = window.innerWidth; // 初始化屏幕宽度\r\n  @HostListener(\"window:resize\", [\"$event\"])\r\n  onResize(event) {\r\n    this.screenWidth = window.innerWidth; // 更新屏幕宽度\r\n    // this.setEllipsisTitle(); 在最外面容器调用\r\n  }\r\n\r\n  ngOnInit() {\r\n    this.initTab();\r\n    // 解决刷新页面后，选中的 tab 丢失问题\r\n    const isExistIdx = this.tabList.findIndex(\r\n      (ele) =>\r\n        this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(this.router.url)\r\n    );\r\n    if (isExistIdx !== -1) {\r\n      this.selectedTab = isExistIdx;\r\n    }\r\n\r\n    this.subscriptions.push(\r\n      this.router.events\r\n        .pipe(filter((event) => event instanceof NavigationEnd))\r\n        .subscribe(() => {\r\n          const navigation = this.router.getCurrentNavigation(); // 获取当前导航\r\n          if (navigation) {\r\n            const tooltipElements = document.querySelectorAll(\".e-popup-open\");\r\n            // 删除tooltips\r\n            tooltipElements.forEach((element) => {\r\n              const htmlElement = element as HTMLElement;\r\n              htmlElement.style.display = \"none\";\r\n            });\r\n            const state = navigation.extras.state; // 获取传递的 state\r\n            const skipLocationChange = navigation.extras.skipLocationChange; // 获取是否跳过 location change\r\n            const currentRoute = this.router.routerState.root.firstChild;\r\n            const navigationInfo = JSON.parse(\r\n              sessionStorage.getItem(\"navigationInfo\") || \"{}\"\r\n            );\r\n            let title =\r\n              (state && state.title) ||\r\n              navigationInfo.title ||\r\n              navigationInfo.subTitle ||\r\n              navigationInfo.name;\r\n\r\n            let noReused = (state && state.noReused) || false; // 当前tab不复用，新开一个tab,当有已经存在的tab时候也是新开\r\n            if (currentRoute && !skipLocationChange) {\r\n              if (\r\n                this.noGenerateTabUrls.includes(\r\n                  this.urlWithoutQuery(this.router.url)\r\n                )\r\n              ) {\r\n                return; // 排除不生成tab的url\r\n              }\r\n              this.setTab(\r\n                this.router.url,\r\n                currentRoute.snapshot.routeConfig.path,\r\n                title,\r\n                noReused\r\n              );\r\n            }\r\n          }\r\n        })\r\n    );\r\n  }\r\n  ngAfterViewInit() {\r\n    setTimeout(() => {\r\n      this.setEllipsisTitle();\r\n    }, 50);\r\n  }\r\n  ngOnDestroy() {\r\n    this.tabList = []; // 清空 tab 列表\r\n    this.selectedTab = 0; // 重置选中的 tab 索引\r\n    this.subscriptions.forEach((sub) => sub.unsubscribe());\r\n  }\r\n\r\n  setEllipsisTitle(title?) {\r\n    this.textGap = this.GAP_NORMAL;\r\n    if (this.screenWidth <= 1100) {\r\n      this.textGap = this.GAP_SMALL;\r\n    }\r\n    let { allWidth, leftWidth, rightWidth } = this.calcTabWidth();\r\n    let width = Math.floor(\r\n      (allWidth - rightWidth) / (this.tabList && this.tabList.length)\r\n    );\r\n    if (title) {\r\n      return this.cf.setMiddleEllipsis(\r\n        title,\r\n        width > this.TAB_WIDTH\r\n          ? this.TAB_WIDTH - this.textGap\r\n          : width - this.textGap,\r\n        12\r\n      );\r\n    } else {\r\n      this.tabList.forEach((ele, idx) => {\r\n        ele.displayTitle = this.cf.setMiddleEllipsis(\r\n          ele.title,\r\n          width > this.TAB_WIDTH\r\n            ? this.TAB_WIDTH - this.textGap\r\n            : width - this.textGap,\r\n          12\r\n        );\r\n      });\r\n    }\r\n    this.ref.markForCheck();\r\n    this.ref.detectChanges();\r\n  }\r\n\r\n  calcTabWidth() {\r\n    const wrap = document.querySelector(\".rs-multi-tab\");\r\n    const ulElement = document.querySelector(\".rs-multi-tab > ul\");\r\n    const refreshTabDiv = document.querySelector(\".rs-multi-tab .refresh-tab\");\r\n    let allWidth;\r\n    let leftWidth;\r\n    let rightWidth;\r\n    if (wrap && ulElement) {\r\n      // 获取元素的位置信息\r\n      const wrapRect = wrap.getBoundingClientRect();\r\n      const ulRect = ulElement.getBoundingClientRect();\r\n      const refreshTabRect =\r\n        refreshTabDiv && refreshTabDiv.getBoundingClientRect();\r\n      allWidth = wrapRect.width;\r\n      leftWidth = ulRect.width;\r\n      rightWidth = (refreshTabRect && refreshTabRect.width) || 100;\r\n    }\r\n    return {\r\n      allWidth,\r\n      leftWidth,\r\n      rightWidth,\r\n    };\r\n  }\r\n  initTab() {\r\n    let TabCache = JSON.parse(sessionStorage.getItem(\"TabCache\"));\r\n    this.tabList = TabCache || [];\r\n    if (this.tabList.length === 0) {\r\n      const title = sessionStorage.getItem(\"firstTabTitle\");\r\n      if (title) {\r\n        sessionStorage.removeItem(\"firstTabTitle\");\r\n        const url = this.router.url;\r\n        this.addTab(url, title);\r\n      }\r\n    }\r\n  }\r\n\r\n  closeTab(idx, noChange?) {\r\n    const tab = this.tabList[idx];\r\n    this.tabList = this.tabList.filter((ele) => ele.url !== tab.url);\r\n    this.clearCache(this.urlWithoutQuery(tab.url));\r\n    if (!noChange && this.selectedTab === idx) {\r\n      const targetIdx = Math.max(0, idx - 1);\r\n      this.changeTab(this.tabList[targetIdx], targetIdx);\r\n    }\r\n    if (idx < this.selectedTab) {\r\n      this.selectedTab = this.selectedTab - 1; // 如果关闭的tab在当前选中的tab之前，选中tab索引减1\r\n    }\r\n    this.setEllipsisTitle();\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  changeTab(tab, idx) {\r\n    this.router.navigateByUrl(tab.url);\r\n    if (tab.navigationInfo) {\r\n      sessionStorage.setItem(\r\n        \"navigationInfo\",\r\n        JSON.stringify(tab.navigationInfo)\r\n      );\r\n    }\r\n    if (tab.fromInfo) {\r\n      sessionStorage.setItem(\"fromInfo\", JSON.stringify(tab.fromInfo));\r\n    }\r\n    if (tab.permissions) {\r\n      sessionStorage.setItem(\"permissions\", JSON.stringify(tab.permissions));\r\n    }\r\n    this.selectedTab = idx;\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  addTab(url, title) {\r\n    if (this.tabList.length >= this.maxTabs) {\r\n      this.closeTab(1); // 删除第二个，第一个固定\r\n    }\r\n    const localPermissions =\r\n      sessionStorage.getItem(\"permissions\") ||\r\n      localStorage.getItem(\"permissions\");\r\n    const navigationInfo = JSON.parse(sessionStorage.getItem(\"navigationInfo\"));\r\n    const fromInfo = JSON.parse(sessionStorage.getItem(\"fromInfo\"));\r\n    const permissions = JSON.parse(localPermissions);\r\n\r\n    this.tabList.push({\r\n      url: url,\r\n      title: title || \"default\",\r\n      displayTitle: title,\r\n      navigationInfo: navigationInfo,\r\n      permissions: permissions,\r\n      fromInfo: fromInfo,\r\n    });\r\n    this.selectedTab = this.tabList.length - 1;\r\n    this.setEllipsisTitle();\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\r\n    this.ref.markForCheck();\r\n  }\r\n\r\n  public setTab(url, pureUrl, title, noReused) {\r\n    const isExistIdx = this.tabList.findIndex(\r\n      (ele) => this.urlWithoutQuery(ele.url) === this.urlWithoutQuery(url)\r\n    );\r\n    if (isExistIdx === -1) {\r\n      const singleIdx = this.singleReuseUrls.findIndex(\r\n        (ele) => ele === pureUrl\r\n      );\r\n      if (singleIdx !== -1) {\r\n        this.tabList = this.tabList.filter(\r\n          (ele) => !ele.url.includes(this.singleReuseUrls[singleIdx])\r\n        );\r\n        this.keepAlive.clearCache(url);\r\n        this.drawer.deleteCache(url);\r\n      }\r\n      this.addTab(url, title);\r\n    } else {\r\n      const targetTabUrl = this.tabList[isExistIdx].url;\r\n      if (targetTabUrl !== url || noReused) {\r\n        // 当缓存一致时候，但是url不一致，重新按照新的url生成tab\r\n        this.closeTab(isExistIdx, true);\r\n        setTimeout(() => {\r\n          this.addTab(url, title);\r\n        }, 30);\r\n      } else {\r\n        this.changeTab(this.tabList[isExistIdx], isExistIdx);\r\n      }\r\n      this.ref.markForCheck();\r\n    }\r\n  }\r\n  timer = null;\r\n  refreshTab() {\r\n    const loadingIcon = document.getElementById(\"loadingIcon\");\r\n    loadingIcon.classList.add(\"refresh-tab-loading\");\r\n    if (this.timer) {\r\n      clearInterval(this.timer);\r\n    }\r\n    // 模拟加载过程，1秒后移除动画\r\n    this.timer = setTimeout(() => {\r\n      loadingIcon.classList.remove(\"refresh-tab-loading\");\r\n      this.timer = null;\r\n    }, 1500);\r\n    // this.keepAlive.clearCache(this.tabList[this.selectedTab].url);\r\n    // this.drawer.deleteCache(this.tabList[this.selectedTab].url);\r\n    const currentUrl = this.router.url; // 获取当前 URL\r\n    this.onRefreshTab.emit(currentUrl);\r\n    // this.router.navigateByUrl(\"/\", { skipLocationChange: true }).then(() => {\r\n    //   this.router.navigateByUrl(currentUrl); // 重新导航到当前 URL\r\n    // });\r\n  }\r\n\r\n  clearCache(url) {\r\n    this.keepAlive.clearCache(url); // 调用自定义策略的清除缓存方法\r\n    this.drawer.deleteCache(url);\r\n  }\r\n  cleanAllCache() {\r\n    sessionStorage.removeItem(\"TabCache\"); // 清除缓存\r\n    this.tabList = []; // 清空 tab 列表\r\n    this.selectedTab = 0; // 重置选中的 tab 索引\r\n    this.keepAlive.clearAllCache(); // 调用自定义策略的清除缓存方法\r\n  }\r\n  private urlWithoutQuery(url) {\r\n    return url.split(\"?\")[0];\r\n  }\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"]}
|
|
@@ -1669,7 +1669,7 @@ class MultiTabComponent {
|
|
|
1669
1669
|
screenWidth = window.innerWidth; // 初始化屏幕宽度
|
|
1670
1670
|
onResize(event) {
|
|
1671
1671
|
this.screenWidth = window.innerWidth; // 更新屏幕宽度
|
|
1672
|
-
this.setEllipsisTitle();
|
|
1672
|
+
// this.setEllipsisTitle(); 在最外面容器调用
|
|
1673
1673
|
}
|
|
1674
1674
|
ngOnInit() {
|
|
1675
1675
|
this.initTab();
|
|
@@ -1713,6 +1713,8 @@ class MultiTabComponent {
|
|
|
1713
1713
|
}, 50);
|
|
1714
1714
|
}
|
|
1715
1715
|
ngOnDestroy() {
|
|
1716
|
+
this.tabList = []; // 清空 tab 列表
|
|
1717
|
+
this.selectedTab = 0; // 重置选中的 tab 索引
|
|
1716
1718
|
this.subscriptions.forEach((sub) => sub.unsubscribe());
|
|
1717
1719
|
}
|
|
1718
1720
|
setEllipsisTitle(title) {
|
|
@@ -1734,6 +1736,8 @@ class MultiTabComponent {
|
|
|
1734
1736
|
: width - this.textGap, 12);
|
|
1735
1737
|
});
|
|
1736
1738
|
}
|
|
1739
|
+
this.ref.markForCheck();
|
|
1740
|
+
this.ref.detectChanges();
|
|
1737
1741
|
}
|
|
1738
1742
|
calcTabWidth() {
|
|
1739
1743
|
const wrap = document.querySelector(".rs-multi-tab");
|
|
@@ -1870,6 +1874,12 @@ class MultiTabComponent {
|
|
|
1870
1874
|
this.keepAlive.clearCache(url); // 调用自定义策略的清除缓存方法
|
|
1871
1875
|
this.drawer.deleteCache(url);
|
|
1872
1876
|
}
|
|
1877
|
+
cleanAllCache() {
|
|
1878
|
+
sessionStorage.removeItem("TabCache"); // 清除缓存
|
|
1879
|
+
this.tabList = []; // 清空 tab 列表
|
|
1880
|
+
this.selectedTab = 0; // 重置选中的 tab 索引
|
|
1881
|
+
this.keepAlive.clearAllCache(); // 调用自定义策略的清除缓存方法
|
|
1882
|
+
}
|
|
1873
1883
|
urlWithoutQuery(url) {
|
|
1874
1884
|
return url.split("?")[0];
|
|
1875
1885
|
}
|
|
@@ -18865,12 +18875,24 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
18865
18875
|
// 组件类
|
|
18866
18876
|
class MainContainerComponent {
|
|
18867
18877
|
globalDrawer;
|
|
18878
|
+
elementRef;
|
|
18868
18879
|
headerRef;
|
|
18880
|
+
multiTabRef;
|
|
18869
18881
|
drawer;
|
|
18870
18882
|
isCollapsed = false; // 接收输入属性
|
|
18871
18883
|
singleReuseUrls = []; //只能单个缓存的url
|
|
18872
|
-
|
|
18884
|
+
onWidthChange = new EventEmitter();
|
|
18885
|
+
resizeObserver;
|
|
18886
|
+
debouncedHandleResize;
|
|
18887
|
+
constructor(globalDrawer, elementRef) {
|
|
18873
18888
|
this.globalDrawer = globalDrawer;
|
|
18889
|
+
this.elementRef = elementRef;
|
|
18890
|
+
this.debouncedHandleResize = debounce((width) => {
|
|
18891
|
+
console.log("Debounced width change:", width);
|
|
18892
|
+
// 在这里处理防抖后的宽度变化逻辑
|
|
18893
|
+
this.multiTabRef && this.multiTabRef.setEllipsisTitle();
|
|
18894
|
+
this.onWidthChange.emit(width);
|
|
18895
|
+
}, 300);
|
|
18874
18896
|
}
|
|
18875
18897
|
ngOnInit() { }
|
|
18876
18898
|
onResize(event) {
|
|
@@ -18887,6 +18909,19 @@ class MainContainerComponent {
|
|
|
18887
18909
|
}
|
|
18888
18910
|
ngAfterViewInit() {
|
|
18889
18911
|
this.globalDrawer.setDrawer(this.drawer); // 设置抽屉组件
|
|
18912
|
+
const rightAside = this.elementRef.nativeElement.querySelector(".right-aside");
|
|
18913
|
+
this.resizeObserver = new ResizeObserver((entries) => {
|
|
18914
|
+
for (const entry of entries) {
|
|
18915
|
+
const width = entry.contentRect.width;
|
|
18916
|
+
this.debouncedHandleResize(width);
|
|
18917
|
+
}
|
|
18918
|
+
});
|
|
18919
|
+
this.resizeObserver.observe(rightAside);
|
|
18920
|
+
}
|
|
18921
|
+
ngOnDestroy() {
|
|
18922
|
+
if (this.resizeObserver) {
|
|
18923
|
+
this.resizeObserver.disconnect();
|
|
18924
|
+
}
|
|
18890
18925
|
}
|
|
18891
18926
|
onRightAsideClick() {
|
|
18892
18927
|
const screenWidth = window.innerWidth;
|
|
@@ -18894,15 +18929,18 @@ class MainContainerComponent {
|
|
|
18894
18929
|
this.headerRef && this.headerRef.onToggleMenu();
|
|
18895
18930
|
}
|
|
18896
18931
|
}
|
|
18897
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MainContainerComponent, deps: [{ token: DrawerService }], target: i0.ɵɵFactoryTarget.Component });
|
|
18898
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MainContainerComponent, selector: "rs-main-container", inputs: { isCollapsed: "isCollapsed", singleReuseUrls: "singleReuseUrls" }, host: { listeners: { "window:resize": "onResize($event)" } }, queries: [{ propertyName: "headerRef", first: true, predicate: RSHeaderComponent, descendants: true, static: true }], viewQueries: [{ propertyName: "drawer", first: true, predicate: ["drawer"], descendants: true }], ngImport: i0, template: "<div class=\"app-main-container\">\r\n <ng-content select=\"[headerSlot]\"></ng-content>\r\n <div class=\"main-page\">\r\n <div class=\"left-aside\">\r\n <ng-content select=\"[leftAsideSlot]\"></ng-content>\r\n </div>\r\n <div\r\n class=\"right-aside\"\r\n [ngClass]=\"{ isCollapsed: isCollapsed }\"\r\n (click)=\"onRightAsideClick()\"\r\n >\r\n <ng-content select=\"[multiTabSlot]\"></ng-content>\r\n <!-- <rs-multi-tab [singleReuseUrls]=\"singleReuseUrls\"></rs-multi-tab> -->\r\n <div class=\"router-content\">\r\n <rs-drawer #drawer>\r\n <ng-content select=\"[routerSlot]\"></ng-content>\r\n </rs-drawer>\r\n </div>\r\n <rs-footer></rs-footer>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".app-main-container{display:flex;flex-direction:column;height:100vh}.app-main-container .main-page{flex:1;height:0;display:flex;background-color:var(--rs-container-bg)}.app-main-container .left-aside{height:100%}.app-main-container .right-aside{width:0;flex:1;display:flex;flex-direction:column;padding-right:12px}.app-main-container .right-aside .router-content{flex:1;overflow:auto;max-width:1886px;width:100%;margin:0 auto}@media (max-width: 992px){.app-main-container .right-aside.isCollapsed{position:relative}.app-main-container .right-aside.isCollapsed:after{content:\" \";position:absolute;z-index:5;inset:0;background-color:#0003}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: RSFooterComponent, selector: "rs-footer" }, { kind: "component", type: DrawerComponent, selector: "rs-drawer" }] });
|
|
18932
|
+
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MainContainerComponent, deps: [{ token: DrawerService }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component });
|
|
18933
|
+
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: MainContainerComponent, selector: "rs-main-container", inputs: { isCollapsed: "isCollapsed", singleReuseUrls: "singleReuseUrls" }, outputs: { onWidthChange: "onWidthChange" }, host: { listeners: { "window:resize": "onResize($event)" } }, queries: [{ propertyName: "headerRef", first: true, predicate: RSHeaderComponent, descendants: true, static: true }, { propertyName: "multiTabRef", first: true, predicate: MultiTabComponent, descendants: true, static: true }], viewQueries: [{ propertyName: "drawer", first: true, predicate: ["drawer"], descendants: true }], ngImport: i0, template: "<div class=\"app-main-container\">\r\n <ng-content select=\"[headerSlot]\"></ng-content>\r\n <div class=\"main-page\">\r\n <div class=\"left-aside\">\r\n <ng-content select=\"[leftAsideSlot]\"></ng-content>\r\n </div>\r\n <div\r\n class=\"right-aside\"\r\n [ngClass]=\"{ isCollapsed: isCollapsed }\"\r\n (click)=\"onRightAsideClick()\"\r\n >\r\n <ng-content select=\"[multiTabSlot]\"></ng-content>\r\n <!-- <rs-multi-tab [singleReuseUrls]=\"singleReuseUrls\"></rs-multi-tab> -->\r\n <div class=\"router-content\">\r\n <rs-drawer #drawer>\r\n <ng-content select=\"[routerSlot]\"></ng-content>\r\n </rs-drawer>\r\n </div>\r\n <rs-footer></rs-footer>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".app-main-container{display:flex;flex-direction:column;height:100vh}.app-main-container .main-page{flex:1;height:0;display:flex;background-color:var(--rs-container-bg)}.app-main-container .left-aside{height:100%}.app-main-container .right-aside{width:0;flex:1;display:flex;flex-direction:column;padding-right:12px}.app-main-container .right-aside .router-content{flex:1;overflow:auto;max-width:1886px;width:100%;margin:0 auto}@media (max-width: 992px){.app-main-container .right-aside.isCollapsed{position:relative}.app-main-container .right-aside.isCollapsed:after{content:\" \";position:absolute;z-index:5;inset:0;background-color:#0003}}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "component", type: RSFooterComponent, selector: "rs-footer" }, { kind: "component", type: DrawerComponent, selector: "rs-drawer" }] });
|
|
18899
18934
|
}
|
|
18900
18935
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: MainContainerComponent, decorators: [{
|
|
18901
18936
|
type: Component,
|
|
18902
18937
|
args: [{ selector: "rs-main-container", template: "<div class=\"app-main-container\">\r\n <ng-content select=\"[headerSlot]\"></ng-content>\r\n <div class=\"main-page\">\r\n <div class=\"left-aside\">\r\n <ng-content select=\"[leftAsideSlot]\"></ng-content>\r\n </div>\r\n <div\r\n class=\"right-aside\"\r\n [ngClass]=\"{ isCollapsed: isCollapsed }\"\r\n (click)=\"onRightAsideClick()\"\r\n >\r\n <ng-content select=\"[multiTabSlot]\"></ng-content>\r\n <!-- <rs-multi-tab [singleReuseUrls]=\"singleReuseUrls\"></rs-multi-tab> -->\r\n <div class=\"router-content\">\r\n <rs-drawer #drawer>\r\n <ng-content select=\"[routerSlot]\"></ng-content>\r\n </rs-drawer>\r\n </div>\r\n <rs-footer></rs-footer>\r\n </div>\r\n </div>\r\n</div>\r\n", styles: [".app-main-container{display:flex;flex-direction:column;height:100vh}.app-main-container .main-page{flex:1;height:0;display:flex;background-color:var(--rs-container-bg)}.app-main-container .left-aside{height:100%}.app-main-container .right-aside{width:0;flex:1;display:flex;flex-direction:column;padding-right:12px}.app-main-container .right-aside .router-content{flex:1;overflow:auto;max-width:1886px;width:100%;margin:0 auto}@media (max-width: 992px){.app-main-container .right-aside.isCollapsed{position:relative}.app-main-container .right-aside.isCollapsed:after{content:\" \";position:absolute;z-index:5;inset:0;background-color:#0003}}\n"] }]
|
|
18903
|
-
}], ctorParameters: function () { return [{ type: DrawerService }]; }, propDecorators: { headerRef: [{
|
|
18938
|
+
}], ctorParameters: function () { return [{ type: DrawerService }, { type: i0.ElementRef }]; }, propDecorators: { headerRef: [{
|
|
18904
18939
|
type: ContentChild,
|
|
18905
18940
|
args: [RSHeaderComponent, { static: true }]
|
|
18941
|
+
}], multiTabRef: [{
|
|
18942
|
+
type: ContentChild,
|
|
18943
|
+
args: [MultiTabComponent, { static: true }]
|
|
18906
18944
|
}], drawer: [{
|
|
18907
18945
|
type: ViewChild,
|
|
18908
18946
|
args: ["drawer", { static: false }]
|
|
@@ -18910,6 +18948,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
18910
18948
|
type: Input
|
|
18911
18949
|
}], singleReuseUrls: [{
|
|
18912
18950
|
type: Input
|
|
18951
|
+
}], onWidthChange: [{
|
|
18952
|
+
type: Output
|
|
18913
18953
|
}], onResize: [{
|
|
18914
18954
|
type: HostListener,
|
|
18915
18955
|
args: ["window:resize", ["$event"]]
|