UNPKG

ng-zorro-antd

Version:

An enterprise-class UI components based on Ant Design and Angular

214 lines 16.6 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; /** * @license * Copyright Alibaba.com All Rights Reserved. * * Use of this source code is governed by an MIT-style license that can be * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE */ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, Injector, Input, NgZone, Renderer2, ViewEncapsulation } from '@angular/core'; import { ActivatedRoute, NavigationEnd, PRIMARY_OUTLET, Router } from '@angular/router'; import { Subject } from 'rxjs'; import { startWith } from 'rxjs/internal/operators/startWith'; import { filter, takeUntil } from 'rxjs/operators'; import { InputBoolean } from 'ng-zorro-antd/core'; /** @type {?} */ export const NZ_ROUTE_DATA_BREADCRUMB = 'breadcrumb'; /** * @record */ export function BreadcrumbOption() { } if (false) { /** @type {?} */ BreadcrumbOption.prototype.label; /** @type {?} */ BreadcrumbOption.prototype.params; /** @type {?} */ BreadcrumbOption.prototype.url; } export class NzBreadCrumbComponent { /** * @param {?} injector * @param {?} ngZone * @param {?} cdr * @param {?} elementRef * @param {?} renderer */ constructor(injector, ngZone, cdr, elementRef, renderer) { this.injector = injector; this.ngZone = ngZone; this.cdr = cdr; this.nzAutoGenerate = false; this.nzSeparator = '/'; this.breadcrumbs = []; this.destroy$ = new Subject(); renderer.addClass(elementRef.nativeElement, 'ant-breadcrumb'); } /** * @return {?} */ ngOnInit() { if (this.nzAutoGenerate) { this.registerRouterChange(); } } /** * @return {?} */ ngOnDestroy() { this.destroy$.next(); this.destroy$.complete(); } /** * @param {?} url * @param {?} e * @return {?} */ navigate(url, e) { e.preventDefault(); this.ngZone .run((/** * @return {?} */ () => this.injector .get(Router) .navigateByUrl(url) .then())) .then(); } /** * @private * @return {?} */ registerRouterChange() { try { /** @type {?} */ const router = this.injector.get(Router); /** @type {?} */ const activatedRoute = this.injector.get(ActivatedRoute); router.events .pipe(filter((/** * @param {?} e * @return {?} */ e => e instanceof NavigationEnd)), takeUntil(this.destroy$), startWith(true) // Trigger initial render. ) .subscribe((/** * @return {?} */ () => { this.breadcrumbs = this.getBreadcrumbs(activatedRoute.root); this.cdr.markForCheck(); })); } catch (e) { throw new Error('[NG-ZORRO] You should import RouterModule if you want to use `NzAutoGenerate`'); } } /** * @private * @param {?} route * @param {?=} url * @param {?=} breadcrumbs * @return {?} */ getBreadcrumbs(route, url = '', breadcrumbs = []) { /** @type {?} */ const children = route.children; // If there's no sub root, then stop the recurse and returns the generated breadcrumbs. if (children.length === 0) { return breadcrumbs; } for (const child of children) { if (child.outlet === PRIMARY_OUTLET) { // Only parse components in primary router-outlet (in another word, router-outlet without a specific name). // Parse this layer and generate a breadcrumb item. /** @type {?} */ const routeURL = child.snapshot.url.map((/** * @param {?} segment * @return {?} */ segment => segment.path)).join('/'); /** @type {?} */ const nextUrl = url + `/${routeURL}`; /** @type {?} */ const breadcrumbLabel = child.snapshot.data[NZ_ROUTE_DATA_BREADCRUMB]; // If have data, go to generate a breadcrumb for it. if (routeURL && breadcrumbLabel) { /** @type {?} */ const breadcrumb = { label: breadcrumbLabel, params: child.snapshot.params, url: nextUrl }; breadcrumbs.push(breadcrumb); } return this.getBreadcrumbs(child, nextUrl, breadcrumbs); } } } } NzBreadCrumbComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, selector: 'nz-breadcrumb', exportAs: 'nzBreadcrumb', preserveWhitespaces: false, template: "<ng-content></ng-content>\n<ng-container *ngIf=\"nzAutoGenerate\">\n <nz-breadcrumb-item *ngFor=\"let breadcrumb of breadcrumbs\">\n <a [attr.href]=\"breadcrumb.url\" (click)=\"navigate(breadcrumb.url, $event)\">{{ breadcrumb.label }}</a>\n </nz-breadcrumb-item>\n</ng-container>", styles: [` nz-breadcrumb { display: block; } `] }] } ]; /** @nocollapse */ NzBreadCrumbComponent.ctorParameters = () => [ { type: Injector }, { type: NgZone }, { type: ChangeDetectorRef }, { type: ElementRef }, { type: Renderer2 } ]; NzBreadCrumbComponent.propDecorators = { nzAutoGenerate: [{ type: Input }], nzSeparator: [{ type: Input }] }; tslib_1.__decorate([ InputBoolean(), tslib_1.__metadata("design:type", Object) ], NzBreadCrumbComponent.prototype, "nzAutoGenerate", void 0); if (false) { /** @type {?} */ NzBreadCrumbComponent.prototype.nzAutoGenerate; /** @type {?} */ NzBreadCrumbComponent.prototype.nzSeparator; /** @type {?} */ NzBreadCrumbComponent.prototype.breadcrumbs; /** * @type {?} * @private */ NzBreadCrumbComponent.prototype.destroy$; /** * @type {?} * @private */ NzBreadCrumbComponent.prototype.injector; /** * @type {?} * @private */ NzBreadCrumbComponent.prototype.ngZone; /** * @type {?} * @private */ NzBreadCrumbComponent.prototype.cdr; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-breadcrumb.component.js","sourceRoot":"ng://ng-zorro-antd/breadcrumb/","sources":["nz-breadcrumb.component.ts"],"names":[],"mappings":"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","sourcesContent":["/**\n * @license\n * Copyright Alibaba.com All Rights Reserved.\n *\n * Use of this source code is governed by an MIT-style license that can be\n * found in the LICENSE file at https://github.com/NG-ZORRO/ng-zorro-antd/blob/master/LICENSE\n */\n\nimport {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit,\n  Renderer2,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ActivatedRoute, NavigationEnd, Params, PRIMARY_OUTLET, Router } from '@angular/router';\nimport { Subject } from 'rxjs';\nimport { startWith } from 'rxjs/internal/operators/startWith';\nimport { filter, takeUntil } from 'rxjs/operators';\n\nimport { InputBoolean } from 'ng-zorro-antd/core';\n\nexport const NZ_ROUTE_DATA_BREADCRUMB = 'breadcrumb';\n\nexport interface BreadcrumbOption {\n  label: string;\n  params: Params;\n  url: string;\n}\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  selector: 'nz-breadcrumb',\n  exportAs: 'nzBreadcrumb',\n  preserveWhitespaces: false,\n  templateUrl: './nz-breadcrumb.component.html',\n  styles: [\n    `\n      nz-breadcrumb {\n        display: block;\n      }\n    `\n  ]\n})\nexport class NzBreadCrumbComponent implements OnInit, OnDestroy {\n  @Input() @InputBoolean() nzAutoGenerate = false;\n  @Input() nzSeparator: string | TemplateRef<void> = '/';\n\n  breadcrumbs: BreadcrumbOption[] | undefined = [];\n\n  private destroy$ = new Subject<void>();\n\n  constructor(\n    private injector: Injector,\n    private ngZone: NgZone,\n    private cdr: ChangeDetectorRef,\n    elementRef: ElementRef,\n    renderer: Renderer2\n  ) {\n    renderer.addClass(elementRef.nativeElement, 'ant-breadcrumb');\n  }\n\n  ngOnInit(): void {\n    if (this.nzAutoGenerate) {\n      this.registerRouterChange();\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  navigate(url: string, e: MouseEvent): void {\n    e.preventDefault();\n\n    this.ngZone\n      .run(() =>\n        this.injector\n          .get(Router)\n          .navigateByUrl(url)\n          .then()\n      )\n      .then();\n  }\n\n  private registerRouterChange(): void {\n    try {\n      const router = this.injector.get(Router);\n      const activatedRoute = this.injector.get(ActivatedRoute);\n      router.events\n        .pipe(\n          filter(e => e instanceof NavigationEnd),\n          takeUntil(this.destroy$),\n          startWith(true) // Trigger initial render.\n        )\n        .subscribe(() => {\n          this.breadcrumbs = this.getBreadcrumbs(activatedRoute.root);\n          this.cdr.markForCheck();\n        });\n    } catch (e) {\n      throw new Error('[NG-ZORRO] You should import RouterModule if you want to use `NzAutoGenerate`');\n    }\n  }\n\n  private getBreadcrumbs(\n    route: ActivatedRoute,\n    url: string = '',\n    breadcrumbs: BreadcrumbOption[] = []\n  ): BreadcrumbOption[] | undefined {\n    const children: ActivatedRoute[] = route.children;\n    // If there's no sub root, then stop the recurse and returns the generated breadcrumbs.\n    if (children.length === 0) {\n      return breadcrumbs;\n    }\n    for (const child of children) {\n      if (child.outlet === PRIMARY_OUTLET) {\n        // Only parse components in primary router-outlet (in another word, router-outlet without a specific name).\n        // Parse this layer and generate a breadcrumb item.\n        const routeURL: string = child.snapshot.url.map(segment => segment.path).join('/');\n        const nextUrl = url + `/${routeURL}`;\n        const breadcrumbLabel = child.snapshot.data[NZ_ROUTE_DATA_BREADCRUMB];\n        // If have data, go to generate a breadcrumb for it.\n        if (routeURL && breadcrumbLabel) {\n          const breadcrumb: BreadcrumbOption = {\n            label: breadcrumbLabel,\n            params: child.snapshot.params,\n            url: nextUrl\n          };\n          breadcrumbs.push(breadcrumb);\n        }\n        return this.getBreadcrumbs(child, nextUrl, breadcrumbs);\n      }\n    }\n  }\n}\n"]}