@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
JavaScript
/**
* @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":"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","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"]}