UNPKG

ng-zorro-antd-mobile

Version:

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

255 lines 16.3 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, Input, HostBinding, ViewEncapsulation } from '@angular/core'; export class SliderStepsComponent { /** * @param {?} _elf */ constructor(_elf) { this._elf = _elf; this.prefixCls = 'am-slider'; this.stepArray = []; this._min = 0; this._max = 100; this._marks = {}; this._included = true; this._dots = false; } /** * @param {?} value * @return {?} */ set min(value) { if (value && value <= this._max) { this._min = value; } } /** * @param {?} value * @return {?} */ set max(value) { if (value && value >= this._min) { this._max = value; } } /** * @param {?} value * @return {?} */ set marks(value) { this._marks = value; } /** * @param {?} value * @return {?} */ set step(value) { this._step = value; } /** * @param {?} value * @return {?} */ set included(value) { this._included = value; } /** * @param {?} value * @return {?} */ set dots(value) { this._dots = value; } /** * @param {?} value * @return {?} */ set upperBound(value) { if (value !== undefined && value !== this._upperBound) { this._upperBound = value; this.setActiveCls(); } } /** * @param {?} value * @return {?} */ set lowerBound(value) { if (value !== undefined && value !== this.lowerBound) { this._lowerBound = value; this.setActiveCls(); } } /** * @return {?} */ get class() { return 'am-slider-step'; } /** * @return {?} */ calPoints() { /** @type {?} */ const points = Object.keys(this._marks).map(parseFloat); if (this._dots) { for (let i = this._min; i <= this._max; i = i + this._step) { if (points.indexOf(i) < 0) { points.push(i); } } } return points; } /** * @param {?} points * @return {?} */ getSteps(points) { /** @type {?} */ const range = this._max - this._min; this.stepArray = []; points.map((/** * @param {?} point * @return {?} */ point => { /** @type {?} */ const stepItem = { stepStyle: {}, stepClass: {}, point: null }; /** @type {?} */ const offset = `${(Math.abs(point - this._min) / range) * 100}%`; /** @type {?} */ const isActived = (!this._included && point === this._upperBound) || (this._included && point <= this._upperBound && point >= this._lowerBound); /** @type {?} */ let style = Object.assign({ left: offset }, this._dotStyle); if (isActived) { style = Object.assign({}, style, this._activeDotStyle); } /** @type {?} */ const pointClassName = { [`${this.prefixCls}-dot`]: true, [`${this.prefixCls}-dot-active`]: isActived }; stepItem.point = point; stepItem.stepStyle = style; stepItem.stepClass = pointClassName; this.stepArray.push(stepItem); })); } /** * @return {?} */ setActiveCls() { for (let i = 0; i < this.stepArray.length; i++) { /** @type {?} */ const point = this.stepArray[i].point; /** @type {?} */ const isActived = (!this._included && point === this._upperBound) || (this._included && point <= this._upperBound && point >= this._lowerBound); this.stepArray[i].stepClass = { [`${this.prefixCls}-dot`]: true, [`${this.prefixCls}-dot-active`]: isActived }; } } /** * @return {?} */ ngOnInit() { /** @type {?} */ const points = this.calPoints(); this.getSteps(points); } } SliderStepsComponent.decorators = [ { type: Component, args: [{ selector: 'SliderSteps, nzm-slider-steps', template: "<span *ngFor=\"let item of stepArray\" [ngClass]=\"item.stepClass\" [ngStyle]=\"item.stepStyle\"> </span>\n", encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ SliderStepsComponent.ctorParameters = () => [ { type: ElementRef } ]; SliderStepsComponent.propDecorators = { min: [{ type: Input }], max: [{ type: Input }], marks: [{ type: Input }], step: [{ type: Input }], included: [{ type: Input }], dots: [{ type: Input }], upperBound: [{ type: Input }], lowerBound: [{ type: Input }], class: [{ type: HostBinding }] }; if (false) { /** @type {?} */ SliderStepsComponent.prototype.prefixCls; /** @type {?} */ SliderStepsComponent.prototype.stepArray; /** * @type {?} * @private */ SliderStepsComponent.prototype._min; /** * @type {?} * @private */ SliderStepsComponent.prototype._max; /** * @type {?} * @private */ SliderStepsComponent.prototype._step; /** * @type {?} * @private */ SliderStepsComponent.prototype._marks; /** * @type {?} * @private */ SliderStepsComponent.prototype._included; /** * @type {?} * @private */ SliderStepsComponent.prototype._upperBound; /** * @type {?} * @private */ SliderStepsComponent.prototype._lowerBound; /** * @type {?} * @private */ SliderStepsComponent.prototype._dots; /** * @type {?} * @private */ SliderStepsComponent.prototype._dotStyle; /** * @type {?} * @private */ SliderStepsComponent.prototype._activeDotStyle; /** * @type {?} * @private */ SliderStepsComponent.prototype._elf; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-steps.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["slider/slider-steps/slider-steps.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ElementRef, Input, HostBinding, ViewEncapsulation } from '@angular/core';\n\n@Component({\n  selector: 'SliderSteps, nzm-slider-steps',\n  templateUrl: './slider-steps.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class SliderStepsComponent implements OnInit {\n  prefixCls = 'am-slider';\n  stepArray = [];\n\n  private _min: number = 0;\n  private _max: number = 100;\n  private _step: number;\n  private _marks: object = {};\n  private _included: boolean = true;\n  private _upperBound: number;\n  private _lowerBound: number;\n  private _dots: boolean = false;\n  private _dotStyle: object;\n  private _activeDotStyle: object;\n\n  @Input()\n  set min(value: number) {\n    if (value && value <= this._max) {\n      this._min = value;\n    }\n  }\n  @Input()\n  set max(value: number) {\n    if (value && value >= this._min) {\n      this._max = value;\n    }\n  }\n  @Input()\n  set marks(value: object) {\n    this._marks = value;\n  }\n  @Input()\n  set step(value: number) {\n    this._step = value;\n  }\n  @Input()\n  set included(value: boolean) {\n    this._included = value;\n  }\n  @Input()\n  set dots(value: boolean) {\n    this._dots = value;\n  }\n  @Input()\n  set upperBound(value: number) {\n    if (value !== undefined && value !== this._upperBound) {\n      this._upperBound = value;\n      this.setActiveCls();\n    }\n  }\n  @Input()\n  set lowerBound(value: number) {\n    if (value !== undefined && value !== this.lowerBound) {\n      this._lowerBound = value;\n      this.setActiveCls();\n    }\n  }\n\n  @HostBinding()\n  get class() {\n    return 'am-slider-step';\n  }\n\n  constructor(private _elf: ElementRef) {}\n\n  calPoints() {\n    const points = Object.keys(this._marks).map(parseFloat);\n    if (this._dots) {\n      for (let i = this._min; i <= this._max; i = i + this._step) {\n        if (points.indexOf(i) < 0) {\n          points.push(i);\n        }\n      }\n    }\n    return points;\n  }\n\n  getSteps(points) {\n    const range = this._max - this._min;\n    this.stepArray = [];\n    points.map(point => {\n      const stepItem = {\n        stepStyle: {},\n        stepClass: {},\n        point: null\n      };\n      const offset = `${(Math.abs(point - this._min) / range) * 100}%`;\n      const isActived =\n        (!this._included && point === this._upperBound) ||\n        (this._included && point <= this._upperBound && point >= this._lowerBound);\n      let style = { left: offset, ...this._dotStyle };\n      if (isActived) {\n        style = { ...style, ...this._activeDotStyle };\n      }\n\n      const pointClassName = {\n        [`${this.prefixCls}-dot`]: true,\n        [`${this.prefixCls}-dot-active`]: isActived\n      };\n      stepItem.point = point;\n      stepItem.stepStyle = style;\n      stepItem.stepClass = pointClassName;\n      this.stepArray.push(stepItem);\n    });\n  }\n\n  setActiveCls() {\n    for (let i = 0; i < this.stepArray.length; i++) {\n      const point = this.stepArray[i].point;\n      const isActived =\n        (!this._included && point === this._upperBound) ||\n        (this._included && point <= this._upperBound && point >= this._lowerBound);\n      this.stepArray[i].stepClass = {\n        [`${this.prefixCls}-dot`]: true,\n        [`${this.prefixCls}-dot-active`]: isActived\n      };\n    }\n  }\n\n  ngOnInit() {\n    const points = this.calPoints();\n    this.getSteps(points);\n  }\n}\n"]}