UNPKG

ng-zorro-antd

Version:

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

315 lines 28.9 kB
/** * @fileoverview added by tsickle * Generated from: nz-descriptions.component.ts * @suppress {checkTypes,constantProperty,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 { MediaMatcher } from '@angular/cdk/layout'; import { Platform } from '@angular/cdk/platform'; import { ChangeDetectionStrategy, ChangeDetectorRef, Component, ContentChildren, Input, QueryList, ViewEncapsulation } from '@angular/core'; import { merge, Subject } from 'rxjs'; import { auditTime, finalize, startWith, switchMap, takeUntil } from 'rxjs/operators'; import { responsiveMap, warn, InputBoolean, NzBreakpoint, NzConfigService, NzDomEventService, WithConfig } from 'ng-zorro-antd/core'; import { NzDescriptionsItemComponent } from './nz-descriptions-item.component'; /** @type {?} */ var NZ_CONFIG_COMPONENT_NAME = 'descriptions'; /** @type {?} */ var defaultColumnMap = { xxl: 3, xl: 3, lg: 3, md: 3, sm: 2, xs: 1 }; var NzDescriptionsComponent = /** @class */ (function () { function NzDescriptionsComponent(nzConfigService, cdr, mediaMatcher, platform, nzDomEventService) { this.nzConfigService = nzConfigService; this.cdr = cdr; this.mediaMatcher = mediaMatcher; this.platform = platform; this.nzDomEventService = nzDomEventService; this.nzLayout = 'horizontal'; this.nzTitle = ''; this.itemMatrix = []; this.realColumn = 3; this.destroy$ = new Subject(); this.resize$ = new Subject(); } /** * @param {?} changes * @return {?} */ NzDescriptionsComponent.prototype.ngOnChanges = /** * @param {?} changes * @return {?} */ function (changes) { if (changes.nzColumn) { this.resize$.next(); } }; /** * @return {?} */ NzDescriptionsComponent.prototype.ngAfterContentInit = /** * @return {?} */ function () { var _this = this; /** @type {?} */ var contentChange$ = this.items.changes.pipe(startWith(this.items), takeUntil(this.destroy$)); merge(contentChange$, contentChange$.pipe(switchMap((/** * @return {?} */ function () { return merge.apply(void 0, tslib_1.__spread(_this.items.map((/** * @param {?} i * @return {?} */ function (i) { return i.inputChange$; })))).pipe(auditTime(16)); }))), this.resize$) .pipe(takeUntil(this.destroy$)) .subscribe((/** * @return {?} */ function () { _this.prepareMatrix(); _this.cdr.markForCheck(); })); if (this.platform.isBrowser) { this.nzDomEventService .registerResizeListener() .pipe(takeUntil(this.destroy$), finalize((/** * @return {?} */ function () { return _this.nzDomEventService.unregisterResizeListener(); }))) .subscribe((/** * @return {?} */ function () { return _this.resize$.next(); })); } }; /** * @return {?} */ NzDescriptionsComponent.prototype.ngOnDestroy = /** * @return {?} */ function () { this.destroy$.next(); this.destroy$.complete(); this.resize$.complete(); }; /** * Prepare the render matrix according to description items' spans. */ /** * Prepare the render matrix according to description items' spans. * @private * @return {?} */ NzDescriptionsComponent.prototype.prepareMatrix = /** * Prepare the render matrix according to description items' spans. * @private * @return {?} */ function () { /** @type {?} */ var currentRow = []; /** @type {?} */ var width = 0; /** @type {?} */ var column = (this.realColumn = this.getColumn()); /** @type {?} */ var items = this.items.toArray(); /** @type {?} */ var length = items.length; /** @type {?} */ var matrix = []; /** @type {?} */ var flushRow = (/** * @return {?} */ function () { matrix.push(currentRow); currentRow = []; width = 0; }); for (var i = 0; i < length; i++) { /** @type {?} */ var item = items[i]; var title = item.nzTitle, content = item.content, span = item.nzSpan; width += span; // If the last item make the row's length exceeds `nzColumn`, the last // item should take all the space left. This logic is implemented in the template. // Warn user about that. if (width >= column) { if (width > column) { warn("\"nzColumn\" is " + column + " but we have row length " + width); } currentRow.push({ title: title, content: content, span: column - (width - span) }); flushRow(); } else if (i === length - 1) { currentRow.push({ title: title, content: content, span: column - (width - span) }); flushRow(); } else { currentRow.push({ title: title, content: content, span: span }); } } this.itemMatrix = matrix; }; /** * @private * @return {?} */ NzDescriptionsComponent.prototype.matchMedia = /** * @private * @return {?} */ function () { var _this = this; /** @type {?} */ var bp = NzBreakpoint.md; Object.keys(responsiveMap).map((/** * @param {?} breakpoint * @return {?} */ function (breakpoint) { /** @type {?} */ var castBP = (/** @type {?} */ (breakpoint)); /** @type {?} */ var matchBelow = _this.mediaMatcher.matchMedia(responsiveMap[castBP]).matches; if (matchBelow) { bp = castBP; } })); return bp; }; /** * @private * @return {?} */ NzDescriptionsComponent.prototype.getColumn = /** * @private * @return {?} */ function () { if (typeof this.nzColumn !== 'number') { return this.nzColumn[this.matchMedia()]; } return this.nzColumn; }; NzDescriptionsComponent.decorators = [ { type: Component, args: [{ changeDetection: ChangeDetectionStrategy.OnPush, encapsulation: ViewEncapsulation.None, selector: 'nz-descriptions', template: "<div *ngIf=\"nzTitle\"\n class=\"ant-descriptions-title\">\n <ng-container *nzStringTemplateOutlet=\"nzTitle\">{{ nzTitle }}</ng-container>\n</div>\n<div class=\"ant-descriptions-view\">\n <table>\n <tbody>\n <ng-container *ngIf=\"nzLayout === 'horizontal'\">\n <tr class=\"ant-descriptions-row\"\n *ngFor=\"let row of itemMatrix; let i = index\">\n <ng-container *ngFor=\"let item of row; let isLast = last\">\n <!-- Horizontal & NOT Bordered -->\n <ng-container *ngIf=\"!nzBordered\">\n <td class=\"ant-descriptions-item\"\n [colSpan]=\"item.span\">\n <span class=\"ant-descriptions-item-label\"\n [class.ant-descriptions-item-colon]=\"nzColon\">{{ item.title }}</span>\n <span class=\"ant-descriptions-item-content\">\n <ng-template [ngTemplateOutlet]=\"item.content\"></ng-template>\n </span>\n </td>\n </ng-container>\n <!-- Horizontal & Bordered -->\n <ng-container *ngIf=\"nzBordered\">\n <td class=\"ant-descriptions-item-label\"\n *nzStringTemplateOutlet=\"item.title\">{{ item.title }}</td>\n <td class=\"ant-descriptions-item-content\"\n [colSpan]=\"item.span * 2 - 1\">\n <ng-template [ngTemplateOutlet]=\"item.content\"></ng-template>\n </td>\n </ng-container>\n </ng-container>\n </tr>\n </ng-container>\n\n <ng-container *ngIf=\"nzLayout === 'vertical'\">\n <!-- Vertical & NOT Bordered -->\n <ng-container *ngIf=\"!nzBordered\">\n <ng-container *ngFor=\"let row of itemMatrix; let i = index\">\n <tr class=\"ant-descriptions-row\">\n <ng-container *ngFor=\"let item of row; let isLast = last\">\n <td class=\"ant-descriptions-item\"\n [colSpan]=\"item.span\">\n <span class=\"ant-descriptions-item-label\"\n [class.ant-descriptions-item-colon]=\"nzColon\">{{ item.title }}</span>\n </td>\n </ng-container>\n </tr>\n <tr class=\"ant-descriptions-row\">\n <ng-container *ngFor=\"let item of row; let isLast = last\">\n <td class=\"ant-descriptions-item\"\n [colSpan]=\"item.span\">\n <span class=\"ant-descriptions-item-content\">\n <ng-template [ngTemplateOutlet]=\"item.content\"></ng-template>\n </span>\n </td>\n </ng-container>\n </tr>\n </ng-container>\n </ng-container>\n <!-- Vertical & Bordered -->\n <ng-container *ngIf=\"nzBordered\">\n <ng-container *ngFor=\"let row of itemMatrix; let i = index\">\n <tr class=\"ant-descriptions-row\">\n <ng-container *ngFor=\"let item of row; let isLast = last\">\n <td class=\"ant-descriptions-item-label\"\n [colSpan]=\"item.span\">\n {{ item.title }}\n </td>\n </ng-container>\n </tr>\n <tr class=\"ant-descriptions-row\">\n <ng-container *ngFor=\"let item of row; let isLast = last\">\n <td class=\"ant-descriptions-item-content\"\n [colSpan]=\"item.span\">\n <ng-template [ngTemplateOutlet]=\"item.content\"></ng-template>\n </td>\n </ng-container>\n </tr>\n </ng-container>\n </ng-container>\n </ng-container>\n </tbody>\n </table>\n</div>\n", exportAs: 'nzDescriptions', preserveWhitespaces: false, host: { class: 'ant-descriptions', '[class.ant-descriptions-bordered]': 'nzBordered', '[class.ant-descriptions-middle]': 'nzSize === "middle"', '[class.ant-descriptions-small]': 'nzSize === "small"' }, styles: ["\n nz-descriptions {\n display: block;\n }\n "] }] } ]; /** @nocollapse */ NzDescriptionsComponent.ctorParameters = function () { return [ { type: NzConfigService }, { type: ChangeDetectorRef }, { type: MediaMatcher }, { type: Platform }, { type: NzDomEventService } ]; }; NzDescriptionsComponent.propDecorators = { items: [{ type: ContentChildren, args: [NzDescriptionsItemComponent,] }], nzBordered: [{ type: Input }], nzLayout: [{ type: Input }], nzColumn: [{ type: Input }], nzSize: [{ type: Input }], nzTitle: [{ type: Input }], nzColon: [{ type: Input }] }; tslib_1.__decorate([ InputBoolean(), WithConfig(NZ_CONFIG_COMPONENT_NAME, false), tslib_1.__metadata("design:type", Boolean) ], NzDescriptionsComponent.prototype, "nzBordered", void 0); tslib_1.__decorate([ WithConfig(NZ_CONFIG_COMPONENT_NAME, defaultColumnMap), tslib_1.__metadata("design:type", Object) ], NzDescriptionsComponent.prototype, "nzColumn", void 0); tslib_1.__decorate([ WithConfig(NZ_CONFIG_COMPONENT_NAME, 'default'), tslib_1.__metadata("design:type", String) ], NzDescriptionsComponent.prototype, "nzSize", void 0); tslib_1.__decorate([ WithConfig(NZ_CONFIG_COMPONENT_NAME, true), InputBoolean(), tslib_1.__metadata("design:type", Boolean) ], NzDescriptionsComponent.prototype, "nzColon", void 0); return NzDescriptionsComponent; }()); export { NzDescriptionsComponent }; if (false) { /** @type {?} */ NzDescriptionsComponent.prototype.items; /** @type {?} */ NzDescriptionsComponent.prototype.nzBordered; /** @type {?} */ NzDescriptionsComponent.prototype.nzLayout; /** @type {?} */ NzDescriptionsComponent.prototype.nzColumn; /** @type {?} */ NzDescriptionsComponent.prototype.nzSize; /** @type {?} */ NzDescriptionsComponent.prototype.nzTitle; /** @type {?} */ NzDescriptionsComponent.prototype.nzColon; /** @type {?} */ NzDescriptionsComponent.prototype.itemMatrix; /** @type {?} */ NzDescriptionsComponent.prototype.realColumn; /** * @type {?} * @private */ NzDescriptionsComponent.prototype.destroy$; /** * @type {?} * @private */ NzDescriptionsComponent.prototype.resize$; /** @type {?} */ NzDescriptionsComponent.prototype.nzConfigService; /** * @type {?} * @private */ NzDescriptionsComponent.prototype.cdr; /** * @type {?} * @private */ NzDescriptionsComponent.prototype.mediaMatcher; /** * @type {?} * @private */ NzDescriptionsComponent.prototype.platform; /** * @type {?} * @private */ NzDescriptionsComponent.prototype.nzDomEventService; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"nz-descriptions.component.js","sourceRoot":"ng://ng-zorro-antd/descriptions/","sources":["nz-descriptions.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 { MediaMatcher } from '@angular/cdk/layout';\nimport { Platform } from '@angular/cdk/platform';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  ChangeDetectorRef,\n  Component,\n  ContentChildren,\n  Input,\n  OnChanges,\n  OnDestroy,\n  QueryList,\n  SimpleChanges,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { merge, Subject } from 'rxjs';\nimport { auditTime, finalize, startWith, switchMap, takeUntil } from 'rxjs/operators';\n\nimport {\n  responsiveMap,\n  warn,\n  InputBoolean,\n  NzBreakpoint,\n  NzConfigService,\n  NzDomEventService,\n  WithConfig\n} from 'ng-zorro-antd/core';\nimport { NzDescriptionsItemRenderProps, NzDescriptionsLayout, NzDescriptionsSize } from './nz-descriptions-definitions';\nimport { NzDescriptionsItemComponent } from './nz-descriptions-item.component';\n\nconst NZ_CONFIG_COMPONENT_NAME = 'descriptions';\nconst defaultColumnMap: { [key in NzBreakpoint]: number } = {\n  xxl: 3,\n  xl: 3,\n  lg: 3,\n  md: 3,\n  sm: 2,\n  xs: 1\n};\n\n@Component({\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  encapsulation: ViewEncapsulation.None,\n  selector: 'nz-descriptions',\n  templateUrl: './nz-descriptions.component.html',\n  exportAs: 'nzDescriptions',\n  preserveWhitespaces: false,\n  host: {\n    class: 'ant-descriptions',\n    '[class.ant-descriptions-bordered]': 'nzBordered',\n    '[class.ant-descriptions-middle]': 'nzSize === \"middle\"',\n    '[class.ant-descriptions-small]': 'nzSize === \"small\"'\n  },\n  styles: [\n    `\n      nz-descriptions {\n        display: block;\n      }\n    `\n  ]\n})\nexport class NzDescriptionsComponent implements OnChanges, OnDestroy, AfterContentInit {\n  @ContentChildren(NzDescriptionsItemComponent) items: QueryList<NzDescriptionsItemComponent>;\n\n  @Input() @InputBoolean() @WithConfig(NZ_CONFIG_COMPONENT_NAME, false) nzBordered: boolean;\n  @Input() nzLayout: NzDescriptionsLayout = 'horizontal';\n  @Input() @WithConfig(NZ_CONFIG_COMPONENT_NAME, defaultColumnMap) nzColumn: number | { [key in NzBreakpoint]: number };\n  @Input() @WithConfig(NZ_CONFIG_COMPONENT_NAME, 'default') nzSize: NzDescriptionsSize;\n  @Input() nzTitle: string | TemplateRef<void> = '';\n  @Input() @WithConfig(NZ_CONFIG_COMPONENT_NAME, true) @InputBoolean() nzColon: boolean;\n\n  itemMatrix: NzDescriptionsItemRenderProps[][] = [];\n\n  realColumn = 3;\n\n  private destroy$ = new Subject<void>();\n  private resize$ = new Subject<void>();\n\n  constructor(\n    public nzConfigService: NzConfigService,\n    private cdr: ChangeDetectorRef,\n    private mediaMatcher: MediaMatcher,\n    private platform: Platform,\n    private nzDomEventService: NzDomEventService\n  ) {}\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzColumn) {\n      this.resize$.next();\n    }\n  }\n\n  ngAfterContentInit(): void {\n    const contentChange$ = this.items.changes.pipe(\n      startWith(this.items),\n      takeUntil(this.destroy$)\n    );\n\n    merge(\n      contentChange$,\n      contentChange$.pipe(switchMap(() => merge(...this.items.map(i => i.inputChange$)).pipe(auditTime(16)))),\n      this.resize$\n    )\n      .pipe(takeUntil(this.destroy$))\n      .subscribe(() => {\n        this.prepareMatrix();\n        this.cdr.markForCheck();\n      });\n\n    if (this.platform.isBrowser) {\n      this.nzDomEventService\n        .registerResizeListener()\n        .pipe(\n          takeUntil(this.destroy$),\n          finalize(() => this.nzDomEventService.unregisterResizeListener())\n        )\n        .subscribe(() => this.resize$.next());\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$.next();\n    this.destroy$.complete();\n    this.resize$.complete();\n  }\n\n  /**\n   * Prepare the render matrix according to description items' spans.\n   */\n  private prepareMatrix(): void {\n    let currentRow: NzDescriptionsItemRenderProps[] = [];\n    let width = 0;\n\n    const column = (this.realColumn = this.getColumn());\n    const items = this.items.toArray();\n    const length = items.length;\n    const matrix: NzDescriptionsItemRenderProps[][] = [];\n    const flushRow = () => {\n      matrix.push(currentRow);\n      currentRow = [];\n      width = 0;\n    };\n\n    for (let i = 0; i < length; i++) {\n      const item = items[i];\n      const { nzTitle: title, content, nzSpan: span } = item;\n\n      width += span;\n\n      // If the last item make the row's length exceeds `nzColumn`, the last\n      // item should take all the space left. This logic is implemented in the template.\n      // Warn user about that.\n      if (width >= column) {\n        if (width > column) {\n          warn(`\"nzColumn\" is ${column} but we have row length ${width}`);\n        }\n        currentRow.push({ title, content, span: column - (width - span) });\n        flushRow();\n      } else if (i === length - 1) {\n        currentRow.push({ title, content, span: column - (width - span) });\n        flushRow();\n      } else {\n        currentRow.push({ title, content, span });\n      }\n    }\n\n    this.itemMatrix = matrix;\n  }\n\n  private matchMedia(): NzBreakpoint {\n    let bp: NzBreakpoint = NzBreakpoint.md;\n\n    Object.keys(responsiveMap).map((breakpoint: string) => {\n      const castBP = breakpoint as NzBreakpoint;\n      const matchBelow = this.mediaMatcher.matchMedia(responsiveMap[castBP]).matches;\n      if (matchBelow) {\n        bp = castBP;\n      }\n    });\n\n    return bp;\n  }\n\n  private getColumn(): number {\n    if (typeof this.nzColumn !== 'number') {\n      return this.nzColumn[this.matchMedia()];\n    }\n\n    return this.nzColumn;\n  }\n}\n"]}