UNPKG

ng-zorro-antd-mobile

Version:

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

271 lines 19.4 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import { Component, ElementRef, Input, Output, EventEmitter, HostBinding, ViewEncapsulation } from '@angular/core'; export class SliderMarksComponent { /** * @param {?} _elf */ constructor(_elf) { this._elf = _elf; this.markArray = []; this._min = 0; this._max = 100; this._marks = {}; this._included = true; this._className = 'am-slider-mark'; this.onChange = new EventEmitter(); this.onAfterChange = new EventEmitter(); } /** * @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 included(value) { this._included = value; } /** * @param {?} value * @return {?} */ set upperBound(value) { if (value && value !== this._upperBound) { this._upperBound = value; this.setActiveCls(); } } /** * @param {?} value * @return {?} */ set lowerBound(value) { if (value && value !== this.lowerBound) { this._lowerBound = value; this.setActiveCls(); } } /** * @return {?} */ get class() { return this._className; } /** * @param {?} marksKeys * @return {?} */ getMarks(marksKeys) { this.markArray = []; marksKeys .map(parseFloat) .sort((/** * @param {?} a * @param {?} b * @return {?} */ (a, b) => a - b)) .map((/** * @param {?} point * @return {?} */ point => { /** @type {?} */ const markItem = { markLabel: '', point: '', className: {}, style: {} }; /** @type {?} */ const markPoint = this._marks[point]; /** @type {?} */ const markPointIsObject = typeof markPoint === 'object'; /** @type {?} */ const markLabel = markPointIsObject ? markPoint.label : markPoint; if (!markLabel && markLabel !== 0) { return null; } /** @type {?} */ const isActive = (!this._included && point === this._upperBound) || (this._included && point <= this._upperBound && point >= this._lowerBound); /** @type {?} */ const markClassName = { [`${this._className}-text`]: true, [`${this._className}-text-active`]: isActive }; /** @type {?} */ const bottomStyle = { marginBottom: '-50%', bottom: `${((point - this._min) / this._range) * 100}%` }; /** @type {?} */ const leftStyle = { width: `${this._markWidth}%`, marginLeft: `${-this._markWidth / 2}%`, left: `${((point - this._min) / this._range) * 100}%` }; /** @type {?} */ const style = leftStyle; /** @type {?} */ const markStyle = markPointIsObject ? Object.assign({}, style, markPoint.style) : style; markItem.markLabel = markLabel; markItem.point = point; markItem.className = Object.keys(markClassName).join(' '); markItem.style = markStyle; this.markArray.push(markItem); })); } /** * @return {?} */ setActiveCls() { for (let i = 0; i < this.markArray.length; i++) { /** @type {?} */ const point = this.markArray[i].point; /** @type {?} */ const isActive = (!this._included && point === this._upperBound) || (this._included && point <= this._upperBound && point >= this._lowerBound); this.markArray[i].className = { [`${this._className}-text`]: true, [`${this._className}-text-active`]: isActive }; } } /** * @return {?} */ setMarksLable() { for (let i = 0; i < this.markArray.length; i++) { /** @type {?} */ const markEle = this._elf.nativeElement.getElementsByClassName(this._className + '-text')[i]; markEle.innerHTML = this.markArray[i].markLabel; } } /** * @return {?} */ ngOnInit() { /** @type {?} */ const marksKeys = Object.keys(this._marks); /** @type {?} */ const marksCount = marksKeys.length; /** @type {?} */ const unit = marksCount > 1 ? 100 / (marksCount - 1) : 100; this._markWidth = unit * 0.9; this._range = this._max - this._min; this.getMarks(marksKeys); } /** * @return {?} */ ngAfterViewInit() { this.setMarksLable(); } } SliderMarksComponent.decorators = [ { type: Component, args: [{ selector: 'SliderMarks, nzm-slider-marks', template: "<span *ngFor=\"let item of markArray\" [ngClass]=\"item.className\" [ngStyle]=\"item.style\"> </span>\n", encapsulation: ViewEncapsulation.None }] } ]; /** @nocollapse */ SliderMarksComponent.ctorParameters = () => [ { type: ElementRef } ]; SliderMarksComponent.propDecorators = { min: [{ type: Input }], max: [{ type: Input }], marks: [{ type: Input }], included: [{ type: Input }], upperBound: [{ type: Input }], lowerBound: [{ type: Input }], onChange: [{ type: Output }], onAfterChange: [{ type: Output }], class: [{ type: HostBinding }] }; if (false) { /** @type {?} */ SliderMarksComponent.prototype.markArray; /** * @type {?} * @private */ SliderMarksComponent.prototype._min; /** * @type {?} * @private */ SliderMarksComponent.prototype._max; /** * @type {?} * @private */ SliderMarksComponent.prototype._marks; /** * @type {?} * @private */ SliderMarksComponent.prototype._included; /** * @type {?} * @private */ SliderMarksComponent.prototype._className; /** * @type {?} * @private */ SliderMarksComponent.prototype._upperBound; /** * @type {?} * @private */ SliderMarksComponent.prototype._lowerBound; /** * @type {?} * @private */ SliderMarksComponent.prototype._range; /** * @type {?} * @private */ SliderMarksComponent.prototype._markWidth; /** @type {?} */ SliderMarksComponent.prototype.onChange; /** @type {?} */ SliderMarksComponent.prototype.onAfterChange; /** * @type {?} * @private */ SliderMarksComponent.prototype._elf; } //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider-marks.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["slider/slider-marks/slider-marks.component.ts"],"names":[],"mappings":";;;;AAAA,OAAO,EACL,SAAS,EAET,UAAU,EACV,KAAK,EACL,MAAM,EACN,YAAY,EAEZ,WAAW,EACX,iBAAiB,EAClB,MAAM,eAAe,CAAC;AAOvB,MAAM,OAAO,oBAAoB;;;;IAyD/B,YAAoB,IAAgB;QAAhB,SAAI,GAAJ,IAAI,CAAY;QAxDpC,cAAS,GAAe,EAAE,CAAC;QAEnB,SAAI,GAAW,CAAC,CAAC;QACjB,SAAI,GAAW,GAAG,CAAC;QACnB,WAAM,GAAW,EAAE,CAAC;QACpB,cAAS,GAAY,IAAI,CAAC;QAC1B,eAAU,GAAW,gBAAgB,CAAC;QAyC9C,aAAQ,GAAG,IAAI,YAAY,EAAO,CAAC;QAEnC,kBAAa,GAAG,IAAI,YAAY,EAAO,CAAC;IAOD,CAAC;;;;;IA5CxC,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,QAAQ,CAAC,KAAc;QACzB,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;;;;;IACD,IACI,UAAU,CAAC,KAAa;QAC1B,IAAI,KAAK,IAAI,KAAK,KAAK,IAAI,CAAC,WAAW,EAAE;YACvC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;;;;;IACD,IACI,UAAU,CAAC,KAAa;QAC1B,IAAI,KAAK,IAAI,KAAK,KAAK,IAAI,CAAC,UAAU,EAAE;YACtC,IAAI,CAAC,WAAW,GAAG,KAAK,CAAC;YACzB,IAAI,CAAC,YAAY,EAAE,CAAC;SACrB;IACH,CAAC;;;;IAMD,IACI,KAAK;QACP,OAAO,IAAI,CAAC,UAAU,CAAC;IACzB,CAAC;;;;;IAID,QAAQ,CAAC,SAAS;QAChB,IAAI,CAAC,SAAS,GAAG,EAAE,CAAC;QACpB,SAAS;aACN,GAAG,CAAC,UAAU,CAAC;aACf,IAAI;;;;;QAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAAC,GAAG,CAAC,EAAC;aACrB,GAAG;;;;QAAC,KAAK,CAAC,EAAE;;kBACL,QAAQ,GAAG;gBACf,SAAS,EAAE,EAAE;gBACb,KAAK,EAAE,EAAE;gBACT,SAAS,EAAE,EAAE;gBACb,KAAK,EAAE,EAAE;aACV;;kBACK,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC;;kBAC9B,iBAAiB,GAAG,OAAO,SAAS,KAAK,QAAQ;;kBACjD,SAAS,GAAG,iBAAiB,CAAC,CAAC,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS;YACjE,IAAI,CAAC,SAAS,IAAI,SAAS,KAAK,CAAC,EAAE;gBACjC,OAAO,IAAI,CAAC;aACb;;kBACK,QAAQ,GACZ,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;;kBACtE,aAAa,GAAG;gBACpB,CAAC,GAAG,IAAI,CAAC,UAAU,OAAO,CAAC,EAAE,IAAI;gBACjC,CAAC,GAAG,IAAI,CAAC,UAAU,cAAc,CAAC,EAAE,QAAQ;aAC7C;;kBACK,WAAW,GAAG;gBAClB,YAAY,EAAE,MAAM;gBACpB,MAAM,EAAE,GAAG,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,GAAG,GAAG;aACxD;;kBACK,SAAS,GAAG;gBAChB,KAAK,EAAE,GAAG,IAAI,CAAC,UAAU,GAAG;gBAC5B,UAAU,EAAE,GAAG,CAAC,IAAI,CAAC,UAAU,GAAG,CAAC,GAAG;gBACtC,IAAI,EAAE,GAAG,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC,GAAG,GAAG,GAAG;aACtD;;kBACK,KAAK,GAAG,SAAS;;kBACjB,SAAS,GAAG,iBAAiB,CAAC,CAAC,mBAAM,KAAK,EAAK,SAAS,CAAC,KAAK,EAAG,CAAC,CAAC,KAAK;YAC9E,QAAQ,CAAC,SAAS,GAAG,SAAS,CAAC;YAC/B,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;YACvB,QAAQ,CAAC,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC1D,QAAQ,CAAC,KAAK,GAAG,SAAS,CAAC;YAC3B,IAAI,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAChC,CAAC,EAAC,CAAC;IACP,CAAC;;;;IAED,YAAY;QACV,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;;kBACxC,KAAK,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,KAAK;;kBAC/B,QAAQ,GACZ,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;YAC5E,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,GAAG;gBAC5B,CAAC,GAAG,IAAI,CAAC,UAAU,OAAO,CAAC,EAAE,IAAI;gBACjC,CAAC,GAAG,IAAI,CAAC,UAAU,cAAc,CAAC,EAAE,QAAQ;aAC7C,CAAC;SACH;IACH,CAAC;;;;IAED,aAAa;QACX,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,GAAG,IAAI,CAAC,SAAS,CAAC,MAAM,EAAE,CAAC,EAAE,EAAE;;kBACxC,OAAO,GAAG,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,sBAAsB,CAAC,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC,CAAC,CAAC,CAAC;YAC5F,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC,SAAS,CAAC;SACjD;IACH,CAAC;;;;IAED,QAAQ;;cACA,SAAS,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,MAAM,CAAC;;cACpC,UAAU,GAAG,SAAS,CAAC,MAAM;;cAC7B,IAAI,GAAG,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,GAAG,GAAG,CAAC,UAAU,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,GAAG;QAC1D,IAAI,CAAC,UAAU,GAAG,IAAI,GAAG,GAAG,CAAC;QAC7B,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,IAAI,CAAC;QACpC,IAAI,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC;IAC3B,CAAC;;;;IAED,eAAe;QACb,IAAI,CAAC,aAAa,EAAE,CAAC;IACvB,CAAC;;;YA3IF,SAAS,SAAC;gBACT,QAAQ,EAAE,+BAA+B;gBACzC,mHAA4C;gBAC5C,aAAa,EAAE,iBAAiB,CAAC,IAAI;aACtC;;;;YAbC,UAAU;;;kBA2BT,KAAK;kBAML,KAAK;oBAML,KAAK;uBAIL,KAAK;yBAIL,KAAK;yBAOL,KAAK;uBAOL,MAAM;4BAEN,MAAM;oBAGN,WAAW;;;;IAnDZ,yCAA2B;;;;;IAE3B,oCAAyB;;;;;IACzB,oCAA2B;;;;;IAC3B,sCAA4B;;;;;IAC5B,yCAAkC;;;;;IAClC,0CAA8C;;;;;IAC9C,2CAA4B;;;;;IAC5B,2CAA4B;;;;;IAC5B,sCAAuB;;;;;IACvB,0CAA2B;;IAoC3B,wCACmC;;IACnC,6CACwC;;;;;IAO5B,oCAAwB","sourcesContent":["import {\n  Component,\n  OnInit,\n  ElementRef,\n  Input,\n  Output,\n  EventEmitter,\n  AfterViewInit,\n  HostBinding,\n  ViewEncapsulation\n} from '@angular/core';\n\n@Component({\n  selector: 'SliderMarks, nzm-slider-marks',\n  templateUrl: './slider-marks.component.html',\n  encapsulation: ViewEncapsulation.None\n})\nexport class SliderMarksComponent implements OnInit, AfterViewInit {\n  markArray: Array<any> = [];\n\n  private _min: number = 0;\n  private _max: number = 100;\n  private _marks: object = {};\n  private _included: boolean = true;\n  private _className: string = 'am-slider-mark';\n  private _upperBound: number;\n  private _lowerBound: number;\n  private _range: number;\n  private _markWidth: number;\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 included(value: boolean) {\n    this._included = value;\n  }\n  @Input()\n  set upperBound(value: number) {\n    if (value && value !== this._upperBound) {\n      this._upperBound = value;\n      this.setActiveCls();\n    }\n  }\n  @Input()\n  set lowerBound(value: number) {\n    if (value && value !== this.lowerBound) {\n      this._lowerBound = value;\n      this.setActiveCls();\n    }\n  }\n  @Output()\n  onChange = new EventEmitter<any>();\n  @Output()\n  onAfterChange = new EventEmitter<any>();\n\n  @HostBinding()\n  get class() {\n    return this._className;\n  }\n\n  constructor(private _elf: ElementRef) {}\n\n  getMarks(marksKeys) {\n    this.markArray = [];\n    marksKeys\n      .map(parseFloat)\n      .sort((a, b) => a - b)\n      .map(point => {\n        const markItem = {\n          markLabel: '',\n          point: '',\n          className: {},\n          style: {}\n        };\n        const markPoint = this._marks[point];\n        const markPointIsObject = typeof markPoint === 'object';\n        const markLabel = markPointIsObject ? markPoint.label : markPoint;\n        if (!markLabel && markLabel !== 0) {\n          return null;\n        }\n        const isActive =\n          (!this._included && point === this._upperBound) ||\n          (this._included && point <= this._upperBound && point >= this._lowerBound);\n        const markClassName = {\n          [`${this._className}-text`]: true,\n          [`${this._className}-text-active`]: isActive\n        };\n        const bottomStyle = {\n          marginBottom: '-50%',\n          bottom: `${((point - this._min) / this._range) * 100}%`\n        };\n        const leftStyle = {\n          width: `${this._markWidth}%`,\n          marginLeft: `${-this._markWidth / 2}%`,\n          left: `${((point - this._min) / this._range) * 100}%`\n        };\n        const style = leftStyle;\n        const markStyle = markPointIsObject ? { ...style, ...markPoint.style } : style;\n        markItem.markLabel = markLabel;\n        markItem.point = point;\n        markItem.className = Object.keys(markClassName).join(' ');\n        markItem.style = markStyle;\n        this.markArray.push(markItem);\n      });\n  }\n\n  setActiveCls() {\n    for (let i = 0; i < this.markArray.length; i++) {\n      const point = this.markArray[i].point;\n      const isActive =\n        (!this._included && point === this._upperBound) ||\n        (this._included && point <= this._upperBound && point >= this._lowerBound);\n      this.markArray[i].className = {\n        [`${this._className}-text`]: true,\n        [`${this._className}-text-active`]: isActive\n      };\n    }\n  }\n\n  setMarksLable() {\n    for (let i = 0; i < this.markArray.length; i++) {\n      const markEle = this._elf.nativeElement.getElementsByClassName(this._className + '-text')[i];\n      markEle.innerHTML = this.markArray[i].markLabel;\n    }\n  }\n\n  ngOnInit() {\n    const marksKeys = Object.keys(this._marks);\n    const marksCount = marksKeys.length;\n    const unit = marksCount > 1 ? 100 / (marksCount - 1) : 100;\n    this._markWidth = unit * 0.9;\n    this._range = this._max - this._min;\n    this.getMarks(marksKeys);\n  }\n\n  ngAfterViewInit() {\n    this.setMarksLable();\n  }\n}\n"]}