ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
334 lines • 24.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, EventEmitter, Input, Output, ViewChild, ViewEncapsulation } from '@angular/core';
var SwipeActionComponent = /** @class */ (function () {
function SwipeActionComponent() {
var _this = this;
this.prefixCls = 'am-swipe';
this.wrapCls = {};
this._swiping = false;
this._openedLeft = false;
this._openedRight = false;
this.left = [];
this.right = [];
this.autoClose = false;
this.disabled = false;
this.onOpen = new EventEmitter();
this.onClose = new EventEmitter();
this.onCloseSwipe = (/**
* @param {?} ev
* @return {?}
*/
function (ev) {
if (!(_this._openedLeft || _this._openedRight)) {
return;
}
/** @type {?} */
var pNode = ev.target.closest("." + _this.prefixCls + "-actions");
if (!pNode) {
_this.close();
}
});
}
/**
* @return {?}
*/
SwipeActionComponent.prototype.setClassMap = /**
* @return {?}
*/
function () {
var _a;
this.wrapCls = (_a = {},
_a[this.prefixCls] = true,
_a[this.prefixCls + "-swiping"] = this._swiping,
_a);
};
/**
* @return {?}
*/
SwipeActionComponent.prototype.close = /**
* @return {?}
*/
function () {
if (this._openedLeft || this._openedRight) {
this.onClose.emit();
}
this.setBtnStyle(0);
this._openedLeft = false;
this._openedRight = false;
};
/**
* @param {?} value
* @return {?}
*/
SwipeActionComponent.prototype.setBtnStyle = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (this._btnsLeftWidth === 0 || this._btnsRightWidth === 0) {
this._btnsLeftWidth = this.leftBtnRef ? this.leftBtnRef.nativeElement.offsetWidth : 0;
this._btnsRightWidth = this.rightBtnRef ? this.rightBtnRef.nativeElement.offsetWidth : 0;
}
/** @type {?} */
var limit = value > 0 ? this._btnsLeftWidth : -this._btnsRightWidth;
/** @type {?} */
var contentLeft = this.getContentEasing(value, limit);
this.content.nativeElement.style.left = contentLeft + "px";
this.cover.nativeElement.style.display = Math.abs(value) > 0 ? 'block' : 'none';
this.cover.nativeElement.style.left = contentLeft + "px";
};
/**
* @param {?} value
* @param {?} limit
* @return {?}
*/
SwipeActionComponent.prototype.getContentEasing = /**
* @param {?} value
* @param {?} limit
* @return {?}
*/
function (value, limit) {
return Math.abs(value) - Math.abs(limit) > 0 ? limit : value;
};
/**
* @param {?} e
* @return {?}
*/
SwipeActionComponent.prototype.onTouchStart = /**
* @param {?} e
* @return {?}
*/
function (e) {
this._startX = e.changedTouches[0].clientX;
this._swiping = true;
};
/**
* @param {?} e
* @return {?}
*/
SwipeActionComponent.prototype.onTouchMove = /**
* @param {?} e
* @return {?}
*/
function (e) {
/** @type {?} */
var deltaX = e.changedTouches[0].clientX - this._startX;
this._needShowRight = deltaX < -5 && this.right.length > 0;
this._needShowLeft = deltaX > 5 && this.left.length > 0;
if (this.leftBtnRef) {
this.leftBtnRef.nativeElement.style.visibility = this._needShowRight ? 'hidden' : 'visible';
}
if (this.rightBtnRef) {
this.rightBtnRef.nativeElement.style.visibility = this._needShowLeft ? 'hidden' : 'visible';
}
this.setBtnStyle(deltaX);
};
/**
* @param {?} e
* @return {?}
*/
SwipeActionComponent.prototype.onTouchEnd = /**
* @param {?} e
* @return {?}
*/
function (e) {
/** @type {?} */
var deltaX = e.changedTouches[0].clientX - this._startX;
/** @type {?} */
var needOpenRight = this._needShowRight && Math.abs(deltaX) > this._btnsRightWidth / 2;
/** @type {?} */
var needOpenLeft = this._needShowLeft && Math.abs(deltaX) > this._btnsLeftWidth / 2;
if (needOpenRight) {
this.doOpenRight();
}
else if (needOpenLeft) {
this.doOpenLeft();
}
else {
this.close();
}
this._swiping = false;
this._needShowLeft = false;
this._needShowRight = false;
};
/**
* @return {?}
*/
SwipeActionComponent.prototype.doOpenLeft = /**
* @return {?}
*/
function () {
this.open(this._btnsLeftWidth, true, false);
};
/**
* @return {?}
*/
SwipeActionComponent.prototype.doOpenRight = /**
* @return {?}
*/
function () {
this.open(-this._btnsRightWidth, false, true);
};
/**
* @param {?} ev
* @param {?} btn
* @return {?}
*/
SwipeActionComponent.prototype.onBtnClick = /**
* @param {?} ev
* @param {?} btn
* @return {?}
*/
function (ev, btn) {
/** @type {?} */
var onPress = btn.onPress;
if (onPress) {
onPress(ev);
}
if (this.autoClose) {
this.close();
}
};
/**
* @param {?} value
* @param {?} openedLeft
* @param {?} openedRight
* @return {?}
*/
SwipeActionComponent.prototype.open = /**
* @param {?} value
* @param {?} openedLeft
* @param {?} openedRight
* @return {?}
*/
function (value, openedLeft, openedRight) {
this.onOpen.emit();
this._openedLeft = openedLeft;
this._openedRight = openedRight;
this.setBtnStyle(value);
};
/**
* @return {?}
*/
SwipeActionComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.setClassMap();
};
/**
* @return {?}
*/
SwipeActionComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
this._btnsLeftWidth = this.leftBtnRef ? this.leftBtnRef.nativeElement.offsetWidth : 0;
this._btnsRightWidth = this.rightBtnRef ? this.rightBtnRef.nativeElement.offsetWidth : 0;
document.body.addEventListener('touchstart', this.onCloseSwipe, true);
};
/**
* @return {?}
*/
SwipeActionComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
document.body.removeEventListener('touchstart', this.onCloseSwipe, true);
};
SwipeActionComponent.decorators = [
{ type: Component, args: [{
selector: 'SwipeAction, nzm-swipe-action',
template: "<div *ngIf=\"(left.length != 0 || right.length != 0) && !disabled\" [ngClass]=\"wrapCls\">\n <div class=\"{{ prefixCls }}-cover\" #coverRef></div>\n <div *ngIf=\"left && left.length > 0\" class=\"{{ prefixCls }}-actions {{ prefixCls }}-actions-left\" #leftBtnRef>\n <div\n *ngFor=\"let btn of left\"\n class=\"{{ prefixCls }}-btn {{ btn.className }}\"\n [ngStyle]=\"btn.style\"\n role=\"button\"\n (click)=\"onBtnClick($event, btn)\"\n >\n <div class=\"{{ prefixCls }}-btn-text\">\n {{ btn.text || 'Click' }}\n </div>\n </div>\n </div>\n <div *ngIf=\"right && right.length > 0\" class=\"{{ prefixCls }}-actions {{ prefixCls }}-actions-right\" #rightBtnRef>\n <div\n *ngFor=\"let btn of right\"\n class=\"{{ prefixCls }}-btn {{ btn.className }}\"\n [ngStyle]=\"btn.style\"\n role=\"button\"\n (click)=\"onBtnClick($event, btn)\"\n >\n <div class=\"{{ prefixCls }}-btn-text\">\n {{ btn.text || 'Click' }}\n </div>\n </div>\n </div>\n <div\n class=\"{{ prefixCls }}-content\"\n #contentRef\n (touchstart)=\"onTouchStart($event)\"\n (touchmove)=\"onTouchMove($event)\"\n (touchend)=\"onTouchEnd($event)\"\n >\n <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n </div>\n</div>\n<div *ngIf=\"!((left.length != 0 || right.length != 0) && !disabled)\" class=\"{{ prefixCls }}-content\" #contentRef>\n <ng-template [ngTemplateOutlet]=\"content\"></ng-template>\n</div>\n\n<ng-template #content>\n <ng-content></ng-content>\n</ng-template>\n",
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
SwipeActionComponent.ctorParameters = function () { return []; };
SwipeActionComponent.propDecorators = {
leftBtnRef: [{ type: ViewChild, args: ['leftBtnRef', { static: false },] }],
rightBtnRef: [{ type: ViewChild, args: ['rightBtnRef', { static: false },] }],
content: [{ type: ViewChild, args: ['contentRef', { static: false },] }],
cover: [{ type: ViewChild, args: ['coverRef', { static: false },] }],
left: [{ type: Input }],
right: [{ type: Input }],
autoClose: [{ type: Input }],
disabled: [{ type: Input }],
onOpen: [{ type: Output }],
onClose: [{ type: Output }]
};
return SwipeActionComponent;
}());
export { SwipeActionComponent };
if (false) {
/** @type {?} */
SwipeActionComponent.prototype.prefixCls;
/** @type {?} */
SwipeActionComponent.prototype.wrapCls;
/**
* @type {?}
* @private
*/
SwipeActionComponent.prototype._swiping;
/**
* @type {?}
* @private
*/
SwipeActionComponent.prototype._openedLeft;
/**
* @type {?}
* @private
*/
SwipeActionComponent.prototype._openedRight;
/**
* @type {?}
* @private
*/
SwipeActionComponent.prototype._btnsLeftWidth;
/**
* @type {?}
* @private
*/
SwipeActionComponent.prototype._btnsRightWidth;
/**
* @type {?}
* @private
*/
SwipeActionComponent.prototype._needShowLeft;
/**
* @type {?}
* @private
*/
SwipeActionComponent.prototype._needShowRight;
/**
* @type {?}
* @private
*/
SwipeActionComponent.prototype._startX;
/** @type {?} */
SwipeActionComponent.prototype.leftBtnRef;
/** @type {?} */
SwipeActionComponent.prototype.rightBtnRef;
/** @type {?} */
SwipeActionComponent.prototype.content;
/** @type {?} */
SwipeActionComponent.prototype.cover;
/** @type {?} */
SwipeActionComponent.prototype.left;
/** @type {?} */
SwipeActionComponent.prototype.right;
/** @type {?} */
SwipeActionComponent.prototype.autoClose;
/** @type {?} */
SwipeActionComponent.prototype.disabled;
/** @type {?} */
SwipeActionComponent.prototype.onOpen;
/** @type {?} */
SwipeActionComponent.prototype.onClose;
/** @type {?} */
SwipeActionComponent.prototype.onCloseSwipe;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"swipe-action.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["swipe-action/swipe-action.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterViewInit,\n  Component,\n  EventEmitter,\n  Input,\n  OnDestroy,\n  OnInit,\n  Output,\n  ViewChild,\n  ViewEncapsulation\n} from '@angular/core';\n\n@Component({\n  selector: 'SwipeAction, nzm-swipe-action',\n  templateUrl: './swipe-action.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class SwipeActionComponent implements OnInit, AfterViewInit, OnDestroy {\n  prefixCls: string = 'am-swipe';\n  wrapCls: object = {};\n\n  private _swiping: boolean = false;\n  private _openedLeft: boolean = false;\n  private _openedRight: boolean = false;\n  private _btnsLeftWidth: number;\n  private _btnsRightWidth: number;\n  private _needShowLeft: boolean;\n  private _needShowRight: boolean;\n  private _startX: number;\n\n  @ViewChild('leftBtnRef', { static: false })\n  leftBtnRef;\n  @ViewChild('rightBtnRef', { static: false })\n  rightBtnRef;\n  @ViewChild('contentRef', { static: false })\n  content;\n  @ViewChild('coverRef', { static: false })\n  cover;\n\n  @Input()\n  left: Array<object> = [];\n  @Input()\n  right: Array<object> = [];\n  @Input()\n  autoClose: boolean = false;\n  @Input()\n  disabled: boolean = false;\n  @Output()\n  onOpen: EventEmitter<any> = new EventEmitter<any>();\n  @Output()\n  onClose: EventEmitter<any> = new EventEmitter<any>();\n\n  constructor() {}\n\n  setClassMap() {\n    this.wrapCls = {\n      [this.prefixCls]: true,\n      [`${this.prefixCls}-swiping`]: this._swiping\n    };\n  }\n\n  onCloseSwipe = ev => {\n    if (!(this._openedLeft || this._openedRight)) {\n      return;\n    }\n    const pNode = ev.target.closest(`.${this.prefixCls}-actions`);\n    if (!pNode) {\n      this.close();\n    }\n  }\n\n  close() {\n    if (this._openedLeft || this._openedRight) {\n      this.onClose.emit();\n    }\n    this.setBtnStyle(0);\n    this._openedLeft = false;\n    this._openedRight = false;\n  }\n\n  setBtnStyle(value) {\n    if (this._btnsLeftWidth === 0 || this._btnsRightWidth === 0) {\n      this._btnsLeftWidth = this.leftBtnRef ? this.leftBtnRef.nativeElement.offsetWidth : 0;\n      this._btnsRightWidth = this.rightBtnRef ? this.rightBtnRef.nativeElement.offsetWidth : 0;\n    }\n    const limit = value > 0 ? this._btnsLeftWidth : -this._btnsRightWidth;\n    const contentLeft = this.getContentEasing(value, limit);\n    this.content.nativeElement.style.left = `${contentLeft}px`;\n    this.cover.nativeElement.style.display = Math.abs(value) > 0 ? 'block' : 'none';\n    this.cover.nativeElement.style.left = `${contentLeft}px`;\n  }\n\n  getContentEasing(value, limit) {\n    return Math.abs(value) - Math.abs(limit) > 0 ? limit : value;\n  }\n\n  onTouchStart(e) {\n    this._startX = e.changedTouches[0].clientX;\n    this._swiping = true;\n  }\n\n  onTouchMove(e) {\n    const deltaX = e.changedTouches[0].clientX - this._startX;\n    this._needShowRight = deltaX < -5 && this.right.length > 0;\n    this._needShowLeft = deltaX > 5 && this.left.length > 0;\n    if (this.leftBtnRef) {\n      this.leftBtnRef.nativeElement.style.visibility = this._needShowRight ? 'hidden' : 'visible';\n    }\n    if (this.rightBtnRef) {\n      this.rightBtnRef.nativeElement.style.visibility = this._needShowLeft ? 'hidden' : 'visible';\n    }\n    this.setBtnStyle(deltaX);\n  }\n\n  onTouchEnd(e) {\n    const deltaX = e.changedTouches[0].clientX - this._startX;\n\n    const needOpenRight = this._needShowRight && Math.abs(deltaX) > this._btnsRightWidth / 2;\n    const needOpenLeft = this._needShowLeft && Math.abs(deltaX) > this._btnsLeftWidth / 2;\n\n    if (needOpenRight) {\n      this.doOpenRight();\n    } else if (needOpenLeft) {\n      this.doOpenLeft();\n    } else {\n      this.close();\n    }\n    this._swiping = false;\n    this._needShowLeft = false;\n    this._needShowRight = false;\n  }\n\n  doOpenLeft() {\n    this.open(this._btnsLeftWidth, true, false);\n  }\n\n  doOpenRight() {\n    this.open(-this._btnsRightWidth, false, true);\n  }\n\n  onBtnClick(ev, btn) {\n    const onPress = btn.onPress;\n    if (onPress) {\n      onPress(ev);\n    }\n    if (this.autoClose) {\n      this.close();\n    }\n  }\n\n  open(value, openedLeft, openedRight) {\n    this.onOpen.emit();\n    this._openedLeft = openedLeft;\n    this._openedRight = openedRight;\n    this.setBtnStyle(value);\n  }\n\n  ngOnInit() {\n    this.setClassMap();\n  }\n\n  ngAfterViewInit(): void {\n    this._btnsLeftWidth = this.leftBtnRef ? this.leftBtnRef.nativeElement.offsetWidth : 0;\n    this._btnsRightWidth = this.rightBtnRef ? this.rightBtnRef.nativeElement.offsetWidth : 0;\n    document.body.addEventListener('touchstart', this.onCloseSwipe, true);\n  }\n\n  ngOnDestroy(): void {\n    document.body.removeEventListener('touchstart', this.onCloseSwipe, true);\n  }\n}\n"]}