ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
459 lines • 32.5 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';
export class SliderHandleComponent {
/**
* @param {?} _elf
* @param {?} _sanitizer
*/
constructor(_elf, _sanitizer) {
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 {?}
*/
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 {?}
*/
event => {
if (!this._disabled && this._isDraging) {
this.pauseEvent(event);
/** @type {?} */
const 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 {?}
*/
event => {
if (!this._disabled && this._isDraging) {
this._handleStatus = 'end';
this._isDraging = false;
/** @type {?} */
const pos = event.clientX;
this._value = Math.round(this.calcValueByPos(pos));
this.left = this.calcOffset(this._value);
this.onAfterChange.emit(this._value);
}
});
}
/**
* @param {?} value
* @return {?}
*/
set min(value) {
this._min = value;
}
/**
* @param {?} value
* @return {?}
*/
set max(value) {
this._max = value;
}
/**
* @param {?} value
* @return {?}
*/
set minBound(value) {
this._minBound = value;
}
/**
* @param {?} value
* @return {?}
*/
set maxBound(value) {
this._maxBound = value;
}
/**
* @param {?} value
* @return {?}
*/
set step(value) {
this._step = value;
}
/**
* @param {?} value
* @return {?}
*/
set value(value) {
this._value = value;
if (this._value) {
this.left = this.calcOffset(this._value);
}
}
/**
* @param {?} value
* @return {?}
*/
set disabled(value) {
this._disabled = value;
}
/**
* @param {?} value
* @return {?}
*/
set sliderLength(value) {
this._sliderLength = value;
}
/**
* @param {?} value
* @return {?}
*/
set sliderStart(value) {
this._sliderStart = value;
}
/**
* @return {?}
*/
get handleStyle() {
return this._handleStyle;
}
/**
* @param {?} value
* @return {?}
*/
set handleStyle(value) {
this._handleStyle = value;
}
/* 手势操作 */
/**
* @param {?} event
* @return {?}
*/
panstart(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 {?}
*/
panmove(event) {
event.preventDefault();
if (!this._disabled && this._isDraging) {
/** @type {?} */
const 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 {?}
*/
panend(event) {
event.preventDefault();
if (!this._disabled && this._isDraging) {
this._handleStatus = 'end';
this._isDraging = false;
/** @type {?} */
const 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 {?}
*/
calcValueByPos(pos) {
/** @type {?} */
const offset = pos - this._sliderStart;
/** @type {?} */
let value = this.calcValue(offset);
if (value <= this._minBound) {
value = this._minBound;
}
if (value >= this._maxBound) {
value = this._maxBound;
}
/** @type {?} */
const closestPoint = this.getClosestPoint(value);
return this._step === null ? closestPoint : parseFloat(closestPoint.toFixed(this.getPrecision(this._step)));
}
/**
* @param {?} offset
* @return {?}
*/
calcValue(offset) {
/** @type {?} */
const ratio = Math.abs(Math.max(offset, 0) / this._sliderLength);
/** @type {?} */
const value = ratio * (this._max - this._min) + this._min;
return value;
}
/**
* @param {?} val
* @return {?}
*/
getClosestPoint(val) {
/** @type {?} */
const points = Object.keys(this._marks).map(parseFloat);
if (this._step !== null) {
/** @type {?} */
const closestStep = Math.round((val - this._min) / this._step) * this._step + this._min;
points.push(closestStep);
}
/** @type {?} */
const 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 {?}
*/
getPrecision(step) {
/** @type {?} */
const stepString = step.toString();
/** @type {?} */
let precision = 0;
if (stepString.indexOf('.') >= 0) {
precision = stepString.length - stepString.indexOf('.') - 1;
}
return precision;
}
/**
* @param {?} value
* @return {?}
*/
calcOffset(value) {
/** @type {?} */
const ratio = (value - this._min) / (this._max - this._min);
return ratio * 100;
}
/**
* @param {?} e
* @return {?}
*/
pauseEvent(e) {
e.stopPropagation();
e.preventDefault();
}
/**
* @param {?} event
* @return {?}
*/
isMouseTarget(event) {
/** @type {?} */
let target = event.target;
/** @type {?} */
let parentFound = false;
while (target !== null && !parentFound) {
if (target === this._elf.nativeElement) {
parentFound = true;
}
target = target.parentElement;
}
return parentFound;
}
/**
* @param {?} arr
* @return {?}
*/
toConsumableArray(arr) {
if (Array.isArray(arr)) {
/** @type {?} */
const arr2 = Array(arr.length);
for (let i = 0; i < arr.length; i++) {
arr2[i] = arr[i];
}
return arr2;
}
}
/**
* @return {?}
*/
ngOnInit() {
/** @type {?} */
const 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 {?}
*/
ngOnDestroy() {
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 = () => [
{ 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'],] }]
};
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"]}