UNPKG

@lxlib/theme

Version:

This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 9.1.1.

260 lines 17.5 kB
/** * @fileoverview added by tsickle * Generated from: src/services/title/title.service.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { DOCUMENT } from '@angular/common'; import { Inject, Injectable, Injector, Optional } from '@angular/core'; import { Title } from '@angular/platform-browser'; import { ActivatedRoute, Router } from '@angular/router'; import { filter } from 'rxjs/operators'; import { LXLIB_I18N_TOKEN } from '../i18n/i18n'; import { MenuService } from '../menu/menu.service'; import * as i0 from "@angular/core"; import * as i1 from "@angular/platform-browser"; import * as i2 from "../menu/menu.service"; import * as i3 from "../i18n/i18n"; import * as i4 from "@angular/common"; export class TitleService { /** * @param {?} injector * @param {?} title * @param {?} menuSrv * @param {?} i18nSrv * @param {?} doc */ constructor(injector, title, menuSrv, i18nSrv, doc) { this.injector = injector; this.title = title; this.menuSrv = menuSrv; this.i18nSrv = i18nSrv; this.doc = doc; this._prefix = ''; this._suffix = ''; this._separator = ' - '; this._reverse = false; this.DELAY_TIME = 25; /** * 设置默认标题名 */ this.default = `Not Page Name`; this.i18n$ = this.i18nSrv.change.pipe(filter((/** * @return {?} */ () => !!this.i18n$))).subscribe((/** * @return {?} */ () => this.setTitle())); } /** * 设置分隔符 * @param {?} value * @return {?} */ set separator(value) { this._separator = value; } /** * 设置前缀 * @param {?} value * @return {?} */ set prefix(value) { this._prefix = value; } /** * 设置后缀 * @param {?} value * @return {?} */ set suffix(value) { this._suffix = value; } /** * 设置是否反转 * @param {?} value * @return {?} */ set reverse(value) { this._reverse = value; } /** * @private * @return {?} */ getByElement() { /** @type {?} */ const el = (/** @type {?} */ ((this.doc.querySelector('.lxlib-default__content-title h1') || this.doc.querySelector('.page-header__title')))); if (el) { /** @type {?} */ let text = ''; el.childNodes.forEach((/** * @param {?} val * @return {?} */ val => { if (!text && val.nodeType === 3) { text = (/** @type {?} */ (val.textContent)).trim(); } })); return text || (/** @type {?} */ ((/** @type {?} */ (el.firstChild)).textContent)).trim(); } return ''; } /** * @private * @return {?} */ getByRoute() { /** @type {?} */ let next = this.injector.get(ActivatedRoute); while (next.firstChild) next = next.firstChild; /** @type {?} */ const data = (next.snapshot && next.snapshot.data) || {}; if (data.titleI18n && this.i18nSrv) data.title = this.i18nSrv.fanyi(data.titleI18n); return data.title; } /** * @private * @return {?} */ getByMenu() { /** @type {?} */ const menus = this.menuSrv.getPathByUrl(this.injector.get(Router).url); if (!menus || menus.length <= 0) return ''; /** @type {?} */ const item = menus[menus.length - 1]; /** @type {?} */ let title; if (item.i18n && this.i18nSrv) title = this.i18nSrv.fanyi(item.i18n); return title || (/** @type {?} */ (item.text)); } /** * @private * @param {?=} title * @return {?} */ _setTitle(title) { if (!title) { title = this.getByRoute() || this.getByMenu() || this.getByElement() || this.default; } if (title && !Array.isArray(title)) { title = [title]; } /** @type {?} */ let newTitles = []; if (this._prefix) { newTitles.push(this._prefix); } newTitles.push(...((/** @type {?} */ (title)))); if (this._suffix) { newTitles.push(this._suffix); } if (this._reverse) { newTitles = newTitles.reverse(); } this.title.setTitle(newTitles.join(this._separator)); } /** * Set the document title, will be delay `25ms`, pls refer to [#1261](https://github.com/ng-alain/ng-alain/issues/1261) * @param {?=} title * @return {?} */ setTitle(title) { setTimeout((/** * @return {?} */ () => this._setTitle(title)), this.DELAY_TIME); } /** * Set i18n key of the document title * @param {?} key * @param {?=} params * @return {?} */ setTitleByI18n(key, params) { this.setTitle(this.i18nSrv.fanyi(key, params)); } /** * @return {?} */ ngOnDestroy() { this.i18n$.unsubscribe(); } } TitleService.decorators = [ { type: Injectable, args: [{ providedIn: 'root' },] } ]; /** @nocollapse */ TitleService.ctorParameters = () => [ { type: Injector }, { type: Title }, { type: MenuService }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [LXLIB_I18N_TOKEN,] }] }, { type: undefined, decorators: [{ type: Inject, args: [DOCUMENT,] }] } ]; /** @nocollapse */ TitleService.ɵprov = i0.ɵɵdefineInjectable({ factory: function TitleService_Factory() { return new TitleService(i0.ɵɵinject(i0.INJECTOR), i0.ɵɵinject(i1.Title), i0.ɵɵinject(i2.MenuService), i0.ɵɵinject(i3.LXLIB_I18N_TOKEN, 8), i0.ɵɵinject(i4.DOCUMENT)); }, token: TitleService, providedIn: "root" }); if (false) { /** * @type {?} * @private */ TitleService.prototype._prefix; /** * @type {?} * @private */ TitleService.prototype._suffix; /** * @type {?} * @private */ TitleService.prototype._separator; /** * @type {?} * @private */ TitleService.prototype._reverse; /** * @type {?} * @private */ TitleService.prototype.i18n$; /** @type {?} */ TitleService.prototype.DELAY_TIME; /** * 设置默认标题名 * @type {?} */ TitleService.prototype.default; /** * @type {?} * @private */ TitleService.prototype.injector; /** * @type {?} * @private */ TitleService.prototype.title; /** * @type {?} * @private */ TitleService.prototype.menuSrv; /** * @type {?} * @private */ TitleService.prototype.i18nSrv; /** * @type {?} * @private */ TitleService.prototype.doc; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"title.service.js","sourceRoot":"ng://@lxlib/theme/","sources":["src/services/title/title.service.ts"],"names":[],"mappings":";;;;;AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,iBAAiB,CAAC;AAC3C,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAa,QAAQ,EAAE,MAAM,eAAe,CAAC;AAClF,OAAO,EAAE,KAAK,EAAE,MAAM,2BAA2B,CAAC;AAClD,OAAO,EAAE,cAAc,EAAE,MAAM,EAAE,MAAM,iBAAiB,CAAC;AAEzD,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAExC,OAAO,EAAoB,gBAAgB,EAAE,MAAM,cAAc,CAAC;AAClE,OAAO,EAAE,WAAW,EAAE,MAAM,sBAAsB,CAAC;;;;;;AAGnD,MAAM,OAAO,YAAY;;;;;;;;IASvB,YACU,QAAkB,EAClB,KAAY,EACZ,OAAoB,EAGpB,OAAyB,EACP,GAAQ;QAN1B,aAAQ,GAAR,QAAQ,CAAU;QAClB,UAAK,GAAL,KAAK,CAAO;QACZ,YAAO,GAAP,OAAO,CAAa;QAGpB,YAAO,GAAP,OAAO,CAAkB;QACP,QAAG,GAAH,GAAG,CAAK;QAf5B,YAAO,GAAW,EAAE,CAAC;QACrB,YAAO,GAAW,EAAE,CAAC;QACrB,eAAU,GAAW,KAAK,CAAC;QAC3B,aAAQ,GAAY,KAAK,CAAC;QAGzB,eAAU,GAAG,EAAE,CAAC;;;;QAmCzB,YAAO,GAAG,eAAe,CAAC;QAxBxB,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,MAAM;;;QAAC,GAAG,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,EAAC,CAAC,CAAC,SAAS;;;QAAC,GAAG,EAAE,CAAC,IAAI,CAAC,QAAQ,EAAE,EAAC,CAAC;IACrG,CAAC;;;;;;IAGD,IAAI,SAAS,CAAC,KAAa;QACzB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;IAC1B,CAAC;;;;;;IAGD,IAAI,MAAM,CAAC,KAAa;QACtB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;;;;;;IAGD,IAAI,MAAM,CAAC,KAAa;QACtB,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;IACvB,CAAC;;;;;;IAGD,IAAI,OAAO,CAAC,KAAc;QACxB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;IACxB,CAAC;;;;;IAKO,YAAY;;cACZ,EAAE,GAAG,mBAAA,CAAC,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,kCAAkC,CAAC,IAAI,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,qBAAqB,CAAC,CAAC,EAAe;QACvI,IAAI,EAAE,EAAE;;gBACF,IAAI,GAAG,EAAE;YACb,EAAE,CAAC,UAAU,CAAC,OAAO;;;;YAAC,GAAG,CAAC,EAAE;gBAC1B,IAAI,CAAC,IAAI,IAAI,GAAG,CAAC,QAAQ,KAAK,CAAC,EAAE;oBAC/B,IAAI,GAAG,mBAAA,GAAG,CAAC,WAAW,EAAC,CAAC,IAAI,EAAE,CAAC;iBAChC;YACH,CAAC,EAAC,CAAC;YACH,OAAO,IAAI,IAAI,mBAAA,mBAAA,EAAE,CAAC,UAAU,EAAC,CAAC,WAAW,EAAC,CAAC,IAAI,EAAE,CAAC;SACnD;QACD,OAAO,EAAE,CAAC;IACZ,CAAC;;;;;IAEO,UAAU;;YACZ,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,cAAc,CAAC;QAC5C,OAAO,IAAI,CAAC,UAAU;YAAE,IAAI,GAAG,IAAI,CAAC,UAAU,CAAC;;cACzC,IAAI,GAAG,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,IAAI,EAAE;QACxD,IAAI,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO;YAAE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;QACpF,OAAO,IAAI,CAAC,KAAK,CAAC;IACpB,CAAC;;;;;IAEO,SAAS;;cACT,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,YAAY,CAAC,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAS,MAAM,CAAC,CAAC,GAAG,CAAC;QAC9E,IAAI,CAAC,KAAK,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC;YAAE,OAAO,EAAE,CAAC;;cAErC,IAAI,GAAG,KAAK,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;;YAChC,KAAK;QACT,IAAI,IAAI,CAAC,IAAI,IAAI,IAAI,CAAC,OAAO;YAAE,KAAK,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;QACrE,OAAO,KAAK,IAAI,mBAAA,IAAI,CAAC,IAAI,EAAC,CAAC;IAC7B,CAAC;;;;;;IAEO,SAAS,CAAC,KAAyB;QACzC,IAAI,CAAC,KAAK,EAAE;YACV,KAAK,GAAG,IAAI,CAAC,UAAU,EAAE,IAAI,IAAI,CAAC,SAAS,EAAE,IAAI,IAAI,CAAC,YAAY,EAAE,IAAI,IAAI,CAAC,OAAO,CAAC;SACtF;QACD,IAAI,KAAK,IAAI,CAAC,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YAClC,KAAK,GAAG,CAAC,KAAK,CAAC,CAAC;SACjB;;YAEG,SAAS,GAAa,EAAE;QAC5B,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAC9B;QACD,SAAS,CAAC,IAAI,CAAC,GAAG,CAAC,mBAAA,KAAK,EAAY,CAAC,CAAC,CAAC;QACvC,IAAI,IAAI,CAAC,OAAO,EAAE;YAChB,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;SAC9B;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,SAAS,GAAG,SAAS,CAAC,OAAO,EAAE,CAAC;SACjC;QACD,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,SAAS,CAAC,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,CAAC;IACvD,CAAC;;;;;;IAKD,QAAQ,CAAC,KAAyB;QAChC,UAAU;;;QAAC,GAAG,EAAE,CAAC,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC,GAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IAC3D,CAAC;;;;;;;IAKD,cAAc,CAAC,GAAW,EAAE,MAAW;QACrC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,GAAG,EAAE,MAAM,CAAC,CAAC,CAAC;IACjD,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,KAAK,CAAC,WAAW,EAAE,CAAC;IAC3B,CAAC;;;YAnHF,UAAU,SAAC,EAAE,UAAU,EAAE,MAAM,EAAE;;;;YATL,QAAQ;YAC5B,KAAK;YAML,WAAW;4CAgBf,QAAQ,YACR,MAAM,SAAC,gBAAgB;4CAEvB,MAAM,SAAC,QAAQ;;;;;;;;IAflB,+BAA6B;;;;;IAC7B,+BAA6B;;;;;IAC7B,kCAAmC;;;;;IACnC,gCAAkC;;;;;IAClC,6BAA4B;;IAE5B,kCAAyB;;;;;IAmCzB,+BAA0B;;;;;IAhCxB,gCAA0B;;;;;IAC1B,6BAAoB;;;;;IACpB,+BAA4B;;;;;IAC5B,+BAEiC;;;;;IACjC,2BAAkC","sourcesContent":["import { DOCUMENT } from '@angular/common';\nimport { Inject, Injectable, Injector, OnDestroy, Optional } from '@angular/core';\nimport { Title } from '@angular/platform-browser';\nimport { ActivatedRoute, Router } from '@angular/router';\nimport { Subscription } from 'rxjs';\nimport { filter } from 'rxjs/operators';\n\nimport { LxlibI18NService, LXLIB_I18N_TOKEN } from '../i18n/i18n';\nimport { MenuService } from '../menu/menu.service';\n\n@Injectable({ providedIn: 'root' })\nexport class TitleService implements OnDestroy {\n  private _prefix: string = '';\n  private _suffix: string = '';\n  private _separator: string = ' - ';\n  private _reverse: boolean = false;\n  private i18n$: Subscription;\n\n  readonly DELAY_TIME = 25;\n\n  constructor(\n    private injector: Injector,\n    private title: Title,\n    private menuSrv: MenuService,\n    @Optional()\n    @Inject(LXLIB_I18N_TOKEN)\n    private i18nSrv: LxlibI18NService,\n    @Inject(DOCUMENT) private doc: any,\n  ) {\n    this.i18n$ = this.i18nSrv.change.pipe(filter(() => !!this.i18n$)).subscribe(() => this.setTitle());\n  }\n\n  /** 设置分隔符 */\n  set separator(value: string) {\n    this._separator = value;\n  }\n\n  /** 设置前缀 */\n  set prefix(value: string) {\n    this._prefix = value;\n  }\n\n  /** 设置后缀 */\n  set suffix(value: string) {\n    this._suffix = value;\n  }\n\n  /** 设置是否反转 */\n  set reverse(value: boolean) {\n    this._reverse = value;\n  }\n\n  /** 设置默认标题名 */\n  default = `Not Page Name`;\n\n  private getByElement(): string {\n    const el = (this.doc.querySelector('.lxlib-default__content-title h1') || this.doc.querySelector('.page-header__title')) as HTMLElement;\n    if (el) {\n      let text = '';\n      el.childNodes.forEach(val => {\n        if (!text && val.nodeType === 3) {\n          text = val.textContent!.trim();\n        }\n      });\n      return text || el.firstChild!.textContent!.trim();\n    }\n    return '';\n  }\n\n  private getByRoute(): string {\n    let next = this.injector.get(ActivatedRoute);\n    while (next.firstChild) next = next.firstChild;\n    const data = (next.snapshot && next.snapshot.data) || {};\n    if (data.titleI18n && this.i18nSrv) data.title = this.i18nSrv.fanyi(data.titleI18n);\n    return data.title;\n  }\n\n  private getByMenu(): string {\n    const menus = this.menuSrv.getPathByUrl(this.injector.get<Router>(Router).url);\n    if (!menus || menus.length <= 0) return '';\n\n    const item = menus[menus.length - 1];\n    let title;\n    if (item.i18n && this.i18nSrv) title = this.i18nSrv.fanyi(item.i18n);\n    return title || item.text!;\n  }\n\n  private _setTitle(title?: string | string[]) {\n    if (!title) {\n      title = this.getByRoute() || this.getByMenu() || this.getByElement() || this.default;\n    }\n    if (title && !Array.isArray(title)) {\n      title = [title];\n    }\n\n    let newTitles: string[] = [];\n    if (this._prefix) {\n      newTitles.push(this._prefix);\n    }\n    newTitles.push(...(title as string[]));\n    if (this._suffix) {\n      newTitles.push(this._suffix);\n    }\n    if (this._reverse) {\n      newTitles = newTitles.reverse();\n    }\n    this.title.setTitle(newTitles.join(this._separator));\n  }\n\n  /**\n   * Set the document title, will be delay `25ms`, pls refer to [#1261](https://github.com/ng-alain/ng-alain/issues/1261)\n   */\n  setTitle(title?: string | string[]) {\n    setTimeout(() => this._setTitle(title), this.DELAY_TIME);\n  }\n\n  /**\n   * Set i18n key of the document title\n   */\n  setTitleByI18n(key: string, params?: {}) {\n    this.setTitle(this.i18nSrv.fanyi(key, params));\n  }\n\n  ngOnDestroy(): void {\n    this.i18n$.unsubscribe();\n  }\n}\n"]}