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