ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
550 lines • 36.1 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, ElementRef, Input, Output, EventEmitter, HostListener, ViewEncapsulation } from '@angular/core';
import { DomSanitizer } from '@angular/platform-browser';
var SliderHandleComponent = /** @class */ (function () {
function SliderHandleComponent(_elf, _sanitizer) {
var _this = this;
this._elf = _elf;
this._sanitizer = _sanitizer;
this._disabled = false;
this._marks = {};
this._isDraging = false;
this.onChange = new EventEmitter();
this.onAfterChange = new EventEmitter();
this.mouseDown = (/**
* @param {?} event
* @return {?}
*/
function (event) {
if (!_this._disabled && _this.isMouseTarget(event)) {
_this._startX = event.clientX;
_this._handleStatus = 'start';
_this._isDraging = true;
document.addEventListener('mousemove', _this.mouseMove, false);
document.addEventListener('mouseup', _this.mouseUp, false);
_this.pauseEvent(event);
}
});
this.mouseMove = (/**
* @param {?} event
* @return {?}
*/
function (event) {
if (!_this._disabled && _this._isDraging) {
_this.pauseEvent(event);
/** @type {?} */
var pos = event.clientX;
_this._value = Math.round(_this.calcValueByPos(pos));
_this.left = _this.calcOffset(_this._value);
if (_this._oldValue !== _this._value) {
_this._oldValue = _this._value;
_this.onChange.emit(_this._value);
}
}
});
this.mouseUp = (/**
* @param {?} event
* @return {?}
*/
function (event) {
if (!_this._disabled && _this._isDraging) {
_this._handleStatus = 'end';
_this._isDraging = false;
/** @type {?} */
var pos = event.clientX;
_this._value = Math.round(_this.calcValueByPos(pos));
_this.left = _this.calcOffset(_this._value);
_this.onAfterChange.emit(_this._value);
}
});
}
Object.defineProperty(SliderHandleComponent.prototype, "min", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._min = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderHandleComponent.prototype, "max", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._max = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderHandleComponent.prototype, "minBound", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._minBound = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderHandleComponent.prototype, "maxBound", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._maxBound = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderHandleComponent.prototype, "step", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._step = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderHandleComponent.prototype, "value", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._value = value;
if (this._value) {
this.left = this.calcOffset(this._value);
}
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderHandleComponent.prototype, "disabled", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._disabled = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderHandleComponent.prototype, "sliderLength", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._sliderLength = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderHandleComponent.prototype, "sliderStart", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._sliderStart = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderHandleComponent.prototype, "handleStyle", {
get: /**
* @return {?}
*/
function () {
return this._handleStyle;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._handleStyle = value;
},
enumerable: true,
configurable: true
});
/* 手势操作 */
/* 手势操作 */
/**
* @param {?} event
* @return {?}
*/
SliderHandleComponent.prototype.panstart = /* 手势操作 */
/**
* @param {?} event
* @return {?}
*/
function (event) {
// event.preventDefault();
if (!this._disabled) {
this._startX = event && event.changedTouches && event.changedTouches[0] && event.changedTouches[0].clientX;
this._handleStatus = 'start';
this._isDraging = true;
}
};
/**
* @param {?} event
* @return {?}
*/
SliderHandleComponent.prototype.panmove = /**
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
if (!this._disabled && this._isDraging) {
/** @type {?} */
var pos = event.changedTouches[0].clientX;
this._value = Math.round(this.calcValueByPos(pos));
this.left = this.calcOffset(this._value);
if (this._oldValue !== this._value) {
this._oldValue = this._value;
this.onChange.emit(this._value);
}
}
};
/**
* @param {?} event
* @return {?}
*/
SliderHandleComponent.prototype.panend = /**
* @param {?} event
* @return {?}
*/
function (event) {
event.preventDefault();
if (!this._disabled && this._isDraging) {
this._handleStatus = 'end';
this._isDraging = false;
/** @type {?} */
var pos = event.changedTouches[0].clientX;
this._value = Math.round(this.calcValueByPos(pos));
this.left = this.calcOffset(this._value);
this.onAfterChange.emit(this._value);
}
};
/**
* @param {?} pos
* @return {?}
*/
SliderHandleComponent.prototype.calcValueByPos = /**
* @param {?} pos
* @return {?}
*/
function (pos) {
/** @type {?} */
var offset = pos - this._sliderStart;
/** @type {?} */
var value = this.calcValue(offset);
if (value <= this._minBound) {
value = this._minBound;
}
if (value >= this._maxBound) {
value = this._maxBound;
}
/** @type {?} */
var closestPoint = this.getClosestPoint(value);
return this._step === null ? closestPoint : parseFloat(closestPoint.toFixed(this.getPrecision(this._step)));
};
/**
* @param {?} offset
* @return {?}
*/
SliderHandleComponent.prototype.calcValue = /**
* @param {?} offset
* @return {?}
*/
function (offset) {
/** @type {?} */
var ratio = Math.abs(Math.max(offset, 0) / this._sliderLength);
/** @type {?} */
var value = ratio * (this._max - this._min) + this._min;
return value;
};
/**
* @param {?} val
* @return {?}
*/
SliderHandleComponent.prototype.getClosestPoint = /**
* @param {?} val
* @return {?}
*/
function (val) {
/** @type {?} */
var points = Object.keys(this._marks).map(parseFloat);
if (this._step !== null) {
/** @type {?} */
var closestStep = Math.round((val - this._min) / this._step) * this._step + this._min;
points.push(closestStep);
}
/** @type {?} */
var diffs = points.map((/**
* @param {?} point
* @return {?}
*/
function (point) {
return Math.abs(val - point);
}));
return points[diffs.indexOf(Math.min.apply(Math, this.toConsumableArray(diffs)))];
};
/**
* @param {?} step
* @return {?}
*/
SliderHandleComponent.prototype.getPrecision = /**
* @param {?} step
* @return {?}
*/
function (step) {
/** @type {?} */
var stepString = step.toString();
/** @type {?} */
var precision = 0;
if (stepString.indexOf('.') >= 0) {
precision = stepString.length - stepString.indexOf('.') - 1;
}
return precision;
};
/**
* @param {?} value
* @return {?}
*/
SliderHandleComponent.prototype.calcOffset = /**
* @param {?} value
* @return {?}
*/
function (value) {
/** @type {?} */
var ratio = (value - this._min) / (this._max - this._min);
return ratio * 100;
};
/**
* @param {?} e
* @return {?}
*/
SliderHandleComponent.prototype.pauseEvent = /**
* @param {?} e
* @return {?}
*/
function (e) {
e.stopPropagation();
e.preventDefault();
};
/**
* @param {?} event
* @return {?}
*/
SliderHandleComponent.prototype.isMouseTarget = /**
* @param {?} event
* @return {?}
*/
function (event) {
/** @type {?} */
var target = event.target;
/** @type {?} */
var parentFound = false;
while (target !== null && !parentFound) {
if (target === this._elf.nativeElement) {
parentFound = true;
}
target = target.parentElement;
}
return parentFound;
};
/**
* @param {?} arr
* @return {?}
*/
SliderHandleComponent.prototype.toConsumableArray = /**
* @param {?} arr
* @return {?}
*/
function (arr) {
if (Array.isArray(arr)) {
/** @type {?} */
var arr2 = Array(arr.length);
for (var i = 0; i < arr.length; i++) {
arr2[i] = arr[i];
}
return arr2;
}
};
/**
* @return {?}
*/
SliderHandleComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
/** @type {?} */
var self = this;
this._elf.nativeElement.addEventListener('mousedown', this.mouseDown, false);
this._handleOffsetX = this._elf.nativeElement.getBoundingClientRect().x;
this.left = this.calcOffset(this._value);
this._minBound = this._minBound === undefined ? this._min : this._minBound;
this._maxBound = this._maxBound === undefined ? this._max : this._maxBound;
};
/**
* @return {?}
*/
SliderHandleComponent.prototype.ngOnDestroy = /**
* @return {?}
*/
function () {
document.removeEventListener('mousemove', this.mouseMove, false);
document.removeEventListener('mouseup', this.mouseUp, false);
};
SliderHandleComponent.decorators = [
{ type: Component, args: [{
selector: 'SliderHandle, nzm-slider-handle',
template: "<div role=\"slider\" class=\"am-slider-handle\" [ngStyle]=\"handleStyle\" [style.left.%]=\"left\"></div>\n",
encapsulation: ViewEncapsulation.None
}] }
];
/** @nocollapse */
SliderHandleComponent.ctorParameters = function () { return [
{ type: ElementRef },
{ type: DomSanitizer }
]; };
SliderHandleComponent.propDecorators = {
min: [{ type: Input }],
max: [{ type: Input }],
minBound: [{ type: Input }],
maxBound: [{ type: Input }],
step: [{ type: Input }],
value: [{ type: Input }],
disabled: [{ type: Input }],
sliderLength: [{ type: Input }],
sliderStart: [{ type: Input }],
handleStyle: [{ type: Input }],
onChange: [{ type: Output }],
onAfterChange: [{ type: Output }],
panstart: [{ type: HostListener, args: ['touchstart', ['$event'],] }],
panmove: [{ type: HostListener, args: ['touchmove', ['$event'],] }],
panend: [{ type: HostListener, args: ['touchend', ['$event'],] }]
};
return SliderHandleComponent;
}());
export { SliderHandleComponent };
if (false) {
/** @type {?} */
SliderHandleComponent.prototype.left;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._min;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._max;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._step;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._value;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._marks;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._handleStyle;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._sliderLength;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._sliderStart;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._minBound;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._maxBound;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._startX;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._isDraging;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._handleStatus;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._handleOffsetX;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._oldValue;
/** @type {?} */
SliderHandleComponent.prototype.onChange;
/** @type {?} */
SliderHandleComponent.prototype.onAfterChange;
/** @type {?} */
SliderHandleComponent.prototype.mouseDown;
/** @type {?} */
SliderHandleComponent.prototype.mouseMove;
/** @type {?} */
SliderHandleComponent.prototype.mouseUp;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._elf;
/**
* @type {?}
* @private
*/
SliderHandleComponent.prototype._sanitizer;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-handle.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["slider/slider-handle/slider-handle.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  ElementRef,\n  Input,\n  Output,\n  EventEmitter,\n  HostListener,\n  OnDestroy,\n  ViewEncapsulation\n} from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\n\n@Component({\n  selector: 'SliderHandle, nzm-slider-handle',\n  templateUrl: './slider-handle.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class SliderHandleComponent implements OnInit, OnDestroy {\n  left: number;\n\n  private _min: number;\n  private _max: number;\n  private _step: number;\n  private _value: number;\n  private _disabled: boolean = false;\n  private _marks: object = {};\n  private _handleStyle: object;\n  private _sliderLength: number;\n  private _sliderStart: number;\n  private _minBound: number;\n  private _maxBound: number;\n  private _startX: number;\n  private _isDraging: boolean = false;\n  private _handleStatus: string;\n  private _handleOffsetX: number;\n  private _oldValue: number;\n\n  @Input()\n  set min(value: number) {\n    this._min = value;\n  }\n  @Input()\n  set max(value: number) {\n    this._max = value;\n  }\n  @Input()\n  set minBound(value: number) {\n    this._minBound = value;\n  }\n  @Input()\n  set maxBound(value: number) {\n    this._maxBound = value;\n  }\n  @Input()\n  set step(value: number) {\n    this._step = value;\n  }\n  @Input()\n  set value(value: number) {\n    this._value = value;\n    if (this._value) {\n      this.left = this.calcOffset(this._value);\n    }\n  }\n  @Input()\n  set disabled(value: boolean) {\n    this._disabled = value;\n  }\n  @Input()\n  set sliderLength(value: number) {\n    this._sliderLength = value;\n  }\n  @Input()\n  set sliderStart(value: number) {\n    this._sliderStart = value;\n  }\n  @Input()\n  get handleStyle(): object {\n    return this._handleStyle;\n  }\n  set handleStyle(value: object) {\n    this._handleStyle = value;\n  }\n  @Output()\n  onChange = new EventEmitter<any>();\n  @Output()\n  onAfterChange = new EventEmitter<any>();\n\n  /* 手势操作 */\n  @HostListener('touchstart', ['$event'])\n  panstart(event) {\n    // event.preventDefault();\n    if (!this._disabled) {\n      this._startX = event && event.changedTouches && event.changedTouches[0] && event.changedTouches[0].clientX;\n      this._handleStatus = 'start';\n      this._isDraging = true;\n    }\n  }\n\n  @HostListener('touchmove', ['$event'])\n  panmove(event) {\n    event.preventDefault();\n    if (!this._disabled && this._isDraging) {\n      const pos = event.changedTouches[0].clientX;\n      this._value = Math.round(this.calcValueByPos(pos));\n      this.left = this.calcOffset(this._value);\n      if (this._oldValue !== this._value) {\n        this._oldValue = this._value;\n        this.onChange.emit(this._value);\n      }\n    }\n  }\n  @HostListener('touchend', ['$event'])\n  panend(event) {\n    event.preventDefault();\n    if (!this._disabled && this._isDraging) {\n      this._handleStatus = 'end';\n      this._isDraging = false;\n      const pos = event.changedTouches[0].clientX;\n      this._value = Math.round(this.calcValueByPos(pos));\n      this.left = this.calcOffset(this._value);\n      this.onAfterChange.emit(this._value);\n    }\n  }\n\n  constructor(private _elf: ElementRef, private _sanitizer: DomSanitizer) {}\n\n  mouseDown = event => {\n    if (!this._disabled && this.isMouseTarget(event)) {\n      this._startX = event.clientX;\n      this._handleStatus = 'start';\n      this._isDraging = true;\n      document.addEventListener('mousemove', this.mouseMove, false);\n      document.addEventListener('mouseup', this.mouseUp, false);\n      this.pauseEvent(event);\n    }\n  }\n\n  mouseMove = event => {\n    if (!this._disabled && this._isDraging) {\n      this.pauseEvent(event);\n      const pos = event.clientX;\n      this._value = Math.round(this.calcValueByPos(pos));\n      this.left = this.calcOffset(this._value);\n      if (this._oldValue !== this._value) {\n        this._oldValue = this._value;\n        this.onChange.emit(this._value);\n      }\n    }\n  }\n\n  mouseUp = event => {\n    if (!this._disabled && this._isDraging) {\n      this._handleStatus = 'end';\n      this._isDraging = false;\n      const pos = event.clientX;\n      this._value = Math.round(this.calcValueByPos(pos));\n      this.left = this.calcOffset(this._value);\n      this.onAfterChange.emit(this._value);\n    }\n  }\n\n  calcValueByPos(pos) {\n    const offset = pos - this._sliderStart;\n    let value = this.calcValue(offset);\n    if (value <= this._minBound) {\n      value = this._minBound;\n    }\n    if (value >= this._maxBound) {\n      value = this._maxBound;\n    }\n    const closestPoint = this.getClosestPoint(value);\n    return this._step === null ? closestPoint : parseFloat(closestPoint.toFixed(this.getPrecision(this._step)));\n  }\n\n  calcValue(offset) {\n    const ratio = Math.abs(Math.max(offset, 0) / this._sliderLength);\n    const value = ratio * (this._max - this._min) + this._min;\n    return value;\n  }\n\n  getClosestPoint(val) {\n    const points = Object.keys(this._marks).map(parseFloat);\n    if (this._step !== null) {\n      const closestStep = Math.round((val - this._min) / this._step) * this._step + this._min;\n      points.push(closestStep);\n    }\n    const diffs = points.map(function(point) {\n      return Math.abs(val - point);\n    });\n    return points[diffs.indexOf(Math.min.apply(Math, this.toConsumableArray(diffs)))];\n  }\n\n  getPrecision(step) {\n    const stepString = step.toString();\n    let precision = 0;\n    if (stepString.indexOf('.') >= 0) {\n      precision = stepString.length - stepString.indexOf('.') - 1;\n    }\n    return precision;\n  }\n\n  calcOffset(value) {\n    const ratio = (value - this._min) / (this._max - this._min);\n    return ratio * 100;\n  }\n\n  pauseEvent(e) {\n    e.stopPropagation();\n    e.preventDefault();\n  }\n\n  isMouseTarget(event) {\n    let target = event.target;\n    let parentFound = false;\n    while (target !== null && !parentFound) {\n      if (target === this._elf.nativeElement) {\n        parentFound = true;\n      }\n      target = target.parentElement;\n    }\n    return parentFound;\n  }\n\n  toConsumableArray(arr) {\n    if (Array.isArray(arr)) {\n      const arr2 = Array(arr.length);\n      for (let i = 0; i < arr.length; i++) {\n        arr2[i] = arr[i];\n      }\n      return arr2;\n    }\n  }\n\n  ngOnInit() {\n    const self = this;\n    this._elf.nativeElement.addEventListener('mousedown', this.mouseDown, false);\n    this._handleOffsetX = this._elf.nativeElement.getBoundingClientRect().x;\n    this.left = this.calcOffset(this._value);\n    this._minBound = this._minBound === undefined ? this._min : this._minBound;\n    this._maxBound = this._maxBound === undefined ? this._max : this._maxBound;\n  }\n\n  ngOnDestroy() {\n    document.removeEventListener('mousemove', this.mouseMove, false);\n    document.removeEventListener('mouseup', this.mouseUp, false);\n  }\n}\n"]}