ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
427 lines • 32.8 kB
JavaScript
/**
* @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":"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","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"]}