UNPKG

ng-zorro-antd

Version:

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

278 lines (262 loc) 27.2 kB
import { NgTemplateOutlet } from '@angular/common'; import { ChangeDetectionStrategy, Component, ContentChild, Input, ViewEncapsulation, booleanAttribute } from '@angular/core'; import { BehaviorSubject, Subject } from 'rxjs'; import { takeUntil } from 'rxjs/operators'; import { NzOutletModule } from 'ng-zorro-antd/core/outlet'; import { NzGridModule } from 'ng-zorro-antd/grid'; import { NzSpinModule } from 'ng-zorro-antd/spin'; import { NzListEmptyComponent, NzListFooterComponent, NzListHeaderComponent, NzListLoadMoreDirective, NzListPaginationComponent } from './list-cell'; import * as i0 from "@angular/core"; import * as i1 from "@angular/cdk/bidi"; import * as i2 from "ng-zorro-antd/core/outlet"; import * as i3 from "ng-zorro-antd/spin"; import * as i4 from "ng-zorro-antd/grid"; export class NzListComponent { get itemLayoutNotify$() { return this.itemLayoutNotifySource.asObservable(); } constructor(directionality) { this.directionality = directionality; this.nzBordered = false; this.nzGrid = ''; this.nzItemLayout = 'horizontal'; this.nzRenderItem = null; this.nzLoading = false; this.nzLoadMore = null; this.nzSize = 'default'; this.nzSplit = true; this.hasSomethingAfterLastItem = false; this.dir = 'ltr'; this.itemLayoutNotifySource = new BehaviorSubject(this.nzItemLayout); this.destroy$ = new Subject(); } ngOnInit() { this.dir = this.directionality.value; this.directionality.change?.pipe(takeUntil(this.destroy$)).subscribe((direction) => { this.dir = direction; }); } getSomethingAfterLastItem() { return !!(this.nzLoadMore || this.nzPagination || this.nzFooter || this.nzListFooterComponent || this.nzListPaginationComponent || this.nzListLoadMoreDirective); } ngOnChanges(changes) { if (changes.nzItemLayout) { this.itemLayoutNotifySource.next(this.nzItemLayout); } } ngOnDestroy() { this.itemLayoutNotifySource.unsubscribe(); this.destroy$.next(); this.destroy$.complete(); } ngAfterContentInit() { this.hasSomethingAfterLastItem = this.getSomethingAfterLastItem(); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzListComponent, deps: [{ token: i1.Directionality }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.1.2", type: NzListComponent, isStandalone: true, selector: "nz-list, [nz-list]", inputs: { nzDataSource: "nzDataSource", nzBordered: ["nzBordered", "nzBordered", booleanAttribute], nzGrid: "nzGrid", nzHeader: "nzHeader", nzFooter: "nzFooter", nzItemLayout: "nzItemLayout", nzRenderItem: "nzRenderItem", nzLoading: ["nzLoading", "nzLoading", booleanAttribute], nzLoadMore: "nzLoadMore", nzPagination: "nzPagination", nzSize: "nzSize", nzSplit: ["nzSplit", "nzSplit", booleanAttribute], nzNoResult: "nzNoResult" }, host: { properties: { "class.ant-list-rtl": "dir === 'rtl'", "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" }, classAttribute: "ant-list" }, queries: [{ propertyName: "nzListFooterComponent", first: true, predicate: NzListFooterComponent, descendants: true }, { propertyName: "nzListPaginationComponent", first: true, predicate: NzListPaginationComponent, descendants: true }, { propertyName: "nzListLoadMoreDirective", first: true, predicate: NzListLoadMoreDirective, descendants: true }], exportAs: ["nzList"], usesOnChanges: true, ngImport: i0, template: ` @if (nzHeader) { <nz-list-header> <ng-container *nzStringTemplateOutlet="nzHeader">{{ nzHeader }}</ng-container> </nz-list-header> } <ng-content select="nz-list-header" /> <nz-spin [nzSpinning]="nzLoading"> <ng-container> @if (nzLoading && nzDataSource && nzDataSource.length === 0) { <div [style.min-height.px]="53"></div> } @if (nzGrid && nzDataSource) { <div nz-row [nzGutter]="nzGrid.gutter || null"> @for (item of nzDataSource; track item; let index = $index) { <div nz-col [nzSpan]="nzGrid.span || null" [nzXs]="nzGrid.xs || null" [nzSm]="nzGrid.sm || null" [nzMd]="nzGrid.md || null" [nzLg]="nzGrid.lg || null" [nzXl]="nzGrid.xl || null" [nzXXl]="nzGrid.xxl || null" > <ng-template [ngTemplateOutlet]="nzRenderItem" [ngTemplateOutletContext]="{ $implicit: item, index: index }" /> </div> } </div> } @else { <div class="ant-list-items"> @for (item of nzDataSource; track item; let index = $index) { <ng-container> <ng-template [ngTemplateOutlet]="nzRenderItem" [ngTemplateOutletContext]="{ $implicit: item, index: index }" /> </ng-container> } <ng-content /> </div> } @if (!nzLoading && nzDataSource && nzDataSource.length === 0) { <nz-list-empty [nzNoResult]="nzNoResult" /> } </ng-container> </nz-spin> @if (nzFooter) { <nz-list-footer> <ng-container *nzStringTemplateOutlet="nzFooter">{{ nzFooter }}</ng-container> </nz-list-footer> } <ng-content select="nz-list-footer, [nz-list-footer]" /> <ng-template [ngTemplateOutlet]="nzLoadMore"></ng-template> <ng-content select="nz-list-load-more, [nz-list-load-more]" /> @if (nzPagination) { <nz-list-pagination> <ng-template [ngTemplateOutlet]="nzPagination" /> </nz-list-pagination> } <ng-content select="nz-list-pagination, [nz-list-pagination]" /> `, isInline: true, dependencies: [{ kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "component", type: NzListHeaderComponent, selector: "nz-list-header", exportAs: ["nzListHeader"] }, { kind: "ngmodule", type: NzOutletModule }, { kind: "directive", type: i2.NzStringTemplateOutletDirective, selector: "[nzStringTemplateOutlet]", inputs: ["nzStringTemplateOutletContext", "nzStringTemplateOutlet"], exportAs: ["nzStringTemplateOutlet"] }, { kind: "ngmodule", type: NzSpinModule }, { kind: "component", type: i3.NzSpinComponent, selector: "nz-spin", inputs: ["nzIndicator", "nzSize", "nzTip", "nzDelay", "nzSimple", "nzSpinning"], exportAs: ["nzSpin"] }, { kind: "ngmodule", type: NzGridModule }, { kind: "directive", type: i4.NzColDirective, selector: "[nz-col],nz-col,nz-form-control,nz-form-label", inputs: ["nzFlex", "nzSpan", "nzOrder", "nzOffset", "nzPush", "nzPull", "nzXs", "nzSm", "nzMd", "nzLg", "nzXl", "nzXXl"], exportAs: ["nzCol"] }, { kind: "directive", type: i4.NzRowDirective, selector: "[nz-row],nz-row,nz-form-item", inputs: ["nzAlign", "nzJustify", "nzGutter"], exportAs: ["nzRow"] }, { kind: "component", type: NzListEmptyComponent, selector: "nz-list-empty", inputs: ["nzNoResult"], exportAs: ["nzListHeader"] }, { kind: "component", type: NzListFooterComponent, selector: "nz-list-footer", exportAs: ["nzListFooter"] }, { kind: "component", type: NzListPaginationComponent, selector: "nz-list-pagination", exportAs: ["nzListPagination"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush, encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.1.2", ngImport: i0, type: NzListComponent, decorators: [{ type: Component, args: [{ selector: 'nz-list, [nz-list]', exportAs: 'nzList', template: ` @if (nzHeader) { <nz-list-header> <ng-container *nzStringTemplateOutlet="nzHeader">{{ nzHeader }}</ng-container> </nz-list-header> } <ng-content select="nz-list-header" /> <nz-spin [nzSpinning]="nzLoading"> <ng-container> @if (nzLoading && nzDataSource && nzDataSource.length === 0) { <div [style.min-height.px]="53"></div> } @if (nzGrid && nzDataSource) { <div nz-row [nzGutter]="nzGrid.gutter || null"> @for (item of nzDataSource; track item; let index = $index) { <div nz-col [nzSpan]="nzGrid.span || null" [nzXs]="nzGrid.xs || null" [nzSm]="nzGrid.sm || null" [nzMd]="nzGrid.md || null" [nzLg]="nzGrid.lg || null" [nzXl]="nzGrid.xl || null" [nzXXl]="nzGrid.xxl || null" > <ng-template [ngTemplateOutlet]="nzRenderItem" [ngTemplateOutletContext]="{ $implicit: item, index: index }" /> </div> } </div> } @else { <div class="ant-list-items"> @for (item of nzDataSource; track item; let index = $index) { <ng-container> <ng-template [ngTemplateOutlet]="nzRenderItem" [ngTemplateOutletContext]="{ $implicit: item, index: index }" /> </ng-container> } <ng-content /> </div> } @if (!nzLoading && nzDataSource && nzDataSource.length === 0) { <nz-list-empty [nzNoResult]="nzNoResult" /> } </ng-container> </nz-spin> @if (nzFooter) { <nz-list-footer> <ng-container *nzStringTemplateOutlet="nzFooter">{{ nzFooter }}</ng-container> </nz-list-footer> } <ng-content select="nz-list-footer, [nz-list-footer]" /> <ng-template [ngTemplateOutlet]="nzLoadMore"></ng-template> <ng-content select="nz-list-load-more, [nz-list-load-more]" /> @if (nzPagination) { <nz-list-pagination> <ng-template [ngTemplateOutlet]="nzPagination" /> </nz-list-pagination> } <ng-content select="nz-list-pagination, [nz-list-pagination]" /> `, preserveWhitespaces: false, encapsulation: ViewEncapsulation.None, changeDetection: ChangeDetectionStrategy.OnPush, host: { class: 'ant-list', '[class.ant-list-rtl]': `dir === 'rtl'`, '[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' }, imports: [ NgTemplateOutlet, NzListHeaderComponent, NzOutletModule, NzSpinModule, NzGridModule, NzListEmptyComponent, NzListFooterComponent, NzListPaginationComponent ], standalone: true }] }], ctorParameters: () => [{ type: i1.Directionality }], propDecorators: { nzDataSource: [{ type: Input }], nzBordered: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzGrid: [{ type: Input }], nzHeader: [{ type: Input }], nzFooter: [{ type: Input }], nzItemLayout: [{ type: Input }], nzRenderItem: [{ type: Input }], nzLoading: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzLoadMore: [{ type: Input }], nzPagination: [{ type: Input }], nzSize: [{ type: Input }], nzSplit: [{ type: Input, args: [{ transform: booleanAttribute }] }], nzNoResult: [{ type: Input }], nzListFooterComponent: [{ type: ContentChild, args: [NzListFooterComponent] }], nzListPaginationComponent: [{ type: ContentChild, args: [NzListPaginationComponent] }], nzListLoadMoreDirective: [{ type: ContentChild, args: [NzListLoadMoreDirective] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.component.js","sourceRoot":"","sources":["../../../components/list/list.component.ts"],"names":[],"mappings":"AAMA,OAAO,EAAE,gBAAgB,EAAE,MAAM,iBAAiB,CAAC;AACnD,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,KAAK,EAML,iBAAiB,EACjB,gBAAgB,EACjB,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAc,OAAO,EAAE,MAAM,MAAM,CAAC;AAC5D,OAAO,EAAE,SAAS,EAAE,MAAM,gBAAgB,CAAC;AAE3C,OAAO,EAAE,cAAc,EAAE,MAAM,2BAA2B,CAAC;AAE3D,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAClD,OAAO,EAAE,YAAY,EAAE,MAAM,oBAAoB,CAAC;AAGlD,OAAO,EACL,oBAAoB,EACpB,qBAAqB,EACrB,qBAAqB,EACrB,uBAAuB,EACvB,yBAAyB,EAC1B,MAAM,aAAa,CAAC;;;;;;AAwGrB,MAAM,OAAO,eAAe;IAwB1B,IAAI,iBAAiB;QACnB,OAAO,IAAI,CAAC,sBAAsB,CAAC,YAAY,EAAE,CAAC;IACpD,CAAC;IAED,YAAoB,cAA8B;QAA9B,mBAAc,GAAd,cAAc,CAAgB;QA1BV,eAAU,GAAG,KAAK,CAAC;QAClD,WAAM,GAAwC,EAAE,CAAC;QAGjD,iBAAY,GAAsB,YAAY,CAAC;QAC/C,iBAAY,GAAgE,IAAI,CAAC;QAClD,cAAS,GAAG,KAAK,CAAC;QACjD,eAAU,GAA6B,IAAI,CAAC;QAE5C,WAAM,GAAkB,SAAS,CAAC;QACH,YAAO,GAAG,IAAI,CAAC;QAOvD,8BAAyB,GAAG,KAAK,CAAC;QAClC,QAAG,GAAc,KAAK,CAAC;QACf,2BAAsB,GAAG,IAAI,eAAe,CAAoB,IAAI,CAAC,YAAY,CAAC,CAAC;QACnF,aAAQ,GAAG,IAAI,OAAO,EAAQ,CAAC;IAMc,CAAC;IACtD,QAAQ;QACN,IAAI,CAAC,GAAG,GAAG,IAAI,CAAC,cAAc,CAAC,KAAK,CAAC;QACrC,IAAI,CAAC,cAAc,CAAC,MAAM,EAAE,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,SAAoB,EAAE,EAAE;YAC5F,IAAI,CAAC,GAAG,GAAG,SAAS,CAAC;QACvB,CAAC,CAAC,CAAC;IACL,CAAC;IAED,yBAAyB;QACvB,OAAO,CAAC,CAAC,CACP,IAAI,CAAC,UAAU;YACf,IAAI,CAAC,YAAY;YACjB,IAAI,CAAC,QAAQ;YACb,IAAI,CAAC,qBAAqB;YAC1B,IAAI,CAAC,yBAAyB;YAC9B,IAAI,CAAC,uBAAuB,CAC7B,CAAC;IACJ,CAAC;IACD,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,YAAY,EAAE,CAAC;YACzB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC;QACtD,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,sBAAsB,CAAC,WAAW,EAAE,CAAC;QAC1C,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACrB,IAAI,CAAC,QAAQ,CAAC,QAAQ,EAAE,CAAC;IAC3B,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,yBAAyB,GAAG,IAAI,CAAC,yBAAyB,EAAE,CAAC;IACpE,CAAC;8GA5DU,eAAe;kGAAf,eAAe,uIAEN,gBAAgB,mKAMhB,gBAAgB,6GAIhB,gBAAgB,yhBAGtB,qBAAqB,4FACrB,yBAAyB,0FACzB,uBAAuB,2FApH3B;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwET,4DAgBC,gBAAgB,oJAChB,qBAAqB,sFACrB,cAAc,gPACd,YAAY,2MACZ,YAAY,sbACZ,oBAAoB,8GACpB,qBAAqB,uFACrB,yBAAyB;;2FAIhB,eAAe;kBAtG3B,SAAS;mBAAC;oBACT,QAAQ,EAAE,oBAAoB;oBAC9B,QAAQ,EAAE,QAAQ;oBAClB,QAAQ,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GAwET;oBACD,mBAAmB,EAAE,KAAK;oBAC1B,aAAa,EAAE,iBAAiB,CAAC,IAAI;oBACrC,eAAe,EAAE,uBAAuB,CAAC,MAAM;oBAC/C,IAAI,EAAE;wBACJ,KAAK,EAAE,UAAU;wBACjB,sBAAsB,EAAE,eAAe;wBACvC,2BAA2B,EAAE,6BAA6B;wBAC1D,qBAAqB,EAAE,oBAAoB;wBAC3C,qBAAqB,EAAE,oBAAoB;wBAC3C,wBAAwB,EAAE,SAAS;wBACnC,2BAA2B,EAAE,YAAY;wBACzC,0BAA0B,EAAE,WAAW;wBACvC,4CAA4C,EAAE,2BAA2B;qBAC1E;oBACD,OAAO,EAAE;wBACP,gBAAgB;wBAChB,qBAAqB;wBACrB,cAAc;wBACd,YAAY;wBACZ,YAAY;wBACZ,oBAAoB;wBACpB,qBAAqB;wBACrB,yBAAyB;qBAC1B;oBACD,UAAU,EAAE,IAAI;iBACjB;mFAEU,YAAY;sBAApB,KAAK;gBACkC,UAAU;sBAAjD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAC7B,MAAM;sBAAd,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACkC,SAAS;sBAAhD,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAC7B,UAAU;sBAAlB,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACkC,OAAO;sBAA9C,KAAK;uBAAC,EAAE,SAAS,EAAE,gBAAgB,EAAE;gBAC7B,UAAU;sBAAlB,KAAK;gBAE+B,qBAAqB;sBAAzD,YAAY;uBAAC,qBAAqB;gBACM,yBAAyB;sBAAjE,YAAY;uBAAC,yBAAyB;gBACA,uBAAuB;sBAA7D,YAAY;uBAAC,uBAAuB","sourcesContent":["/**\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 { Direction, Directionality } from '@angular/cdk/bidi';\nimport { NgTemplateOutlet } from '@angular/common';\nimport {\n  AfterContentInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  Input,\n  OnChanges,\n  OnDestroy,\n  OnInit,\n  SimpleChanges,\n  TemplateRef,\n  ViewEncapsulation,\n  booleanAttribute\n} from '@angular/core';\nimport { BehaviorSubject, Observable, Subject } from 'rxjs';\nimport { takeUntil } from 'rxjs/operators';\n\nimport { NzOutletModule } from 'ng-zorro-antd/core/outlet';\nimport { NzDirectionVHType, NzSafeAny, NzSizeLDSType } from 'ng-zorro-antd/core/types';\nimport { NzGridModule } from 'ng-zorro-antd/grid';\nimport { NzSpinModule } from 'ng-zorro-antd/spin';\n\nimport { NzListGrid } from './interface';\nimport {\n  NzListEmptyComponent,\n  NzListFooterComponent,\n  NzListHeaderComponent,\n  NzListLoadMoreDirective,\n  NzListPaginationComponent\n} from './list-cell';\n\n@Component({\n  selector: 'nz-list, [nz-list]',\n  exportAs: 'nzList',\n  template: `\n    @if (nzHeader) {\n      <nz-list-header>\n        <ng-container *nzStringTemplateOutlet=\"nzHeader\">{{ nzHeader }}</ng-container>\n      </nz-list-header>\n    }\n\n    <ng-content select=\"nz-list-header\" />\n\n    <nz-spin [nzSpinning]=\"nzLoading\">\n      <ng-container>\n        @if (nzLoading && nzDataSource && nzDataSource.length === 0) {\n          <div [style.min-height.px]=\"53\"></div>\n        }\n        @if (nzGrid && nzDataSource) {\n          <div nz-row [nzGutter]=\"nzGrid.gutter || null\">\n            @for (item of nzDataSource; track item; let index = $index) {\n              <div\n                nz-col\n                [nzSpan]=\"nzGrid.span || null\"\n                [nzXs]=\"nzGrid.xs || null\"\n                [nzSm]=\"nzGrid.sm || null\"\n                [nzMd]=\"nzGrid.md || null\"\n                [nzLg]=\"nzGrid.lg || null\"\n                [nzXl]=\"nzGrid.xl || null\"\n                [nzXXl]=\"nzGrid.xxl || null\"\n              >\n                <ng-template\n                  [ngTemplateOutlet]=\"nzRenderItem\"\n                  [ngTemplateOutletContext]=\"{ $implicit: item, index: index }\"\n                />\n              </div>\n            }\n          </div>\n        } @else {\n          <div class=\"ant-list-items\">\n            @for (item of nzDataSource; track item; let index = $index) {\n              <ng-container>\n                <ng-template\n                  [ngTemplateOutlet]=\"nzRenderItem\"\n                  [ngTemplateOutletContext]=\"{ $implicit: item, index: index }\"\n                />\n              </ng-container>\n            }\n            <ng-content />\n          </div>\n        }\n\n        @if (!nzLoading && nzDataSource && nzDataSource.length === 0) {\n          <nz-list-empty [nzNoResult]=\"nzNoResult\" />\n        }\n      </ng-container>\n    </nz-spin>\n\n    @if (nzFooter) {\n      <nz-list-footer>\n        <ng-container *nzStringTemplateOutlet=\"nzFooter\">{{ nzFooter }}</ng-container>\n      </nz-list-footer>\n    }\n\n    <ng-content select=\"nz-list-footer, [nz-list-footer]\" />\n\n    <ng-template [ngTemplateOutlet]=\"nzLoadMore\"></ng-template>\n    <ng-content select=\"nz-list-load-more, [nz-list-load-more]\" />\n\n    @if (nzPagination) {\n      <nz-list-pagination>\n        <ng-template [ngTemplateOutlet]=\"nzPagination\" />\n      </nz-list-pagination>\n    }\n\n    <ng-content select=\"nz-list-pagination, [nz-list-pagination]\" />\n  `,\n  preserveWhitespaces: false,\n  encapsulation: ViewEncapsulation.None,\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  host: {\n    class: 'ant-list',\n    '[class.ant-list-rtl]': `dir === 'rtl'`,\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  imports: [\n    NgTemplateOutlet,\n    NzListHeaderComponent,\n    NzOutletModule,\n    NzSpinModule,\n    NzGridModule,\n    NzListEmptyComponent,\n    NzListFooterComponent,\n    NzListPaginationComponent\n  ],\n  standalone: true\n})\nexport class NzListComponent implements AfterContentInit, OnChanges, OnDestroy, OnInit {\n  @Input() nzDataSource?: NzSafeAny[];\n  @Input({ transform: booleanAttribute }) nzBordered = false;\n  @Input() nzGrid?: NzListGrid | '' | null | undefined = '';\n  @Input() nzHeader?: string | TemplateRef<void>;\n  @Input() nzFooter?: string | TemplateRef<void>;\n  @Input() nzItemLayout: NzDirectionVHType = 'horizontal';\n  @Input() nzRenderItem: TemplateRef<{ $implicit: NzSafeAny; index: number }> | null = null;\n  @Input({ transform: booleanAttribute }) nzLoading = false;\n  @Input() nzLoadMore: TemplateRef<void> | null = null;\n  @Input() nzPagination?: TemplateRef<void>;\n  @Input() nzSize: NzSizeLDSType = 'default';\n  @Input({ transform: booleanAttribute }) 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  dir: Direction = 'ltr';\n  private itemLayoutNotifySource = new BehaviorSubject<NzDirectionVHType>(this.nzItemLayout);\n  private destroy$ = new Subject<void>();\n\n  get itemLayoutNotify$(): Observable<NzDirectionVHType> {\n    return this.itemLayoutNotifySource.asObservable();\n  }\n\n  constructor(private directionality: Directionality) {}\n  ngOnInit(): void {\n    this.dir = this.directionality.value;\n    this.directionality.change?.pipe(takeUntil(this.destroy$)).subscribe((direction: Direction) => {\n      this.dir = direction;\n    });\n  }\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    this.destroy$.next();\n    this.destroy$.complete();\n  }\n\n  ngAfterContentInit(): void {\n    this.hasSomethingAfterLastItem = this.getSomethingAfterLastItem();\n  }\n}\n"]}