UNPKG

ng-zorro-antd-mobile

Version:

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

318 lines 21.5 kB
/** * @fileoverview added by tsickle * @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc */ import * as tslib_1 from "tslib"; import { Component, ElementRef, Input, Output, EventEmitter, HostBinding, ViewEncapsulation } from '@angular/core'; var SliderMarksComponent = /** @class */ (function () { function SliderMarksComponent(_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(); } Object.defineProperty(SliderMarksComponent.prototype, "min", { set: /** * @param {?} value * @return {?} */ function (value) { if (value && value <= this._max) { this._min = value; } }, enumerable: true, configurable: true }); Object.defineProperty(SliderMarksComponent.prototype, "max", { set: /** * @param {?} value * @return {?} */ function (value) { if (value && value >= this._min) { this._max = value; } }, enumerable: true, configurable: true }); Object.defineProperty(SliderMarksComponent.prototype, "marks", { set: /** * @param {?} value * @return {?} */ function (value) { this._marks = value; }, enumerable: true, configurable: true }); Object.defineProperty(SliderMarksComponent.prototype, "included", { set: /** * @param {?} value * @return {?} */ function (value) { this._included = value; }, enumerable: true, configurable: true }); Object.defineProperty(SliderMarksComponent.prototype, "upperBound", { set: /** * @param {?} value * @return {?} */ function (value) { if (value && value !== this._upperBound) { this._upperBound = value; this.setActiveCls(); } }, enumerable: true, configurable: true }); Object.defineProperty(SliderMarksComponent.prototype, "lowerBound", { set: /** * @param {?} value * @return {?} */ function (value) { if (value && value !== this.lowerBound) { this._lowerBound = value; this.setActiveCls(); } }, enumerable: true, configurable: true }); Object.defineProperty(SliderMarksComponent.prototype, "class", { get: /** * @return {?} */ function () { return this._className; }, enumerable: true, configurable: true }); /** * @param {?} marksKeys * @return {?} */ SliderMarksComponent.prototype.getMarks = /** * @param {?} marksKeys * @return {?} */ function (marksKeys) { var _this = this; this.markArray = []; marksKeys .map(parseFloat) .sort((/** * @param {?} a * @param {?} b * @return {?} */ function (a, b) { return a - b; })) .map((/** * @param {?} point * @return {?} */ function (point) { var _a; /** @type {?} */ var markItem = { markLabel: '', point: '', className: {}, style: {} }; /** @type {?} */ var markPoint = _this._marks[point]; /** @type {?} */ var markPointIsObject = typeof markPoint === 'object'; /** @type {?} */ var markLabel = markPointIsObject ? markPoint.label : markPoint; if (!markLabel && markLabel !== 0) { return null; } /** @type {?} */ var isActive = (!_this._included && point === _this._upperBound) || (_this._included && point <= _this._upperBound && point >= _this._lowerBound); /** @type {?} */ var markClassName = (_a = {}, _a[_this._className + "-text"] = true, _a[_this._className + "-text-active"] = isActive, _a); /** @type {?} */ var bottomStyle = { marginBottom: '-50%', bottom: ((point - _this._min) / _this._range) * 100 + "%" }; /** @type {?} */ var leftStyle = { width: _this._markWidth + "%", marginLeft: -_this._markWidth / 2 + "%", left: ((point - _this._min) / _this._range) * 100 + "%" }; /** @type {?} */ var style = leftStyle; /** @type {?} */ var markStyle = markPointIsObject ? tslib_1.__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 {?} */ SliderMarksComponent.prototype.setActiveCls = /** * @return {?} */ function () { var _a; for (var i = 0; i < this.markArray.length; i++) { /** @type {?} */ var point = this.markArray[i].point; /** @type {?} */ var isActive = (!this._included && point === this._upperBound) || (this._included && point <= this._upperBound && point >= this._lowerBound); this.markArray[i].className = (_a = {}, _a[this._className + "-text"] = true, _a[this._className + "-text-active"] = isActive, _a); } }; /** * @return {?} */ SliderMarksComponent.prototype.setMarksLable = /** * @return {?} */ function () { for (var i = 0; i < this.markArray.length; i++) { /** @type {?} */ var markEle = this._elf.nativeElement.getElementsByClassName(this._className + '-text')[i]; markEle.innerHTML = this.markArray[i].markLabel; } }; /** * @return {?} */ SliderMarksComponent.prototype.ngOnInit = /** * @return {?} */ function () { /** @type {?} */ var marksKeys = Object.keys(this._marks); /** @type {?} */ var marksCount = marksKeys.length; /** @type {?} */ var unit = marksCount > 1 ? 100 / (marksCount - 1) : 100; this._markWidth = unit * 0.9; this._range = this._max - this._min; this.getMarks(marksKeys); }; /** * @return {?} */ SliderMarksComponent.prototype.ngAfterViewInit = /** * @return {?} */ function () { 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 = function () { return [ { 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 }] }; return SliderMarksComponent; }()); export { SliderMarksComponent }; 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":"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","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"]}