ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
129 lines • 15.3 kB
JavaScript
import { Component, ElementRef, Input, HostBinding, ViewEncapsulation } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class SliderStepsComponent {
set min(value) {
if (value && value <= this._max) {
this._min = value;
}
}
set max(value) {
if (value && value >= this._min) {
this._max = value;
}
}
set marks(value) {
this._marks = value;
}
set step(value) {
this._step = value;
}
set included(value) {
this._included = value;
}
set dots(value) {
this._dots = value;
}
set upperBound(value) {
if (value !== undefined && value !== this._upperBound) {
this._upperBound = value;
this.setActiveCls();
}
}
set lowerBound(value) {
if (value !== undefined && value !== this.lowerBound) {
this._lowerBound = value;
this.setActiveCls();
}
}
get class() {
return 'am-slider-step';
}
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;
}
calPoints() {
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;
}
getSteps(points) {
const range = this._max - this._min;
this.stepArray = [];
points.map(point => {
const stepItem = {
stepStyle: {},
stepClass: {},
point: null
};
const offset = `${(Math.abs(point - this._min) / range) * 100}%`;
const isActived = (!this._included && point === this._upperBound) ||
(this._included && point <= this._upperBound && point >= this._lowerBound);
let style = { left: offset, ...this._dotStyle };
if (isActived) {
style = { ...style, ...this._activeDotStyle };
}
const pointClassName = {
[`${this.prefixCls}-dot`]: true,
[`${this.prefixCls}-dot-active`]: isActived
};
stepItem.point = point;
stepItem.stepStyle = style;
stepItem.stepClass = pointClassName;
this.stepArray.push(stepItem);
});
}
setActiveCls() {
for (let i = 0; i < this.stepArray.length; i++) {
const point = this.stepArray[i].point;
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
};
}
}
ngOnInit() {
const points = this.calPoints();
this.getSteps(points);
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SliderStepsComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: SliderStepsComponent, selector: "SliderSteps, nzm-slider-steps", inputs: { min: "min", max: "max", marks: "marks", step: "step", included: "included", dots: "dots", upperBound: "upperBound", lowerBound: "lowerBound" }, host: { properties: { "class": "this.class" } }, ngImport: i0, template: "<span *ngFor=\"let item of stepArray\" [ngClass]=\"item.stepClass\" [ngStyle]=\"item.stepStyle\"> </span>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }], encapsulation: i0.ViewEncapsulation.None }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: SliderStepsComponent, decorators: [{
type: Component,
args: [{ selector: 'SliderSteps, nzm-slider-steps', encapsulation: ViewEncapsulation.None, template: "<span *ngFor=\"let item of stepArray\" [ngClass]=\"item.stepClass\" [ngStyle]=\"item.stepStyle\"> </span>\n" }]
}], ctorParameters: () => [{ type: i0.ElementRef }], 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
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-steps.component.js","sourceRoot":"","sources":["../../../../components/slider/slider-steps/slider-steps.component.ts","../../../../components/slider/slider-steps/slider-steps.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAU,UAAU,EAAE,KAAK,EAAE,WAAW,EAAE,iBAAiB,EAAE,MAAM,eAAe,CAAC;;;AAOrG,MAAM,OAAO,oBAAoB;IAe/B,IACI,GAAG,CAAC,KAAa;QACnB,IAAI,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,IAAI,EAAE;YAC/B,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;SACnB;IACH,CAAC;IACD,IACI,GAAG,CAAC,KAAa;QACnB,IAAI,KAAK,IAAI,KAAK,IAAI,IAAI,CAAC,IAAI,EAAE;YAC/B,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;SACnB;IACH,CAAC;IACD,IACI,KAAK,CAAC,KAAa;QACrB,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;IACtB,CAAC;IACD,IACI,IAAI,CAAC,KAAa;QACpB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IACD,IACI,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IACD,IACI,IAAI,CAAC,KAAc;QACrB,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;IACrB,CAAC;IACD,IACI,UAAU,CAAC,KAAa;QAC1B,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC,WAAW,EAAE;YACrD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;IACD,IACI,UAAU,CAAC,KAAa;QAC1B,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC,UAAU,EAAE;YACpD,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;IAED,IACI,KAAK;QACP,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAED,YAAoB,IAAgB;QAAhB,SAAI,GAAJ,IAAI,CAAY;QA9DpC,cAAS,GAAG,WAAW,CAAC;QACxB,cAAS,GAAG,EAAE,CAAC;QAEP,SAAI,GAAW,CAAC,CAAC;QACjB,SAAI,GAAW,GAAG,CAAC;QAEnB,WAAM,GAAW,EAAE,CAAC;QACpB,cAAS,GAAY,IAAI,CAAC;QAG1B,UAAK,GAAY,KAAK,CAAC;IAoDQ,CAAC;IAExC,SAAS;QACP,MAAM,MAAM,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC,GAAG,CAAC,UAAU,CAAC,CAAC;QACxD,IAAI,IAAI,CAAC,KAAK,EAAE;YACd,KAAK,IAAI,CAAC,GAAG,IAAI,CAAC,IAAI,EAAE,CAAC,IAAI,IAAI,CAAC,IAAI,EAAE,CAAC,GAAG,CAAC,GAAG,IAAI,CAAC,KAAK,EAAE;gBAC1D,IAAI,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,GAAG,CAAC,EAAE;oBACzB,MAAM,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;iBAChB;aACF;SACF;QACD,OAAO,MAAM,CAAC;IAChB,CAAC;IAED,QAAQ,CAAC,MAAM;QACb,MAAM,KAAK,GAAG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACpC,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,MAAM,CAAC,GAAG,CAAC,KAAK,CAAC,EAAE;YACjB,MAAM,QAAQ,GAAG;gBACf,SAAS,EAAE,EAAE;gBACb,SAAS,EAAE,EAAE;gBACb,KAAK,EAAE,IAAI;aACZ,CAAC;YACF,MAAM,MAAM,GAAG,GAAG,CAAC,IAAI,CAAC,GAAG,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,KAAK,CAAC,GAAG,GAAG,GAAG,CAAC;YACjE,MAAM,SAAS,GACb,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC,WAAW,CAAC;gBAC/C,CAAC,IAAI,CAAC,SAAS,IAAI,KAAK,IAAI,IAAI,CAAC,WAAW,IAAI,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC;YAC7E,IAAI,KAAK,GAAG,EAAE,IAAI,EAAE,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;YAChD,IAAI,SAAS,EAAE;gBACb,KAAK,GAAG,EAAE,GAAG,KAAK,EAAE,GAAG,IAAI,CAAC,eAAe,EAAE,CAAC;aAC/C;YAED,MAAM,cAAc,GAAG;gBACrB,CAAC,GAAG,IAAI,CAAC,SAAS,MAAM,CAAC,EAAE,IAAI;gBAC/B,CAAC,GAAG,IAAI,CAAC,SAAS,aAAa,CAAC,EAAE,SAAS;aAC5C,CAAC;YACF,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;YACvB,QAAQ,CAAC,SAAS,GAAG,KAAK,CAAC;YAC3B,QAAQ,CAAC,SAAS,GAAG,cAAc,CAAC;YACpC,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAChC,CAAC,CAAC,CAAC;IACL,CAAC;IAED,YAAY;QACV,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;YAC9C,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC;YACtC,MAAM,SAAS,GACb,CAAC,CAAC,IAAI,CAAC,SAAS,IAAI,KAAK,KAAK,IAAI,CAAC,WAAW,CAAC;gBAC/C,CAAC,IAAI,CAAC,SAAS,IAAI,KAAK,IAAI,IAAI,CAAC,WAAW,IAAI,KAAK,IAAI,IAAI,CAAC,WAAW,CAAC,CAAC;YAC7E,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG;gBAC5B,CAAC,GAAG,IAAI,CAAC,SAAS,MAAM,CAAC,EAAE,IAAI;gBAC/B,CAAC,GAAG,IAAI,CAAC,SAAS,aAAa,CAAC,EAAE,SAAS;aAC5C,CAAC;SACH;IACH,CAAC;IAED,QAAQ;QACN,MAAM,MAAM,GAAG,IAAI,CAAC,SAAS,EAAE,CAAC;QAChC,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,CAAC;IACxB,CAAC;8GA1HU,oBAAoB;kGAApB,oBAAoB,gRCPjC,6GACA;;2FDMa,oBAAoB;kBALhC,SAAS;+BACE,+BAA+B,iBAE1B,iBAAiB,CAAC,IAAI;+EAkBjC,GAAG;sBADN,KAAK;gBAOF,GAAG;sBADN,KAAK;gBAOF,KAAK;sBADR,KAAK;gBAKF,IAAI;sBADP,KAAK;gBAKF,QAAQ;sBADX,KAAK;gBAKF,IAAI;sBADP,KAAK;gBAKF,UAAU;sBADb,KAAK;gBAQF,UAAU;sBADb,KAAK;gBASF,KAAK;sBADR,WAAW","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","<span *ngFor=\"let item of stepArray\" [ngClass]=\"item.stepClass\" [ngStyle]=\"item.stepStyle\"> </span>\n"]}