UNPKG

ng-zorro-antd-mobile

Version:

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

427 lines 32.8 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ViewEncapsulation, Input, TemplateRef, EventEmitter, Output, HostBinding, HostListener } from '@angular/core'; export class ListItemComponent { constructor() { this.defaultProps = { prefixCls: 'am-list', align: 'middle', error: false, multipleLine: false, wrap: false, platform: 'ios', rippleStyle: {} }; this.arrowCls = {}; this.lineCls = {}; this.wrapCls = ''; this.rippleCls = {}; this.rippleClicked = false; this._thumb_component = false; this._thumb_src = ''; this._extra_component = false; this._extra_title = ''; this._arrow = ''; this._disabled = false; this._className = ''; this._active = false; this.onClick = new EventEmitter(); } /** * @return {?} */ get extra() { return this._extra; } /** * @return {?} */ get extra_component() { return this._extra_component; } /** * @return {?} */ get extra_title() { return this._extra_title; } /** * @param {?} value * @return {?} */ set extra(value) { if (value instanceof TemplateRef) { this._extra_component = true; this._extra = value; } else { this._extra_component = false; this._extra_title = (/** @type {?} */ (value)); } } /** * @param {?} value * @return {?} */ set className(value) { this._className = value; this.setClsMap(); } /** * @return {?} */ get arrow() { return this._arrow; } /** * @param {?} value * @return {?} */ set arrow(value) { this._arrow = value; this.setClsMap(); } /** * @param {?} value * @return {?} */ set multipleLine(value) { this.defaultProps.multipleLine = value === '' ? true : value; this.setClsMap(); } /** * @param {?} value * @return {?} */ set error(value) { this.defaultProps.error = value === '' ? true : value; this.setClsMap(); } /** * @param {?} value * @return {?} */ set wrap(value) { this.defaultProps.wrap = value === '' ? true : value; this.setClsMap(); } /** * @param {?} value * @return {?} */ set align(value) { this.defaultProps.align = value; this.setClsMap(); } /** * @param {?} value * @return {?} */ set platform(value) { this.defaultProps.platform = value; } /** * @param {?} value * @return {?} */ set disabled(value) { if (typeof value === 'boolean') { this._disabled = value; } else { if (value === 'true') { this._disabled = true; } else { this._disabled = false; } } this.setClsMap(); } /** * @return {?} */ get thumb() { return this._thumb; } /** * @return {?} */ get thumb_component() { return this._thumb_component; } /** * @return {?} */ get thumb_src() { return this._thumb_src; } /** * @param {?} value * @return {?} */ set thumb(value) { if (value instanceof TemplateRef) { this._thumb_component = true; this._thumb = value; } else { this._thumb_component = false; this._thumb_src = (/** @type {?} */ (value)); } } /** * @return {?} */ get bingClassName() { return this.wrapCls; } /** * @param {?} event * @return {?} */ click(event) { this.onItemClick(event); } /** * @return {?} */ start() { if (!this._disabled && this.onClick.observers.length > 0) { this._active = true; this.setClsMap(); } } /** * @return {?} */ move() { if (!this._disabled && this.onClick.observers.length > 0) { this._active = false; this.setClsMap(); } } /** * @return {?} */ end() { if (!this._disabled && this.onClick.observers.length > 0) { this._active = false; this.setClsMap(); } } /** * @return {?} */ mouse_start() { if (!this._disabled && this.onClick.observers.length > 0) { this._active = true; this.setClsMap(); } } /** * @return {?} */ mouse_end() { if (!this._disabled && this.onClick.observers.length > 0) { this._active = false; this.setClsMap(); } } /** * @return {?} */ setClsMap() { /** @type {?} */ const classNameList = this._className.split(' '); /** @type {?} */ let classNameObj = {}; this.wrapCls = ''; for (const value of classNameList) { if (value) { classNameObj = Object.assign({}, classNameObj, { [`${value}`]: true }); } } /** @type {?} */ const wrapClsObj = Object.assign({ [`${this.defaultProps.prefixCls}-item`]: true, [`${this.defaultProps.prefixCls}-item-disabled`]: this._disabled, [`${this.defaultProps.prefixCls}-item-active`]: this._active, [`${this.defaultProps.prefixCls}-item-error`]: this.defaultProps.error, [`${this.defaultProps.prefixCls}-item-top`]: this.defaultProps.align === 'top', [`${this.defaultProps.prefixCls}-item-middle`]: this.defaultProps.align === 'middle', [`${this.defaultProps.prefixCls}-item-bottom`]: this.defaultProps.align === 'bottom' }, classNameObj); for (const key in wrapClsObj) { if (wrapClsObj[key]) { this.wrapCls += ` ${key}`; } } this.rippleCls = { [`${this.defaultProps.prefixCls}-ripple`]: true, [`${this.defaultProps.prefixCls}-ripple-animate`]: this.rippleClicked }; this.lineCls = { [`${this.defaultProps.prefixCls}-line`]: true, [`${this.defaultProps.prefixCls}-line-multiple`]: this.defaultProps.multipleLine, [`${this.defaultProps.prefixCls}-line-wrap`]: this.defaultProps.wrap }; this.arrowCls = { [`${this.defaultProps.prefixCls}-arrow`]: true, [`${this.defaultProps.prefixCls}-arrow-horizontal`]: this._arrow === 'horizontal', [`${this.defaultProps.prefixCls}-arrow-vertical`]: this._arrow === 'down' || this._arrow === 'up', [`${this.defaultProps.prefixCls}-arrow-vertical-up`]: this._arrow === 'up' }; } /** * @param {?} ev * @return {?} */ onItemClick(ev) { /** @type {?} */ const isAndroid = this.defaultProps.platform === 'android'; if (isAndroid) { if (this.debounceTimeout) { clearTimeout(this.debounceTimeout); this.debounceTimeout = null; } /** @type {?} */ const Item = ev.currentTarget; /** @type {?} */ const RippleWidth = Math.max(Item.offsetHeight, Item.offsetWidth); /** @type {?} */ const ClientRect = ev.currentTarget.getBoundingClientRect(); /** @type {?} */ const pointX = ev.clientX - ClientRect.left - Item.offsetWidth / 2; /** @type {?} */ const pointY = ev.clientY - ClientRect.top - Item.offsetWidth / 2; /** @type {?} */ const coverRippleStyle = { width: `${RippleWidth}px`, height: `${RippleWidth}px`, left: `${pointX}px`, top: `${pointY}px` }; this.defaultProps.rippleStyle = coverRippleStyle; this.rippleClicked = true; this.setClsMap(); this.debounceTimeout = setTimeout((/** * @return {?} */ () => { this.rippleClicked = false; this.defaultProps.rippleStyle = { display: 'none' }; this.setClsMap(); }), 1000); } this.onClick.emit(ev); } /** * @return {?} */ ngOnInit() { this.defaultProps.rippleStyle = { display: 'none' }; this.setClsMap(); } /** * @return {?} */ ngOnDestroy() { if (this.debounceTimeout) { clearTimeout(this.debounceTimeout); this.debounceTimeout = null; } } } ListItemComponent.decorators = [ { type: Component, args: [{ selector: 'ListItem, nzm-list-item', template: "<div *ngIf=\"thumb_src && !thumb_component\" class=\"{{ defaultProps.prefixCls }}-thumb\">\n <img src=\"{{ thumb_src }}\" />\n</div>\n<div *ngIf=\"thumb && thumb_component\" class=\"{{ defaultProps.prefixCls }}-thumb\">\n <ng-template [ngTemplateOutlet]=\"thumb\"></ng-template>\n</div>\n<div [ngClass]=\"lineCls\">\n <div class=\"{{ defaultProps.prefixCls }}-content\">\n <ng-content></ng-content>\n </div>\n <div\n *ngIf=\"extra_title && !extra_component\"\n class=\"{{ defaultProps.prefixCls }}-extra\"\n [innerHTML]=\"extra_title\"\n ></div>\n <div *ngIf=\"extra && extra_component\" class=\"{{ defaultProps.prefixCls }}-extra\">\n <ng-template [ngTemplateOutlet]=\"extra\"></ng-template>\n </div>\n <div *ngIf=\"arrow\" [ngClass]=\"arrowCls\" aria-hidden=\"true\"></div>\n</div>\n<div [ngClass]=\"rippleCls\" [ngStyle]=\"defaultProps.rippleStyle\"></div>\n", encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ ListItemComponent.ctorParameters = () => []; ListItemComponent.propDecorators = { extra: [{ type: Input }], className: [{ type: Input }], arrow: [{ type: Input }], multipleLine: [{ type: Input }], error: [{ type: Input }], wrap: [{ type: Input }], align: [{ type: Input }], platform: [{ type: Input }], disabled: [{ type: Input }], thumb: [{ type: Input }], onClick: [{ type: Output }], bingClassName: [{ type: HostBinding, args: ['class',] }], click: [{ type: HostListener, args: ['click', ['$event'],] }], start: [{ type: HostListener, args: ['touchstart',] }], move: [{ type: HostListener, args: ['touchmove',] }], end: [{ type: HostListener, args: ['touchend',] }], mouse_start: [{ type: HostListener, args: ['mousedown',] }], mouse_end: [{ type: HostListener, args: ['mouseup',] }] }; if (false) { /** @type {?} */ ListItemComponent.prototype.defaultProps; /** @type {?} */ ListItemComponent.prototype.arrowCls; /** @type {?} */ ListItemComponent.prototype.lineCls; /** @type {?} */ ListItemComponent.prototype.wrapCls; /** @type {?} */ ListItemComponent.prototype.rippleCls; /** @type {?} */ ListItemComponent.prototype.rippleClicked; /** @type {?} */ ListItemComponent.prototype.debounceTimeout; /** * @type {?} * @private */ ListItemComponent.prototype._thumb_component; /** * @type {?} * @private */ ListItemComponent.prototype._thumb; /** * @type {?} * @private */ ListItemComponent.prototype._thumb_src; /** * @type {?} * @private */ ListItemComponent.prototype._extra_component; /** * @type {?} * @private */ ListItemComponent.prototype._extra; /** * @type {?} * @private */ ListItemComponent.prototype._extra_title; /** * @type {?} * @private */ ListItemComponent.prototype._arrow; /** * @type {?} * @private */ ListItemComponent.prototype._disabled; /** * @type {?} * @private */ ListItemComponent.prototype._className; /** * @type {?} * @private */ ListItemComponent.prototype._active; /** @type {?} */ ListItemComponent.prototype.onClick; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"list-item.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["list/list-item/list-item.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EACT,iBAAiB,EAEjB,KAAK,EACL,WAAW,EACX,YAAY,EACZ,MAAM,EAEN,WAAW,EACX,YAAY,EACb,MAAM,eAAe,CAAC;AAOvB,MAAM,OAAO,iBAAiB;IAmK5B;QAlKA,iBAAY,GAAG;YACb,SAAS,EAAE,SAAS;YACpB,KAAK,EAAE,QAAQ;YACf,KAAK,EAAE,KAAK;YACZ,YAAY,EAAE,KAAK;YACnB,IAAI,EAAE,KAAK;YACX,QAAQ,EAAE,KAAK;YACf,WAAW,EAAE,EAAE;SAChB,CAAC;QACF,aAAQ,GAAQ,EAAE,CAAC;QACnB,YAAO,GAAQ,EAAE,CAAC;QAClB,YAAO,GAAW,EAAE,CAAC;QACrB,cAAS,GAAQ,EAAE,CAAC;QACpB,kBAAa,GAAY,KAAK,CAAC;QAGvB,qBAAgB,GAAY,KAAK,CAAC;QAElC,eAAU,GAAW,EAAE,CAAC;QACxB,qBAAgB,GAAY,KAAK,CAAC;QAElC,iBAAY,GAAW,EAAE,CAAC;QAC1B,WAAM,GAAW,EAAE,CAAC;QACpB,cAAS,GAAY,KAAK,CAAC;QAC3B,eAAU,GAAW,EAAE,CAAC;QACxB,YAAO,GAAY,KAAK,CAAC;QA2FjC,YAAO,GAAsB,IAAI,YAAY,EAAO,CAAC;IA8CtC,CAAC;;;;IAvIhB,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;;;;IACD,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;;;;IACD,IAAI,WAAW;QACb,OAAO,IAAI,CAAC,YAAY,CAAC;IAC3B,CAAC;;;;;IACD,IAAI,KAAK,CAAC,KAAgC;QACxC,IAAI,KAAK,YAAY,WAAW,EAAE;YAChC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;SACrB;aAAM;YACL,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;YAC9B,IAAI,CAAC,YAAY,GAAG,mBAAQ,KAAK,EAAA,CAAC;SACnC;IACH,CAAC;;;;;IACD,IACI,SAAS,CAAC,KAAK;QACjB,IAAI,CAAC,UAAU,GAAG,KAAK,CAAC;QACxB,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;IACD,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;;;;;IACD,IAAI,KAAK,CAAC,KAAK;QACb,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;QACpB,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;;IACD,IACI,YAAY,CAAC,KAAK;QACpB,IAAI,CAAC,YAAY,CAAC,YAAY,GAAG,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QAC7D,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;;IACD,IACI,KAAK,CAAC,KAAK;QACb,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACtD,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;;IACD,IACI,IAAI,CAAC,KAAK;QACZ,IAAI,CAAC,YAAY,CAAC,IAAI,GAAG,KAAK,KAAK,EAAE,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;QACrD,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;;IACD,IACI,KAAK,CAAC,KAAK;QACb,IAAI,CAAC,YAAY,CAAC,KAAK,GAAG,KAAK,CAAC;QAChC,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;;IACD,IACI,QAAQ,CAAC,KAAK;QAChB,IAAI,CAAC,YAAY,CAAC,QAAQ,GAAG,KAAK,CAAC;IACrC,CAAC;;;;;IACD,IACI,QAAQ,CAAC,KAAK;QAChB,IAAI,OAAO,KAAK,KAAK,SAAS,EAAE;YAC9B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;SACxB;aAAM;YACL,IAAI,KAAK,KAAK,MAAM,EAAE;gBACpB,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;aACvB;iBAAM;gBACL,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;aACxB;SACF;QACD,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;IACD,IACI,KAAK;QACP,OAAO,IAAI,CAAC,MAAM,CAAC;IACrB,CAAC;;;;IACD,IAAI,eAAe;QACjB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;;;;IACD,IAAI,SAAS;QACX,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;;;;;IACD,IAAI,KAAK,CAAC,KAAK;QACb,IAAI,KAAK,YAAY,WAAW,EAAE;YAChC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC;YAC7B,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;SACrB;aAAM;YACL,IAAI,CAAC,gBAAgB,GAAG,KAAK,CAAC;YAC9B,IAAI,CAAC,UAAU,GAAG,mBAAQ,KAAK,EAAA,CAAC;SACjC;IACH,CAAC;;;;IAID,IACI,aAAa;QACf,OAAO,IAAI,CAAC,OAAO,CAAC;IACtB,CAAC;;;;;IAED,KAAK,CAAC,KAAK;QACT,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;IAC1B,CAAC;;;;IAED,KAAK;QACH,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACxD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;IACH,CAAC;;;;IAED,IAAI;QACF,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACxD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;IACH,CAAC;;;;IAED,GAAG;QACD,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACxD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;IACH,CAAC;;;;IAED,WAAW;QACT,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACxD,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;YACpB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;IACH,CAAC;;;;IAED,SAAS;QACP,IAAI,CAAC,IAAI,CAAC,SAAS,IAAI,IAAI,CAAC,OAAO,CAAC,SAAS,CAAC,MAAM,GAAG,CAAC,EAAE;YACxD,IAAI,CAAC,OAAO,GAAG,KAAK,CAAC;YACrB,IAAI,CAAC,SAAS,EAAE,CAAC;SAClB;IACH,CAAC;;;;IAID,SAAS;;cACD,aAAa,GAAG,IAAI,CAAC,UAAU,CAAC,KAAK,CAAC,GAAG,CAAC;;YAC5C,YAAY,GAAG,EAAE;QACrB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;QAElB,KAAK,MAAM,KAAK,IAAI,aAAa,EAAE;YACjC,IAAI,KAAK,EAAE;gBACT,YAAY,qBACP,YAAY,EACZ,EAAE,CAAC,GAAG,KAAK,EAAE,CAAC,EAAE,IAAI,EAAE,CAC1B,CAAC;aACH;SACF;;cAEK,UAAU,mBACd,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,OAAO,CAAC,EAAE,IAAI,EAC7C,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,gBAAgB,CAAC,EAAE,IAAI,CAAC,SAAS,EAChE,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,cAAc,CAAC,EAAE,IAAI,CAAC,OAAO,EAC5D,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,aAAa,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,EACtE,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,WAAW,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,KAAK,KAAK,EAC9E,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,cAAc,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,KAAK,QAAQ,EACpF,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,cAAc,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,KAAK,KAAK,QAAQ,IACjF,YAAY,CAChB;QAED,KAAK,MAAM,GAAG,IAAI,UAAU,EAAE;YAC5B,IAAI,UAAU,CAAC,GAAG,CAAC,EAAE;gBACnB,IAAI,CAAC,OAAO,IAAI,IAAI,GAAG,EAAE,CAAC;aAC3B;SACF;QAED,IAAI,CAAC,SAAS,GAAG;YACf,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,SAAS,CAAC,EAAE,IAAI;YAC/C,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,iBAAiB,CAAC,EAAE,IAAI,CAAC,aAAa;SACtE,CAAC;QAEF,IAAI,CAAC,OAAO,GAAG;YACb,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,OAAO,CAAC,EAAE,IAAI;YAC7C,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,gBAAgB,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,YAAY;YAChF,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,YAAY,CAAC,EAAE,IAAI,CAAC,YAAY,CAAC,IAAI;SACrE,CAAC;QAEF,IAAI,CAAC,QAAQ,GAAG;YACd,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,QAAQ,CAAC,EAAE,IAAI;YAC9C,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,mBAAmB,CAAC,EAAE,IAAI,CAAC,MAAM,KAAK,YAAY;YACjF,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,iBAAiB,CAAC,EAAE,IAAI,CAAC,MAAM,KAAK,MAAM,IAAI,IAAI,CAAC,MAAM,KAAK,IAAI;YACjG,CAAC,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,oBAAoB,CAAC,EAAE,IAAI,CAAC,MAAM,KAAK,IAAI;SAC3E,CAAC;IACJ,CAAC;;;;;IAED,WAAW,CAAC,EAAE;;cACN,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,QAAQ,KAAK,SAAS;QAC1D,IAAI,SAAS,EAAE;YACb,IAAI,IAAI,CAAC,eAAe,EAAE;gBACxB,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;gBACnC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;aAC7B;;kBACK,IAAI,GAAG,EAAE,CAAC,aAAa;;kBACvB,WAAW,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,YAAY,EAAE,IAAI,CAAC,WAAW,CAAC;;kBAC3D,UAAU,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE;;kBACrD,MAAM,GAAG,EAAE,CAAC,OAAO,GAAG,UAAU,CAAC,IAAI,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC;;kBAC5D,MAAM,GAAG,EAAE,CAAC,OAAO,GAAG,UAAU,CAAC,GAAG,GAAG,IAAI,CAAC,WAAW,GAAG,CAAC;;kBAC3D,gBAAgB,GAAG;gBACvB,KAAK,EAAE,GAAG,WAAW,IAAI;gBACzB,MAAM,EAAE,GAAG,WAAW,IAAI;gBAC1B,IAAI,EAAE,GAAG,MAAM,IAAI;gBACnB,GAAG,EAAE,GAAG,MAAM,IAAI;aACnB;YACD,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,gBAAgB,CAAC;YACjD,IAAI,CAAC,aAAa,GAAG,IAAI,CAAC;YAC1B,IAAI,CAAC,SAAS,EAAE,CAAC;YACjB,IAAI,CAAC,eAAe,GAAG,UAAU;;;YAAC,GAAG,EAAE;gBACrC,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC;gBAC3B,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;gBACpD,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,CAAC,GAAE,IAAI,CAAC,CAAC;SACV;QACD,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;IACxB,CAAC;;;;IAED,QAAQ;QACN,IAAI,CAAC,YAAY,CAAC,WAAW,GAAG,EAAE,OAAO,EAAE,MAAM,EAAE,CAAC;QACpD,IAAI,CAAC,SAAS,EAAE,CAAC;IACnB,CAAC;;;;IAED,WAAW;QACT,IAAI,IAAI,CAAC,eAAe,EAAE;YACxB,YAAY,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;YACnC,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;SAC7B;IACH,CAAC;;;YApQF,SAAS,SAAC;gBACT,QAAQ,EAAE,yBAAyB;gBACnC,i4BAAyC;gBACzC,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;;;oBA6BE,KAAK;wBAmBL,KAAK;oBAKL,KAAK;2BAQL,KAAK;oBAKL,KAAK;mBAKL,KAAK;oBAKL,KAAK;uBAKL,KAAK;uBAIL,KAAK;oBAaL,KAAK;sBAmBL,MAAM;4BAGN,WAAW,SAAC,OAAO;oBAInB,YAAY,SAAC,OAAO,EAAE,CAAC,QAAQ,CAAC;oBAIhC,YAAY,SAAC,YAAY;mBAOzB,YAAY,SAAC,WAAW;kBAOxB,YAAY,SAAC,UAAU;0BAOvB,YAAY,SAAC,WAAW;wBAOxB,YAAY,SAAC,SAAS;;;;IA1JvB,yCAQE;;IACF,qCAAmB;;IACnB,oCAAkB;;IAClB,oCAAqB;;IACrB,sCAAoB;;IACpB,0CAA+B;;IAC/B,4CAAqB;;;;;IAErB,6CAA0C;;;;;IAC1C,mCAAiC;;;;;IACjC,uCAAgC;;;;;IAChC,6CAA0C;;;;;IAC1C,mCAAiC;;;;;IACjC,yCAAkC;;;;;IAClC,mCAA4B;;;;;IAC5B,sCAAmC;;;;;IACnC,uCAAgC;;;;;IAChC,oCAAiC;;IA0FjC,oCACqD","sourcesContent":["import {\n  Component,\n  ViewEncapsulation,\n  OnInit,\n  Input,\n  TemplateRef,\n  EventEmitter,\n  Output,\n  OnDestroy,\n  HostBinding,\n  HostListener\n} from '@angular/core';\n\n@Component({\n  selector: 'ListItem, nzm-list-item',\n  templateUrl: './list-item.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class ListItemComponent implements OnInit, OnDestroy {\n  defaultProps = {\n    prefixCls: 'am-list',\n    align: 'middle',\n    error: false,\n    multipleLine: false,\n    wrap: false,\n    platform: 'ios',\n    rippleStyle: {}\n  };\n  arrowCls: any = {};\n  lineCls: any = {};\n  wrapCls: string = '';\n  rippleCls: any = {};\n  rippleClicked: boolean = false;\n  debounceTimeout: any;\n\n  private _thumb_component: boolean = false;\n  private _thumb: TemplateRef<any>;\n  private _thumb_src: string = '';\n  private _extra_component: boolean = false;\n  private _extra: TemplateRef<any>;\n  private _extra_title: string = '';\n  private _arrow: string = '';\n  private _disabled: boolean = false;\n  private _className: string = '';\n  private _active: boolean = false;\n\n  @Input()\n  get extra() {\n    return this._extra;\n  }\n  get extra_component() {\n    return this._extra_component;\n  }\n  get extra_title() {\n    return this._extra_title;\n  }\n  set extra(value: string | TemplateRef<any>) {\n    if (value instanceof TemplateRef) {\n      this._extra_component = true;\n      this._extra = value;\n    } else {\n      this._extra_component = false;\n      this._extra_title = <string>value;\n    }\n  }\n  @Input()\n  set className(value) {\n    this._className = value;\n    this.setClsMap();\n  }\n  @Input()\n  get arrow() {\n    return this._arrow;\n  }\n  set arrow(value) {\n    this._arrow = value;\n    this.setClsMap();\n  }\n  @Input()\n  set multipleLine(value) {\n    this.defaultProps.multipleLine = value === '' ? true : value;\n    this.setClsMap();\n  }\n  @Input()\n  set error(value) {\n    this.defaultProps.error = value === '' ? true : value;\n    this.setClsMap();\n  }\n  @Input()\n  set wrap(value) {\n    this.defaultProps.wrap = value === '' ? true : value;\n    this.setClsMap();\n  }\n  @Input()\n  set align(value) {\n    this.defaultProps.align = value;\n    this.setClsMap();\n  }\n  @Input()\n  set platform(value) {\n    this.defaultProps.platform = value;\n  }\n  @Input()\n  set disabled(value) {\n    if (typeof value === 'boolean') {\n      this._disabled = value;\n    } else {\n      if (value === 'true') {\n        this._disabled = true;\n      } else {\n        this._disabled = false;\n      }\n    }\n    this.setClsMap();\n  }\n  @Input()\n  get thumb() {\n    return this._thumb;\n  }\n  get thumb_component() {\n    return this._thumb_component;\n  }\n  get thumb_src() {\n    return this._thumb_src;\n  }\n  set thumb(value) {\n    if (value instanceof TemplateRef) {\n      this._thumb_component = true;\n      this._thumb = value;\n    } else {\n      this._thumb_component = false;\n      this._thumb_src = <string>value;\n    }\n  }\n  @Output()\n  onClick: EventEmitter<any> = new EventEmitter<any>();\n\n  @HostBinding('class')\n  get bingClassName(): string {\n    return this.wrapCls;\n  }\n  @HostListener('click', ['$event'])\n  click(event) {\n    this.onItemClick(event);\n  }\n  @HostListener('touchstart')\n  start() {\n    if (!this._disabled && this.onClick.observers.length > 0) {\n      this._active = true;\n      this.setClsMap();\n    }\n  }\n  @HostListener('touchmove')\n  move() {\n    if (!this._disabled && this.onClick.observers.length > 0) {\n      this._active = false;\n      this.setClsMap();\n    }\n  }\n  @HostListener('touchend')\n  end() {\n    if (!this._disabled && this.onClick.observers.length > 0) {\n      this._active = false;\n      this.setClsMap();\n    }\n  }\n  @HostListener('mousedown')\n  mouse_start() {\n    if (!this._disabled && this.onClick.observers.length > 0) {\n      this._active = true;\n      this.setClsMap();\n    }\n  }\n  @HostListener('mouseup')\n  mouse_end() {\n    if (!this._disabled && this.onClick.observers.length > 0) {\n      this._active = false;\n      this.setClsMap();\n    }\n  }\n\n  constructor() {}\n\n  setClsMap() {\n    const classNameList = this._className.split(' ');\n    let classNameObj = {};\n    this.wrapCls = '';\n\n    for (const value of classNameList) {\n      if (value) {\n        classNameObj = {\n          ...classNameObj,\n          ...{ [`${value}`]: true }\n        };\n      }\n    }\n\n    const wrapClsObj = {\n      [`${this.defaultProps.prefixCls}-item`]: true,\n      [`${this.defaultProps.prefixCls}-item-disabled`]: this._disabled,\n      [`${this.defaultProps.prefixCls}-item-active`]: this._active,\n      [`${this.defaultProps.prefixCls}-item-error`]: this.defaultProps.error,\n      [`${this.defaultProps.prefixCls}-item-top`]: this.defaultProps.align === 'top',\n      [`${this.defaultProps.prefixCls}-item-middle`]: this.defaultProps.align === 'middle',\n      [`${this.defaultProps.prefixCls}-item-bottom`]: this.defaultProps.align === 'bottom',\n      ...classNameObj\n    };\n\n    for (const key in wrapClsObj) {\n      if (wrapClsObj[key]) {\n        this.wrapCls += ` ${key}`;\n      }\n    }\n\n    this.rippleCls = {\n      [`${this.defaultProps.prefixCls}-ripple`]: true,\n      [`${this.defaultProps.prefixCls}-ripple-animate`]: this.rippleClicked\n    };\n\n    this.lineCls = {\n      [`${this.defaultProps.prefixCls}-line`]: true,\n      [`${this.defaultProps.prefixCls}-line-multiple`]: this.defaultProps.multipleLine,\n      [`${this.defaultProps.prefixCls}-line-wrap`]: this.defaultProps.wrap\n    };\n\n    this.arrowCls = {\n      [`${this.defaultProps.prefixCls}-arrow`]: true,\n      [`${this.defaultProps.prefixCls}-arrow-horizontal`]: this._arrow === 'horizontal',\n      [`${this.defaultProps.prefixCls}-arrow-vertical`]: this._arrow === 'down' || this._arrow === 'up',\n      [`${this.defaultProps.prefixCls}-arrow-vertical-up`]: this._arrow === 'up'\n    };\n  }\n\n  onItemClick(ev) {\n    const isAndroid = this.defaultProps.platform === 'android';\n    if (isAndroid) {\n      if (this.debounceTimeout) {\n        clearTimeout(this.debounceTimeout);\n        this.debounceTimeout = null;\n      }\n      const Item = ev.currentTarget;\n      const RippleWidth = Math.max(Item.offsetHeight, Item.offsetWidth);\n      const ClientRect = ev.currentTarget.getBoundingClientRect();\n      const pointX = ev.clientX - ClientRect.left - Item.offsetWidth / 2;\n      const pointY = ev.clientY - ClientRect.top - Item.offsetWidth / 2;\n      const coverRippleStyle = {\n        width: `${RippleWidth}px`,\n        height: `${RippleWidth}px`,\n        left: `${pointX}px`,\n        top: `${pointY}px`\n      };\n      this.defaultProps.rippleStyle = coverRippleStyle;\n      this.rippleClicked = true;\n      this.setClsMap();\n      this.debounceTimeout = setTimeout(() => {\n        this.rippleClicked = false;\n        this.defaultProps.rippleStyle = { display: 'none' };\n        this.setClsMap();\n      }, 1000);\n    }\n    this.onClick.emit(ev);\n  }\n\n  ngOnInit() {\n    this.defaultProps.rippleStyle = { display: 'none' };\n    this.setClsMap();\n  }\n\n  ngOnDestroy(): void {\n    if (this.debounceTimeout) {\n      clearTimeout(this.debounceTimeout);\n      this.debounceTimeout = null;\n    }\n  }\n}\n"]}