ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
330 lines (322 loc) • 12.6 kB
JavaScript
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