UNPKG

ng-zorro-antd-mobile

Version:

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

565 lines 36.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, Input, Output, EventEmitter, ElementRef, HostBinding, forwardRef } from '@angular/core'; import { NG_VALUE_ACCESSOR } from '@angular/forms'; export class RangeComponent { /** * @param {?} _elf */ constructor(_elf) { this._elf = _elf; this.prefixCls = 'am-slider'; this.offset = []; this.length = []; this._min = 0; this._max = 100; this._step = 1; this._defaultValue = [0, 0, 0]; this._disabled = false; this._marks = {}; this._dots = false; this._included = true; this._count = 1; this._allowCross = true; this._handleStyle = []; this._trackStyle = []; this.onChange = new EventEmitter(); this.onAfterChange = new EventEmitter(); this.amWrapper = true; this._ngModelOnChange = (/** * @return {?} */ () => { }); this._ngModelOnTouched = (/** * @return {?} */ () => { }); } /** * @return {?} */ get min() { return this._min; } /** * @param {?} value * @return {?} */ set min(value) { this._min = value; } /** * @return {?} */ get max() { return this._max; } /** * @param {?} value * @return {?} */ set max(value) { this._max = value; } /** * @return {?} */ get step() { return this._step; } /** * @param {?} value * @return {?} */ set step(value) { this._step = value; } /** * @return {?} */ get value() { return this._value; } /** * @param {?} value * @return {?} */ set value(value) { this.setValue(value); } /** * @param {?} value * @return {?} */ set defaultValue(value) { this._defaultValue = value; this._value = this._defaultValue; this.setValue(value); } /** * @return {?} */ get disabled() { return this._disabled; } /** * @param {?} value * @return {?} */ set disabled(value) { this._disabled = value; } /** * @return {?} */ get marks() { return this._marks; } /** * @param {?} value * @return {?} */ set marks(value) { this._marks = value; } /** * @return {?} */ get dots() { return this._dots; } /** * @param {?} value * @return {?} */ set dots(value) { this._dots = value; } /** * @return {?} */ get included() { return this._included; } /** * @param {?} value * @return {?} */ set included(value) { this._included = value; } /** * @param {?} value * @return {?} */ set count(value) { this._count = value; } /** * @param {?} value * @return {?} */ set allowCross(value) { this._allowCross = value; this.setValueBound(); } /** * @param {?} value * @return {?} */ set pushable(value) { this._pushable = value; if (this.verifyPushable()) { this.setValueBound(); } } /** * @return {?} */ get handleStyle() { return this._handleStyle; } /** * @param {?} value * @return {?} */ set handleStyle(value) { this._handleStyle = value; } /** * @return {?} */ get trackStyle() { return this._trackStyle; } /** * @param {?} value * @return {?} */ set trackStyle(value) { this._trackStyle = value; } /** * @return {?} */ get railStyle() { return this._railStyle; } /** * @param {?} value * @return {?} */ set railStyle(value) { this._railStyle = value; } /** * @return {?} */ setCls() { this.sliderCls = { [`${this.prefixCls}-disabled`]: this._disabled }; } /** * @return {?} */ initialValue() { /** @type {?} */ const minTemp = this._min; if (!this.verifyPushable()) { this._pushable = 0; console.log('pushable设置无效,已大于有些value间隔,被强制设为0'); } /** @type {?} */ const initialValue = Array.apply(null, Array(this._count + 1)).map((/** * @return {?} */ function () { return minTemp; })); this._defaultValue = this._defaultValue !== undefined ? this._defaultValue : initialValue; this._value = this._value !== undefined ? this._value : this._defaultValue; // 验证count值 this._count = this._value.length - 1; // 验证value区间 for (let i = 0; i < this._value.length; i++) { if (this._value[i] < this._min) { this._value[i] = this._min; } else if (this._value[i] > this._max) { this._value[i] = this._max; } } if (this._count > 0) { this.upperBound = Math.max(...this._value); this.lowerBound = Math.min(...this._value); } } /** * @param {?} e * @param {?} i * @return {?} */ handleChange(e, i) { /** @type {?} */ let temp = [...this._value]; temp[i] = e; this.upperBound = Math.max(...temp); this.lowerBound = Math.min(...temp); this.setTrackStyle(temp); this.onChange.emit(temp); } /** * @param {?} e * @param {?} i * @return {?} */ handleAfterChange(e, i) { setTimeout((/** * @return {?} */ () => { this._value[i] = e; this.upperBound = Math.max(...this._value); this.lowerBound = Math.min(...this._value); this.setTrackStyle(this._value); this.onAfterChange.emit(this._value); this._ngModelOnChange(this._value); this.setValueBound(); }), 0); } /** * @param {?} value * @return {?} */ setTrackStyle(value) { if (value && value.length === this._count + 1) { value.sort((/** * @param {?} a * @param {?} b * @return {?} */ (a, b) => a - b)); for (let i = 0; i < this._count; i++) { this.offset[i] = (value[i] * 100) / (this._max - this._min); this.length[i] = ((value[i + 1] - value[i]) * 100) / (this._max - this._min); } } } /** * @return {?} */ setValueBound() { this.maxBound = []; this.minBound = []; if ((this._allowCross && this._pushable === undefined) || this._handleCount <= 1) { for (let i = 0; i < this._handleCount; i++) { this.maxBound[i] = this._max; this.minBound[i] = this._min; } } else { if (this._pushable === undefined) { this._pushable = 0; } for (let i = 0; i < this._handleCount; i++) { this.maxBound[i] = i === this._handleCount - 1 ? this._max : this._value[i + 1] - this._pushable; this.minBound[i] = i === 0 ? this._min : this._value[i - 1] + this._pushable; } } } /** * @return {?} */ verifyPushable() { for (let i = 1; i < this._handleCount; i++) { /** @type {?} */ const diff = this._value[i] - this._value[i - 1]; if (diff < this._pushable) { return false; } } return true; } /** * @param {?} value * @return {?} */ writeValue(value) { this.setValue(value, true); } /** * @param {?} value * @param {?=} isWriteValue * @return {?} */ setValue(value, isWriteValue = false) { if (value) { this._value = value; this._handleCount = this._value.length + 1; this.initialValue(); this.setValueBound(); this.setCls(); this.setTrackStyle(this._value); if (isWriteValue) { this._ngModelOnChange(this._value); } else { this.onAfterChange.emit(this._value); } } } /** * @param {?} fn * @return {?} */ registerOnChange(fn) { this._ngModelOnChange = fn; } /** * @param {?} fn * @return {?} */ registerOnTouched(fn) { this._ngModelOnTouched = fn; } /** * @return {?} */ ngOnInit() { this.initialValue(); this.setValueBound(); this._handleCount = this._count + 1; this.setCls(); /** @type {?} */ const sliderCoords = this._elf.nativeElement.getElementsByClassName('am-slider')[0].getBoundingClientRect(); this.sliderLength = sliderCoords.width; this.sliderStart = sliderCoords.left; } } RangeComponent.decorators = [ { type: Component, args: [{ selector: 'Range , nzm-range', template: "<div class=\"am-slider\" [ngClass]=\"sliderCls\">\n <div class=\"am-slider-rail\" [ngStyle]=\"railStyle\"></div>\n <SliderTrack\n *ngFor=\"let off of offset; let i = index\"\n [className]=\"'am-slider-track'\"\n [included]=\"included\"\n [style]=\"trackStyle[i]\"\n [offset]=\"off\"\n [length]=\"length[i]\"\n ></SliderTrack>\n <SliderSteps\n [max]=\"max\"\n [min]=\"min\"\n [dots]=\"dots\"\n [step]=\"step\"\n [marks]=\"marks\"\n [upperBound]=\"upperBound\"\n [lowerBound]=\"lowerBound\"\n ></SliderSteps>\n <SliderHandle\n *ngFor=\"let val of value; let i = index\"\n [max]=\"max\"\n [min]=\"min\"\n [maxBound]=\"maxBound[i]\"\n [minBound]=\"minBound[i]\"\n [value]=\"val\"\n [step]=\"step\"\n [disabled]=\"disabled\"\n [sliderLength]=\"sliderLength\"\n [sliderStart]=\"sliderStart\"\n [handleStyle]=\"handleStyle[i]\"\n (onChange)=\"handleChange($event, i)\"\n (onAfterChange)=\"handleAfterChange($event, i)\"\n ></SliderHandle>\n <SliderMarks\n [max]=\"max\"\n [min]=\"min\"\n [marks]=\"marks\"\n [upperBound]=\"upperBound\"\n [lowerBound]=\"lowerBound\"\n ></SliderMarks>\n</div>\n", providers: [ { provide: NG_VALUE_ACCESSOR, useExisting: forwardRef((/** * @return {?} */ () => RangeComponent)), multi: true } ] }] } ]; /** @nocollapse */ RangeComponent.ctorParameters = () => [ { type: ElementRef } ]; RangeComponent.propDecorators = { min: [{ type: Input }], max: [{ type: Input }], step: [{ type: Input }], value: [{ type: Input }], defaultValue: [{ type: Input }], disabled: [{ type: Input }], marks: [{ type: Input }], dots: [{ type: Input }], included: [{ type: Input }], count: [{ type: Input }], allowCross: [{ type: Input }], pushable: [{ type: Input }], handleStyle: [{ type: Input }], trackStyle: [{ type: Input }], railStyle: [{ type: Input }], onChange: [{ type: Output }], onAfterChange: [{ type: Output }], amWrapper: [{ type: HostBinding, args: ['class.am-slider-wrapper',] }] }; if (false) { /** @type {?} */ RangeComponent.prototype.prefixCls; /** @type {?} */ RangeComponent.prototype.offset; /** @type {?} */ RangeComponent.prototype.length; /** @type {?} */ RangeComponent.prototype.upperBound; /** @type {?} */ RangeComponent.prototype.lowerBound; /** @type {?} */ RangeComponent.prototype.maxBound; /** @type {?} */ RangeComponent.prototype.minBound; /** @type {?} */ RangeComponent.prototype.sliderCls; /** @type {?} */ RangeComponent.prototype.sliderLength; /** @type {?} */ RangeComponent.prototype.sliderStart; /** * @type {?} * @private */ RangeComponent.prototype._min; /** * @type {?} * @private */ RangeComponent.prototype._max; /** * @type {?} * @private */ RangeComponent.prototype._step; /** * @type {?} * @private */ RangeComponent.prototype._value; /** * @type {?} * @private */ RangeComponent.prototype._defaultValue; /** * @type {?} * @private */ RangeComponent.prototype._disabled; /** * @type {?} * @private */ RangeComponent.prototype._marks; /** * @type {?} * @private */ RangeComponent.prototype._dots; /** * @type {?} * @private */ RangeComponent.prototype._included; /** * @type {?} * @private */ RangeComponent.prototype._count; /** * @type {?} * @private */ RangeComponent.prototype._allowCross; /** * @type {?} * @private */ RangeComponent.prototype._pushable; /** * @type {?} * @private */ RangeComponent.prototype._handleStyle; /** * @type {?} * @private */ RangeComponent.prototype._trackStyle; /** * @type {?} * @private */ RangeComponent.prototype._railStyle; /** * @type {?} * @private */ RangeComponent.prototype._handleCount; /** @type {?} */ RangeComponent.prototype.onChange; /** @type {?} */ RangeComponent.prototype.onAfterChange; /** @type {?} */ RangeComponent.prototype.amWrapper; /** * @type {?} * @private */ RangeComponent.prototype._ngModelOnChange; /** * @type {?} * @private */ RangeComponent.prototype._ngModelOnTouched; /** * @type {?} * @private */ RangeComponent.prototype._elf; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"range.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["range/range.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, Input, Output, EventEmitter, ElementRef, HostBinding, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'Range , nzm-range',\n  templateUrl: './range.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => RangeComponent),\n      multi: true\n    }\n  ]\n})\nexport class RangeComponent implements OnInit, ControlValueAccessor {\n  prefixCls: string = 'am-slider';\n  offset: any[] = [];\n  length: any[] = [];\n  upperBound: number;\n  lowerBound: number;\n  maxBound: number[];\n  minBound: number[];\n  sliderCls: object;\n  sliderLength: number;\n  sliderStart: number;\n\n  private _min = 0;\n  private _max = 100;\n  private _step = 1;\n  private _value;\n  private _defaultValue = [0, 0, 0];\n  private _disabled = false;\n  private _marks = {};\n  private _dots = false;\n  private _included = true;\n  private _count = 1;\n  private _allowCross = true;\n  private _pushable;\n  private _handleStyle = [];\n  private _trackStyle = [];\n  private _railStyle;\n  private _handleCount;\n\n  @Input()\n  get min(): number {\n    return this._min;\n  }\n  set min(value: number) {\n    this._min = value;\n  }\n  @Input()\n  get max(): number {\n    return this._max;\n  }\n  set max(value: number) {\n    this._max = value;\n  }\n  @Input()\n  get step(): number {\n    return this._step;\n  }\n  set step(value: number) {\n    this._step = value;\n  }\n  @Input()\n  get value(): [number] {\n    return this._value;\n  }\n  set value(value: [number]) {\n    this.setValue(value);\n  }\n  @Input()\n  set defaultValue(value) {\n    this._defaultValue = value;\n    this._value = this._defaultValue;\n    this.setValue(value);\n  }\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = value;\n  }\n  @Input()\n  get marks(): object {\n    return this._marks;\n  }\n  set marks(value: object) {\n    this._marks = value;\n  }\n  @Input()\n  get dots(): boolean {\n    return this._dots;\n  }\n  set dots(value: boolean) {\n    this._dots = value;\n  }\n  @Input()\n  get included(): boolean {\n    return this._included;\n  }\n  set included(value: boolean) {\n    this._included = value;\n  }\n  @Input()\n  set count(value: number) {\n    this._count = value;\n  }\n  @Input()\n  set allowCross(value: boolean) {\n    this._allowCross = value;\n    this.setValueBound();\n  }\n  @Input()\n  set pushable(value: number) {\n    this._pushable = value;\n    if (this.verifyPushable()) {\n      this.setValueBound();\n    }\n  }\n  @Input()\n  get handleStyle(): any[] {\n    return this._handleStyle;\n  }\n  set handleStyle(value: any[]) {\n    this._handleStyle = value;\n  }\n  @Input()\n  get trackStyle(): any[] {\n    return this._trackStyle;\n  }\n  set trackStyle(value: any[]) {\n    this._trackStyle = value;\n  }\n  @Input()\n  get railStyle(): any[] {\n    return this._railStyle;\n  }\n  set railStyle(value: any[]) {\n    this._railStyle = value;\n  }\n  @Output()\n  onChange = new EventEmitter<any>();\n  @Output()\n  onAfterChange = new EventEmitter<any>();\n\n  @HostBinding('class.am-slider-wrapper')\n  amWrapper: boolean = true;\n\n  private _ngModelOnChange: (value: number[]) => void = () => {};\n  private _ngModelOnTouched: (value: number) => void = () => {};\n\n  constructor(private _elf: ElementRef) {}\n\n  setCls() {\n    this.sliderCls = {\n      [`${this.prefixCls}-disabled`]: this._disabled\n    };\n  }\n\n  initialValue() {\n    const minTemp = this._min;\n    if (!this.verifyPushable()) {\n      this._pushable = 0;\n      console.log('pushable设置无效，已大于有些value间隔，被强制设为0');\n    }\n    const initialValue = Array.apply(null, Array(this._count + 1)).map(function() {\n      return minTemp;\n    });\n    this._defaultValue = this._defaultValue !== undefined ? this._defaultValue : initialValue;\n    this._value = this._value !== undefined ? this._value : this._defaultValue;\n    // 验证count值\n    this._count = this._value.length - 1;\n    // 验证value区间\n    for (let i = 0; i < this._value.length; i++) {\n      if (this._value[i] < this._min) {\n        this._value[i] = this._min;\n      } else if (this._value[i] > this._max) {\n        this._value[i] = this._max;\n      }\n    }\n    if (this._count > 0) {\n      this.upperBound = Math.max(...this._value);\n      this.lowerBound = Math.min(...this._value);\n    }\n  }\n\n  handleChange(e, i) {\n    let temp = [...this._value];\n    temp[i] = e;\n    this.upperBound = Math.max(...temp);\n    this.lowerBound = Math.min(...temp);\n    this.setTrackStyle(temp);\n    this.onChange.emit(temp);\n  }\n\n  handleAfterChange(e, i) {\n    setTimeout(() => {\n      this._value[i] = e;\n      this.upperBound = Math.max(...this._value);\n      this.lowerBound = Math.min(...this._value);\n      this.setTrackStyle(this._value);\n      this.onAfterChange.emit(this._value);\n      this._ngModelOnChange(this._value);\n      this.setValueBound();\n    }, 0);\n  }\n\n  setTrackStyle(value) {\n    if (value && value.length === this._count + 1) {\n      value.sort((a, b) => a - b);\n      for (let i = 0; i < this._count; i++) {\n        this.offset[i] = (value[i] * 100) / (this._max - this._min);\n        this.length[i] = ((value[i + 1] - value[i]) * 100) / (this._max - this._min);\n      }\n    }\n  }\n\n  setValueBound() {\n    this.maxBound = [];\n    this.minBound = [];\n    if ((this._allowCross && this._pushable === undefined) || this._handleCount <= 1) {\n      for (let i = 0; i < this._handleCount; i++) {\n        this.maxBound[i] = this._max;\n        this.minBound[i] = this._min;\n      }\n    } else {\n      if (this._pushable === undefined) {\n        this._pushable = 0;\n      }\n      for (let i = 0; i < this._handleCount; i++) {\n        this.maxBound[i] = i === this._handleCount - 1 ? this._max : this._value[i + 1] - this._pushable;\n        this.minBound[i] = i === 0 ? this._min : this._value[i - 1] + this._pushable;\n      }\n    }\n  }\n\n  verifyPushable() {\n    for (let i = 1; i < this._handleCount; i++) {\n      const diff = this._value[i] - this._value[i - 1];\n      if (diff < this._pushable) {\n        return false;\n      }\n    }\n    return true;\n  }\n\n  writeValue(value: number[]): void {\n    this.setValue(value, true);\n  }\n\n  setValue(value: number[], isWriteValue = false) {\n    if (value) {\n      this._value = value;\n      this._handleCount = this._value.length + 1;\n      this.initialValue();\n      this.setValueBound();\n      this.setCls();\n      this.setTrackStyle(this._value);\n      if (isWriteValue) {\n        this._ngModelOnChange(this._value);\n      } else {\n        this.onAfterChange.emit(this._value);\n      }\n    }\n  }\n\n  registerOnChange(fn: (value: number[]) => void): void {\n    this._ngModelOnChange = fn;\n  }\n\n  registerOnTouched(fn: (value: number) => void): void {\n    this._ngModelOnTouched = fn;\n  }\n\n  ngOnInit() {\n    this.initialValue();\n    this.setValueBound();\n    this._handleCount = this._count + 1;\n    this.setCls();\n    const sliderCoords = this._elf.nativeElement.getElementsByClassName('am-slider')[0].getBoundingClientRect();\n    this.sliderLength = sliderCoords.width;\n    this.sliderStart = sliderCoords.left;\n  }\n}\n"]}