UNPKG

ng-zorro-antd

Version:

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

207 lines 16.1 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; 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 { filter, takeUntil } from 'rxjs/operators'; /** @type {?} */ export var NZ_ROUTE_DATA_BREADCRUMB = 'breadcrumb'; /** * @record */ export function BreadcrumbOption() { } if (false) { /** @type {?} */ BreadcrumbOption.prototype.label; /** @type {?} */ BreadcrumbOption.prototype.params; /** @type {?} */ BreadcrumbOption.prototype.url; } var NzBreadCrumbComponent = /** @class */ (function () { function NzBreadCrumbComponent(injector, ngZone, cd, elementRef, renderer) { this.injector = injector; this.ngZone = ngZone; this.cd = cd; this.nzAutoGenerate = false; this.nzSeparator = '/'; this.breadcrumbs = []; this.destroy$ = new Subject(); renderer.addClass(elementRef.nativeElement, 'ant-breadcrumb'); } /** * @return {?} */ NzBreadCrumbComponent.prototype.ngOnInit = /** * @return {?} */ function () { var _this = this; if (this.nzAutoGenerate) { try { /** @type {?} */ var activatedRoute_1 = this.injector.get(ActivatedRoute); /** @type {?} */ var router = this.injector.get(Router); router.events.pipe(filter((/** * @param {?} e * @return {?} */ function (e) { return e instanceof NavigationEnd; })), takeUntil(this.destroy$)).subscribe((/** * @return {?} */ function () { _this.breadcrumbs = _this.getBreadcrumbs(activatedRoute_1.root); _this.cd.markForCheck(); })); } catch (e) { throw new Error('[NG-ZORRO] You should import RouterModule if you want to use NzAutoGenerate'); } } }; /** * @return {?} */ NzBreadCrumbComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.destroy$.next(); this.destroy$.complete(); }; /** * @param {?} url * @param {?} e * @return {?} */ NzBreadCrumbComponent.prototype.navigate = /** * @param {?} url * @param {?} e * @return {?} */ function (url, e) { var _this = this; e.preventDefault(); this.ngZone.run((/** * @return {?} */ function () { return _this.injector.get(Router).navigateByUrl(url).then(); })).then(); }; /** * @private * @param {?} route * @param {?=} url * @param {?=} breadcrumbs * @return {?} */ NzBreadCrumbComponent.prototype.getBreadcrumbs = /** * @private * @param {?} route * @param {?=} url * @param {?=} breadcrumbs * @return {?} */ function (route, url, breadcrumbs) { if (url === void 0) { url = ''; } if (breadcrumbs === void 0) { breadcrumbs = []; } var e_1, _a; /** @type {?} */ var children = route.children; // If there's no sub root, then stop the recurse and returns the generated breadcrumbs. if (children.length === 0) { return breadcrumbs; } try { for (var children_1 = tslib_1.__values(children), children_1_1 = children_1.next(); !children_1_1.done; children_1_1 = children_1.next()) { var child = children_1_1.value; 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 {?} */ var routeURL = child.snapshot.url.map((/** * @param {?} segment * @return {?} */ function (segment) { return segment.path; })).join('/'); /** @type {?} */ var nextUrl = url + ("/" + routeURL); // If have data, go to generate a breadcrumb for it. if (child.snapshot.data.hasOwnProperty(NZ_ROUTE_DATA_BREADCRUMB)) { /** @type {?} */ var breadcrumb = { label: child.snapshot.data[NZ_ROUTE_DATA_BREADCRUMB] || 'Breadcrumb', params: child.snapshot.params, url: nextUrl }; breadcrumbs.push(breadcrumb); } return this.getBreadcrumbs(child, nextUrl, breadcrumbs); } } } catch (e_1_1) { e_1 = { error: e_1_1 }; } finally { try { if (children_1_1 && !children_1_1.done && (_a = children_1.return)) _a.call(children_1); } finally { if (e_1) throw e_1.error; } } }; NzBreadCrumbComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, selector: 'nz-breadcrumb', 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: ["\n nz-breadcrumb {\n display: block;\n }\n "] }] } ]; /** @nocollapse */ NzBreadCrumbComponent.ctorParameters = function () { return [ { type: Injector }, { type: NgZone }, { type: ChangeDetectorRef }, { type: ElementRef }, { type: Renderer2 } ]; }; NzBreadCrumbComponent.propDecorators = { nzAutoGenerate: [{ type: Input }], nzSeparator: [{ type: Input }] }; return NzBreadCrumbComponent; }()); export { NzBreadCrumbComponent }; 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.cd; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-breadcrumb.component.js","sourceRoot":"ng://ng-zorro-antd/","sources":["breadcrumb/nz-breadcrumb.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component, ElementRef,\n  Injector,\n  Input,\n  NgZone,\n  OnDestroy,\n  OnInit, Renderer2,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { ActivatedRoute, NavigationEnd, Params, PRIMARY_OUTLET, Router } from '@angular/router';\nimport { Subject } from 'rxjs';\nimport { filter, takeUntil } from 'rxjs/operators';\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  preserveWhitespaces: false,\n  templateUrl        : './nz-breadcrumb.component.html',\n  styles             : [ `\n    nz-breadcrumb {\n      display: block;\n    }\n  ` ]\n})\nexport class NzBreadCrumbComponent implements OnInit, OnDestroy {\n  @Input() nzAutoGenerate = false;\n  @Input() nzSeparator: string | TemplateRef<void> = '/';\n\n  breadcrumbs: BreadcrumbOption[] = [];\n\n  private destroy$ = new Subject<void>();\n\n  constructor(private injector: Injector, private ngZone: NgZone, private cd: ChangeDetectorRef, elementRef: ElementRef, renderer: Renderer2) {\n    renderer.addClass(elementRef.nativeElement, 'ant-breadcrumb');\n  }\n\n  ngOnInit(): void {\n    if (this.nzAutoGenerate) {\n      try {\n        const activatedRoute = this.injector.get(ActivatedRoute);\n        const router = this.injector.get(Router);\n        router.events.pipe(filter(e => e instanceof NavigationEnd), takeUntil(this.destroy$)).subscribe(() => {\n          this.breadcrumbs = this.getBreadcrumbs(activatedRoute.root);\n          this.cd.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\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  navigate(url: string, e: MouseEvent): void {\n    e.preventDefault();\n    this.ngZone.run(() => this.injector.get(Router).navigateByUrl(url).then()).then();\n  }\n\n  private getBreadcrumbs(route: ActivatedRoute, url: string = '', breadcrumbs: BreadcrumbOption[] = []): BreadcrumbOption[] {\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        // If have data, go to generate a breadcrumb for it.\n        if (child.snapshot.data.hasOwnProperty(NZ_ROUTE_DATA_BREADCRUMB)) {\n          const breadcrumb: BreadcrumbOption = {\n            label : child.snapshot.data[ NZ_ROUTE_DATA_BREADCRUMB ] || 'Breadcrumb',\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"]}