@ohayojp.com/components
Version:
Common business components of ohayojp.
413 lines • 33.2 kB
JavaScript
/**
* @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"]}