raise-common-lib 0.0.129 → 0.0.130
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/bundles/raise-common-lib.umd.js +68 -25
- package/bundles/raise-common-lib.umd.js.map +1 -1
- package/bundles/raise-common-lib.umd.min.js +1 -1
- package/bundles/raise-common-lib.umd.min.js.map +1 -1
- package/esm2015/lib/layout/multi-tab/index.component.js +64 -23
- package/esm2015/lib/layout/toolbar/index.component.js +2 -2
- package/esm5/lib/layout/multi-tab/index.component.js +68 -25
- package/esm5/lib/layout/toolbar/index.component.js +2 -2
- package/fesm2015/raise-common-lib.js +64 -23
- package/fesm2015/raise-common-lib.js.map +1 -1
- package/fesm5/raise-common-lib.js +68 -25
- package/fesm5/raise-common-lib.js.map +1 -1
- package/lib/layout/multi-tab/index.component.d.ts +2 -2
- package/package.json +1 -1
- package/raise-common-lib.metadata.json +1 -1
|
@@ -57,16 +57,6 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
57
57
|
*/
|
|
58
58
|
function () {
|
|
59
59
|
var _this = this;
|
|
60
|
-
this.subscriptions.push(this.cf.closeTab$.subscribe((/**
|
|
61
|
-
* @param {?} idx
|
|
62
|
-
* @return {?}
|
|
63
|
-
*/
|
|
64
|
-
function (idx) {
|
|
65
|
-
if (idx === undefined) {
|
|
66
|
-
idx = _this.selectedTab;
|
|
67
|
-
}
|
|
68
|
-
_this.closeTab(idx);
|
|
69
|
-
})));
|
|
70
60
|
this.initTab();
|
|
71
61
|
// 解决刷新页面后,选中的 tab 丢失问题
|
|
72
62
|
/** @type {?} */
|
|
@@ -75,7 +65,8 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
75
65
|
* @return {?}
|
|
76
66
|
*/
|
|
77
67
|
function (ele) {
|
|
78
|
-
return _this.urlWithoutQuery(ele.url) ===
|
|
68
|
+
return _this.urlWithoutQuery(ele.url) ===
|
|
69
|
+
_this.urlWithoutQuery(_this.router.url);
|
|
79
70
|
}));
|
|
80
71
|
if (isExistIdx !== -1) {
|
|
81
72
|
this.selectedTab = isExistIdx;
|
|
@@ -93,6 +84,18 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
93
84
|
/** @type {?} */
|
|
94
85
|
var navigation = _this.router.getCurrentNavigation();
|
|
95
86
|
if (navigation) {
|
|
87
|
+
/** @type {?} */
|
|
88
|
+
var tooltipElements = document.querySelectorAll(".e-popup-open");
|
|
89
|
+
// 删除tooltips
|
|
90
|
+
tooltipElements.forEach((/**
|
|
91
|
+
* @param {?} element
|
|
92
|
+
* @return {?}
|
|
93
|
+
*/
|
|
94
|
+
function (element) {
|
|
95
|
+
/** @type {?} */
|
|
96
|
+
var htmlElement = (/** @type {?} */ (element));
|
|
97
|
+
htmlElement.style.display = "none";
|
|
98
|
+
}));
|
|
96
99
|
/** @type {?} */
|
|
97
100
|
var state = navigation.extras.state;
|
|
98
101
|
// 获取传递的 state
|
|
@@ -106,12 +109,15 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
106
109
|
/** @type {?} */
|
|
107
110
|
var title = (state && state.title) ||
|
|
108
111
|
navigationInfo.title ||
|
|
109
|
-
navigationInfo.subTitle
|
|
112
|
+
navigationInfo.subTitle ||
|
|
113
|
+
navigationInfo.name;
|
|
114
|
+
/** @type {?} */
|
|
115
|
+
var noReused = (state && state.noReused) || false;
|
|
110
116
|
if (currentRoute && !skipLocationChange) {
|
|
111
117
|
if (_this.noGenerateTabUrls.includes(_this.urlWithoutQuery(_this.router.url))) {
|
|
112
118
|
return; // 排除不生成tab的url
|
|
113
119
|
}
|
|
114
|
-
_this.setTab(_this.router.url, currentRoute.snapshot.routeConfig.path, title);
|
|
120
|
+
_this.setTab(_this.router.url, currentRoute.snapshot.routeConfig.path, title, noReused);
|
|
115
121
|
}
|
|
116
122
|
}
|
|
117
123
|
})));
|
|
@@ -239,13 +245,15 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
239
245
|
};
|
|
240
246
|
/**
|
|
241
247
|
* @param {?} idx
|
|
248
|
+
* @param {?=} isExternal
|
|
242
249
|
* @return {?}
|
|
243
250
|
*/
|
|
244
251
|
MultiTabComponent.prototype.closeTab = /**
|
|
245
252
|
* @param {?} idx
|
|
253
|
+
* @param {?=} isExternal
|
|
246
254
|
* @return {?}
|
|
247
255
|
*/
|
|
248
|
-
function (idx) {
|
|
256
|
+
function (idx, isExternal) {
|
|
249
257
|
/** @type {?} */
|
|
250
258
|
var tab = this.tabList[idx];
|
|
251
259
|
this.tabList = this.tabList.filter((/**
|
|
@@ -254,11 +262,14 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
254
262
|
*/
|
|
255
263
|
function (ele) { return ele.url !== tab.url; }));
|
|
256
264
|
this.clearCache(this.urlWithoutQuery(tab.url));
|
|
257
|
-
if (this.selectedTab === idx) {
|
|
265
|
+
if (!isExternal && this.selectedTab === idx) {
|
|
258
266
|
/** @type {?} */
|
|
259
267
|
var targetIdx = Math.max(0, idx - 1);
|
|
260
268
|
this.changeTab(this.tabList[targetIdx], targetIdx);
|
|
261
269
|
}
|
|
270
|
+
if (idx < this.selectedTab) {
|
|
271
|
+
this.selectedTab = this.selectedTab - 1; // 如果关闭的tab在当前选中的tab之前,选中tab索引减1
|
|
272
|
+
}
|
|
262
273
|
this.setEllipsisTitle();
|
|
263
274
|
sessionStorage.setItem("TabCache", JSON.stringify(this.tabList));
|
|
264
275
|
this.ref.markForCheck();
|
|
@@ -275,6 +286,15 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
275
286
|
*/
|
|
276
287
|
function (tab, idx) {
|
|
277
288
|
this.router.navigateByUrl(tab.url);
|
|
289
|
+
if (tab.navigationInfo) {
|
|
290
|
+
sessionStorage.setItem("navigationInfo", JSON.stringify(tab.navigationInfo));
|
|
291
|
+
}
|
|
292
|
+
if (tab.fromUrl) {
|
|
293
|
+
sessionStorage.setItem("fromUrl", tab.fromUrl);
|
|
294
|
+
}
|
|
295
|
+
if (tab.permissions) {
|
|
296
|
+
sessionStorage.setItem("permissions", JSON.stringify(tab.permissions));
|
|
297
|
+
}
|
|
278
298
|
this.selectedTab = idx;
|
|
279
299
|
this.ref.markForCheck();
|
|
280
300
|
};
|
|
@@ -290,12 +310,24 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
290
310
|
*/
|
|
291
311
|
function (url, title) {
|
|
292
312
|
if (this.tabList.length >= this.maxTabs) {
|
|
293
|
-
this.closeTab(
|
|
313
|
+
this.closeTab(1); // 删除第二个,第一个固定
|
|
294
314
|
}
|
|
315
|
+
/** @type {?} */
|
|
316
|
+
var localPermissions = sessionStorage.getItem("permissions") ||
|
|
317
|
+
localStorage.getItem("permissions");
|
|
318
|
+
/** @type {?} */
|
|
319
|
+
var navigationInfo = JSON.parse(sessionStorage.getItem("navigationInfo"));
|
|
320
|
+
/** @type {?} */
|
|
321
|
+
var fromUrl = sessionStorage.getItem("fromUrl");
|
|
322
|
+
/** @type {?} */
|
|
323
|
+
var permissions = JSON.parse(localPermissions);
|
|
295
324
|
this.tabList.push({
|
|
296
325
|
url: url,
|
|
297
326
|
title: title || "default",
|
|
298
327
|
displayTitle: title,
|
|
328
|
+
navigationInfo: navigationInfo,
|
|
329
|
+
permissions: permissions,
|
|
330
|
+
fromUrl: fromUrl,
|
|
299
331
|
});
|
|
300
332
|
this.selectedTab = this.tabList.length - 1;
|
|
301
333
|
this.setEllipsisTitle();
|
|
@@ -304,17 +336,19 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
304
336
|
};
|
|
305
337
|
/**
|
|
306
338
|
* @param {?} url
|
|
307
|
-
* @param {
|
|
308
|
-
* @param {
|
|
339
|
+
* @param {?} pureUrl
|
|
340
|
+
* @param {?} title
|
|
341
|
+
* @param {?} noReused
|
|
309
342
|
* @return {?}
|
|
310
343
|
*/
|
|
311
344
|
MultiTabComponent.prototype.setTab = /**
|
|
312
345
|
* @param {?} url
|
|
313
|
-
* @param {
|
|
314
|
-
* @param {
|
|
346
|
+
* @param {?} pureUrl
|
|
347
|
+
* @param {?} title
|
|
348
|
+
* @param {?} noReused
|
|
315
349
|
* @return {?}
|
|
316
350
|
*/
|
|
317
|
-
function (url, pureUrl, title) {
|
|
351
|
+
function (url, pureUrl, title, noReused) {
|
|
318
352
|
var _this = this;
|
|
319
353
|
/** @type {?} */
|
|
320
354
|
var isExistIdx = this.tabList.findIndex((/**
|
|
@@ -341,7 +375,16 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
341
375
|
this.addTab(url, title);
|
|
342
376
|
}
|
|
343
377
|
else {
|
|
344
|
-
|
|
378
|
+
/** @type {?} */
|
|
379
|
+
var targetTabUrl = this.tabList[isExistIdx].url;
|
|
380
|
+
if (targetTabUrl !== url || noReused) {
|
|
381
|
+
// 当缓存一致时候,但是url不一致,重新按照新的url生成tab
|
|
382
|
+
this.closeTab(isExistIdx, true);
|
|
383
|
+
this.addTab(url, title);
|
|
384
|
+
}
|
|
385
|
+
else {
|
|
386
|
+
this.changeTab(this.tabList[isExistIdx], isExistIdx);
|
|
387
|
+
}
|
|
345
388
|
this.ref.markForCheck();
|
|
346
389
|
}
|
|
347
390
|
};
|
|
@@ -404,8 +447,8 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
404
447
|
MultiTabComponent.decorators = [
|
|
405
448
|
{ type: Component, args: [{
|
|
406
449
|
selector: "rs-multi-tab",
|
|
407
|
-
template: "<div class=\"rs-multi-tab\" [ngClass]=\"{ 'b-line': tabList.length > 0 }\">\r\n
|
|
408
|
-
styles: [".rs-multi-tab{width:100%;display:flex;justify-content:space-between;margin:0 auto;max-width:1886px}.rs-multi-tab.b-line{border-bottom:1px solid #e5eaef}.rs-multi-tab ul{display:flex;margin:0 8px;padding:0;overflow:hidden;height:100%}.rs-multi-tab ul li{max-width:164px;padding:0 12px;display:flex;align-items:center;flex:auto;border:1px solid #e5eaef;border-bottom:none;color:#5f6f81;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:28px;height:28px;background:#f8fafb;vertical-align:top;position:relative;cursor:default}.rs-multi-tab ul li .tabTitle{display:inline-block;white-space:nowrap;font-size:11px;font-family:Arial;font-style:normal;font-weight:400;line-height:16px;transition:width .3s}.rs-multi-tab ul li img{border-radius:4px;padding:4px;margin-left:6px;margin-top:1px;vertical-align:top;cursor:pointer}.rs-multi-tab ul li img:hover{background:#dce8f6}.rs-multi-tab ul li:not(:last-child){border-right:none}.rs-multi-tab ul li:first-of-type{border-top-left-radius:8px}.rs-multi-tab ul li:last-child{border-top-right-radius:8px}.rs-multi-tab ul .isSelect{color:#1f3f5c;background:#fff}.rs-multi-tab ul .notSelect img{display:none}.rs-multi-tab ul .notSelect .img-block{display:inline-block;width:22px}.rs-multi-tab ul .notSelect:hover{color:#1f3f5c;background-color:rgba(31,123,255,.04)}.rs-multi-tab ul .notSelect:hover .img-block{display:none}.rs-multi-tab ul .notSelect:hover img{display:inline-block}.rs-multi-tab .refresh-tab{cursor:pointer;text-align:right;color:#6c7c90;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:28px;padding-right:12px}.rs-multi-tab .refresh-tab img{vertical-align:middle;margin-right:4px}.refresh-tab-loading{-webkit-animation:1s linear infinite spin;animation:1s linear infinite spin}@-webkit-keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.tooltip-content{padding:4px;color:#f8fafb;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:14px}@media (max-width:1400px){.refresh-tab{padding-right:0!important}.refresh-tab span{display:none!important}}@media (max-width:1100px){.rs-multi-tab ul li img{position:absolute;right:3px;background-color:#fff}.notSelect:hover img{position:absolute;right:3px;background-color:#eff5fb}.img-block{display:none!important}}@media (max-width:600px){.rs-multi-tab ul li{padding:0 8px}.rs-multi-tab ul .notSelect .img-block{width:0!important}}"]
|
|
450
|
+
template: "<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",
|
|
451
|
+
styles: [".rs-multi-tab{width:100%;display:flex;justify-content:space-between;margin:0 auto;max-width:1886px}.rs-multi-tab.b-line{border-bottom:1px solid #e5eaef}.rs-multi-tab ul{display:flex;margin:0 8px;padding:0;overflow:hidden;height:100%}.rs-multi-tab ul li{max-width:164px;padding:0 12px;display:flex;align-items:center;flex:auto;border:1px solid #e5eaef;border-bottom:none;color:#5f6f81;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:28px;height:28px;background:#f8fafb;vertical-align:top;position:relative;cursor:default}.rs-multi-tab ul li .tabTitle{display:inline-block;white-space:nowrap;font-size:11px;font-family:Arial;font-style:normal;font-weight:400;line-height:16px;transition:width .3s}.rs-multi-tab ul li img{border-radius:4px;padding:4px;margin-left:6px;margin-top:1px;vertical-align:top;cursor:pointer}.rs-multi-tab ul li img:hover{background:#dce8f6}.rs-multi-tab ul li:not(:last-child){border-right:none}.rs-multi-tab ul li:first-of-type{border-top-left-radius:8px}.rs-multi-tab ul li:last-child{border-top-right-radius:8px}.rs-multi-tab ul .isSelect{color:#1f3f5c;background:#fff}.rs-multi-tab ul .notSelect img{display:none}.rs-multi-tab ul .notSelect .img-block{display:inline-block;width:22px}.rs-multi-tab ul .notSelect:hover{color:#1f3f5c;background-color:rgba(31,123,255,.04)}.rs-multi-tab ul .notSelect:hover .img-block{display:none}.rs-multi-tab ul .notSelect:hover img{display:inline-block}.rs-multi-tab .refresh-tab{cursor:pointer;text-align:right;color:#6c7c90;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:28px;padding-right:12px}.rs-multi-tab .refresh-tab img{vertical-align:middle;margin-right:4px}.refresh-tab-loading{-webkit-animation:1s linear infinite spin;animation:1s linear infinite spin}.notSelectTooltip{transform:translateX(-12px)}@-webkit-keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.tooltip-content{padding:4px;color:#f8fafb;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:14px}@media (max-width:1400px){.refresh-tab{padding-right:0!important}.refresh-tab span{display:none!important}}@media (max-width:1100px){.rs-multi-tab ul li img{position:absolute;right:3px;background-color:#fff}.notSelect:hover img{position:absolute;right:3px;background-color:#eff5fb}.img-block{display:none!important}.isSelect:not(:first-child){padding-right:20px!important}}@media (max-width:600px){.rs-multi-tab ul li{padding:0 8px}.rs-multi-tab ul .notSelect .img-block{width:0!important}}"]
|
|
409
452
|
}] }
|
|
410
453
|
];
|
|
411
454
|
/** @nocollapse */
|
|
@@ -484,4 +527,4 @@ if (false) {
|
|
|
484
527
|
*/
|
|
485
528
|
MultiTabComponent.prototype.routeReuseStrategy;
|
|
486
529
|
}
|
|
487
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.component.js","sourceRoot":"ng://raise-common-lib/","sources":["lib/layout/multi-tab/index.component.ts"],"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.subscriptions.push(\r\n      this.cf.closeTab$.subscribe((idx) => {\r\n        if (idx === undefined) {\r\n          idx = this.selectedTab;\r\n        }\r\n        this.closeTab(idx);\r\n      })\r\n    );\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 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            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              );\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) {\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 (this.selectedTab === idx) {\r\n      const targetIdx = Math.max(0, idx - 1);\r\n      this.changeTab(this.tabList[targetIdx], targetIdx);\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    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(0); // 删除第一个\r\n    }\r\n    this.tabList.push({\r\n      url: url,\r\n      title: title || \"default\",\r\n      displayTitle: title,\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?) {\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      this.selectedTab = isExistIdx;\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"]}
|
|
530
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"index.component.js","sourceRoot":"ng://raise-common-lib/","sources":["lib/layout/multi-tab/index.component.ts"],"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\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\tprivate urlWithoutQuery(url) {\r\n\t\treturn url.split(\"?\")[0];\r\n\t}\r\n}\r\n"]}
|
|
@@ -78,7 +78,7 @@ var RSToolbarComponent = /** @class */ (function () {
|
|
|
78
78
|
RSToolbarComponent.decorators = [
|
|
79
79
|
{ type: Component, args: [{
|
|
80
80
|
selector: "rs-toolbar",
|
|
81
|
-
template: "<div #toolbarContainer class=\"rs-toolbar-container\">\r\n <!-- \u53EF\u89C1\u6309\u94AE -->\r\n <ng-container *ngFor=\"let button of buttons\">\r\n <div class=\"temp-hidden\" #toolbarItem>\r\n <rs-toolbar-item\r\n [image]=\"button.image\"\r\n [text]=\"button.text\"\r\n [disabled]=\"(button.key && disabledOptions[button.key]) || false\"\r\n (click)=\"button.action && button.action()\"\r\n [children]=\"button.children || []\"\r\n [disabledOptions]=\"disabledOptions\"\r\n >\r\n </rs-toolbar-item>\r\n </div>\r\n </ng-container>\r\n\r\n <!-- \u4E0B\u62C9\u83DC\u5355\uFF08\u5982\u679C\u6709\u9690\u85CF\u6309\u94AE\uFF09 -->\r\n <button\r\n *ngIf=\"hiddenButtons.length > 0\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n #menuTrigger=\"matMenuTrigger\"\r\n class=\"action-toggle\"\r\n >\r\n <mat-icon svgIcon=\"more\"></mat-icon>\r\n </button>\r\n\r\n <mat-menu #menu=\"matMenu\">\r\n <ng-container *ngFor=\"let button of hiddenButtons\">\r\n <rs-toolbar-item\r\n [image]=\"button.image\"\r\n [text]=\"button.text\"\r\n (click)=\"button.action && button.action()\"\r\n [disabled]=\"disabledOptions[button.key] || false\"\r\n [children]=\"button.children || []\"\r\n >\r\n </rs-toolbar-item>\r\n </ng-container>\r\n </mat-menu>\r\n</div>\r\n",
|
|
81
|
+
template: "<div #toolbarContainer class=\"rs-toolbar-container\">\r\n <!-- \u53EF\u89C1\u6309\u94AE -->\r\n <ng-container *ngFor=\"let button of buttons\">\r\n <div class=\"temp-hidden\" #toolbarItem>\r\n <rs-toolbar-item\r\n [image]=\"button.image\"\r\n [text]=\"button.text\"\r\n [disabled]=\"(button.key && disabledOptions[button.key]) || false\"\r\n (click)=\"button.action && button.action()\"\r\n [children]=\"button.children || []\"\r\n [disabledOptions]=\"disabledOptions\"\r\n >\r\n </rs-toolbar-item>\r\n </div>\r\n </ng-container>\r\n\r\n <!-- \u4E0B\u62C9\u83DC\u5355\uFF08\u5982\u679C\u6709\u9690\u85CF\u6309\u94AE\uFF09 -->\r\n <button\r\n *ngIf=\"hiddenButtons.length > 0\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n #menuTrigger=\"matMenuTrigger\"\r\n class=\"action-toggle\"\r\n >\r\n <mat-icon svgIcon=\"more\"></mat-icon>\r\n </button>\r\n\r\n <mat-menu #menu=\"matMenu\">\r\n <ng-container *ngFor=\"let button of hiddenButtons\">\r\n <rs-toolbar-item\r\n [image]=\"button.image\"\r\n [text]=\"button.text\"\r\n (click)=\"button.action && button.action()\"\r\n [disabled]=\"disabledOptions[button.key] || false\"\r\n [children]=\"button.children || []\"\r\n [disabledOptions]=\"disabledOptions\"\r\n >\r\n </rs-toolbar-item>\r\n </ng-container>\r\n </mat-menu>\r\n</div>\r\n",
|
|
82
82
|
styles: [":host{display:block;width:100%}.rs-toolbar-container{width:100%;display:flex;align-items:center}.rs-toolbar-container .temp-hidden{visibility:hidden;position:absolute}.rs-toolbar-container .action-toggle{width:24px;height:24px;min-width:24px;max-width:24px;padding:0;border-radius:4px;display:flex;flex-flow:row nowrap;justify-content:center;align-items:center;background:0 0}.rs-toolbar-container .action-toggle:hover{background:rgba(214,227,245,.2)}.rs-toolbar-container .action-toggle .mat-button-wrapper{max-height:24px;height:24px}.rs-toolbar-container .action-toggle ::ng-deep .mat-icon{width:16px;height:16px;display:flex;flex-flow:row nowrap;justify-content:center;align-items:center}"]
|
|
83
83
|
}] }
|
|
84
84
|
];
|
|
@@ -118,4 +118,4 @@ if (false) {
|
|
|
118
118
|
*/
|
|
119
119
|
RSToolbarComponent.prototype.ref;
|
|
120
120
|
}
|
|
121
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
121
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6Im5nOi8vcmFpc2UtY29tbW9uLWxpYi8iLCJzb3VyY2VzIjpbImxpYi9sYXlvdXQvdG9vbGJhci9pbmRleC5jb21wb25lbnQudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7O0FBQ0EsT0FBTyxFQUVMLGlCQUFpQixFQUNqQixTQUFTLEVBQ1QsVUFBVSxFQUVWLFlBQVksRUFDWixLQUFLLEVBR0wsU0FBUyxFQUNULFNBQVMsRUFDVCxZQUFZLEdBQ2IsTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLE1BQU0sRUFBRSxNQUFNLGlCQUFpQixDQUFDO0FBR3pDO0lBY0UsNEJBQW1CLE1BQWMsRUFBVSxHQUFzQjtRQUE5QyxXQUFNLEdBQU4sTUFBTSxDQUFRO1FBQVUsUUFBRyxHQUFILEdBQUcsQ0FBbUI7UUFSeEQsWUFBTyxHQUFvQixFQUFFLENBQUM7UUFDOUIsb0JBQWUsR0FBMkIsRUFBRSxDQUFDO1FBWXRELG1CQUFjLEdBQW9CLEVBQUUsQ0FBQztRQUNyQyxrQkFBYSxHQUFvQixFQUFFLENBQUM7SUFOZ0MsQ0FBQzs7OztJQUNyRSw0Q0FBZTs7O0lBQWY7UUFDRSxJQUFJLENBQUMsc0JBQXNCLEVBQUUsQ0FBQztJQUNoQyxDQUFDOzs7O0lBS00sbURBQXNCOzs7SUFBN0I7UUFDRSxJQUFJLENBQUMsSUFBSSxDQUFDLGdCQUFnQixJQUFJLENBQUMsSUFBSSxDQUFDLGNBQWM7WUFBRSxPQUFPOztZQUVyRCxVQUFVLEdBQUcsSUFBSSxDQUFDLGNBQWMsQ0FBQyxPQUFPLEVBQUU7O1lBQzFDLGNBQWMsR0FBRyxJQUFJLENBQUMsZ0JBQWdCLENBQUMsYUFBYSxDQUFDLFdBQVcsR0FBRyxFQUFFOzs7WUFFdkUsVUFBVSxHQUFHLENBQUM7O1lBQ1osZUFBZSxHQUFHLEVBQUU7UUFFMUIsSUFBSSxDQUFDLGNBQWMsR0FBRyxFQUFFLENBQUM7UUFDekIsSUFBSSxDQUFDLGFBQWEsR0FBRyxFQUFFLENBQUM7UUFFeEIsS0FBSyxJQUFJLENBQUMsR0FBRyxDQUFDLEVBQUUsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxNQUFNLEVBQUUsQ0FBQyxFQUFFLEVBQUU7O2dCQUNwQyxXQUFXLEdBQ2YsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxxQkFBcUIsRUFBRSxDQUFDLEtBQUs7WUFDM0QsMkNBQTJDO1lBQzNDLElBQ0UsVUFBVTtnQkFDUixDQUFDLEdBQUcsNkJBQTZCO2dCQUNqQyxXQUFXO2dCQUNYLENBQUMsQ0FBQyxHQUFHLFVBQVUsQ0FBQyxNQUFNLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxlQUFlLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDbkQsY0FBYyxFQUNkO2dCQUNBLElBQUksQ0FBQyxjQUFjLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxPQUFPLENBQUMsQ0FBQyxDQUFDLENBQUMsQ0FBQztnQkFDMUMsVUFBVSxDQUFDLENBQUMsQ0FBQyxDQUFDLGFBQWEsQ0FBQyxTQUFTLENBQUMsTUFBTSxDQUFDLGFBQWEsQ0FBQyxDQUFDO2dCQUM1RCxVQUFVLElBQUksV0FBVyxDQUFDO2FBQzNCO2lCQUFNO2dCQUNMLFVBQVUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxhQUFhLENBQUMsU0FBUyxDQUFDLEdBQUcsQ0FBQyxhQUFhLENBQUMsQ0FBQztnQkFDekQsSUFBSSxDQUFDLGFBQWEsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLE9BQU8sQ0FBQyxDQUFDLENBQUMsQ0FBQyxDQUFDO2FBQzFDO1NBQ0Y7UUFDRCxzREFBc0Q7UUFDdEQsb0RBQW9EO1FBQ3BELElBQUksQ0FBQyxHQUFHLENBQUMsYUFBYSxFQUFFLENBQUM7SUFDM0IsQ0FBQzs7OztJQUdELDJDQUFjOzs7SUFEZDtRQUVFLElBQUksQ0FBQyxzQkFBc0IsRUFBRSxDQUFDO0lBQ2hDLENBQUM7O2dCQTdERixTQUFTLFNBQUM7b0JBQ1QsUUFBUSxFQUFFLFlBQVk7b0JBQ3RCLGc3Q0FBcUM7O2lCQUV0Qzs7OztnQkFQUSxNQUFNO2dCQVpiLGlCQUFpQjs7OzBCQXFCaEIsS0FBSztrQ0FDTCxLQUFLO21DQUVMLFNBQVMsU0FBQyxrQkFBa0IsRUFBRSxFQUFFLE1BQU0sRUFBRSxLQUFLLEVBQUU7aUNBRy9DLFlBQVksU0FBQyxhQUFhO2lDQThDMUIsWUFBWSxTQUFDLGVBQWU7O0lBSS9CLHlCQUFDO0NBQUEsQUE5REQsSUE4REM7U0F6RFksa0JBQWtCOzs7SUFDN0IscUNBQXVDOztJQUN2Qyw2Q0FBc0Q7O0lBRXRELDhDQUM4Qjs7SUFFOUIsNENBQW9FOztJQU9wRSw0Q0FBcUM7O0lBQ3JDLDJDQUFvQzs7SUFOeEIsb0NBQXFCOzs7OztJQUFFLGlDQUE4QiIsInNvdXJjZXNDb250ZW50IjpbIi8vIOe7hOS7tuexu1xyXG5pbXBvcnQge1xyXG4gIEFmdGVyVmlld0luaXQsXHJcbiAgQ2hhbmdlRGV0ZWN0b3JSZWYsXHJcbiAgQ29tcG9uZW50LFxyXG4gIEVsZW1lbnRSZWYsXHJcbiAgRXZlbnRFbWl0dGVyLFxyXG4gIEhvc3RMaXN0ZW5lcixcclxuICBJbnB1dCxcclxuICBPbkluaXQsXHJcbiAgT3V0cHV0LFxyXG4gIFF1ZXJ5TGlzdCxcclxuICBWaWV3Q2hpbGQsXHJcbiAgVmlld0NoaWxkcmVuLFxyXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IFJvdXRlciB9IGZyb20gXCJAYW5ndWxhci9yb3V0ZXJcIjtcclxuaW1wb3J0IHsgVG9vbGJhckJ1dHRvbiB9IGZyb20gXCIuL2NvbnN0YW50c1wiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwicnMtdG9vbGJhclwiLFxyXG4gIHRlbXBsYXRlVXJsOiBcIi4vaW5kZXguY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vaW5kZXguY29tcG9uZW50LnNjc3NcIl0sXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBSU1Rvb2xiYXJDb21wb25lbnQgaW1wbGVtZW50cyBBZnRlclZpZXdJbml0IHtcclxuICBASW5wdXQoKSBidXR0b25zOiBUb29sYmFyQnV0dG9uW10gPSBbXTtcclxuICBASW5wdXQoKSBkaXNhYmxlZE9wdGlvbnM6IHsgW2tleTogc3RyaW5nXTogYW55IH0gPSB7fTtcclxuXHJcbiAgQFZpZXdDaGlsZChcInRvb2xiYXJDb250YWluZXJcIiwgeyBzdGF0aWM6IGZhbHNlIH0pXHJcbiAgdG9vbGJhckNvbnRhaW5lciE6IEVsZW1lbnRSZWY7XHJcblxyXG4gIEBWaWV3Q2hpbGRyZW4oXCJ0b29sYmFySXRlbVwiKSBidXR0b25FbGVtZW50cyE6IFF1ZXJ5TGlzdDxFbGVtZW50UmVmPjtcclxuXHJcbiAgY29uc3RydWN0b3IocHVibGljIHJvdXRlcjogUm91dGVyLCBwcml2YXRlIHJlZjogQ2hhbmdlRGV0ZWN0b3JSZWYpIHt9XHJcbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xyXG4gICAgdGhpcy51cGRhdGVCdXR0b25WaXNpYmlsaXR5KCk7XHJcbiAgfVxyXG5cclxuICB2aXNpYmxlQnV0dG9uczogVG9vbGJhckJ1dHRvbltdID0gW107XHJcbiAgaGlkZGVuQnV0dG9uczogVG9vbGJhckJ1dHRvbltdID0gW107XHJcblxyXG4gIHB1YmxpYyB1cGRhdGVCdXR0b25WaXNpYmlsaXR5KCk6IHZvaWQge1xyXG4gICAgaWYgKCF0aGlzLnRvb2xiYXJDb250YWluZXIgfHwgIXRoaXMuYnV0dG9uRWxlbWVudHMpIHJldHVybjtcclxuXHJcbiAgICBjb25zdCBidXR0b25SZWZzID0gdGhpcy5idXR0b25FbGVtZW50cy50b0FycmF5KCk7XHJcbiAgICBjb25zdCBjb250YWluZXJXaWR0aCA9IHRoaXMudG9vbGJhckNvbnRhaW5lci5uYXRpdmVFbGVtZW50Lm9mZnNldFdpZHRoIC0gNTA7XHJcbiAgICAvLyBjb25zb2xlLmxvZyhcImNvbnRhaW5lcldpZHRoXCIsIGNvbnRhaW5lcldpZHRoKTtcclxuICAgIGxldCB0b3RhbFdpZHRoID0gMDtcclxuICAgIGNvbnN0IG1lbnVCdXR0b25XaWR0aCA9IDYwO1xyXG5cclxuICAgIHRoaXMudmlzaWJsZUJ1dHRvbnMgPSBbXTtcclxuICAgIHRoaXMuaGlkZGVuQnV0dG9ucyA9IFtdO1xyXG5cclxuICAgIGZvciAobGV0IGkgPSAwOyBpIDwgYnV0dG9uUmVmcy5sZW5ndGg7IGkrKykge1xyXG4gICAgICBjb25zdCBidXR0b25XaWR0aCA9XHJcbiAgICAgICAgYnV0dG9uUmVmc1tpXS5uYXRpdmVFbGVtZW50LmdldEJvdW5kaW5nQ2xpZW50UmVjdCgpLndpZHRoO1xyXG4gICAgICAvLyBjb25zb2xlLmxvZyhcImJ1dHRvbldpZHRoXCIsIGJ1dHRvbldpZHRoKTtcclxuICAgICAgaWYgKFxyXG4gICAgICAgIHRvdGFsV2lkdGggK1xyXG4gICAgICAgICAgNCArIC8vIDRweCBtYXJnaW4gYmV0d2VlbiBidXR0b25zXHJcbiAgICAgICAgICBidXR0b25XaWR0aCArXHJcbiAgICAgICAgICAoaSA8IGJ1dHRvblJlZnMubGVuZ3RoIC0gMSA/IG1lbnVCdXR0b25XaWR0aCA6IDApIDw9XHJcbiAgICAgICAgY29udGFpbmVyV2lkdGhcclxuICAgICAgKSB7XHJcbiAgICAgICAgdGhpcy52aXNpYmxlQnV0dG9ucy5wdXNoKHRoaXMuYnV0dG9uc1tpXSk7XHJcbiAgICAgICAgYnV0dG9uUmVmc1tpXS5uYXRpdmVFbGVtZW50LmNsYXNzTGlzdC5yZW1vdmUoXCJ0ZW1wLWhpZGRlblwiKTtcclxuICAgICAgICB0b3RhbFdpZHRoICs9IGJ1dHRvbldpZHRoO1xyXG4gICAgICB9IGVsc2Uge1xyXG4gICAgICAgIGJ1dHRvblJlZnNbaV0ubmF0aXZlRWxlbWVudC5jbGFzc0xpc3QuYWRkKFwidGVtcC1oaWRkZW5cIik7XHJcbiAgICAgICAgdGhpcy5oaWRkZW5CdXR0b25zLnB1c2godGhpcy5idXR0b25zW2ldKTtcclxuICAgICAgfVxyXG4gICAgfVxyXG4gICAgLy8gY29uc29sZS5sb2coXCJ2aXNpYmxlQnV0dG9uc1wiLCB0aGlzLnZpc2libGVCdXR0b25zKTtcclxuICAgIC8vIGNvbnNvbGUubG9nKFwiaGlkZGVuQnV0dG9uc1wiLCB0aGlzLmhpZGRlbkJ1dHRvbnMpO1xyXG4gICAgdGhpcy5yZWYuZGV0ZWN0Q2hhbmdlcygpO1xyXG4gIH1cclxuXHJcbiAgQEhvc3RMaXN0ZW5lcihcIndpbmRvdzpyZXNpemVcIilcclxuICBvbldpbmRvd1Jlc2l6ZSgpIHtcclxuICAgIHRoaXMudXBkYXRlQnV0dG9uVmlzaWJpbGl0eSgpO1xyXG4gIH1cclxufVxyXG4iXX0=
|
|
@@ -2577,16 +2577,6 @@ class MultiTabComponent {
|
|
|
2577
2577
|
* @return {?}
|
|
2578
2578
|
*/
|
|
2579
2579
|
ngOnInit() {
|
|
2580
|
-
this.subscriptions.push(this.cf.closeTab$.subscribe((/**
|
|
2581
|
-
* @param {?} idx
|
|
2582
|
-
* @return {?}
|
|
2583
|
-
*/
|
|
2584
|
-
(idx) => {
|
|
2585
|
-
if (idx === undefined) {
|
|
2586
|
-
idx = this.selectedTab;
|
|
2587
|
-
}
|
|
2588
|
-
this.closeTab(idx);
|
|
2589
|
-
})));
|
|
2590
2580
|
this.initTab();
|
|
2591
2581
|
// 解决刷新页面后,选中的 tab 丢失问题
|
|
2592
2582
|
/** @type {?} */
|
|
@@ -2594,7 +2584,8 @@ class MultiTabComponent {
|
|
|
2594
2584
|
* @param {?} ele
|
|
2595
2585
|
* @return {?}
|
|
2596
2586
|
*/
|
|
2597
|
-
(ele) => this.urlWithoutQuery(ele.url) ===
|
|
2587
|
+
(ele) => this.urlWithoutQuery(ele.url) ===
|
|
2588
|
+
this.urlWithoutQuery(this.router.url)));
|
|
2598
2589
|
if (isExistIdx !== -1) {
|
|
2599
2590
|
this.selectedTab = isExistIdx;
|
|
2600
2591
|
}
|
|
@@ -2611,6 +2602,18 @@ class MultiTabComponent {
|
|
|
2611
2602
|
/** @type {?} */
|
|
2612
2603
|
const navigation = this.router.getCurrentNavigation();
|
|
2613
2604
|
if (navigation) {
|
|
2605
|
+
/** @type {?} */
|
|
2606
|
+
const tooltipElements = document.querySelectorAll(".e-popup-open");
|
|
2607
|
+
// 删除tooltips
|
|
2608
|
+
tooltipElements.forEach((/**
|
|
2609
|
+
* @param {?} element
|
|
2610
|
+
* @return {?}
|
|
2611
|
+
*/
|
|
2612
|
+
(element) => {
|
|
2613
|
+
/** @type {?} */
|
|
2614
|
+
const htmlElement = (/** @type {?} */ (element));
|
|
2615
|
+
htmlElement.style.display = "none";
|
|
2616
|
+
}));
|
|
2614
2617
|
/** @type {?} */
|
|
2615
2618
|
const state = navigation.extras.state;
|
|
2616
2619
|
// 获取传递的 state
|
|
@@ -2624,12 +2627,15 @@ class MultiTabComponent {
|
|
|
2624
2627
|
/** @type {?} */
|
|
2625
2628
|
let title = (state && state.title) ||
|
|
2626
2629
|
navigationInfo.title ||
|
|
2627
|
-
navigationInfo.subTitle
|
|
2630
|
+
navigationInfo.subTitle ||
|
|
2631
|
+
navigationInfo.name;
|
|
2632
|
+
/** @type {?} */
|
|
2633
|
+
let noReused = (state && state.noReused) || false;
|
|
2628
2634
|
if (currentRoute && !skipLocationChange) {
|
|
2629
2635
|
if (this.noGenerateTabUrls.includes(this.urlWithoutQuery(this.router.url))) {
|
|
2630
2636
|
return; // 排除不生成tab的url
|
|
2631
2637
|
}
|
|
2632
|
-
this.setTab(this.router.url, currentRoute.snapshot.routeConfig.path, title);
|
|
2638
|
+
this.setTab(this.router.url, currentRoute.snapshot.routeConfig.path, title, noReused);
|
|
2633
2639
|
}
|
|
2634
2640
|
}
|
|
2635
2641
|
})));
|
|
@@ -2739,9 +2745,10 @@ class MultiTabComponent {
|
|
|
2739
2745
|
}
|
|
2740
2746
|
/**
|
|
2741
2747
|
* @param {?} idx
|
|
2748
|
+
* @param {?=} isExternal
|
|
2742
2749
|
* @return {?}
|
|
2743
2750
|
*/
|
|
2744
|
-
closeTab(idx) {
|
|
2751
|
+
closeTab(idx, isExternal) {
|
|
2745
2752
|
/** @type {?} */
|
|
2746
2753
|
const tab = this.tabList[idx];
|
|
2747
2754
|
this.tabList = this.tabList.filter((/**
|
|
@@ -2750,11 +2757,14 @@ class MultiTabComponent {
|
|
|
2750
2757
|
*/
|
|
2751
2758
|
(ele) => ele.url !== tab.url));
|
|
2752
2759
|
this.clearCache(this.urlWithoutQuery(tab.url));
|
|
2753
|
-
if (this.selectedTab === idx) {
|
|
2760
|
+
if (!isExternal && this.selectedTab === idx) {
|
|
2754
2761
|
/** @type {?} */
|
|
2755
2762
|
const targetIdx = Math.max(0, idx - 1);
|
|
2756
2763
|
this.changeTab(this.tabList[targetIdx], targetIdx);
|
|
2757
2764
|
}
|
|
2765
|
+
if (idx < this.selectedTab) {
|
|
2766
|
+
this.selectedTab = this.selectedTab - 1; // 如果关闭的tab在当前选中的tab之前,选中tab索引减1
|
|
2767
|
+
}
|
|
2758
2768
|
this.setEllipsisTitle();
|
|
2759
2769
|
sessionStorage.setItem("TabCache", JSON.stringify(this.tabList));
|
|
2760
2770
|
this.ref.markForCheck();
|
|
@@ -2766,6 +2776,15 @@ class MultiTabComponent {
|
|
|
2766
2776
|
*/
|
|
2767
2777
|
changeTab(tab, idx) {
|
|
2768
2778
|
this.router.navigateByUrl(tab.url);
|
|
2779
|
+
if (tab.navigationInfo) {
|
|
2780
|
+
sessionStorage.setItem("navigationInfo", JSON.stringify(tab.navigationInfo));
|
|
2781
|
+
}
|
|
2782
|
+
if (tab.fromUrl) {
|
|
2783
|
+
sessionStorage.setItem("fromUrl", tab.fromUrl);
|
|
2784
|
+
}
|
|
2785
|
+
if (tab.permissions) {
|
|
2786
|
+
sessionStorage.setItem("permissions", JSON.stringify(tab.permissions));
|
|
2787
|
+
}
|
|
2769
2788
|
this.selectedTab = idx;
|
|
2770
2789
|
this.ref.markForCheck();
|
|
2771
2790
|
}
|
|
@@ -2776,12 +2795,24 @@ class MultiTabComponent {
|
|
|
2776
2795
|
*/
|
|
2777
2796
|
addTab(url, title) {
|
|
2778
2797
|
if (this.tabList.length >= this.maxTabs) {
|
|
2779
|
-
this.closeTab(
|
|
2798
|
+
this.closeTab(1); // 删除第二个,第一个固定
|
|
2780
2799
|
}
|
|
2800
|
+
/** @type {?} */
|
|
2801
|
+
const localPermissions = sessionStorage.getItem("permissions") ||
|
|
2802
|
+
localStorage.getItem("permissions");
|
|
2803
|
+
/** @type {?} */
|
|
2804
|
+
const navigationInfo = JSON.parse(sessionStorage.getItem("navigationInfo"));
|
|
2805
|
+
/** @type {?} */
|
|
2806
|
+
const fromUrl = sessionStorage.getItem("fromUrl");
|
|
2807
|
+
/** @type {?} */
|
|
2808
|
+
const permissions = JSON.parse(localPermissions);
|
|
2781
2809
|
this.tabList.push({
|
|
2782
2810
|
url: url,
|
|
2783
2811
|
title: title || "default",
|
|
2784
2812
|
displayTitle: title,
|
|
2813
|
+
navigationInfo: navigationInfo,
|
|
2814
|
+
permissions: permissions,
|
|
2815
|
+
fromUrl: fromUrl,
|
|
2785
2816
|
});
|
|
2786
2817
|
this.selectedTab = this.tabList.length - 1;
|
|
2787
2818
|
this.setEllipsisTitle();
|
|
@@ -2790,11 +2821,12 @@ class MultiTabComponent {
|
|
|
2790
2821
|
}
|
|
2791
2822
|
/**
|
|
2792
2823
|
* @param {?} url
|
|
2793
|
-
* @param {
|
|
2794
|
-
* @param {
|
|
2824
|
+
* @param {?} pureUrl
|
|
2825
|
+
* @param {?} title
|
|
2826
|
+
* @param {?} noReused
|
|
2795
2827
|
* @return {?}
|
|
2796
2828
|
*/
|
|
2797
|
-
setTab(url, pureUrl, title) {
|
|
2829
|
+
setTab(url, pureUrl, title, noReused) {
|
|
2798
2830
|
/** @type {?} */
|
|
2799
2831
|
const isExistIdx = this.tabList.findIndex((/**
|
|
2800
2832
|
* @param {?} ele
|
|
@@ -2820,7 +2852,16 @@ class MultiTabComponent {
|
|
|
2820
2852
|
this.addTab(url, title);
|
|
2821
2853
|
}
|
|
2822
2854
|
else {
|
|
2823
|
-
|
|
2855
|
+
/** @type {?} */
|
|
2856
|
+
const targetTabUrl = this.tabList[isExistIdx].url;
|
|
2857
|
+
if (targetTabUrl !== url || noReused) {
|
|
2858
|
+
// 当缓存一致时候,但是url不一致,重新按照新的url生成tab
|
|
2859
|
+
this.closeTab(isExistIdx, true);
|
|
2860
|
+
this.addTab(url, title);
|
|
2861
|
+
}
|
|
2862
|
+
else {
|
|
2863
|
+
this.changeTab(this.tabList[isExistIdx], isExistIdx);
|
|
2864
|
+
}
|
|
2824
2865
|
this.ref.markForCheck();
|
|
2825
2866
|
}
|
|
2826
2867
|
}
|
|
@@ -2871,8 +2912,8 @@ class MultiTabComponent {
|
|
|
2871
2912
|
MultiTabComponent.decorators = [
|
|
2872
2913
|
{ type: Component, args: [{
|
|
2873
2914
|
selector: "rs-multi-tab",
|
|
2874
|
-
template: "<div class=\"rs-multi-tab\" [ngClass]=\"{ 'b-line': tabList.length > 0 }\">\r\n
|
|
2875
|
-
styles: [".rs-multi-tab{width:100%;display:flex;justify-content:space-between;margin:0 auto;max-width:1886px}.rs-multi-tab.b-line{border-bottom:1px solid #e5eaef}.rs-multi-tab ul{display:flex;margin:0 8px;padding:0;overflow:hidden;height:100%}.rs-multi-tab ul li{max-width:164px;padding:0 12px;display:flex;align-items:center;flex:auto;border:1px solid #e5eaef;border-bottom:none;color:#5f6f81;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:28px;height:28px;background:#f8fafb;vertical-align:top;position:relative;cursor:default}.rs-multi-tab ul li .tabTitle{display:inline-block;white-space:nowrap;font-size:11px;font-family:Arial;font-style:normal;font-weight:400;line-height:16px;transition:width .3s}.rs-multi-tab ul li img{border-radius:4px;padding:4px;margin-left:6px;margin-top:1px;vertical-align:top;cursor:pointer}.rs-multi-tab ul li img:hover{background:#dce8f6}.rs-multi-tab ul li:not(:last-child){border-right:none}.rs-multi-tab ul li:first-of-type{border-top-left-radius:8px}.rs-multi-tab ul li:last-child{border-top-right-radius:8px}.rs-multi-tab ul .isSelect{color:#1f3f5c;background:#fff}.rs-multi-tab ul .notSelect img{display:none}.rs-multi-tab ul .notSelect .img-block{display:inline-block;width:22px}.rs-multi-tab ul .notSelect:hover{color:#1f3f5c;background-color:rgba(31,123,255,.04)}.rs-multi-tab ul .notSelect:hover .img-block{display:none}.rs-multi-tab ul .notSelect:hover img{display:inline-block}.rs-multi-tab .refresh-tab{cursor:pointer;text-align:right;color:#6c7c90;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:28px;padding-right:12px}.rs-multi-tab .refresh-tab img{vertical-align:middle;margin-right:4px}.refresh-tab-loading{-webkit-animation:1s linear infinite spin;animation:1s linear infinite spin}@-webkit-keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.tooltip-content{padding:4px;color:#f8fafb;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:14px}@media (max-width:1400px){.refresh-tab{padding-right:0!important}.refresh-tab span{display:none!important}}@media (max-width:1100px){.rs-multi-tab ul li img{position:absolute;right:3px;background-color:#fff}.notSelect:hover img{position:absolute;right:3px;background-color:#eff5fb}.img-block{display:none!important}}@media (max-width:600px){.rs-multi-tab ul li{padding:0 8px}.rs-multi-tab ul .notSelect .img-block{width:0!important}}"]
|
|
2915
|
+
template: "<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",
|
|
2916
|
+
styles: [".rs-multi-tab{width:100%;display:flex;justify-content:space-between;margin:0 auto;max-width:1886px}.rs-multi-tab.b-line{border-bottom:1px solid #e5eaef}.rs-multi-tab ul{display:flex;margin:0 8px;padding:0;overflow:hidden;height:100%}.rs-multi-tab ul li{max-width:164px;padding:0 12px;display:flex;align-items:center;flex:auto;border:1px solid #e5eaef;border-bottom:none;color:#5f6f81;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:28px;height:28px;background:#f8fafb;vertical-align:top;position:relative;cursor:default}.rs-multi-tab ul li .tabTitle{display:inline-block;white-space:nowrap;font-size:11px;font-family:Arial;font-style:normal;font-weight:400;line-height:16px;transition:width .3s}.rs-multi-tab ul li img{border-radius:4px;padding:4px;margin-left:6px;margin-top:1px;vertical-align:top;cursor:pointer}.rs-multi-tab ul li img:hover{background:#dce8f6}.rs-multi-tab ul li:not(:last-child){border-right:none}.rs-multi-tab ul li:first-of-type{border-top-left-radius:8px}.rs-multi-tab ul li:last-child{border-top-right-radius:8px}.rs-multi-tab ul .isSelect{color:#1f3f5c;background:#fff}.rs-multi-tab ul .notSelect img{display:none}.rs-multi-tab ul .notSelect .img-block{display:inline-block;width:22px}.rs-multi-tab ul .notSelect:hover{color:#1f3f5c;background-color:rgba(31,123,255,.04)}.rs-multi-tab ul .notSelect:hover .img-block{display:none}.rs-multi-tab ul .notSelect:hover img{display:inline-block}.rs-multi-tab .refresh-tab{cursor:pointer;text-align:right;color:#6c7c90;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:28px;padding-right:12px}.rs-multi-tab .refresh-tab img{vertical-align:middle;margin-right:4px}.refresh-tab-loading{-webkit-animation:1s linear infinite spin;animation:1s linear infinite spin}.notSelectTooltip{transform:translateX(-12px)}@-webkit-keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}@keyframes spin{0%{transform:rotate(0)}100%{transform:rotate(360deg)}}.tooltip-content{padding:4px;color:#f8fafb;font-family:Arial;font-size:11px;font-style:normal;font-weight:400;line-height:14px}@media (max-width:1400px){.refresh-tab{padding-right:0!important}.refresh-tab span{display:none!important}}@media (max-width:1100px){.rs-multi-tab ul li img{position:absolute;right:3px;background-color:#fff}.notSelect:hover img{position:absolute;right:3px;background-color:#eff5fb}.img-block{display:none!important}.isSelect:not(:first-child){padding-right:20px!important}}@media (max-width:600px){.rs-multi-tab ul li{padding:0 8px}.rs-multi-tab ul .notSelect .img-block{width:0!important}}"]
|
|
2876
2917
|
}] }
|
|
2877
2918
|
];
|
|
2878
2919
|
/** @nocollapse */
|
|
@@ -3358,7 +3399,7 @@ class RSToolbarComponent {
|
|
|
3358
3399
|
RSToolbarComponent.decorators = [
|
|
3359
3400
|
{ type: Component, args: [{
|
|
3360
3401
|
selector: "rs-toolbar",
|
|
3361
|
-
template: "<div #toolbarContainer class=\"rs-toolbar-container\">\r\n <!-- \u53EF\u89C1\u6309\u94AE -->\r\n <ng-container *ngFor=\"let button of buttons\">\r\n <div class=\"temp-hidden\" #toolbarItem>\r\n <rs-toolbar-item\r\n [image]=\"button.image\"\r\n [text]=\"button.text\"\r\n [disabled]=\"(button.key && disabledOptions[button.key]) || false\"\r\n (click)=\"button.action && button.action()\"\r\n [children]=\"button.children || []\"\r\n [disabledOptions]=\"disabledOptions\"\r\n >\r\n </rs-toolbar-item>\r\n </div>\r\n </ng-container>\r\n\r\n <!-- \u4E0B\u62C9\u83DC\u5355\uFF08\u5982\u679C\u6709\u9690\u85CF\u6309\u94AE\uFF09 -->\r\n <button\r\n *ngIf=\"hiddenButtons.length > 0\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n #menuTrigger=\"matMenuTrigger\"\r\n class=\"action-toggle\"\r\n >\r\n <mat-icon svgIcon=\"more\"></mat-icon>\r\n </button>\r\n\r\n <mat-menu #menu=\"matMenu\">\r\n <ng-container *ngFor=\"let button of hiddenButtons\">\r\n <rs-toolbar-item\r\n [image]=\"button.image\"\r\n [text]=\"button.text\"\r\n (click)=\"button.action && button.action()\"\r\n [disabled]=\"disabledOptions[button.key] || false\"\r\n [children]=\"button.children || []\"\r\n >\r\n </rs-toolbar-item>\r\n </ng-container>\r\n </mat-menu>\r\n</div>\r\n",
|
|
3402
|
+
template: "<div #toolbarContainer class=\"rs-toolbar-container\">\r\n <!-- \u53EF\u89C1\u6309\u94AE -->\r\n <ng-container *ngFor=\"let button of buttons\">\r\n <div class=\"temp-hidden\" #toolbarItem>\r\n <rs-toolbar-item\r\n [image]=\"button.image\"\r\n [text]=\"button.text\"\r\n [disabled]=\"(button.key && disabledOptions[button.key]) || false\"\r\n (click)=\"button.action && button.action()\"\r\n [children]=\"button.children || []\"\r\n [disabledOptions]=\"disabledOptions\"\r\n >\r\n </rs-toolbar-item>\r\n </div>\r\n </ng-container>\r\n\r\n <!-- \u4E0B\u62C9\u83DC\u5355\uFF08\u5982\u679C\u6709\u9690\u85CF\u6309\u94AE\uFF09 -->\r\n <button\r\n *ngIf=\"hiddenButtons.length > 0\"\r\n mat-button\r\n [matMenuTriggerFor]=\"menu\"\r\n #menuTrigger=\"matMenuTrigger\"\r\n class=\"action-toggle\"\r\n >\r\n <mat-icon svgIcon=\"more\"></mat-icon>\r\n </button>\r\n\r\n <mat-menu #menu=\"matMenu\">\r\n <ng-container *ngFor=\"let button of hiddenButtons\">\r\n <rs-toolbar-item\r\n [image]=\"button.image\"\r\n [text]=\"button.text\"\r\n (click)=\"button.action && button.action()\"\r\n [disabled]=\"disabledOptions[button.key] || false\"\r\n [children]=\"button.children || []\"\r\n [disabledOptions]=\"disabledOptions\"\r\n >\r\n </rs-toolbar-item>\r\n </ng-container>\r\n </mat-menu>\r\n</div>\r\n",
|
|
3362
3403
|
styles: [":host{display:block;width:100%}.rs-toolbar-container{width:100%;display:flex;align-items:center}.rs-toolbar-container .temp-hidden{visibility:hidden;position:absolute}.rs-toolbar-container .action-toggle{width:24px;height:24px;min-width:24px;max-width:24px;padding:0;border-radius:4px;display:flex;flex-flow:row nowrap;justify-content:center;align-items:center;background:0 0}.rs-toolbar-container .action-toggle:hover{background:rgba(214,227,245,.2)}.rs-toolbar-container .action-toggle .mat-button-wrapper{max-height:24px;height:24px}.rs-toolbar-container .action-toggle ::ng-deep .mat-icon{width:16px;height:16px;display:flex;flex-flow:row nowrap;justify-content:center;align-items:center}"]
|
|
3363
3404
|
}] }
|
|
3364
3405
|
];
|