ng-zorro-antd
Version:
An enterprise-class UI components based on Ant Design and Angular
216 lines (211 loc) • 18.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: list.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { __decorate, __metadata } 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, Component, ContentChild, Input, TemplateRef, ViewEncapsulation } from '@angular/core';
import { InputBoolean } from 'ng-zorro-antd/core/util';
import { BehaviorSubject } from 'rxjs';
import { NzListFooterComponent, NzListLoadMoreDirective, NzListPaginationComponent } from './list-cell';
export class NzListComponent {
constructor() {
this.nzBordered = false;
this.nzItemLayout = 'horizontal';
this.nzLoading = false;
this.nzSize = 'default';
this.nzSplit = true;
this.hasSomethingAfterLastItem = false;
this.itemLayoutNotifySource = new BehaviorSubject(this.nzItemLayout);
}
/**
* @return {?}
*/
get itemLayoutNotify$() {
return this.itemLayoutNotifySource.asObservable();
}
/**
* @return {?}
*/
getSomethingAfterLastItem() {
return !!(this.nzLoadMore ||
this.nzPagination ||
this.nzFooter ||
this.nzListFooterComponent ||
this.nzListPaginationComponent ||
this.nzListLoadMoreDirective);
}
/**
* @param {?} changes
* @return {?}
*/
ngOnChanges(changes) {
if (changes.nzItemLayout) {
this.itemLayoutNotifySource.next(this.nzItemLayout);
}
}
/**
* @return {?}
*/
ngOnDestroy() {
this.itemLayoutNotifySource.unsubscribe();
}
/**
* @return {?}
*/
ngAfterContentInit() {
this.hasSomethingAfterLastItem = this.getSomethingAfterLastItem();
}
}
NzListComponent.decorators = [
{ type: Component, args: [{
selector: 'nz-list, [nz-list]',
exportAs: 'nzList',
template: `
<ng-template #itemsTpl>
<div class="ant-list-items">
<ng-container *ngFor="let item of nzDataSource; let index = index">
<ng-template [ngTemplateOutlet]="nzRenderItem" [ngTemplateOutletContext]="{ $implicit: item, index: index }"></ng-template>
</ng-container>
<ng-content select="nz-list-item, [nz-list-item]"></ng-content>
</div>
</ng-template>
<nz-list-header *ngIf="nzHeader">
<ng-container *nzStringTemplateOutlet="nzHeader">{{ nzHeader }}</ng-container>
</nz-list-header>
<ng-content select="nz-list-header"></ng-content>
<nz-spin [nzSpinning]="nzLoading">
<ng-container>
<div *ngIf="nzLoading && nzDataSource && nzDataSource.length === 0" [style.min-height.px]="53"></div>
<div *ngIf="nzGrid && nzDataSource; else itemsTpl" nz-row [nzGutter]="nzGrid.gutter">
<div
nz-col
[nzSpan]="nzGrid.span"
[nzXs]="nzGrid.xs"
[nzSm]="nzGrid.sm"
[nzMd]="nzGrid.md"
[nzLg]="nzGrid.lg"
[nzXl]="nzGrid.xl"
[nzXXl]="nzGrid.xxl"
*ngFor="let item of nzDataSource; let index = index"
>
<ng-template [ngTemplateOutlet]="nzRenderItem" [ngTemplateOutletContext]="{ $implicit: item, index: index }"></ng-template>
</div>
</div>
<nz-list-empty *ngIf="!nzLoading && nzDataSource && nzDataSource.length === 0" [nzNoResult]="nzNoResult"></nz-list-empty>
</ng-container>
<ng-content></ng-content>
</nz-spin>
<nz-list-footer *ngIf="nzFooter">
<ng-container *nzStringTemplateOutlet="nzFooter">{{ nzFooter }}</ng-container>
</nz-list-footer>
<ng-content select="nz-list-footer, [nz-list-footer]"></ng-content>
<ng-template [ngTemplateOutlet]="nzLoadMore"></ng-template>
<ng-content select="nz-list-load-more, [nz-list-load-more]"></ng-content>
<nz-list-pagination *ngIf="nzPagination">
<ng-template [ngTemplateOutlet]="nzPagination"></ng-template>
</nz-list-pagination>
<ng-content select="nz-list-pagination, [nz-list-pagination]"></ng-content>
`,
preserveWhitespaces: false,
encapsulation: ViewEncapsulation.None,
changeDetection: ChangeDetectionStrategy.OnPush,
host: {
'[class.ant-list]': 'true',
'[class.ant-list-vertical]': 'nzItemLayout === "vertical"',
'[class.ant-list-lg]': 'nzSize === "large"',
'[class.ant-list-sm]': 'nzSize === "small"',
'[class.ant-list-split]': 'nzSplit',
'[class.ant-list-bordered]': 'nzBordered',
'[class.ant-list-loading]': 'nzLoading',
'[class.ant-list-something-after-last-item]': 'hasSomethingAfterLastItem'
}
}] }
];
/** @nocollapse */
NzListComponent.ctorParameters = () => [];
NzListComponent.propDecorators = {
nzDataSource: [{ type: Input }],
nzBordered: [{ type: Input }],
nzGrid: [{ type: Input }],
nzHeader: [{ type: Input }],
nzFooter: [{ type: Input }],
nzItemLayout: [{ type: Input }],
nzRenderItem: [{ type: Input }],
nzLoading: [{ type: Input }],
nzLoadMore: [{ type: Input }],
nzPagination: [{ type: Input }],
nzSize: [{ type: Input }],
nzSplit: [{ type: Input }],
nzNoResult: [{ type: Input }],
nzListFooterComponent: [{ type: ContentChild, args: [NzListFooterComponent,] }],
nzListPaginationComponent: [{ type: ContentChild, args: [NzListPaginationComponent,] }],
nzListLoadMoreDirective: [{ type: ContentChild, args: [NzListLoadMoreDirective,] }]
};
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzListComponent.prototype, "nzBordered", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzListComponent.prototype, "nzLoading", void 0);
__decorate([
InputBoolean(),
__metadata("design:type", Object)
], NzListComponent.prototype, "nzSplit", void 0);
if (false) {
/** @type {?} */
NzListComponent.ngAcceptInputType_nzBordered;
/** @type {?} */
NzListComponent.ngAcceptInputType_nzLoading;
/** @type {?} */
NzListComponent.ngAcceptInputType_nzSplit;
/** @type {?} */
NzListComponent.prototype.nzDataSource;
/** @type {?} */
NzListComponent.prototype.nzBordered;
/** @type {?} */
NzListComponent.prototype.nzGrid;
/** @type {?} */
NzListComponent.prototype.nzHeader;
/** @type {?} */
NzListComponent.prototype.nzFooter;
/** @type {?} */
NzListComponent.prototype.nzItemLayout;
/** @type {?} */
NzListComponent.prototype.nzRenderItem;
/** @type {?} */
NzListComponent.prototype.nzLoading;
/** @type {?} */
NzListComponent.prototype.nzLoadMore;
/** @type {?} */
NzListComponent.prototype.nzPagination;
/** @type {?} */
NzListComponent.prototype.nzSize;
/** @type {?} */
NzListComponent.prototype.nzSplit;
/** @type {?} */
NzListComponent.prototype.nzNoResult;
/** @type {?} */
NzListComponent.prototype.nzListFooterComponent;
/** @type {?} */
NzListComponent.prototype.nzListPaginationComponent;
/** @type {?} */
NzListComponent.prototype.nzListLoadMoreDirective;
/** @type {?} */
NzListComponent.prototype.hasSomethingAfterLastItem;
/**
* @type {?}
* @private
*/
NzListComponent.prototype.itemLayoutNotifySource;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.component.js","sourceRoot":"ng://ng-zorro-antd/list/","sources":["list.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  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  Input,\n  OnChanges,\n  OnDestroy,\n  SimpleChanges,\n  TemplateRef,\n  ViewEncapsulation\n} from '@angular/core';\nimport { BooleanInput, NzDirectionVHType, NzSafeAny, NzSizeLDSType } from 'ng-zorro-antd/core/types';\nimport { InputBoolean } from 'ng-zorro-antd/core/util';\nimport { BehaviorSubject, Observable } from 'rxjs';\nimport { NzListGrid } from './interface';\nimport { NzListFooterComponent, NzListLoadMoreDirective, NzListPaginationComponent } from './list-cell';\n\n@Component({\n  selector: 'nz-list, [nz-list]',\n  exportAs: 'nzList',\n  template: `\n    <ng-template #itemsTpl>\n      <div class=\"ant-list-items\">\n        <ng-container *ngFor=\"let item of nzDataSource; let index = index\">\n          <ng-template [ngTemplateOutlet]=\"nzRenderItem\" [ngTemplateOutletContext]=\"{ $implicit: item, index: index }\"></ng-template>\n        </ng-container>\n        <ng-content select=\"nz-list-item, [nz-list-item]\"></ng-content>\n      </div>\n    </ng-template>\n\n    <nz-list-header *ngIf=\"nzHeader\">\n      <ng-container *nzStringTemplateOutlet=\"nzHeader\">{{ nzHeader }}</ng-container>\n    </nz-list-header>\n    <ng-content select=\"nz-list-header\"></ng-content>\n\n    <nz-spin [nzSpinning]=\"nzLoading\">\n      <ng-container>\n        <div *ngIf=\"nzLoading && nzDataSource && nzDataSource.length === 0\" [style.min-height.px]=\"53\"></div>\n        <div *ngIf=\"nzGrid && nzDataSource; else itemsTpl\" nz-row [nzGutter]=\"nzGrid.gutter\">\n          <div\n            nz-col\n            [nzSpan]=\"nzGrid.span\"\n            [nzXs]=\"nzGrid.xs\"\n            [nzSm]=\"nzGrid.sm\"\n            [nzMd]=\"nzGrid.md\"\n            [nzLg]=\"nzGrid.lg\"\n            [nzXl]=\"nzGrid.xl\"\n            [nzXXl]=\"nzGrid.xxl\"\n            *ngFor=\"let item of nzDataSource; let index = index\"\n          >\n            <ng-template [ngTemplateOutlet]=\"nzRenderItem\" [ngTemplateOutletContext]=\"{ $implicit: item, index: index }\"></ng-template>\n          </div>\n        </div>\n        <nz-list-empty *ngIf=\"!nzLoading && nzDataSource && nzDataSource.length === 0\" [nzNoResult]=\"nzNoResult\"></nz-list-empty>\n      </ng-container>\n      <ng-content></ng-content>\n    </nz-spin>\n\n    <nz-list-footer *ngIf=\"nzFooter\">\n      <ng-container *nzStringTemplateOutlet=\"nzFooter\">{{ nzFooter }}</ng-container>\n    </nz-list-footer>\n    <ng-content select=\"nz-list-footer, [nz-list-footer]\"></ng-content>\n\n    <ng-template [ngTemplateOutlet]=\"nzLoadMore\"></ng-template>\n    <ng-content select=\"nz-list-load-more, [nz-list-load-more]\"></ng-content>\n\n    <nz-list-pagination *ngIf=\"nzPagination\">\n      <ng-template [ngTemplateOutlet]=\"nzPagination\"></ng-template>\n    </nz-list-pagination>\n    <ng-content select=\"nz-list-pagination, [nz-list-pagination]\"></ng-content>\n  `,\n  preserveWhitespaces: false,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    '[class.ant-list]': 'true',\n    '[class.ant-list-vertical]': 'nzItemLayout === \"vertical\"',\n    '[class.ant-list-lg]': 'nzSize === \"large\"',\n    '[class.ant-list-sm]': 'nzSize === \"small\"',\n    '[class.ant-list-split]': 'nzSplit',\n    '[class.ant-list-bordered]': 'nzBordered',\n    '[class.ant-list-loading]': 'nzLoading',\n    '[class.ant-list-something-after-last-item]': 'hasSomethingAfterLastItem'\n  }\n})\nexport class NzListComponent implements AfterContentInit, OnChanges, OnDestroy {\n  static ngAcceptInputType_nzBordered: BooleanInput;\n  static ngAcceptInputType_nzLoading: BooleanInput;\n  static ngAcceptInputType_nzSplit: BooleanInput;\n\n  @Input() nzDataSource: NzSafeAny[];\n  @Input() @InputBoolean() nzBordered = false;\n  @Input() nzGrid: NzListGrid;\n  @Input() nzHeader: string | TemplateRef<void>;\n  @Input() nzFooter: string | TemplateRef<void>;\n  @Input() nzItemLayout: NzDirectionVHType = 'horizontal';\n  @Input() nzRenderItem: TemplateRef<void>;\n  @Input() @InputBoolean() nzLoading = false;\n  @Input() nzLoadMore: TemplateRef<void>;\n  @Input() nzPagination: TemplateRef<void>;\n  @Input() nzSize: NzSizeLDSType = 'default';\n  @Input() @InputBoolean() nzSplit = true;\n  @Input() nzNoResult: string | TemplateRef<void>;\n\n  @ContentChild(NzListFooterComponent) nzListFooterComponent: NzListFooterComponent;\n  @ContentChild(NzListPaginationComponent) nzListPaginationComponent: NzListPaginationComponent;\n  @ContentChild(NzListLoadMoreDirective) nzListLoadMoreDirective: NzListLoadMoreDirective;\n\n  hasSomethingAfterLastItem = false;\n\n  private itemLayoutNotifySource = new BehaviorSubject<NzDirectionVHType>(this.nzItemLayout);\n\n  get itemLayoutNotify$(): Observable<NzDirectionVHType> {\n    return this.itemLayoutNotifySource.asObservable();\n  }\n\n  constructor() {}\n\n  getSomethingAfterLastItem(): boolean {\n    return !!(\n      this.nzLoadMore ||\n      this.nzPagination ||\n      this.nzFooter ||\n      this.nzListFooterComponent ||\n      this.nzListPaginationComponent ||\n      this.nzListLoadMoreDirective\n    );\n  }\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.nzItemLayout) {\n      this.itemLayoutNotifySource.next(this.nzItemLayout);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this.itemLayoutNotifySource.unsubscribe();\n  }\n\n  ngAfterContentInit(): void {\n    this.hasSomethingAfterLastItem = this.getSomethingAfterLastItem();\n  }\n}\n"]}