dbweb-common
Version:
用`yarn add dbweb-common`安装,不要忘记修改`angular.json`里的 `architect\build\options\assets`,加上
197 lines • 15 kB
JavaScript
/**
* @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"]}