raise-common-lib 0.0.175 → 0.0.177
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 +50 -40
- 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/drawer/index.component.js +9 -9
- package/esm2015/lib/layout/multi-tab/index.component.js +42 -33
- package/esm5/lib/layout/drawer/index.component.js +9 -9
- package/esm5/lib/layout/multi-tab/index.component.js +44 -34
- package/fesm2015/raise-common-lib.js +49 -40
- package/fesm2015/raise-common-lib.js.map +1 -1
- package/fesm5/raise-common-lib.js +51 -41
- package/fesm5/raise-common-lib.js.map +1 -1
- package/lib/layout/drawer/index.component.d.ts +2 -2
- package/lib/layout/multi-tab/index.component.d.ts +1 -1
- package/package.json +1 -1
- package/raise-common-lib.metadata.json +1 -1
|
@@ -5,7 +5,7 @@
|
|
|
5
5
|
*/
|
|
6
6
|
// 组件类
|
|
7
7
|
import { ChangeDetectorRef, Component, EventEmitter, HostListener, Input, Output, } from "@angular/core";
|
|
8
|
-
import { ActivatedRoute, NavigationEnd, Router, } from "@angular/router";
|
|
8
|
+
import { ActivatedRoute, NavigationEnd, NavigationStart, Router, } from "@angular/router";
|
|
9
9
|
import { filter } from "rxjs/operators";
|
|
10
10
|
import { RouteReuseStrategy } from "@angular/router";
|
|
11
11
|
import { CommonFunctionService } from "../../service/common-function.service";
|
|
@@ -72,6 +72,42 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
72
72
|
if (isExistIdx !== -1) {
|
|
73
73
|
this.selectedTab = isExistIdx;
|
|
74
74
|
}
|
|
75
|
+
this.subscriptions.push(this.router.events
|
|
76
|
+
.pipe(filter((/**
|
|
77
|
+
* @param {?} event
|
|
78
|
+
* @return {?}
|
|
79
|
+
*/
|
|
80
|
+
function (event) { return event instanceof NavigationStart; })))
|
|
81
|
+
.subscribe((/**
|
|
82
|
+
* @param {?} event
|
|
83
|
+
* @return {?}
|
|
84
|
+
*/
|
|
85
|
+
function (event) {
|
|
86
|
+
/** @type {?} */
|
|
87
|
+
var navigation = _this.router.getCurrentNavigation();
|
|
88
|
+
if (navigation) {
|
|
89
|
+
/** @type {?} */
|
|
90
|
+
var state = navigation.extras.state;
|
|
91
|
+
// 获取传递的 state
|
|
92
|
+
/** @type {?} */
|
|
93
|
+
var noReused = (state && state["noReused"]) || false;
|
|
94
|
+
// 当前tab不复用,新开一个tab,当有已经存在的tab时候也是新开
|
|
95
|
+
/** @type {?} */
|
|
96
|
+
var isExistIdx_1 = _this.tabList.findIndex((/**
|
|
97
|
+
* @param {?} ele
|
|
98
|
+
* @return {?}
|
|
99
|
+
*/
|
|
100
|
+
function (ele) {
|
|
101
|
+
return _this.urlWithoutQuery(ele.url) ===
|
|
102
|
+
_this.urlWithoutQuery(event.url);
|
|
103
|
+
}));
|
|
104
|
+
if (isExistIdx_1 !== -1 &&
|
|
105
|
+
(noReused || _this.tabList[isExistIdx_1].url !== event.url)) {
|
|
106
|
+
// 如果当前tab已经存在,并且是新开的tab
|
|
107
|
+
_this.closeTab(isExistIdx_1, true); // 关闭当前tab
|
|
108
|
+
}
|
|
109
|
+
}
|
|
110
|
+
})));
|
|
75
111
|
this.subscriptions.push(this.router.events
|
|
76
112
|
.pipe(filter((/**
|
|
77
113
|
* @param {?} event
|
|
@@ -79,9 +115,10 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
79
115
|
*/
|
|
80
116
|
function (event) { return event instanceof NavigationEnd; })))
|
|
81
117
|
.subscribe((/**
|
|
118
|
+
* @param {?} event
|
|
82
119
|
* @return {?}
|
|
83
120
|
*/
|
|
84
|
-
function () {
|
|
121
|
+
function (event) {
|
|
85
122
|
/** @type {?} */
|
|
86
123
|
var navigation = _this.router.getCurrentNavigation();
|
|
87
124
|
if (navigation) {
|
|
@@ -112,13 +149,11 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
112
149
|
navigationInfo.title ||
|
|
113
150
|
navigationInfo.subTitle ||
|
|
114
151
|
navigationInfo.name;
|
|
115
|
-
/** @type {?} */
|
|
116
|
-
var noReused = (state && state["noReused"]) || false;
|
|
117
152
|
if (currentRoute && !skipLocationChange) {
|
|
118
153
|
if (_this.noGenerateTabUrls.includes(_this.urlWithoutQuery(_this.router.url))) {
|
|
119
154
|
return; // 排除不生成tab的url
|
|
120
155
|
}
|
|
121
|
-
_this.setTab(_this.router.url, currentRoute.snapshot.routeConfig.path, title
|
|
156
|
+
_this.setTab(_this.router.url, currentRoute.snapshot.routeConfig.path, title);
|
|
122
157
|
}
|
|
123
158
|
}
|
|
124
159
|
})));
|
|
@@ -360,17 +395,15 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
360
395
|
* @param {?} url
|
|
361
396
|
* @param {?} pureUrl
|
|
362
397
|
* @param {?} title
|
|
363
|
-
* @param {?} noReused
|
|
364
398
|
* @return {?}
|
|
365
399
|
*/
|
|
366
400
|
MultiTabComponent.prototype.setTab = /**
|
|
367
401
|
* @param {?} url
|
|
368
402
|
* @param {?} pureUrl
|
|
369
403
|
* @param {?} title
|
|
370
|
-
* @param {?} noReused
|
|
371
404
|
* @return {?}
|
|
372
405
|
*/
|
|
373
|
-
function (url, pureUrl, title
|
|
406
|
+
function (url, pureUrl, title) {
|
|
374
407
|
var _this = this;
|
|
375
408
|
/** @type {?} */
|
|
376
409
|
var isExistIdx = this.tabList.findIndex((/**
|
|
@@ -397,30 +430,7 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
397
430
|
this.addTab(url, title);
|
|
398
431
|
}
|
|
399
432
|
else {
|
|
400
|
-
|
|
401
|
-
var targetTabUrl = this.tabList[isExistIdx].url;
|
|
402
|
-
if (targetTabUrl !== url || noReused) {
|
|
403
|
-
// 当缓存一致时候,但是url不一致,重新按照新的url生成tab
|
|
404
|
-
this.closeTab(isExistIdx, true);
|
|
405
|
-
setTimeout((/**
|
|
406
|
-
* @return {?}
|
|
407
|
-
*/
|
|
408
|
-
function () {
|
|
409
|
-
_this.keepAlive.clearCache(url);
|
|
410
|
-
_this.drawer.deleteCache(url);
|
|
411
|
-
_this.router
|
|
412
|
-
.navigateByUrl("/", { skipLocationChange: true })
|
|
413
|
-
.then((/**
|
|
414
|
-
* @return {?}
|
|
415
|
-
*/
|
|
416
|
-
function () {
|
|
417
|
-
_this.router.navigateByUrl(url); // 重新导航到当前 URL
|
|
418
|
-
}));
|
|
419
|
-
}), 30);
|
|
420
|
-
}
|
|
421
|
-
else {
|
|
422
|
-
this.changeTab(this.tabList[isExistIdx], isExistIdx);
|
|
423
|
-
}
|
|
433
|
+
this.changeTab(this.tabList[isExistIdx], isExistIdx);
|
|
424
434
|
this.ref.markForCheck();
|
|
425
435
|
}
|
|
426
436
|
};
|
|
@@ -434,7 +444,7 @@ var MultiTabComponent = /** @class */ (function () {
|
|
|
434
444
|
*/
|
|
435
445
|
function (event) {
|
|
436
446
|
var previousIndex = event.previousIndex, currentIndex = event.currentIndex;
|
|
437
|
-
console.log("previousIndex", previousIndex, "currentIndex", currentIndex);
|
|
447
|
+
// console.log("previousIndex", previousIndex, "currentIndex", currentIndex);
|
|
438
448
|
if (previousIndex === 0 || currentIndex === 0) {
|
|
439
449
|
return;
|
|
440
450
|
}
|
|
@@ -603,4 +613,4 @@ if (false) {
|
|
|
603
613
|
*/
|
|
604
614
|
MultiTabComponent.prototype.routeReuseStrategy;
|
|
605
615
|
}
|
|
606
|
-
//# 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\nimport { CdkDragDrop, moveItemInArray } from \"@angular/cdk/drag-drop\";\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  @Input() flattenMenu = [];\r\n  @Input() defaultTabUrl = \"\";\r\n\r\n  @Output() onRefreshTab = new EventEmitter();\r\n  @Output() onCloseTab = 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  translation;\r\n\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.translation = JSON.parse(localStorage.getItem(\"translation\"));\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 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() {\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    this.tabList.forEach((ele, idx) => {\r\n      ele.displayTitle = this.cf.setMiddleEllipsis(\r\n        this.translation[ele.title] || 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    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    // console.log(\"this.flattenMenu\", this.flattenMenu);\r\n    let TabCache = JSON.parse(sessionStorage.getItem(\"TabCache\"));\r\n    this.tabList = TabCache || [];\r\n    if (this.tabList.length === 0) {\r\n      const pureUrl = this.urlWithoutQuery(this.router.url);\r\n      const target = this.flattenMenu.find((ele) => ele.url === pureUrl);\r\n      if (target) {\r\n        if (target.url !== this.defaultTabUrl) {\r\n          const defaultTab = this.flattenMenu.find(\r\n            (ele) => ele.url === this.defaultTabUrl\r\n          );\r\n          this.tabList.push({\r\n            url: defaultTab.url,\r\n            title: defaultTab.menuCode || defaultTab.label,\r\n            displayTitle: defaultTab.menuCode || defaultTab.label,\r\n          });\r\n        }\r\n        this.addTab(target.url, target.menuCode || target.label);\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(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.onCloseTab.emit(tab);\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      const secondTab = this.tabList[1];\r\n      this.tabList = this.tabList.filter((ele) => ele.url !== secondTab.url);\r\n      this.clearCache(secondTab.url);\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(this.urlWithoutQuery(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.keepAlive.clearCache(url);\r\n          this.drawer.deleteCache(url);\r\n          this.router\r\n            .navigateByUrl(\"/\", { skipLocationChange: true })\r\n            .then(() => {\r\n              this.router.navigateByUrl(url); // 重新导航到当前 URL\r\n            });\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\r\n  onTabDrop(event: CdkDragDrop<string[]>) {\r\n    const { previousIndex, currentIndex } = event;\r\n    console.log(\"previousIndex\", previousIndex, \"currentIndex\", currentIndex);\r\n    if (previousIndex === 0 || currentIndex === 0) {\r\n      return;\r\n    }\r\n    moveItemInArray(this.tabList, event.previousIndex, event.currentIndex);\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\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(this.urlWithoutQuery(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"]}
|
|
616
|
+
//# 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  NavigationStart,\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\nimport { CdkDragDrop, moveItemInArray } from \"@angular/cdk/drag-drop\";\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  @Input() flattenMenu = [];\r\n  @Input() defaultTabUrl = \"\";\r\n\r\n  @Output() onRefreshTab = new EventEmitter();\r\n  @Output() onCloseTab = 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  translation;\r\n\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.translation = JSON.parse(localStorage.getItem(\"translation\"));\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    this.subscriptions.push(\r\n      this.router.events\r\n        .pipe(filter((event) => event instanceof NavigationStart))\r\n        .subscribe((event: any) => {\r\n          const navigation = this.router.getCurrentNavigation(); // 获取当前导航\r\n          if (navigation) {\r\n            const state = navigation.extras.state; // 获取传递的 state\r\n            let noReused = (state && state[\"noReused\"]) || false; // 当前tab不复用，新开一个tab,当有已经存在的tab时候也是新开\r\n\r\n            const isExistIdx = this.tabList.findIndex(\r\n              (ele) =>\r\n                this.urlWithoutQuery(ele.url) ===\r\n                this.urlWithoutQuery(event.url)\r\n            );\r\n            if (\r\n              isExistIdx !== -1 &&\r\n              (noReused || this.tabList[isExistIdx].url !== event.url)\r\n            ) {\r\n              // 如果当前tab已经存在，并且是新开的tab\r\n              this.closeTab(isExistIdx, true); // 关闭当前tab\r\n            }\r\n          }\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((event) => {\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            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.tabList = []; // 清空 tab 列表\r\n    this.selectedTab = 0; // 重置选中的 tab 索引\r\n    this.subscriptions.forEach((sub) => sub.unsubscribe());\r\n  }\r\n\r\n  setEllipsisTitle() {\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    this.tabList.forEach((ele, idx) => {\r\n      ele.displayTitle = this.cf.setMiddleEllipsis(\r\n        this.translation[ele.title] || 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    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    // console.log(\"this.flattenMenu\", this.flattenMenu);\r\n    let TabCache = JSON.parse(sessionStorage.getItem(\"TabCache\"));\r\n    this.tabList = TabCache || [];\r\n    if (this.tabList.length === 0) {\r\n      const pureUrl = this.urlWithoutQuery(this.router.url);\r\n      const target = this.flattenMenu.find((ele) => ele.url === pureUrl);\r\n      if (target) {\r\n        if (target.url !== this.defaultTabUrl) {\r\n          const defaultTab = this.flattenMenu.find(\r\n            (ele) => ele.url === this.defaultTabUrl\r\n          );\r\n          this.tabList.push({\r\n            url: defaultTab.url,\r\n            title: defaultTab.menuCode || defaultTab.label,\r\n            displayTitle: defaultTab.menuCode || defaultTab.label,\r\n          });\r\n        }\r\n        this.addTab(target.url, target.menuCode || target.label);\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(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.onCloseTab.emit(tab);\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      const secondTab = this.tabList[1];\r\n      this.tabList = this.tabList.filter((ele) => ele.url !== secondTab.url);\r\n      this.clearCache(secondTab.url);\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) {\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(this.urlWithoutQuery(url));\r\n        this.drawer.deleteCache(url);\r\n      }\r\n      this.addTab(url, title);\r\n    } else {\r\n      this.changeTab(this.tabList[isExistIdx], isExistIdx);\r\n      this.ref.markForCheck();\r\n    }\r\n  }\r\n\r\n  onTabDrop(event: CdkDragDrop<string[]>) {\r\n    const { previousIndex, currentIndex } = event;\r\n    // console.log(\"previousIndex\", previousIndex, \"currentIndex\", currentIndex);\r\n    if (previousIndex === 0 || currentIndex === 0) {\r\n      return;\r\n    }\r\n    moveItemInArray(this.tabList, event.previousIndex, event.currentIndex);\r\n    sessionStorage.setItem(\"TabCache\", JSON.stringify(this.tabList));\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(this.urlWithoutQuery(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"]}
|
|
@@ -7,7 +7,7 @@ import { MAT_SNACK_BAR_DATA, MatSnackBar, MatSnackBarModule } from '@angular/mat
|
|
|
7
7
|
import { MAT_DIALOG_DATA, MatDialogRef, MatDialog, MatDialogModule } from '@angular/material/dialog';
|
|
8
8
|
import { TreeGridComponent } from '@syncfusion/ej2-angular-treegrid';
|
|
9
9
|
import { CarouselAllModule, ToolbarModule, TabModule, TreeViewModule } from '@syncfusion/ej2-angular-navigations';
|
|
10
|
-
import { NavigationEnd, Router, ActivatedRoute, RouteReuseStrategy } from '@angular/router';
|
|
10
|
+
import { NavigationEnd, Router, NavigationStart, ActivatedRoute, RouteReuseStrategy } from '@angular/router';
|
|
11
11
|
import { filter } from 'rxjs/operators';
|
|
12
12
|
import { moveItemInArray, DragDropModule } from '@angular/cdk/drag-drop';
|
|
13
13
|
import { HttpClient, HttpClientModule } from '@angular/common/http';
|
|
@@ -2725,6 +2725,40 @@ class MultiTabComponent {
|
|
|
2725
2725
|
if (isExistIdx !== -1) {
|
|
2726
2726
|
this.selectedTab = isExistIdx;
|
|
2727
2727
|
}
|
|
2728
|
+
this.subscriptions.push(this.router.events
|
|
2729
|
+
.pipe(filter((/**
|
|
2730
|
+
* @param {?} event
|
|
2731
|
+
* @return {?}
|
|
2732
|
+
*/
|
|
2733
|
+
(event) => event instanceof NavigationStart)))
|
|
2734
|
+
.subscribe((/**
|
|
2735
|
+
* @param {?} event
|
|
2736
|
+
* @return {?}
|
|
2737
|
+
*/
|
|
2738
|
+
(event) => {
|
|
2739
|
+
/** @type {?} */
|
|
2740
|
+
const navigation = this.router.getCurrentNavigation();
|
|
2741
|
+
if (navigation) {
|
|
2742
|
+
/** @type {?} */
|
|
2743
|
+
const state = navigation.extras.state;
|
|
2744
|
+
// 获取传递的 state
|
|
2745
|
+
/** @type {?} */
|
|
2746
|
+
let noReused = (state && state["noReused"]) || false;
|
|
2747
|
+
// 当前tab不复用,新开一个tab,当有已经存在的tab时候也是新开
|
|
2748
|
+
/** @type {?} */
|
|
2749
|
+
const isExistIdx = this.tabList.findIndex((/**
|
|
2750
|
+
* @param {?} ele
|
|
2751
|
+
* @return {?}
|
|
2752
|
+
*/
|
|
2753
|
+
(ele) => this.urlWithoutQuery(ele.url) ===
|
|
2754
|
+
this.urlWithoutQuery(event.url)));
|
|
2755
|
+
if (isExistIdx !== -1 &&
|
|
2756
|
+
(noReused || this.tabList[isExistIdx].url !== event.url)) {
|
|
2757
|
+
// 如果当前tab已经存在,并且是新开的tab
|
|
2758
|
+
this.closeTab(isExistIdx, true); // 关闭当前tab
|
|
2759
|
+
}
|
|
2760
|
+
}
|
|
2761
|
+
})));
|
|
2728
2762
|
this.subscriptions.push(this.router.events
|
|
2729
2763
|
.pipe(filter((/**
|
|
2730
2764
|
* @param {?} event
|
|
@@ -2732,9 +2766,10 @@ class MultiTabComponent {
|
|
|
2732
2766
|
*/
|
|
2733
2767
|
(event) => event instanceof NavigationEnd)))
|
|
2734
2768
|
.subscribe((/**
|
|
2769
|
+
* @param {?} event
|
|
2735
2770
|
* @return {?}
|
|
2736
2771
|
*/
|
|
2737
|
-
() => {
|
|
2772
|
+
(event) => {
|
|
2738
2773
|
/** @type {?} */
|
|
2739
2774
|
const navigation = this.router.getCurrentNavigation();
|
|
2740
2775
|
if (navigation) {
|
|
@@ -2765,13 +2800,11 @@ class MultiTabComponent {
|
|
|
2765
2800
|
navigationInfo.title ||
|
|
2766
2801
|
navigationInfo.subTitle ||
|
|
2767
2802
|
navigationInfo.name;
|
|
2768
|
-
/** @type {?} */
|
|
2769
|
-
let noReused = (state && state["noReused"]) || false;
|
|
2770
2803
|
if (currentRoute && !skipLocationChange) {
|
|
2771
2804
|
if (this.noGenerateTabUrls.includes(this.urlWithoutQuery(this.router.url))) {
|
|
2772
2805
|
return; // 排除不生成tab的url
|
|
2773
2806
|
}
|
|
2774
|
-
this.setTab(this.router.url, currentRoute.snapshot.routeConfig.path, title
|
|
2807
|
+
this.setTab(this.router.url, currentRoute.snapshot.routeConfig.path, title);
|
|
2775
2808
|
}
|
|
2776
2809
|
}
|
|
2777
2810
|
})));
|
|
@@ -2980,10 +3013,9 @@ class MultiTabComponent {
|
|
|
2980
3013
|
* @param {?} url
|
|
2981
3014
|
* @param {?} pureUrl
|
|
2982
3015
|
* @param {?} title
|
|
2983
|
-
* @param {?} noReused
|
|
2984
3016
|
* @return {?}
|
|
2985
3017
|
*/
|
|
2986
|
-
setTab(url, pureUrl, title
|
|
3018
|
+
setTab(url, pureUrl, title) {
|
|
2987
3019
|
/** @type {?} */
|
|
2988
3020
|
const isExistIdx = this.tabList.findIndex((/**
|
|
2989
3021
|
* @param {?} ele
|
|
@@ -3009,30 +3041,7 @@ class MultiTabComponent {
|
|
|
3009
3041
|
this.addTab(url, title);
|
|
3010
3042
|
}
|
|
3011
3043
|
else {
|
|
3012
|
-
|
|
3013
|
-
const targetTabUrl = this.tabList[isExistIdx].url;
|
|
3014
|
-
if (targetTabUrl !== url || noReused) {
|
|
3015
|
-
// 当缓存一致时候,但是url不一致,重新按照新的url生成tab
|
|
3016
|
-
this.closeTab(isExistIdx, true);
|
|
3017
|
-
setTimeout((/**
|
|
3018
|
-
* @return {?}
|
|
3019
|
-
*/
|
|
3020
|
-
() => {
|
|
3021
|
-
this.keepAlive.clearCache(url);
|
|
3022
|
-
this.drawer.deleteCache(url);
|
|
3023
|
-
this.router
|
|
3024
|
-
.navigateByUrl("/", { skipLocationChange: true })
|
|
3025
|
-
.then((/**
|
|
3026
|
-
* @return {?}
|
|
3027
|
-
*/
|
|
3028
|
-
() => {
|
|
3029
|
-
this.router.navigateByUrl(url); // 重新导航到当前 URL
|
|
3030
|
-
}));
|
|
3031
|
-
}), 30);
|
|
3032
|
-
}
|
|
3033
|
-
else {
|
|
3034
|
-
this.changeTab(this.tabList[isExistIdx], isExistIdx);
|
|
3035
|
-
}
|
|
3044
|
+
this.changeTab(this.tabList[isExistIdx], isExistIdx);
|
|
3036
3045
|
this.ref.markForCheck();
|
|
3037
3046
|
}
|
|
3038
3047
|
}
|
|
@@ -3042,7 +3051,7 @@ class MultiTabComponent {
|
|
|
3042
3051
|
*/
|
|
3043
3052
|
onTabDrop(event) {
|
|
3044
3053
|
const { previousIndex, currentIndex } = event;
|
|
3045
|
-
console.log("previousIndex", previousIndex, "currentIndex", currentIndex);
|
|
3054
|
+
// console.log("previousIndex", previousIndex, "currentIndex", currentIndex);
|
|
3046
3055
|
if (previousIndex === 0 || currentIndex === 0) {
|
|
3047
3056
|
return;
|
|
3048
3057
|
}
|
|
@@ -3208,7 +3217,7 @@ class DrawerComponent {
|
|
|
3208
3217
|
this.resolver = resolver;
|
|
3209
3218
|
this.service = service;
|
|
3210
3219
|
this.config = DefaultDrawerConfig;
|
|
3211
|
-
this.
|
|
3220
|
+
this.useAnimation = "yes";
|
|
3212
3221
|
this.isOpened = false;
|
|
3213
3222
|
this.hiddenDrawer = true;
|
|
3214
3223
|
this.componentRefMap = new Map();
|
|
@@ -3377,7 +3386,7 @@ class DrawerComponent {
|
|
|
3377
3386
|
else {
|
|
3378
3387
|
this.toggleOpenStatus(false);
|
|
3379
3388
|
}
|
|
3380
|
-
this.
|
|
3389
|
+
this.useAnimation = "no";
|
|
3381
3390
|
}
|
|
3382
3391
|
/**
|
|
3383
3392
|
* @param {?} isOpen
|
|
@@ -3386,14 +3395,14 @@ class DrawerComponent {
|
|
|
3386
3395
|
*/
|
|
3387
3396
|
toggleOpenStatus(isOpen, useTransition = false) {
|
|
3388
3397
|
this.isOpened = isOpen;
|
|
3389
|
-
this.
|
|
3398
|
+
this.useAnimation = useTransition ? "yes" : "no";
|
|
3390
3399
|
this.hiddenDrawer = !isOpen && !useTransition;
|
|
3391
3400
|
}
|
|
3392
3401
|
/**
|
|
3393
3402
|
* @return {?}
|
|
3394
3403
|
*/
|
|
3395
|
-
|
|
3396
|
-
if (this.isOpened) {
|
|
3404
|
+
onAnimationEnd() {
|
|
3405
|
+
if (!this.isOpened) {
|
|
3397
3406
|
this.hiddenDrawer = true;
|
|
3398
3407
|
}
|
|
3399
3408
|
}
|
|
@@ -3401,8 +3410,8 @@ class DrawerComponent {
|
|
|
3401
3410
|
DrawerComponent.decorators = [
|
|
3402
3411
|
{ type: Component, args: [{
|
|
3403
3412
|
selector: "rs-drawer",
|
|
3404
|
-
template: "<div #element id=\"rs-drawer-container\" class=\"rs-drawer-container\">\r\n <div class=\"rs-drawer-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div\r\n #drawer\r\n class=\"rs-drawer\"\r\n [attr.data-mode]=\"config.mode\"\r\n [attr.data-opened]=\"isOpened ? 'yes' : 'no'\"\r\n [attr.data-
|
|
3405
|
-
styles: [":host{display:block;height:100%}#rs-drawer-container{height:100%}.rs-drawer-container{height:100%;background-color:transparent;overflow:hidden;position:relative}.rs-drawer-container .rs-drawer-content{width:100%;height:100%;overflow:auto;margin-right:0!important}.rs-drawer-container .rs-drawer-content::-webkit-scrollbar{width:5px;height:5px;background:#fff;position:static;z-index:999;border-radius:10px}.rs-drawer-container .rs-drawer-content::-webkit-scrollbar-thumb{background:#eaedf0}.rs-drawer-container .rs-drawer{width:100%;height:100%;border-left:none;background-color:transparent;overflow:visible;pointer-events:none;opacity:0;display:flex;flex-flow:column nowrap;position:absolute;z-index:2;top:0;left:100%}.rs-drawer-container .rs-drawer[data-opened=yes]{left:0;opacity:1}.rs-drawer-container .rs-drawer[data-
|
|
3413
|
+
template: "<div #element id=\"rs-drawer-container\" class=\"rs-drawer-container\">\r\n <div class=\"rs-drawer-content\">\r\n <ng-content></ng-content>\r\n </div>\r\n <div\r\n #drawer\r\n class=\"rs-drawer\"\r\n [attr.data-mode]=\"config.mode\"\r\n [attr.data-opened]=\"isOpened ? 'yes' : 'no'\"\r\n [attr.data-animation]=\"useAnimation\"\r\n [hidden]=\"hiddenDrawer\"\r\n (animationend)=\"onAnimationEnd()\"\r\n >\r\n <div class=\"drawer-header\" #header>\r\n <button class=\"drawer-return-button\" (click)=\"hide()\">\r\n <span class=\"drawer-sub-title\" *ngIf=\"config.subTitle\">\r\n {{ config.subTitle }}\r\n </span>\r\n </button>\r\n <div class=\"drawer-title\">{{ config.title }}</div>\r\n <div class=\"drawer-header-slot\" #headerSlot></div>\r\n </div>\r\n <div class=\"drawer-top-slot\" #topSlot></div>\r\n <div class=\"drawer-content-box\">\r\n <div class=\"drawer-content\" #content>\r\n <div class=\"drawer-content-container\">\r\n <ng-template #dynamicComponentContainer></ng-template>\r\n </div>\r\n </div>\r\n </div>\r\n <div class=\"drawer-toolbar-slot\" #toolbarSlot></div>\r\n </div>\r\n</div>\r\n",
|
|
3414
|
+
styles: [":host{display:block;height:100%}#rs-drawer-container{height:100%}.rs-drawer-container{height:100%;background-color:transparent;overflow:hidden;position:relative}.rs-drawer-container .rs-drawer-content{width:100%;height:100%;overflow:auto;margin-right:0!important}.rs-drawer-container .rs-drawer-content::-webkit-scrollbar{width:5px;height:5px;background:#fff;position:static;z-index:999;border-radius:10px}.rs-drawer-container .rs-drawer-content::-webkit-scrollbar-thumb{background:#eaedf0}.rs-drawer-container .rs-drawer{width:100%;height:100%;border-left:none;background-color:transparent;overflow:visible;pointer-events:none;opacity:0;display:flex;flex-flow:column nowrap;position:absolute;z-index:2;top:0;left:100%}.rs-drawer-container .rs-drawer[data-opened=yes]{left:0;opacity:1}.rs-drawer-container .rs-drawer[data-animation=yes][data-opened=yes]{-webkit-animation:.5s ease-in-out drawer-open;animation:.5s ease-in-out drawer-open}@-webkit-keyframes drawer-open{from{left:100%;opacity:0}to{left:0;opacity:1}}@keyframes drawer-open{from{left:100%;opacity:0}to{left:0;opacity:1}}.rs-drawer-container .rs-drawer[data-animation=yes][data-opened=no]{-webkit-animation:.5s ease-in-out drawer-close;animation:.5s ease-in-out drawer-close}@-webkit-keyframes drawer-close{from{left:0;opacity:1}to{left:100%;opacity:0}}@keyframes drawer-close{from{left:0;opacity:1}to{left:100%;opacity:0}}.rs-drawer-container .rs-drawer[hidden]{display:none}.rs-drawer-container .rs-drawer .drawer-header{flex:none;display:flex;flex-flow:row nowrap;justify-content:flex-start;align-items:center;box-sizing:content-box;pointer-events:auto}.rs-drawer-container .rs-drawer .drawer-header .drawer-return-button{flex:none;display:flex;flex-flow:row nowrap;align-items:center;padding:0;border:none;background-color:transparent;cursor:pointer}.rs-drawer-container .rs-drawer .drawer-header .drawer-return-button::before{content:url(../../assets/img/drawer-back.svg);width:24px;height:24px;margin-right:8px;transition:transform 125ms ease-in-out}.rs-drawer-container .rs-drawer .drawer-header .drawer-return-button:hover::before{transform:translateX(-2px)}.rs-drawer-container .rs-drawer .drawer-header .drawer-return-button .drawer-sub-title{margin-right:12px;font-family:Arial;font-style:normal;font-weight:400}.rs-drawer-container .rs-drawer .drawer-header .drawer-title{flex:none;min-height:14px;padding:0 12px;border-left:1px solid #bdc4ca;font-family:Arial;font-style:normal;font-weight:400}.rs-drawer-container .rs-drawer .drawer-header .drawer-title:empty{padding:0}.rs-drawer-container .rs-drawer .drawer-content-box{flex:auto;height:0;background-color:#f7fafb;pointer-events:auto}.rs-drawer-container .rs-drawer .drawer-content{height:100%;padding:0 20px;border:1px solid #ebedf0;border-radius:15px;background-color:#fff;display:flex;flex-flow:column nowrap}.rs-drawer-container .rs-drawer .drawer-content .drawer-content-container{flex:auto;overflow:hidden auto}.rs-drawer-container .rs-drawer .drawer-toolbar-slot{flex:none;height:32px;margin-left:auto;display:flex;flex-flow:row nowrap;justify-content:flex-end;align-items:center;pointer-events:auto}.rs-drawer-container .rs-drawer .drawer-toolbar-slot:empty{display:none}.rs-drawer-container .rs-drawer .drawer-top-slot{flex:none;pointer-events:auto}.rs-drawer-container .rs-drawer .drawer-top-slot:empty{height:var(--drawer-top,0);pointer-events:none}.rs-drawer-container .rs-drawer[data-mode=outer] .drawer-header{height:46px;padding:0 12px 0 8px;background-color:#f7fafb}.rs-drawer-container .rs-drawer[data-mode=outer] .drawer-header .drawer-sub-title,.rs-drawer-container .rs-drawer[data-mode=outer] .drawer-header .drawer-title{color:#1f3f5c;font-size:15px;font-weight:700;line-height:18px}.rs-drawer-container .rs-drawer[data-mode=outer] .drawer-content{padding-bottom:20px}.rs-drawer-container .rs-drawer[data-mode=outer] .drawer-content .drawer-content-container{margin-right:-20px;padding-right:20px}.rs-drawer-container .rs-drawer[data-mode=inner] .drawer-top-slot:empty+.drawer-content-box{padding-top:calc((var(--drawer-top,0) + 1) * 16px)}.rs-drawer-container .rs-drawer[data-mode=inner] .drawer-header{height:24px;padding:6px 0;border-bottom:1px solid #eaedf0}.rs-drawer-container .rs-drawer[data-mode=inner] .drawer-header .drawer-sub-title,.rs-drawer-container .rs-drawer[data-mode=inner] .drawer-header .drawer-title{color:#44566c;font-size:12px;line-height:14px}.rs-drawer-container .rs-drawer[data-mode=inner] .drawer-header .drawer-title{font-weight:700}.rs-drawer-container .rs-drawer[data-mode=inner] .drawer-content .drawer-content-container{margin-right:-20px;padding-right:20px;padding-left:8px}.rs-drawer-container .rs-drawer[data-mode=inner] .drawer-toolbar-slot{width:100%;padding:16px 0;box-sizing:content-box;border-top:1px solid #eaedf0}::ng-deep .rs-drawer-container .rs-drawer .drawer-toolbar-slot [drawer-toolbar]{display:flex;flex-flow:row nowrap;justify-content:flex-end;align-items:center;gap:12px}::ng-deep .rs-drawer-container .rs-drawer .drawer-toolbar-slot [drawer-toolbar] button{display:flex;flex-flow:row nowrap;justify-content:center;align-items:center;gap:6px;min-width:80px;height:32px;padding:0 12px;border:1px solid #adb5bd;border-radius:4px;background-color:#fff;cursor:pointer;color:#44566c;font-size:13px;font-family:Arial;font-style:normal;font-weight:400;line-height:16px}::ng-deep .rs-drawer-container .rs-drawer .drawer-toolbar-slot [drawer-toolbar] button:hover{border-color:#6c7c90}::ng-deep .rs-drawer-container .rs-drawer .drawer-toolbar-slot [drawer-toolbar] button:disabled{opacity:1!important;border-color:#6c7c9066;color:#44566c66;cursor:unset}::ng-deep .rs-drawer-container .rs-drawer .drawer-toolbar-slot [drawer-toolbar] button.primary{border:none;background-color:#1364b3;color:#fff}::ng-deep .rs-drawer-container .rs-drawer .drawer-toolbar-slot [drawer-toolbar] button.primary:hover{background-color:#176bca}::ng-deep .rs-drawer-container .rs-drawer .drawer-toolbar-slot [drawer-toolbar] button.primary:disabled{background-color:#1364b366}::ng-deep .rs-drawer-container .rs-drawer .drawer-toolbar-slot [drawer-toolbar] button img{width:16px;height:16px}::ng-deep .rs-drawer-container .rs-drawer[data-mode=outer] .drawer-toolbar-slot [drawer-toolbar] button{height:26px;font-size:12px;line-height:14px}::ng-deep .rs-drawer-container .rs-drawer[data-mode=inner] .drawer-toolbar-slot [drawer-toolbar] button img{display:none}"]
|
|
3406
3415
|
}] }
|
|
3407
3416
|
];
|
|
3408
3417
|
/** @nocollapse */
|
|
@@ -3446,7 +3455,7 @@ if (false) {
|
|
|
3446
3455
|
/** @type {?} */
|
|
3447
3456
|
DrawerComponent.prototype.config;
|
|
3448
3457
|
/** @type {?} */
|
|
3449
|
-
DrawerComponent.prototype.
|
|
3458
|
+
DrawerComponent.prototype.useAnimation;
|
|
3450
3459
|
/** @type {?} */
|
|
3451
3460
|
DrawerComponent.prototype.isOpened;
|
|
3452
3461
|
/** @type {?} */
|