UNPKG

dbweb-common

Version:

用`yarn add dbweb-common`安装,不要忘记修改`angular.json`里的 `architect\build\options\assets`,加上

197 lines 15 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Injectable } from '@angular/core'; import { BehaviorSubject } from 'rxjs'; import { SimpleReuseStrategy, ElementsService } from 'dbweb-core'; import { Router, NavigationEnd } from '@angular/router'; import * as i0 from "@angular/core"; import * as i1 from "@angular/router"; import * as i2 from "dbweb-core"; export class Tab { /** * @param {?} state */ constructor(state) { for (const key of Object.keys(state)) { this[key] = state[key]; } this.titleObservable = new BehaviorSubject(state.title); } /** * @return {?} */ data() { return { url: this.url, key: this.key, title: this.title }; } } if (false) { /** @type {?} */ Tab.prototype.url; /** @type {?} */ Tab.prototype.key; /** @type {?} */ Tab.prototype.title; /** @type {?} */ Tab.prototype.titleObservable; } export class TabsService { /** * @param {?} router * @param {?} eles */ constructor(router, eles) { this.router = router; this.eles = eles; this.tabs = []; } // 激活一个tab,如果不存在,则新增并激活 /** * @param {?} data * @return {?} */ activeTab(data) { /** @type {?} */ const find = this.tabs.findIndex((/** * @param {?} v * @return {?} */ v => v.key === data.key)); if (find === -1) { this.tabs.push(new Tab(data)); this._activeIndex = this.tabs.length - 1; } else { this._activeIndex = find; // 同时需要更新url和title this.tabs[this._activeIndex].url = data.url; this.tabs[this._activeIndex].title = data.title; } } // 删除指定序号的tab,并切换激活的tab,如果只有一个tab,则不能被删除 // 返回true指示激活页已经切换 /** * @param {?} index * @return {?} */ removeTab(index) { if (this.tabs.length === 1) { return false; } /** @type {?} */ const deleteURL = this.tabs[index].url.toString(); // 如果是关闭当前页面,则会引起路由变化,所以需要在导航结束事件中删除,因为导航过程中还会进行保存 if (index === this._activeIndex) { /** @type {?} */ const sub = this.router.events.subscribe((/** * @param {?} v * @return {?} */ v => { if (v instanceof NavigationEnd) { SimpleReuseStrategy.deleteRouteSnapshot(deleteURL); sub.unsubscribe(); } })); } else { SimpleReuseStrategy.deleteRouteSnapshot(deleteURL); } this.tabs.splice(index, 1); if (this._activeIndex === index) { this._activeIndex = Math.min(this.tabs.length - 1, index); return true; } if (this._activeIndex > index) { this._activeIndex--; } return false; } // 删除所有的页,一般是logout /** * @return {?} */ clear() { this.tabs.splice(0); this._activeIndex = undefined; SimpleReuseStrategy.clearRouteSnapshot(); } // 关闭当前页,并自动导航到新的页 /** * @return {?} */ close() { if (this.activeIndex >= 0) { /** @type {?} */ const idx = this.activeIndex; if (this.tabs.length === 1) { this.router.navigateByUrl(this.eles.frontElementURL(this.eles.indexElementName)).then((/** * @return {?} */ () => { this.removeTab(idx); })); } if (this.removeTab(idx)) { this.router.navigateByUrl(this.active.url, { state: this.active.data() }); } } } /** * @return {?} */ get active() { if (this._activeIndex >= 0) { return this.tabs[this._activeIndex]; } return undefined; } /** * @return {?} */ get activeIndex() { return this._activeIndex; } /** * @param {?} val * @return {?} */ set activeIndex(val) { this._activeIndex = val; } } TabsService.decorators = [ { type: Injectable, args: [{ providedIn: 'root' },] } ]; /** @nocollapse */ TabsService.ctorParameters = () => [ { type: Router }, { type: ElementsService } ]; /** @nocollapse */ TabsService.ngInjectableDef = i0.ɵɵdefineInjectable({ factory: function TabsService_Factory() { return new TabsService(i0.ɵɵinject(i1.Router), i0.ɵɵinject(i2.ElementsService)); }, token: TabsService, providedIn: "root" }); if (false) { /** @type {?} */ TabsService.prototype.tabs; /** @type {?} */ TabsService.prototype._activeIndex; /** * @type {?} * @private */ TabsService.prototype.router; /** * @type {?} * @private */ TabsService.prototype.eles; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tabs.service.js","sourceRoot":"ng://dbweb-common/","sources":["lib/home/tabs.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport { IRouterState } from '../router-state';\r\nimport { BehaviorSubject } from 'rxjs';\r\nimport { SimpleReuseStrategy, ElementsService } from 'dbweb-core';\r\nimport { UrlTree, Router, NavigationEnd } from '@angular/router';\r\nexport class Tab implements IRouterState {\r\n\turl: UrlTree;\r\n\tkey: string;\r\n\ttitle: string;\r\n\ttitleObservable: BehaviorSubject<string>;\r\n\tconstructor(state: IRouterState) {\r\n\t\tfor (const key of Object.keys(state)) {\r\n\t\t\tthis[key] = state[key];\r\n\t\t}\r\n\t\tthis.titleObservable = new BehaviorSubject<string>(state.title);\r\n\t}\r\n\tdata(): IRouterState {\r\n\t\treturn {\r\n\t\t\turl: this.url,\r\n\t\t\tkey: this.key,\r\n\t\t\ttitle: this.title\r\n\t\t};\r\n\t}\r\n}\r\n\r\n@Injectable({\r\n\tprovidedIn: 'root'\r\n})\r\nexport class TabsService {\r\n\ttabs: Tab[] = [];\r\n\t_activeIndex?: number;\r\n\tconstructor(private router: Router, private eles: ElementsService) {}\r\n\t// 激活一个tab，如果不存在，则新增并激活\r\n\tactiveTab(data: IRouterState) {\r\n\t\tconst find = this.tabs.findIndex(v => v.key === data.key);\r\n\t\tif (find === -1) {\r\n\t\t\tthis.tabs.push(new Tab(data));\r\n\t\t\tthis._activeIndex = this.tabs.length - 1;\r\n\t\t} else {\r\n\t\t\tthis._activeIndex = find;\r\n\t\t\t// 同时需要更新url和title\r\n\t\t\tthis.tabs[this._activeIndex].url = data.url;\r\n\t\t\tthis.tabs[this._activeIndex].title = data.title;\r\n\t\t}\r\n\t}\r\n\t// 删除指定序号的tab，并切换激活的tab，如果只有一个tab，则不能被删除\r\n\t// 返回true指示激活页已经切换\r\n\tremoveTab(index: number): boolean {\r\n\t\tif (this.tabs.length === 1) {\r\n\t\t\treturn false;\r\n\t\t}\r\n\t\tconst deleteURL = this.tabs[index].url.toString();\r\n\t\t// 如果是关闭当前页面，则会引起路由变化，所以需要在导航结束事件中删除，因为导航过程中还会进行保存\r\n\t\tif (index === this._activeIndex) {\r\n\t\t\tconst sub = this.router.events.subscribe(v => {\r\n\t\t\t\tif (v instanceof NavigationEnd) {\r\n\t\t\t\t\tSimpleReuseStrategy.deleteRouteSnapshot(deleteURL);\r\n\t\t\t\t\tsub.unsubscribe();\r\n\t\t\t\t}\r\n\t\t\t});\r\n\t\t} else {\r\n\t\t\tSimpleReuseStrategy.deleteRouteSnapshot(deleteURL);\r\n\t\t}\r\n\t\tthis.tabs.splice(index, 1);\r\n\t\tif (this._activeIndex === index) {\r\n\t\t\tthis._activeIndex = Math.min(this.tabs.length - 1, index);\r\n\t\t\treturn true;\r\n\t\t}\r\n\t\tif (this._activeIndex > index) {\r\n\t\t\tthis._activeIndex--;\r\n\t\t}\r\n\t\treturn false;\r\n\t}\r\n\t// 删除所有的页，一般是logout\r\n\tclear() {\r\n\t\tthis.tabs.splice(0);\r\n\t\tthis._activeIndex = undefined;\r\n\t\tSimpleReuseStrategy.clearRouteSnapshot();\r\n\t}\r\n\t// 关闭当前页，并自动导航到新的页\r\n\tclose() {\r\n\t\tif (this.activeIndex >= 0) {\r\n\t\t\tconst idx = this.activeIndex;\r\n\t\t\tif (this.tabs.length === 1) {\r\n\t\t\t\tthis.router.navigateByUrl(this.eles.frontElementURL(this.eles.indexElementName)).then(() => {\r\n\t\t\t\t\tthis.removeTab(idx);\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t\tif (this.removeTab(idx)) {\r\n\t\t\t\tthis.router.navigateByUrl(this.active.url, {\r\n\t\t\t\t\tstate: this.active.data()\r\n\t\t\t\t});\r\n\t\t\t}\r\n\t\t}\r\n\t}\r\n\tget active() {\r\n\t\tif (this._activeIndex >= 0) {\r\n\t\t\treturn this.tabs[this._activeIndex];\r\n\t\t}\r\n\t\treturn undefined;\r\n\t}\r\n\tget activeIndex() {\r\n\t\treturn this._activeIndex;\r\n\t}\r\n\tset activeIndex(val: number) {\r\n\t\tthis._activeIndex = val;\r\n\t}\r\n}\r\n"]}