ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
255 lines • 16.3 kB
JavaScript
/**
* @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"]}