UNPKG

@ohayojp.com/components

Version:

Common business components of ohayojp.

413 lines 33.2 kB
/** * @fileoverview added by tsickle * Generated from: page-header.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { __decorate, __metadata } from "tslib"; import { Platform } from '@angular/cdk/platform'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Inject, Input, Optional, Renderer2, TemplateRef, ViewChild, ViewEncapsulation, } from '@angular/core'; import { NavigationEnd, Router } from '@angular/router'; import { ReuseTabService } from '@ohayojp.com/components/reuse-tab'; import { OHAYO_I18N_TOKEN, MenuService, SettingsService, TitleService } from '@ohayojp.com/theme'; import { OhayoConfigService, InputBoolean, InputNumber, isEmpty } from '@ohayojp.com/util'; import { NzAffixComponent } from 'ng-zorro-antd/affix'; import { merge, Subject } from 'rxjs'; import { filter, takeUntil } from 'rxjs/operators'; /** * @record */ function PageHeaderPath() { } if (false) { /** @type {?|undefined} */ PageHeaderPath.prototype.title; /** @type {?|undefined} */ PageHeaderPath.prototype.link; } export class PageHeaderComponent { // #endregion /** * @param {?} settings * @param {?} renderer * @param {?} router * @param {?} menuSrv * @param {?} i18nSrv * @param {?} titleSrv * @param {?} reuseSrv * @param {?} cdr * @param {?} configSrv * @param {?} platform */ constructor(settings, renderer, router, menuSrv, i18nSrv, titleSrv, reuseSrv, cdr, configSrv, platform) { this.renderer = renderer; this.router = router; this.menuSrv = menuSrv; this.i18nSrv = i18nSrv; this.titleSrv = titleSrv; this.reuseSrv = reuseSrv; this.cdr = cdr; this.inited = false; this.unsubscribe$ = new Subject(); this.isBrowser = true; this._titleVal = ''; this.paths = []; this.loading = false; this.wide = false; this.isBrowser = platform.isBrowser; configSrv.attach(this, 'pageHeader', { home: '首页', homeLink: '/', autoBreadcrumb: true, recursiveBreadcrumb: false, autoTitle: true, syncTitle: true, fixed: false, fixedOffsetTop: 64, }); settings.notify .pipe(takeUntil(this.unsubscribe$), filter((/** * @param {?} w * @return {?} */ w => this.affix && w.type === 'layout' && w.name === 'collapsed'))) .subscribe((/** * @return {?} */ () => this.affix.updatePosition((/** @type {?} */ ({}))))); merge(menuSrv.change.pipe(filter((/** * @return {?} */ () => this.inited))), router.events.pipe(filter((/** * @param {?} ev * @return {?} */ ev => ev instanceof NavigationEnd))), i18nSrv.change) .pipe(takeUntil(this.unsubscribe$)) .subscribe((/** * @return {?} */ () => this.refresh())); } /** * @private * @return {?} */ get menus() { return this.menuSrv.getPathByUrl(this.router.url, this.recursiveBreadcrumb); } /** * @param {?} value * @return {?} */ set title(value) { if (value instanceof TemplateRef) { this._title = null; this._titleTpl = value; this._titleVal = ''; } else { this._title = value; this._titleVal = this._title; } } /** * @return {?} */ refresh() { this.setTitle().genBreadcrumb(); this.cdr.detectChanges(); } /** * @private * @return {?} */ genBreadcrumb() { if (this.breadcrumb || !this.autoBreadcrumb || this.menus.length <= 0) { this.paths = []; return; } /** @type {?} */ const paths = []; this.menus.forEach((/** * @param {?} item * @return {?} */ item => { if (typeof item.hideInBreadcrumb !== 'undefined' && item.hideInBreadcrumb) return; /** @type {?} */ let title = item.text; if (item.i18n && this.i18nSrv) title = this.i18nSrv.fanyi(item.i18n); paths.push({ title, link: (/** @type {?} */ ((item.link && [item.link]))) }); })); // add home if (this.home) { paths.splice(0, 0, { title: (this.homeI18n && this.i18nSrv && this.i18nSrv.fanyi(this.homeI18n)) || this.home, link: [this.homeLink], }); } this.paths = paths; } /** * @private * @template THIS * @this {THIS} * @return {THIS} */ setTitle() { if ((/** @type {?} */ (this))._title == null && (/** @type {?} */ (this))._titleTpl == null && (/** @type {?} */ (this)).autoTitle && (/** @type {?} */ (this)).menus.length > 0) { /** @type {?} */ const item = (/** @type {?} */ (this)).menus[(/** @type {?} */ (this)).menus.length - 1]; /** @type {?} */ let title = item.text; if (item.i18n && (/** @type {?} */ (this)).i18nSrv) { title = (/** @type {?} */ (this)).i18nSrv.fanyi(item.i18n); } (/** @type {?} */ (this))._titleVal = (/** @type {?} */ (title)); } if ((/** @type {?} */ (this))._titleVal && (/** @type {?} */ (this)).syncTitle) { if ((/** @type {?} */ (this)).titleSrv) { (/** @type {?} */ (this)).titleSrv.setTitle((/** @type {?} */ (this))._titleVal); } if (!(/** @type {?} */ (this)).inited && (/** @type {?} */ (this)).reuseSrv) { (/** @type {?} */ (this)).reuseSrv.title = (/** @type {?} */ (this))._titleVal; } } return (/** @type {?} */ (this)); } /** * @return {?} */ checkContent() { if (isEmpty(this.conTpl.nativeElement)) { this.renderer.setAttribute(this.conTpl.nativeElement, 'hidden', ''); } else { this.renderer.removeAttribute(this.conTpl.nativeElement, 'hidden'); } } /** * @return {?} */ ngOnInit() { this.refresh(); this.inited = true; } /** * @return {?} */ ngAfterViewInit() { this.checkContent(); } /** * @return {?} */ ngOnChanges() { if (this.inited) { this.refresh(); } } /** * @return {?} */ ngOnDestroy() { const { unsubscribe$ } = this; unsubscribe$.next(); unsubscribe$.complete(); } } PageHeaderComponent.decorators = [ { type: Component, args: [{ selector: 'page-header', exportAs: 'pageHeader', template: "<nz-affix #affix *ngIf=\"isBrowser && fixed; else phTpl\" [nzOffsetTop]=\"fixedOffsetTop\">\n <ng-template [ngTemplateOutlet]=\"phTpl\"></ng-template>\n</nz-affix>\n<ng-template #phTpl>\n <div class=\"page-header\">\n <div [ngClass]=\"{ 'page-header__wide': wide }\">\n <nz-skeleton [nzLoading]=\"loading\" [nzTitle]=\"false\" [nzActive]=\"true\" [nzParagraph]=\"{ rows: 3 }\" [nzAvatar]=\"{ size: 'large', shape: 'circle' }\">\n <ng-container *ngIf=\"!breadcrumb; else breadcrumb\">\n <nz-breadcrumb *ngIf=\"paths && paths.length > 0\">\n <nz-breadcrumb-item *ngFor=\"let i of paths\">\n <ng-container *ngIf=\"i.link\">\n <a [routerLink]=\"i.link\">{{ i.title }}</a>\n </ng-container>\n <ng-container *ngIf=\"!i.link\">{{ i.title }}</ng-container>\n </nz-breadcrumb-item>\n </nz-breadcrumb>\n </ng-container>\n <div class=\"page-header__detail\">\n <div *ngIf=\"logo\" class=\"page-header__logo\">\n <ng-template [ngTemplateOutlet]=\"logo\"></ng-template>\n </div>\n <div class=\"page-header__main\">\n <div class=\"page-header__row\">\n <h1 *ngIf=\"_titleVal || _titleTpl\" class=\"page-header__title\">\n <ng-container *ngIf=\"_titleVal; else _titleTpl\">{{ _titleVal }}</ng-container>\n </h1>\n <div *ngIf=\"action\" class=\"page-header__action\">\n <ng-template [ngTemplateOutlet]=\"action\"></ng-template>\n </div>\n </div>\n <div class=\"page-header__row\">\n <div class=\"page-header__desc\" (cdkObserveContent)=\"checkContent()\" #conTpl>\n <ng-content></ng-content>\n <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n </div>\n <div *ngIf=\"extra\" class=\"page-header__extra\">\n <ng-template [ngTemplateOutlet]=\"extra\"></ng-template>\n </div>\n </div>\n </div>\n </div>\n <ng-template [ngTemplateOutlet]=\"tab\"></ng-template>\n </nz-skeleton>\n </div>\n </div>\n</ng-template>\n", preserveWhitespaces: false, changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ PageHeaderComponent.ctorParameters = () => [ { type: SettingsService }, { type: Renderer2 }, { type: Router }, { type: MenuService }, { type: undefined, decorators: [{ type: Optional }, { type: Inject, args: [OHAYO_I18N_TOKEN,] }] }, { type: TitleService, decorators: [{ type: Optional }, { type: Inject, args: [TitleService,] }] }, { type: ReuseTabService, decorators: [{ type: Optional }, { type: Inject, args: [ReuseTabService,] }] }, { type: ChangeDetectorRef }, { type: OhayoConfigService }, { type: Platform } ]; PageHeaderComponent.propDecorators = { conTpl: [{ type: ViewChild, args: ['conTpl', { static: false },] }], affix: [{ type: ViewChild, args: ['affix', { static: false },] }], title: [{ type: Input }], loading: [{ type: Input }], wide: [{ type: Input }], home: [{ type: Input }], homeLink: [{ type: Input }], homeI18n: [{ type: Input }], autoBreadcrumb: [{ type: Input }], autoTitle: [{ type: Input }], syncTitle: [{ type: Input }], fixed: [{ type: Input }], fixedOffsetTop: [{ type: Input }], breadcrumb: [{ type: Input }], recursiveBreadcrumb: [{ type: Input }], logo: [{ type: Input }], action: [{ type: Input }], content: [{ type: Input }], extra: [{ type: Input }], tab: [{ type: Input }] }; __decorate([ InputBoolean(), __metadata("design:type", Object) ], PageHeaderComponent.prototype, "loading", void 0); __decorate([ InputBoolean(), __metadata("design:type", Object) ], PageHeaderComponent.prototype, "wide", void 0); __decorate([ InputBoolean(), __metadata("design:type", Boolean) ], PageHeaderComponent.prototype, "autoBreadcrumb", void 0); __decorate([ InputBoolean(), __metadata("design:type", Boolean) ], PageHeaderComponent.prototype, "autoTitle", void 0); __decorate([ InputBoolean(), __metadata("design:type", Boolean) ], PageHeaderComponent.prototype, "syncTitle", void 0); __decorate([ InputBoolean(), __metadata("design:type", Boolean) ], PageHeaderComponent.prototype, "fixed", void 0); __decorate([ InputNumber(), __metadata("design:type", Number) ], PageHeaderComponent.prototype, "fixedOffsetTop", void 0); __decorate([ InputBoolean(), __metadata("design:type", Boolean) ], PageHeaderComponent.prototype, "recursiveBreadcrumb", void 0); if (false) { /** @type {?} */ PageHeaderComponent.ngAcceptInputType_loading; /** @type {?} */ PageHeaderComponent.ngAcceptInputType_wide; /** @type {?} */ PageHeaderComponent.ngAcceptInputType_autoBreadcrumb; /** @type {?} */ PageHeaderComponent.ngAcceptInputType_autoTitle; /** @type {?} */ PageHeaderComponent.ngAcceptInputType_syncTitle; /** @type {?} */ PageHeaderComponent.ngAcceptInputType_fixed; /** @type {?} */ PageHeaderComponent.ngAcceptInputType_fixedOffsetTop; /** @type {?} */ PageHeaderComponent.ngAcceptInputType_recursiveBreadcrumb; /** @type {?} */ PageHeaderComponent.prototype.inited; /** * @type {?} * @private */ PageHeaderComponent.prototype.unsubscribe$; /** * @type {?} * @private */ PageHeaderComponent.prototype.conTpl; /** * @type {?} * @private */ PageHeaderComponent.prototype.affix; /** @type {?} */ PageHeaderComponent.prototype.isBrowser; /** @type {?} */ PageHeaderComponent.prototype._titleVal; /** @type {?} */ PageHeaderComponent.prototype.paths; /** @type {?} */ PageHeaderComponent.prototype._title; /** @type {?} */ PageHeaderComponent.prototype._titleTpl; /** @type {?} */ PageHeaderComponent.prototype.loading; /** @type {?} */ PageHeaderComponent.prototype.wide; /** @type {?} */ PageHeaderComponent.prototype.home; /** @type {?} */ PageHeaderComponent.prototype.homeLink; /** @type {?} */ PageHeaderComponent.prototype.homeI18n; /** @type {?} */ PageHeaderComponent.prototype.autoBreadcrumb; /** @type {?} */ PageHeaderComponent.prototype.autoTitle; /** @type {?} */ PageHeaderComponent.prototype.syncTitle; /** @type {?} */ PageHeaderComponent.prototype.fixed; /** @type {?} */ PageHeaderComponent.prototype.fixedOffsetTop; /** @type {?} */ PageHeaderComponent.prototype.breadcrumb; /** @type {?} */ PageHeaderComponent.prototype.recursiveBreadcrumb; /** @type {?} */ PageHeaderComponent.prototype.logo; /** @type {?} */ PageHeaderComponent.prototype.action; /** @type {?} */ PageHeaderComponent.prototype.content; /** @type {?} */ PageHeaderComponent.prototype.extra; /** @type {?} */ PageHeaderComponent.prototype.tab; /** * @type {?} * @private */ PageHeaderComponent.prototype.renderer; /** * @type {?} * @private */ PageHeaderComponent.prototype.router; /** * @type {?} * @private */ PageHeaderComponent.prototype.menuSrv; /** * @type {?} * @private */ PageHeaderComponent.prototype.i18nSrv; /** * @type {?} * @private */ PageHeaderComponent.prototype.titleSrv; /** * @type {?} * @private */ PageHeaderComponent.prototype.reuseSrv; /** * @type {?} * @private */ PageHeaderComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"page-header.component.js","sourceRoot":"C:/android/@ohayojp/packages/components/page-header/","sources":["page-header.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Platform } from '@angular/cdk/platform';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Inject,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  Optional,\n  Renderer2,\n  TemplateRef,\n  ViewChild,\n  ViewEncapsulation,\n} from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { ReuseTabService } from '@ohayo/components/reuse-tab';\nimport { OhayoI18NService, OHAYO_I18N_TOKEN, Menu, MenuService, SettingsService, TitleService } from '@ohayo/theme';\nimport { OhayoConfigService, BooleanInput, InputBoolean, InputNumber, isEmpty, NumberInput } from '@ohayo/util';\nimport { NzAffixComponent } from 'ng-zorro-antd/affix';\nimport { merge, Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\n\ninterface PageHeaderPath {\n  title?: string;\n  link?: string[];\n}\n\n@Component({\n  selector: 'page-header',\n  exportAs: 'pageHeader',\n  templateUrl: './page-header.component.html',\n  preserveWhitespaces: false,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n})\nexport class PageHeaderComponent implements OnInit, OnChanges, AfterViewInit, OnDestroy {\n  static ngAcceptInputType_loading: BooleanInput;\n  static ngAcceptInputType_wide: BooleanInput;\n  static ngAcceptInputType_autoBreadcrumb: BooleanInput;\n  static ngAcceptInputType_autoTitle: BooleanInput;\n  static ngAcceptInputType_syncTitle: BooleanInput;\n  static ngAcceptInputType_fixed: BooleanInput;\n  static ngAcceptInputType_fixedOffsetTop: NumberInput;\n  static ngAcceptInputType_recursiveBreadcrumb: BooleanInput;\n\n  inited = false;\n  private unsubscribe$ = new Subject<void>();\n  @ViewChild('conTpl', { static: false }) private conTpl: ElementRef;\n  @ViewChild('affix', { static: false }) private affix: NzAffixComponent;\n  isBrowser = true;\n\n  private get menus(): Menu[] {\n    return this.menuSrv.getPathByUrl(this.router.url, this.recursiveBreadcrumb);\n  }\n\n  _titleVal: string = '';\n  paths: PageHeaderPath[] = [];\n\n  // #region fields\n\n  _title: string | null;\n  _titleTpl: TemplateRef<void>;\n  @Input()\n  set title(value: string | TemplateRef<void>) {\n    if (value instanceof TemplateRef) {\n      this._title = null;\n      this._titleTpl = value;\n      this._titleVal = '';\n    } else {\n      this._title = value;\n      this._titleVal = this._title;\n    }\n  }\n\n  @Input() @InputBoolean() loading = false;\n  @Input() @InputBoolean() wide = false;\n  @Input() home: string;\n  @Input() homeLink: string;\n  @Input() homeI18n: string;\n  @Input() @InputBoolean() autoBreadcrumb: boolean;\n  @Input() @InputBoolean() autoTitle: boolean;\n  @Input() @InputBoolean() syncTitle: boolean;\n  @Input() @InputBoolean() fixed: boolean;\n  @Input() @InputNumber() fixedOffsetTop: number;\n  @Input() breadcrumb: TemplateRef<void>;\n  @Input() @InputBoolean() recursiveBreadcrumb: boolean;\n  @Input() logo: TemplateRef<void>;\n  @Input() action: TemplateRef<void>;\n  @Input() content: TemplateRef<void>;\n  @Input() extra: TemplateRef<void>;\n  @Input() tab: TemplateRef<void>;\n\n  // #endregion\n\n  constructor(\n    settings: SettingsService,\n    private renderer: Renderer2,\n    private router: Router,\n    private menuSrv: MenuService,\n    @Optional() @Inject(OHAYO_I18N_TOKEN) private i18nSrv: OhayoI18NService,\n    @Optional() @Inject(TitleService) private titleSrv: TitleService,\n    @Optional() @Inject(ReuseTabService) private reuseSrv: ReuseTabService,\n    private cdr: ChangeDetectorRef,\n    configSrv: OhayoConfigService,\n    platform: Platform,\n  ) {\n    this.isBrowser = platform.isBrowser;\n    configSrv.attach(this, 'pageHeader', {\n      home: '首页',\n      homeLink: '/',\n      autoBreadcrumb: true,\n      recursiveBreadcrumb: false,\n      autoTitle: true,\n      syncTitle: true,\n      fixed: false,\n      fixedOffsetTop: 64,\n    });\n    settings.notify\n      .pipe(\n        takeUntil(this.unsubscribe$),\n        filter(w => this.affix && w.type === 'layout' && w.name === 'collapsed'),\n      )\n      .subscribe(() => this.affix.updatePosition({} as any));\n\n    merge(menuSrv.change.pipe(filter(() => this.inited)), router.events.pipe(filter(ev => ev instanceof NavigationEnd)), i18nSrv.change)\n      .pipe(takeUntil(this.unsubscribe$))\n      .subscribe(() => this.refresh());\n  }\n\n  refresh(): void {\n    this.setTitle().genBreadcrumb();\n    this.cdr.detectChanges();\n  }\n\n  private genBreadcrumb(): void {\n    if (this.breadcrumb || !this.autoBreadcrumb || this.menus.length <= 0) {\n      this.paths = [];\n      return;\n    }\n    const paths: PageHeaderPath[] = [];\n    this.menus.forEach(item => {\n      if (typeof item.hideInBreadcrumb !== 'undefined' && item.hideInBreadcrumb) return;\n      let title = item.text;\n      if (item.i18n && this.i18nSrv) title = this.i18nSrv.fanyi(item.i18n);\n      paths.push({ title, link: (item.link && [item.link]) as string[] });\n    });\n    // add home\n    if (this.home) {\n      paths.splice(0, 0, {\n        title: (this.homeI18n && this.i18nSrv && this.i18nSrv.fanyi(this.homeI18n)) || this.home,\n        link: [this.homeLink],\n      });\n    }\n    this.paths = paths;\n  }\n\n  private setTitle(): this {\n    if (this._title == null && this._titleTpl == null && this.autoTitle && this.menus.length > 0) {\n      const item = this.menus[this.menus.length - 1];\n      let title = item.text;\n      if (item.i18n && this.i18nSrv) {\n        title = this.i18nSrv.fanyi(item.i18n);\n      }\n      this._titleVal = title!;\n    }\n\n    if (this._titleVal && this.syncTitle) {\n      if (this.titleSrv) {\n        this.titleSrv.setTitle(this._titleVal);\n      }\n      if (!this.inited && this.reuseSrv) {\n        this.reuseSrv.title = this._titleVal;\n      }\n    }\n\n    return this;\n  }\n\n  checkContent(): void {\n    if (isEmpty(this.conTpl.nativeElement)) {\n      this.renderer.setAttribute(this.conTpl.nativeElement, 'hidden', '');\n    } else {\n      this.renderer.removeAttribute(this.conTpl.nativeElement, 'hidden');\n    }\n  }\n\n  ngOnInit(): void {\n    this.refresh();\n    this.inited = true;\n  }\n\n  ngAfterViewInit(): void {\n    this.checkContent();\n  }\n\n  ngOnChanges(): void {\n    if (this.inited) {\n      this.refresh();\n    }\n  }\n\n  ngOnDestroy(): void {\n    const { unsubscribe$ } = this;\n    unsubscribe$.next();\n    unsubscribe$.complete();\n  }\n}\n"]}