igniteui-angular
Version:
Ignite UI for Angular is a dependency-free Angular toolkit for building modern web apps
503 lines • 40 kB
JavaScript
/**
* @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":";;;;AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EACH,SAAS,EACT,YAAY,EACZ,eAAe,EACf,UAAU,EACV,YAAY,EACZ,UAAU,EACV,WAAW,EACX,KAAK,EACL,QAAQ,EACR,MAAM,EACN,SAAS,EACT,WAAW,EACX,SAAS,EACZ,MAAM,eAAe,CAAC;AAEvB,OAAO,EAAE,eAAe,EAAE,MAAM,uCAAuC,CAAC;AAExE,OAAO,EAAE,oBAAoB,EAAE,MAAM,uBAAuB,CAAC;AAC7D,OAAO,EACH,WAAW,EACX,+BAA+B,EAC/B,6BAA6B,EAE7B,uCAAuC,EACvC,wCAAwC,EAAC,MAAM,eAAe,CAAC;;IAE/D,OAAO,GAAG,CAAC;;;;AACf,8CAIC;;;IAHG,4CAA0B;;IAC1B,4CAA0B;;IAC1B,wCAA2B;;;;;AAG/B,6CAIC;;;IAHG,uCAA2B;;IAC3B,wCAAa;;IACb,4CAA2B;;;;;AAG/B,+CAIC;;;IAHG,yCAA2B;;IAC3B,8CAA2B;;IAC3B,6CAAkB;;;;;;;;;;;;;;;;;;;;AA0BtB,MAAM,OAAO,gBAAgB;;;;IAEzB,YAAmB,OAAmB;QAAnB,YAAO,GAAP,OAAO,CAAY;;;;;;;;QAmF/B,8BAAyB,GAAG,GAAG,CAAC;;;;;;;;;;;;QAuBhC,OAAE,GAAG,YAAY,OAAO,EAAE,EAAE,CAAC;;;;;;;;;;;;QAc7B,qBAAgB,GAAG,KAAK,CAAC;;;;;;;;;;;;QAczB,sBAAiB,GAAG,KAAK,CAAC;;;;;;;;;;;;;QAe1B,cAAS,GAAG,KAAK,CAAC;;;;;;;;;QAWlB,cAAS,GAAG,IAAI,YAAY,EAA6B,CAAC;;;;;;;;;QAW1D,eAAU,GAAG,IAAI,YAAY,EAA6B,CAAC;;;;;;;;;QAW3D,qBAAgB,GAAG,IAAI,YAAY,EAA4B,CAAC;;;;;;;;;QAWhE,kBAAa,GAAG,IAAI,YAAY,EAA2B,CAAC;IAhMnE,CAAC;;;;;;;IAgBD,IAAc,cAAc;QACxB,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC7B,OAAO,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE;iBACzB,IAAI,CAAC,CAAC,CAAuB,EAAE,CAAuB,EAAE,EAAE;gBACvD,OAAO,CAAC,CAAC,KAAK,GAAG,CAAC,CAAC,KAAK,CAAC;YAC7B,CAAC,CAAC,CAAC;SACV;QACD,OAAO,IAAI,CAAC;IAChB,CAAC;;;;;;;;;IAiLD,IACW,IAAI;QACX,OAAO,MAAM,CAAC;IAClB,CAAC;;;;;;;;;IASD,IACW,WAAW;QAClB,OAAO,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,KAAK,CAAC,CAAC;IACxD,CAAC;;;;;;;;;IASD,IACW,QAAQ;QACf,OAAO,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,GAAG,CAAC,CAAC;IACrD,CAAC;;;;;;;;;IASD,IAAW,KAAK;;cACN,KAAK,GAA2B,EAAE;QACxC,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC7B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,cAAc,EAAE;gBACrC,IAAI,CAAC,KAAK,CAAC,QAAQ,EAAE;oBACjB,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBACrB;aACJ;SACJ;QACD,OAAO,KAAK,CAAC;IACjB,CAAC;;;;;;;;;IASD,IAAW,OAAO;;cACR,OAAO,GAA2B,EAAE;QAC1C,IAAI,IAAI,CAAC,QAAQ,KAAK,SAAS,EAAE;YAC7B,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,QAAQ,CAAC,OAAO,EAAE,EAAE;gBACzC,IAAI,KAAK,CAAC,QAAQ,EAAE;oBAChB,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;iBACvB;aACJ;SACJ;QACD,OAAO,OAAO,CAAC;IACnB,CAAC;;;;;;;;;IASD,IAAW,OAAO;QACd,OAAO;YACH,SAAS,EAAE,IAAI;SAClB,CAAC;IACN,CAAC;;;;;;;;;IASD,IAAW,QAAQ;QACf,IAAI,IAAI,CAAC,SAAS,EAAE;YAChB,OAAO,IAAI,CAAC,mBAAmB,CAAC,CAAC,CAAC,IAAI,CAAC,mBAAmB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,0BAA0B,CAAC;SACzG;aAAM;YACH,OAAO,IAAI,CAAC,iBAAiB,CAAC,CAAC,CAAC,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC,CAAC,IAAI,CAAC,wBAAwB,CAAC;SACnG;IACL,CAAC;;;YA9SJ,SAAS,SAAC;gBACP,QAAQ,EAAE,UAAU;gBACpB,wgBAAkC;gBAClC,SAAS,EAAE,CAAC,EAAE,OAAO,EAAE,WAAW,EAAE,WAAW,EAAE,gBAAgB,EAAE,CAAC;aACvE;;;;YAhEG,UAAU;;;uBA6ET,eAAe,SAAC,UAAU,CAAC,GAAG,EAAE,CAAC,oBAAoB,CAAC;gCAwBtD,YAAY,SAAC,6BAA6B,EAAE,EAAE,IAAI,EAAE,6BAA6B,EAAE;kCAUnF,YAAY,SAAC,+BAA+B,EAAE,EAAE,IAAI,EAAE,+BAA+B,EAAE;0CAcvF,YAAY,SAAC,uCAAuC,EAAE,EAAE,IAAI,EAAE,uCAAuC,EAAE;2CAcvG,YAAY,SAAC,wCAAwC,EAAE,EAAE,IAAI,EAAE,wCAAwC,EAAE;wCAUzG,KAAK;uCAIL,SAAS,SAAC,kBAAkB,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;yCAInD,SAAS,SAAC,oBAAoB,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE;iBAcrD,WAAW,SAAC,SAAS,cACrB,KAAK;+BAcL,KAAK;gCAcL,KAAK;wBAeL,KAAK;wBAWL,MAAM;yBAWN,MAAM;+BAWN,MAAM;4BAWN,MAAM;mBAUN,WAAW,SAAC,WAAW;0BAYvB,WAAW,SAAC,sBAAsB;uBAYlC,WAAW,SAAC,gBAAgB;;;;;;;;;;;IAxN7B,oCACiD;;;;;;;;;IAuBjD,6CACwD;;;;;;;;;IASxD,+CAC4D;;;;;;;;;;;;;IAa5D,uDAC4E;;;;;;;;;;;;;IAa5E,wDAC8E;;;;;;;;;IAS9E,qDACuC;;;;;;IAGvC,oDACqD;;;;;;IAGrD,sDACuD;;;;;;;;;;;;;IAavD,8BAEoC;;;;;;;;;;;;;IAapC,4CACgC;;;;;;;;;;;;;IAahC,6CACiC;;;;;;;;;;;;;;IAcjC,qCACyB;;;;;;;;;;IAUzB,qCACiE;;;;;;;;;;IAUjE,sCACkE;;;;;;;;;;IAUlE,4CACuE;;;;;;;;;;IAUvE,yCACmE;;IAjMvD,mCAA0B;;;;;AAsT1C,MAAM,OAAO,aAAa;;;YATzB,QAAQ,SAAC;gBACN,YAAY,EAAE,CAAC,gBAAgB,EAAE,oBAAoB;oBACjD,+BAA+B,EAAE,6BAA6B;oBAC9D,uCAAuC,EAAE,wCAAwC,CAAC;gBACtF,OAAO,EAAE,CAAC,gBAAgB,EAAE,oBAAoB;oBAC5C,+BAA+B,EAAE,6BAA6B;oBAC9D,uCAAuC,EAAE,wCAAwC,CAAC;gBACtF,OAAO,EAAE,CAAC,YAAY,EAAE,eAAe,CAAC;aAC3C","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"]}