UNPKG

igniteui-angular

Version:

Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps

503 lines • 40 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,extraRequire,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { CommonModule } from '@angular/common'; import { Component, ContentChild, ContentChildren, ElementRef, EventEmitter, forwardRef, HostBinding, Input, NgModule, Output, QueryList, TemplateRef, ViewChild } from '@angular/core'; import { IgxRippleModule } from '../directives/ripple/ripple.directive'; import { IgxListItemComponent } from './list-item.component'; import { IgxListBase, IgxDataLoadingTemplateDirective, IgxEmptyListTemplateDirective, IgxListItemLeftPanningTemplateDirective, IgxListItemRightPanningTemplateDirective } from './list.common'; /** @type {?} */ let NEXT_ID = 0; /** * @record */ export function IPanStateChangeEventArgs() { } if (false) { /** @type {?} */ IPanStateChangeEventArgs.prototype.oldState; /** @type {?} */ IPanStateChangeEventArgs.prototype.newState; /** @type {?} */ IPanStateChangeEventArgs.prototype.item; } /** * @record */ export function IListItemClickEventArgs() { } if (false) { /** @type {?} */ IListItemClickEventArgs.prototype.item; /** @type {?} */ IListItemClickEventArgs.prototype.event; /** @type {?} */ IListItemClickEventArgs.prototype.direction; } /** * @record */ export function IListItemPanningEventArgs() { } if (false) { /** @type {?} */ IListItemPanningEventArgs.prototype.item; /** @type {?} */ IListItemPanningEventArgs.prototype.direction; /** @type {?} */ IListItemPanningEventArgs.prototype.keepItem; } /** * **Ignite UI for Angular List** - * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/list.html) * * The Ignite UI List displays rows of items and supports one or more header items as well as search and filtering * of list items. Each list item is completely templateable and will support any valid HTML or Angular component. * * Example: * ```html * <igx-list> * <igx-list-item isHeader="true">Contacts</igx-list-item> * <igx-list-item *ngFor="let contact of contacts"> * <span class="name">{{ contact.name }}</span> * <span class="phone">{{ contact.phone }}</span> * </igx-list-item> * </igx-list> * ``` */ export class IgxListComponent { /** * @param {?} element */ constructor(element) { this.element = element; /** * Provides a threshold after which the item's panning will be completed automatically. * By default this property is set to 0.5 which is 50% of the list item's width. * ```typescript * this.list.panEndTriggeringThreshold = 0.8; * ``` */ this.panEndTriggeringThreshold = 0.5; /** * Sets/gets the `id` of the list. * If not set, the `id` of the first list component will be `"igx-list-0"`. * ```html * <igx-list id = "my-first-list"></igx-list> * ``` * ```typescript * let listId = this.list.id; * ``` * \@memberof IgxListComponent */ this.id = `igx-list-${NEXT_ID++}`; /** * Sets/gets whether the left panning of an item is allowed. * Default value is `false`. * ```html * <igx-list [allowLeftPanning] = "true"></igx-list> * ``` * ```typescript * let isLeftPanningAllowed = this.list.allowLeftPanning; * ``` * \@memberof IgxListComponent */ this.allowLeftPanning = false; /** * Sets/gets whether the right panning of an item is allowed. * Default value is `false`. * ```html * <igx-list [allowRightPanning] = "true"></igx-list> * ``` * ```typescript * let isRightPanningAllowed = this.list.allowRightPanning; * ``` * \@memberof IgxListComponent */ this.allowRightPanning = false; /** * Sets/gets whether the list is currently loading data. * Set it to display the dataLoadingTemplate while data is being retrieved. * Default value is `false`. * ```html * <igx-list [isLoading]="true"></igx-list> * ``` * ```typescript * let isLoading = this.list.isLoading; * ``` * \@memberof IgxListComponent */ this.isLoading = false; /** * Emits an event within the current list when left pan gesture is executed on a list item. * Provides a reference to an object of type `IListItemPanningEventArgs` as an event argument. * ```html * <igx-list [allowLeftPanning]="true" (onLeftPan)="onLeftPan($event)"></igx-list> * ``` * \@memberof IgxListComponent */ this.onLeftPan = new EventEmitter(); /** * Emits an event within the current list when right pan gesture is executed on a list item. * Provides a reference to an object of type `IListItemPanningEventArgs` as an event argument. * ```html * <igx-list [allowRightPanning]="true" (onRightPan)="onRightPan($event)"></igx-list> * ``` * \@memberof IgxListComponent */ this.onRightPan = new EventEmitter(); /** * Emits an event within the current list when pan gesture is executed on list item. * Provides references to the `IgxListItemComponent` and `IgxListPanState` as event arguments. * ```html * <igx-list (onPanStateChange) = "onPanStateChange($event)"></igx-list> * ``` * \@memberof IgxListComponent */ this.onPanStateChange = new EventEmitter(); /** * Emits an event within the current list when a list item has been clicked. * Provides references to the `IgxListItemComponent` and `Event` as event arguments. * ```html * <igx-list (onItemClicked) = "onItemClicked($event)"></igx-list> * ``` * \@memberof IgxListComponent */ this.onItemClicked = new EventEmitter(); } /** * @hidden * \@internal * @protected * @return {?} */ get sortedChildren() { if (this.children !== undefined) { return this.children.toArray() .sort((a, b) => { return a.index - b.index; }); } return null; } /** * Gets the `role` attribute. * ```typescript * let listRole = this.list.role; * ``` * \@memberof IgxListComponent * @return {?} */ get role() { return 'list'; } /** * Returns boolean indicating if the list is empty. * ```typescript * let isEmpty = this.list.isListEmpty; * ``` * \@memberof IgxListComponent * @return {?} */ get isListEmpty() { return !this.children || this.children.length === 0; } /** * Returns boolean indicating if the list has a `cssClass` attribute. * ```typescript * let hasCssClass = this.list.cssClass; * ``` * \@memberof IgxListComponent * @return {?} */ get cssClass() { return this.children && this.children.length > 0; } /** * Returns the `items` in the list excluding the headers. * ```typescript * let listItems: IgxListItemComponent[] = this.list.items; * ``` * \@memberof IgxListComponent * @return {?} */ get items() { /** @type {?} */ const items = []; if (this.children !== undefined) { for (const child of this.sortedChildren) { if (!child.isHeader) { items.push(child); } } } return items; } /** * Returns the headers in the list. * ```typescript * let listHeaders: IgxListItemComponent[] = this.list.headers; * ``` * \@memberof IgxListComponent * @return {?} */ get headers() { /** @type {?} */ const headers = []; if (this.children !== undefined) { for (const child of this.children.toArray()) { if (child.isHeader) { headers.push(child); } } } return headers; } /** * Returns the `context` object which represents the `template context` binding into the `list container` * by providing the `$implicit` declaration which is the `IgxListComponent` itself. * ```typescript * let listComponent = this.list.context; * ``` * @return {?} */ get context() { return { $implicit: this }; } /** * Returns the `template` of an empty list. * ```typescript * let listTemplate = this.list.template; * ``` * \@memberof IgxListComponent * @return {?} */ get template() { if (this.isLoading) { return this.dataLoadingTemplate ? this.dataLoadingTemplate.template : this.defaultDataLoadingTemplate; } else { return this.emptyListTemplate ? this.emptyListTemplate.template : this.defaultEmptyListTemplate; } } } IgxListComponent.decorators = [ { type: Component, args: [{ selector: 'igx-list', template: "<ng-content></ng-content>\n\n<ng-template #defaultEmptyList>\n <article class=\"message\">\n <p>There are no items in the list.</p>\n </article>\n</ng-template>\n\n<ng-template #defaultDataLoading>\n <article class=\"message\">\n <p>Loading data from the server...</p>\n </article>\n</ng-template>\n\n<ng-container *ngIf=\"!children || children.length === 0 || isLoading\">\n <ng-container *ngTemplateOutlet=\"template; context: context\">\n </ng-container>\n</ng-container>\n", providers: [{ provide: IgxListBase, useExisting: IgxListComponent }] }] } ]; /** @nocollapse */ IgxListComponent.ctorParameters = () => [ { type: ElementRef } ]; IgxListComponent.propDecorators = { children: [{ type: ContentChildren, args: [forwardRef(() => IgxListItemComponent),] }], emptyListTemplate: [{ type: ContentChild, args: [IgxEmptyListTemplateDirective, { read: IgxEmptyListTemplateDirective },] }], dataLoadingTemplate: [{ type: ContentChild, args: [IgxDataLoadingTemplateDirective, { read: IgxDataLoadingTemplateDirective },] }], listItemLeftPanningTemplate: [{ type: ContentChild, args: [IgxListItemLeftPanningTemplateDirective, { read: IgxListItemLeftPanningTemplateDirective },] }], listItemRightPanningTemplate: [{ type: ContentChild, args: [IgxListItemRightPanningTemplateDirective, { read: IgxListItemRightPanningTemplateDirective },] }], panEndTriggeringThreshold: [{ type: Input }], defaultEmptyListTemplate: [{ type: ViewChild, args: ['defaultEmptyList', { read: TemplateRef },] }], defaultDataLoadingTemplate: [{ type: ViewChild, args: ['defaultDataLoading', { read: TemplateRef },] }], id: [{ type: HostBinding, args: ['attr.id',] }, { type: Input }], allowLeftPanning: [{ type: Input }], allowRightPanning: [{ type: Input }], isLoading: [{ type: Input }], onLeftPan: [{ type: Output }], onRightPan: [{ type: Output }], onPanStateChange: [{ type: Output }], onItemClicked: [{ type: Output }], role: [{ type: HostBinding, args: ['attr.role',] }], isListEmpty: [{ type: HostBinding, args: ['class.igx-list-empty',] }], cssClass: [{ type: HostBinding, args: ['class.igx-list',] }] }; if (false) { /** * Returns a collection of all items and headers in the list. * ```typescript * let listChildren: QueryList = this.list.children; * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.children; /** * Returns the template which will be used by the IgxList in case there are no list items defined and `isLoading` is set to `false`. * ```typescript * let emptyTemplate = this.list.emptyListTemplate; * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.emptyListTemplate; /** * Returns the template which will be used by the IgxList in case there are no list items defined and `isLoading` is set to `true`. * ```typescript * let loadingTemplate = this.list.dataLoadingTemplate; * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.dataLoadingTemplate; /** * Sets/gets the template shown when left panning a list item. * Default value is `null`. * ```html * <igx-list [allowLeftPanning] = "true"></igx-list> * ``` * ```typescript * let itemLeftPanTmpl = this.list.listItemLeftPanningTemplate; * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.listItemLeftPanningTemplate; /** * Sets/gets the template shown when right panning a list item. * Default value is `null`. * ```html * <igx-list [allowLeftPanning] = "true"></igx-list> * ``` * ```typescript * let itemRightPanTmpl = this.list.listItemRightPanningTemplate; * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.listItemRightPanningTemplate; /** * Provides a threshold after which the item's panning will be completed automatically. * By default this property is set to 0.5 which is 50% of the list item's width. * ```typescript * this.list.panEndTriggeringThreshold = 0.8; * ``` * @type {?} */ IgxListComponent.prototype.panEndTriggeringThreshold; /** * @hidden * @type {?} * @protected */ IgxListComponent.prototype.defaultEmptyListTemplate; /** * @hidden * @type {?} * @protected */ IgxListComponent.prototype.defaultDataLoadingTemplate; /** * Sets/gets the `id` of the list. * If not set, the `id` of the first list component will be `"igx-list-0"`. * ```html * <igx-list id = "my-first-list"></igx-list> * ``` * ```typescript * let listId = this.list.id; * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.id; /** * Sets/gets whether the left panning of an item is allowed. * Default value is `false`. * ```html * <igx-list [allowLeftPanning] = "true"></igx-list> * ``` * ```typescript * let isLeftPanningAllowed = this.list.allowLeftPanning; * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.allowLeftPanning; /** * Sets/gets whether the right panning of an item is allowed. * Default value is `false`. * ```html * <igx-list [allowRightPanning] = "true"></igx-list> * ``` * ```typescript * let isRightPanningAllowed = this.list.allowRightPanning; * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.allowRightPanning; /** * Sets/gets whether the list is currently loading data. * Set it to display the dataLoadingTemplate while data is being retrieved. * Default value is `false`. * ```html * <igx-list [isLoading]="true"></igx-list> * ``` * ```typescript * let isLoading = this.list.isLoading; * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.isLoading; /** * Emits an event within the current list when left pan gesture is executed on a list item. * Provides a reference to an object of type `IListItemPanningEventArgs` as an event argument. * ```html * <igx-list [allowLeftPanning]="true" (onLeftPan)="onLeftPan($event)"></igx-list> * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.onLeftPan; /** * Emits an event within the current list when right pan gesture is executed on a list item. * Provides a reference to an object of type `IListItemPanningEventArgs` as an event argument. * ```html * <igx-list [allowRightPanning]="true" (onRightPan)="onRightPan($event)"></igx-list> * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.onRightPan; /** * Emits an event within the current list when pan gesture is executed on list item. * Provides references to the `IgxListItemComponent` and `IgxListPanState` as event arguments. * ```html * <igx-list (onPanStateChange) = "onPanStateChange($event)"></igx-list> * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.onPanStateChange; /** * Emits an event within the current list when a list item has been clicked. * Provides references to the `IgxListItemComponent` and `Event` as event arguments. * ```html * <igx-list (onItemClicked) = "onItemClicked($event)"></igx-list> * ``` * \@memberof IgxListComponent * @type {?} */ IgxListComponent.prototype.onItemClicked; /** @type {?} */ IgxListComponent.prototype.element; } /** * @hidden */ export class IgxListModule { } IgxListModule.decorators = [ { type: NgModule, args: [{ declarations: [IgxListComponent, IgxListItemComponent, IgxDataLoadingTemplateDirective, IgxEmptyListTemplateDirective, IgxListItemLeftPanningTemplateDirective, IgxListItemRightPanningTemplateDirective], exports: [IgxListComponent, IgxListItemComponent, IgxDataLoadingTemplateDirective, IgxEmptyListTemplateDirective, IgxListItemLeftPanningTemplateDirective, IgxListItemRightPanningTemplateDirective], imports: [CommonModule, IgxRippleModule] },] } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list.component.js","sourceRoot":"ng://igniteui-angular/","sources":["lib/list/list.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n    Component,\n    ContentChild,\n    ContentChildren,\n    ElementRef,\n    EventEmitter,\n    forwardRef,\n    HostBinding,\n    Input,\n    NgModule,\n    Output,\n    QueryList,\n    TemplateRef,\n    ViewChild\n} from '@angular/core';\n\nimport { IgxRippleModule } from '../directives/ripple/ripple.directive';\n\nimport { IgxListItemComponent } from './list-item.component';\nimport {\n    IgxListBase,\n    IgxDataLoadingTemplateDirective,\n    IgxEmptyListTemplateDirective,\n    IgxListPanState,\n    IgxListItemLeftPanningTemplateDirective,\n    IgxListItemRightPanningTemplateDirective} from './list.common';\n\nlet NEXT_ID = 0;\nexport interface IPanStateChangeEventArgs {\n    oldState: IgxListPanState;\n    newState: IgxListPanState;\n    item: IgxListItemComponent;\n}\n\nexport interface IListItemClickEventArgs {\n    item: IgxListItemComponent;\n    event: Event;\n    direction: IgxListPanState;\n}\n\nexport interface IListItemPanningEventArgs {\n    item: IgxListItemComponent;\n    direction: IgxListPanState;\n    keepItem: boolean;\n}\n\n/**\n * **Ignite UI for Angular List** -\n * [Documentation](https://www.infragistics.com/products/ignite-ui-angular/angular/components/list.html)\n *\n * The Ignite UI List displays rows of items and supports one or more header items as well as search and filtering\n * of list items. Each list item is completely templateable and will support any valid HTML or Angular component.\n *\n * Example:\n * ```html\n * <igx-list>\n *   <igx-list-item isHeader=\"true\">Contacts</igx-list-item>\n *   <igx-list-item *ngFor=\"let contact of contacts\">\n *     <span class=\"name\">{{ contact.name }}</span>\n *     <span class=\"phone\">{{ contact.phone }}</span>\n *   </igx-list-item>\n * </igx-list>\n * ```\n */\n@Component({\n    selector: 'igx-list',\n    templateUrl: 'list.component.html',\n    providers: [{ provide: IgxListBase, useExisting: IgxListComponent }]\n})\nexport class IgxListComponent implements IgxListBase {\n\n    constructor(public element: ElementRef) {\n    }\n\n    /**\n     * Returns a collection of all items and headers in the list.\n     * ```typescript\n     * let listChildren: QueryList = this.list.children;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @ContentChildren(forwardRef(() => IgxListItemComponent))\n    public children: QueryList<IgxListItemComponent>;\n\n    /**\n     * @hidden\n     * @internal\n     */\n    protected get sortedChildren(): IgxListItemComponent[] {\n        if (this.children !== undefined) {\n            return this.children.toArray()\n                .sort((a: IgxListItemComponent, b: IgxListItemComponent) => {\n                    return a.index - b.index;\n                });\n        }\n        return null;\n    }\n\n    /**\n     * Returns the template which will be used by the IgxList in case there are no list items defined and `isLoading` is set to `false`.\n     * ```typescript\n     * let emptyTemplate = this.list.emptyListTemplate;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @ContentChild(IgxEmptyListTemplateDirective, { read: IgxEmptyListTemplateDirective })\n    public emptyListTemplate: IgxEmptyListTemplateDirective;\n\n    /**\n     * Returns the template which will be used by the IgxList in case there are no list items defined and `isLoading` is set to `true`.\n     * ```typescript\n     * let loadingTemplate = this.list.dataLoadingTemplate;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @ContentChild(IgxDataLoadingTemplateDirective, { read: IgxDataLoadingTemplateDirective })\n    public dataLoadingTemplate: IgxDataLoadingTemplateDirective;\n\n    /**\n     * Sets/gets the template shown when left panning a list item.\n     * Default value is `null`.\n     * ```html\n     *  <igx-list [allowLeftPanning] = \"true\"></igx-list>\n     * ```\n     * ```typescript\n     * let itemLeftPanTmpl = this.list.listItemLeftPanningTemplate;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @ContentChild(IgxListItemLeftPanningTemplateDirective, { read: IgxListItemLeftPanningTemplateDirective })\n    public listItemLeftPanningTemplate: IgxListItemLeftPanningTemplateDirective;\n\n    /**\n     * Sets/gets the template shown when right panning a list item.\n     * Default value is `null`.\n     * ```html\n     *  <igx-list [allowLeftPanning] = \"true\"></igx-list>\n     * ```\n     * ```typescript\n     * let itemRightPanTmpl = this.list.listItemRightPanningTemplate;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @ContentChild(IgxListItemRightPanningTemplateDirective, { read: IgxListItemRightPanningTemplateDirective })\n    public listItemRightPanningTemplate: IgxListItemRightPanningTemplateDirective;\n\n    /**\n     * Provides a threshold after which the item's panning will be completed automatically.\n     * By default this property is set to 0.5 which is 50% of the list item's width.\n     * ```typescript\n     * this.list.panEndTriggeringThreshold = 0.8;\n     * ```\n     */\n    @Input()\n    public panEndTriggeringThreshold = 0.5;\n\n    /**@hidden*/\n    @ViewChild('defaultEmptyList', { read: TemplateRef })\n    protected defaultEmptyListTemplate: TemplateRef<any>;\n\n    /**@hidden*/\n    @ViewChild('defaultDataLoading', { read: TemplateRef })\n    protected defaultDataLoadingTemplate: TemplateRef<any>;\n\n    /**\n     * Sets/gets the `id` of the list.\n     * If not set, the `id` of the first list component will be `\"igx-list-0\"`.\n     * ```html\n     * <igx-list id = \"my-first-list\"></igx-list>\n     * ```\n     * ```typescript\n     * let listId =  this.list.id;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @HostBinding('attr.id')\n    @Input()\n    public id = `igx-list-${NEXT_ID++}`;\n\n    /**\n     * Sets/gets whether the left panning of an item is allowed.\n     * Default value is `false`.\n     * ```html\n     *  <igx-list [allowLeftPanning] = \"true\"></igx-list>\n     * ```\n     * ```typescript\n     * let isLeftPanningAllowed = this.list.allowLeftPanning;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @Input()\n    public allowLeftPanning = false;\n\n    /**\n     * Sets/gets whether the right panning of an item is allowed.\n     * Default value is `false`.\n     * ```html\n     *  <igx-list [allowRightPanning] = \"true\"></igx-list>\n     * ```\n     * ```typescript\n     * let isRightPanningAllowed = this.list.allowRightPanning;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @Input()\n    public allowRightPanning = false;\n\n    /**\n     * Sets/gets whether the list is currently loading data.\n     * Set it to display the dataLoadingTemplate while data is being retrieved.\n     * Default value is `false`.\n     * ```html\n     *  <igx-list [isLoading]=\"true\"></igx-list>\n     * ```\n     * ```typescript\n     * let isLoading = this.list.isLoading;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @Input()\n    public isLoading = false;\n\n    /**\n     * Emits an event within the current list when left pan gesture is executed on a list item.\n     * Provides a reference to an object of type `IListItemPanningEventArgs` as an event argument.\n     * ```html\n     * <igx-list [allowLeftPanning]=\"true\" (onLeftPan)=\"onLeftPan($event)\"></igx-list>\n     * ```\n     * @memberof IgxListComponent\n     */\n    @Output()\n    public onLeftPan = new EventEmitter<IListItemPanningEventArgs>();\n\n    /**\n     * Emits an event within the current list when right pan gesture is executed on a list item.\n     * Provides a reference to an object of type `IListItemPanningEventArgs` as an event argument.\n     * ```html\n     * <igx-list [allowRightPanning]=\"true\" (onRightPan)=\"onRightPan($event)\"></igx-list>\n     * ```\n     * @memberof IgxListComponent\n     */\n    @Output()\n    public onRightPan = new EventEmitter<IListItemPanningEventArgs>();\n\n    /**\n    * Emits an event within the current list when pan gesture is executed on list item.\n    * Provides references to the `IgxListItemComponent` and `IgxListPanState` as event arguments.\n    * ```html\n    * <igx-list (onPanStateChange) = \"onPanStateChange($event)\"></igx-list>\n    * ```\n    * @memberof IgxListComponent\n    */\n    @Output()\n    public onPanStateChange = new EventEmitter<IPanStateChangeEventArgs>();\n\n    /**\n     * Emits an event within the current list when a list item has been clicked.\n     * Provides references to the `IgxListItemComponent` and `Event` as event arguments.\n     *  ```html\n     * <igx-list (onItemClicked) = \"onItemClicked($event)\"></igx-list>\n     * ```\n     * @memberof IgxListComponent\n     */\n    @Output()\n    public onItemClicked = new EventEmitter<IListItemClickEventArgs>();\n\n    /**\n     * Gets the `role` attribute.\n     * ```typescript\n     * let listRole =  this.list.role;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @HostBinding('attr.role')\n    public get role() {\n        return 'list';\n    }\n\n    /**\n     * Returns boolean indicating if the list is empty.\n     * ```typescript\n     * let isEmpty =  this.list.isListEmpty;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @HostBinding('class.igx-list-empty')\n    public get isListEmpty(): boolean {\n        return !this.children || this.children.length === 0;\n    }\n\n    /**\n     * Returns boolean indicating if the list has a `cssClass` attribute.\n     * ```typescript\n     * let hasCssClass =  this.list.cssClass;\n     * ```\n     * @memberof IgxListComponent\n     */\n    @HostBinding('class.igx-list')\n    public get cssClass(): boolean {\n        return this.children && this.children.length > 0;\n    }\n\n    /**\n     * Returns the `items` in the list excluding the headers.\n     * ```typescript\n     * let listItems: IgxListItemComponent[] = this.list.items;\n     * ```\n     * @memberof IgxListComponent\n     */\n    public get items(): IgxListItemComponent[] {\n        const items: IgxListItemComponent[] = [];\n        if (this.children !== undefined) {\n            for (const child of this.sortedChildren) {\n                if (!child.isHeader) {\n                    items.push(child);\n                }\n            }\n        }\n        return items;\n    }\n\n    /**\n     * Returns the headers in the list.\n     * ```typescript\n     * let listHeaders: IgxListItemComponent[] =  this.list.headers;\n     * ```\n     * @memberof IgxListComponent\n     */\n    public get headers(): IgxListItemComponent[] {\n        const headers: IgxListItemComponent[] = [];\n        if (this.children !== undefined) {\n            for (const child of this.children.toArray()) {\n                if (child.isHeader) {\n                    headers.push(child);\n                }\n            }\n        }\n        return headers;\n    }\n\n    /**\n     * Returns the `context` object which represents the `template context` binding into the `list container`\n     * by providing the `$implicit` declaration which is the `IgxListComponent` itself.\n     * ```typescript\n     * let listComponent =  this.list.context;\n     * ```\n     */\n    public get context(): any {\n        return {\n            $implicit: this\n        };\n    }\n\n    /**\n     * Returns the `template` of an empty list.\n     * ```typescript\n     * let listTemplate = this.list.template;\n     * ```\n     * @memberof IgxListComponent\n     */\n    public get template(): TemplateRef<any> {\n        if (this.isLoading) {\n            return this.dataLoadingTemplate ? this.dataLoadingTemplate.template : this.defaultDataLoadingTemplate;\n        } else {\n            return this.emptyListTemplate ? this.emptyListTemplate.template : this.defaultEmptyListTemplate;\n        }\n    }\n}\n\n/**\n * @hidden\n */\n@NgModule({\n    declarations: [IgxListComponent, IgxListItemComponent,\n        IgxDataLoadingTemplateDirective, IgxEmptyListTemplateDirective,\n        IgxListItemLeftPanningTemplateDirective, IgxListItemRightPanningTemplateDirective],\n    exports: [IgxListComponent, IgxListItemComponent,\n        IgxDataLoadingTemplateDirective, IgxEmptyListTemplateDirective,\n        IgxListItemLeftPanningTemplateDirective, IgxListItemRightPanningTemplateDirective],\n    imports: [CommonModule, IgxRippleModule]\n})\nexport class IgxListModule {\n}\n"]}