UNPKG

ng-zorro-antd-mobile

Version:

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

232 lines 29.6 kB
import { Component, ElementRef, Input, Output, EventEmitter, HostListener, ViewEncapsulation } from '@angular/core'; import { DomSanitizer } from '@angular/platform-browser'; import * as i0 from "@angular/core"; import * as i1 from "@angular/platform-browser"; import * as i2 from "@angular/common"; export class SliderHandleComponent { set min(value) { this._min = value; } set max(value) { this._max = value; } set minBound(value) { this._minBound = value; } set maxBound(value) { this._maxBound = value; } set step(value) { this._step = value; } set value(value) { this._value = value; if (this._value) { this.left = this.calcOffset(this._value); } } set disabled(value) { this._disabled = value; } set sliderLength(value) { this._sliderLength = value; } set sliderStart(value) { this._sliderStart = value; } get handleStyle() { return this._handleStyle; } set handleStyle(value) { this._handleStyle = value; } /* 手势操作 */ 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; } } panmove(event) { event.preventDefault(); if (!this._disabled && this._isDraging) { 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); } } } panend(event) { event.preventDefault(); if (!this._disabled && this._isDraging) { this._handleStatus = 'end'; this._isDraging = false; const pos = event.changedTouches[0].clientX; this._value = Math.round(this.calcValueByPos(pos)); this.left = this.calcOffset(this._value); this.onAfterChange.emit(this._value); } } 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 = 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 = event => { if (!this._disabled && this._isDraging) { this.pauseEvent(event); 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 = event => { if (!this._disabled && this._isDraging) { this._handleStatus = 'end'; this._isDraging = false; const pos = event.clientX; this._value = Math.round(this.calcValueByPos(pos)); this.left = this.calcOffset(this._value); this.onAfterChange.emit(this._value); } }; } calcValueByPos(pos) { const offset = pos - this._sliderStart; let value = this.calcValue(offset); if (value <= this._minBound) { value = this._minBound; } if (value >= this._maxBound) { value = this._maxBound; } const closestPoint = this.getClosestPoint(value); return this._step === null ? closestPoint : parseFloat(closestPoint.toFixed(this.getPrecision(this._step))); } calcValue(offset) { const ratio = Math.abs(Math.max(offset, 0) / this._sliderLength); const value = ratio * (this._max - this._min) + this._min; return value; } getClosestPoint(val) { const points = Object.keys(this._marks).map(parseFloat); if (this._step !== null) { const closestStep = Math.round((val - this._min) / this._step) * this._step + this._min; points.push(closestStep); } const diffs = points.map(function (point) { return Math.abs(val - point); }); return points[diffs.indexOf(Math.min.apply(Math, this.toConsumableArray(diffs)))]; } getPrecision(step) { const stepString = step.toString(); let precision = 0; if (stepString.indexOf('.') >= 0) { precision = stepString.length - stepString.indexOf('.') - 1; } return precision; } calcOffset(value) { const ratio = (value - this._min) / (this._max - this._min); return ratio * 100; } pauseEvent(e) { e.stopPropagation(); e.preventDefault(); } isMouseTarget(event) { let target = event.target; let parentFound = false; while (target !== null && !parentFound) { if (target === this._elf.nativeElement) { parentFound = true; } target = target.parentElement; } return parentFound; } toConsumableArray(arr) { if (Array.isArray(arr)) { const arr2 = Array(arr.length); for (let i = 0; i < arr.length; i++) { arr2[i] = arr[i]; } return arr2; } } ngOnInit() { 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; } ngOnDestroy() { document.removeEventListener('mousemove', this.mouseMove, false); document.removeEventListener('mouseup', this.mouseUp, false); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SliderHandleComponent, deps: [{ token: i0.ElementRef }, { token: i1.DomSanitizer }], target: i0.ɵɵFactoryTarget.Component }); } static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: SliderHandleComponent, selector: "SliderHandle, nzm-slider-handle", inputs: { min: "min", max: "max", minBound: "minBound", maxBound: "maxBound", step: "step", value: "value", disabled: "disabled", sliderLength: "sliderLength", sliderStart: "sliderStart", handleStyle: "handleStyle" }, outputs: { onChange: "onChange", onAfterChange: "onAfterChange" }, host: { listeners: { "touchstart": "panstart($event)", "touchmove": "panmove($event)", "touchend": "panend($event)" } }, ngImport: i0, template: "<div role=\"slider\" class=\"am-slider-handle\" [ngStyle]=\"handleStyle\" [style.left.%]=\"left\"></div>\n", dependencies: [{ kind: "directive", type: i2.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], encapsulation: i0.ViewEncapsulation.None }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SliderHandleComponent, decorators: [{ type: Component, args: [{ selector: 'SliderHandle, nzm-slider-handle', encapsulation: ViewEncapsulation.None, template: "<div role=\"slider\" class=\"am-slider-handle\" [ngStyle]=\"handleStyle\" [style.left.%]=\"left\"></div>\n" }] }], ctorParameters: () => [{ type: i0.ElementRef }, { type: i1.DomSanitizer }], 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']] }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-handle.component.js","sourceRoot":"","sources":["../../../../components/slider/slider-handle/slider-handle.component.ts","../../../../components/slider/slider-handle/slider-handle.component.html"],"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","<div role=\"slider\" class=\"am-slider-handle\" [ngStyle]=\"handleStyle\" [style.left.%]=\"left\"></div>\n"]}