UNPKG

ng-zorro-antd

Version:

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

330 lines (322 loc) 12.6 kB
import { Component, ChangeDetectionStrategy, ViewEncapsulation, Injector, NgZone, ChangeDetectorRef, ElementRef, Renderer2, Input, NgModule } from '@angular/core'; import { NzDropDownModule } from 'ng-zorro-antd/dropdown'; import { __values, __decorate, __metadata } from 'tslib'; import { Router, ActivatedRoute, NavigationEnd, PRIMARY_OUTLET } from '@angular/router'; import { PREFIX } from 'ng-zorro-antd/core/logger'; import { InputBoolean } from 'ng-zorro-antd/core/util'; import { Subject } from 'rxjs'; import { filter, takeUntil, startWith } from 'rxjs/operators'; import { OverlayModule } from '@angular/cdk/overlay'; import { CommonModule } from '@angular/common'; import { NzOutletModule } from 'ng-zorro-antd/core/outlet'; import { NzOverlayModule } from 'ng-zorro-antd/core/overlay'; import { NzIconModule } from 'ng-zorro-antd/icon'; /** * @fileoverview added by tsickle * Generated from: breadcrumb.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @record */ function BreadcrumbOption() { } if (false) { /** @type {?} */ BreadcrumbOption.prototype.label; /** @type {?} */ BreadcrumbOption.prototype.params; /** @type {?} */ BreadcrumbOption.prototype.url; } var NzBreadCrumbComponent = /** @class */ (function () { function NzBreadCrumbComponent(injector, ngZone, cdr, elementRef, renderer) { this.injector = injector; this.ngZone = ngZone; this.cdr = cdr; this.nzAutoGenerate = false; this.nzSeparator = '/'; this.nzRouteLabel = 'breadcrumb'; this.breadcrumbs = []; this.destroy$ = new Subject(); renderer.addClass(elementRef.nativeElement, 'ant-breadcrumb'); } /** * @return {?} */ NzBreadCrumbComponent.prototype.ngOnInit = /** * @return {?} */ function () { if (this.nzAutoGenerate) { this.registerRouterChange(); } }; /** * @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 * @return {?} */ NzBreadCrumbComponent.prototype.registerRouterChange = /** * @private * @return {?} */ function () { var _this = this; try { /** @type {?} */ var router = this.injector.get(Router); /** @type {?} */ var activatedRoute_1 = this.injector.get(ActivatedRoute); router.events .pipe(filter((/** * @param {?} e * @return {?} */ function (e) { return e instanceof NavigationEnd; })), takeUntil(this.destroy$), startWith(true) // Trigger initial render. ) .subscribe((/** * @return {?} */ function () { _this.breadcrumbs = _this.getBreadcrumbs(activatedRoute_1.root); _this.cdr.markForCheck(); })); } catch (e) { throw new Error(PREFIX + " You should import RouterModule if you want to use 'NzAutoGenerate'."); } }; /** * @private * @param {?} route * @param {?=} url * @param {?=} breadcrumbs * @return {?} */ NzBreadCrumbComponent.prototype.getBreadcrumbs = /** * @private * @param {?} route * @param {?=} url * @param {?=} breadcrumbs * @return {?} */ function (route, url, breadcrumbs) { var e_1, _a; if (url === void 0) { url = ''; } if (breadcrumbs === void 0) { breadcrumbs = []; } /** @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 = __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); /** @type {?} */ var breadcrumbLabel = child.snapshot.data[this.nzRouteLabel]; // If have data, go to generate a breadcrumb for it. if (routeURL && breadcrumbLabel) { /** @type {?} */ var breadcrumb = { label: breadcrumbLabel, 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; } } return undefined; }; NzBreadCrumbComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, selector: 'nz-breadcrumb', exportAs: 'nzBreadcrumb', preserveWhitespaces: false, template: "\n <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>\n " }] } ]; /** @nocollapse */ NzBreadCrumbComponent.ctorParameters = function () { return [ { type: Injector }, { type: NgZone }, { type: ChangeDetectorRef }, { type: ElementRef }, { type: Renderer2 } ]; }; NzBreadCrumbComponent.propDecorators = { nzAutoGenerate: [{ type: Input }], nzSeparator: [{ type: Input }], nzRouteLabel: [{ type: Input }] }; __decorate([ InputBoolean(), __metadata("design:type", Object) ], NzBreadCrumbComponent.prototype, "nzAutoGenerate", void 0); return NzBreadCrumbComponent; }()); if (false) { /** @type {?} */ NzBreadCrumbComponent.ngAcceptInputType_nzAutoGenerate; /** @type {?} */ NzBreadCrumbComponent.prototype.nzAutoGenerate; /** @type {?} */ NzBreadCrumbComponent.prototype.nzSeparator; /** @type {?} */ NzBreadCrumbComponent.prototype.nzRouteLabel; /** @type {?} */ NzBreadCrumbComponent.prototype.breadcrumbs; /** * @type {?} * @private */ NzBreadCrumbComponent.prototype.destroy$; /** * @type {?} * @private */ NzBreadCrumbComponent.prototype.injector; /** * @type {?} * @private */ NzBreadCrumbComponent.prototype.ngZone; /** * @type {?} * @private */ NzBreadCrumbComponent.prototype.cdr; } /** * @fileoverview added by tsickle * Generated from: breadcrumb-item.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var NzBreadCrumbItemComponent = /** @class */ (function () { function NzBreadCrumbItemComponent(nzBreadCrumbComponent) { this.nzBreadCrumbComponent = nzBreadCrumbComponent; } NzBreadCrumbItemComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, selector: 'nz-breadcrumb-item', exportAs: 'nzBreadcrumbItem', preserveWhitespaces: false, template: "\n <ng-container *ngIf=\"!!nzOverlay; else noMenuTpl\">\n <span class=\"ant-breadcrumb-overlay-link\" nz-dropdown [nzDropdownMenu]=\"nzOverlay\">\n <ng-template [ngTemplateOutlet]=\"noMenuTpl\"></ng-template>\n <i *ngIf=\"!!nzOverlay\" nz-icon nzType=\"down\"></i>\n </span>\n </ng-container>\n\n <ng-template #noMenuTpl>\n <span class=\"ant-breadcrumb-link\">\n <ng-content></ng-content>\n </span>\n </ng-template>\n\n <span class=\"ant-breadcrumb-separator\" *ngIf=\"nzBreadCrumbComponent.nzSeparator\">\n <ng-container *nzStringTemplateOutlet=\"nzBreadCrumbComponent.nzSeparator\">\n {{ nzBreadCrumbComponent.nzSeparator }}\n </ng-container>\n </span>\n " }] } ]; /** @nocollapse */ NzBreadCrumbItemComponent.ctorParameters = function () { return [ { type: NzBreadCrumbComponent } ]; }; NzBreadCrumbItemComponent.propDecorators = { nzOverlay: [{ type: Input }] }; return NzBreadCrumbItemComponent; }()); if (false) { /** * Dropdown content of a breadcrumb item. * @type {?} */ NzBreadCrumbItemComponent.prototype.nzOverlay; /** @type {?} */ NzBreadCrumbItemComponent.prototype.nzBreadCrumbComponent; } /** * @fileoverview added by tsickle * Generated from: breadcrumb-separator.component.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var NzBreadCrumbSeparatorComponent = /** @class */ (function () { function NzBreadCrumbSeparatorComponent() { } NzBreadCrumbSeparatorComponent.decorators = [ { type: Component, args: [{ selector: 'nz-breadcrumb-separator', exportAs: 'nzBreadcrumbSeparator', template: "\n <span class=\"ant-breadcrumb-separator\">\n <ng-content></ng-content>\n </span>\n " }] } ]; return NzBreadCrumbSeparatorComponent; }()); /** * @fileoverview added by tsickle * Generated from: breadcrumb.module.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ var NzBreadCrumbModule = /** @class */ (function () { function NzBreadCrumbModule() { } NzBreadCrumbModule.decorators = [ { type: NgModule, args: [{ imports: [CommonModule, NzOutletModule, OverlayModule, NzOverlayModule, NzDropDownModule, NzIconModule], declarations: [NzBreadCrumbComponent, NzBreadCrumbItemComponent, NzBreadCrumbSeparatorComponent], exports: [NzBreadCrumbComponent, NzBreadCrumbItemComponent, NzBreadCrumbSeparatorComponent] },] } ]; return NzBreadCrumbModule; }()); /** * @fileoverview added by tsickle * Generated from: public-api.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ /** * @fileoverview added by tsickle * Generated from: ng-zorro-antd-breadcrumb.ts * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ export { NzBreadCrumbComponent, NzBreadCrumbItemComponent, NzBreadCrumbModule, NzBreadCrumbSeparatorComponent }; //# sourceMappingURL=ng-zorro-antd-breadcrumb.js.map