ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
521 lines • 27.6 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, ElementRef, ViewEncapsulation, HostBinding, forwardRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
var SliderComponent = /** @class */ (function () {
function SliderComponent(_elf) {
this._elf = _elf;
this.prefixCls = 'am-slider';
this.offset = 0;
this.length = 0;
this._min = 0;
this._max = 100;
this._step = 1;
this._defaultValue = 0;
this._disabled = false;
this._marks = {};
this._dots = false;
this._included = true;
this._trackStyle = {};
this.onAfterChange = new EventEmitter();
this.onChange = new EventEmitter();
this.amSliderWrapper = true;
this._ngModelOnChange = (/**
* @return {?}
*/
function () { });
this._ngModelOnTouched = (/**
* @return {?}
*/
function () { });
}
Object.defineProperty(SliderComponent.prototype, "min", {
get: /**
* @return {?}
*/
function () {
return this._min;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._min = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "max", {
get: /**
* @return {?}
*/
function () {
return this._max;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._max = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "step", {
get: /**
* @return {?}
*/
function () {
return this._step;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._step = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "value", {
get: /**
* @return {?}
*/
function () {
return this._value;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this.setValue(value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "defaultValue", {
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._defaultValue = value;
this.setValue(value);
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "disabled", {
get: /**
* @return {?}
*/
function () {
return this._disabled;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._disabled = value;
this.setCls();
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "marks", {
get: /**
* @return {?}
*/
function () {
return this._marks;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._marks = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "dots", {
get: /**
* @return {?}
*/
function () {
return this._dots;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._dots = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "included", {
get: /**
* @return {?}
*/
function () {
return this._included;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._included = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "handleStyle", {
get: /**
* @return {?}
*/
function () {
return this._handleStyle;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._handleStyle = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "trackStyle", {
get: /**
* @return {?}
*/
function () {
return this._trackStyle;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._trackStyle = value;
},
enumerable: true,
configurable: true
});
Object.defineProperty(SliderComponent.prototype, "railStyle", {
get: /**
* @return {?}
*/
function () {
return this._railStyle;
},
set: /**
* @param {?} value
* @return {?}
*/
function (value) {
this._railStyle = value;
},
enumerable: true,
configurable: true
});
/**
* @return {?}
*/
SliderComponent.prototype.setCls = /**
* @return {?}
*/
function () {
var _a;
this.sliderCls = (_a = {},
_a[this.prefixCls + "-disabled"] = this._disabled,
_a);
};
/**
* @param {?} e
* @return {?}
*/
SliderComponent.prototype.handleChange = /**
* @param {?} e
* @return {?}
*/
function (e) {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this.setTrack(e);
_this._value = e;
}), 10);
this.onChange.emit(e);
this._ngModelOnChange(e);
};
/**
* @param {?} e
* @return {?}
*/
SliderComponent.prototype.handleAfterChange = /**
* @param {?} e
* @return {?}
*/
function (e) {
var _this = this;
setTimeout((/**
* @return {?}
*/
function () {
_this.setTrack(e);
_this._value = e;
}), 10);
this.onAfterChange.emit(e);
};
/**
* @return {?}
*/
SliderComponent.prototype.valueRange = /**
* @return {?}
*/
function () {
if (this._value < this._min) {
this._value = this._min;
}
if (this._value > this._max) {
this._value = this._max;
}
};
/**
* @return {?}
*/
SliderComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.setCls();
this.setValue(this._value);
/** @type {?} */
var sliderCoords = this._elf.nativeElement.getElementsByClassName('am-slider')[0].getBoundingClientRect();
this.sliderLength = sliderCoords.width;
this.sliderStart = sliderCoords.left;
};
/**
* @param {?} value
* @return {?}
*/
SliderComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
this.setValue(value, true);
};
/**
* @param {?} value
* @param {?=} isWriteValue
* @return {?}
*/
SliderComponent.prototype.setValue = /**
* @param {?} value
* @param {?=} isWriteValue
* @return {?}
*/
function (value, isWriteValue) {
if (isWriteValue === void 0) { isWriteValue = false; }
if (value === 0 || value) {
this._value = value;
}
else {
this._value = this._defaultValue;
}
this.valueRange();
this.setTrack(this._value);
if (isWriteValue) {
this._ngModelOnChange(this._value);
}
else {
this.onAfterChange.emit(this._value);
}
};
/**
* @param {?} e
* @return {?}
*/
SliderComponent.prototype.setTrack = /**
* @param {?} e
* @return {?}
*/
function (e) {
this.offset = 0;
this.length = ((e - this._min) * 100) / (this._max - this._min);
};
/**
* @param {?} fn
* @return {?}
*/
SliderComponent.prototype.registerOnChange = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this._ngModelOnChange = fn;
};
/**
* @param {?} fn
* @return {?}
*/
SliderComponent.prototype.registerOnTouched = /**
* @param {?} fn
* @return {?}
*/
function (fn) {
this._ngModelOnTouched = fn;
};
SliderComponent.decorators = [
{ type: Component, args: [{
selector: 'Slider , nzm-slider',
template: "<div class=\"am-slider\" [ngClass]=\"sliderCls\">\n <div class=\"am-slider-rail\" [ngStyle]=\"railStyle\"></div>\n <SliderTrack\n [className]=\"'am-slider-track'\"\n [style]=\"trackStyle\"\n [offset]=\"offset\"\n [length]=\"length\"\n [included]=\"included\"\n ></SliderTrack>\n <SliderSteps\n [max]=\"max\"\n [min]=\"min\"\n [dots]=\"dots\"\n [step]=\"step\"\n [marks]=\"marks\"\n [lowerBound]=\"min\"\n [upperBound]=\"value\"\n [included]=\"included\"\n ></SliderSteps>\n <SliderHandle\n [max]=\"max\"\n [min]=\"min\"\n [value]=\"value\"\n [step]=\"step\"\n [disabled]=\"disabled\"\n [handleStyle]=\"handleStyle\"\n [sliderStart]=\"sliderStart\"\n [sliderLength]=\"sliderLength\"\n (onChange)=\"handleChange($event)\"\n (onAfterChange)=\"handleAfterChange($event)\"\n ></SliderHandle>\n <SliderMarks\n [max]=\"max\"\n [min]=\"min\"\n [marks]=\"marks\"\n [lowerBound]=\"min\"\n [upperBound]=\"value\"\n [included]=\"included\"\n ></SliderMarks>\n</div>\n",
encapsulation: ViewEncapsulation.None,
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
function () { return SliderComponent; })),
multi: true
}
]
}] }
];
/** @nocollapse */
SliderComponent.ctorParameters = function () { return [
{ type: ElementRef }
]; };
SliderComponent.propDecorators = {
min: [{ type: Input }],
max: [{ type: Input }],
step: [{ type: Input }],
value: [{ type: Input }],
defaultValue: [{ type: Input }],
disabled: [{ type: Input }],
marks: [{ type: Input }],
dots: [{ type: Input }],
included: [{ type: Input }],
handleStyle: [{ type: Input }],
trackStyle: [{ type: Input }],
railStyle: [{ type: Input }],
onAfterChange: [{ type: Output }],
onChange: [{ type: Output }],
amSliderWrapper: [{ type: HostBinding, args: ['class.am-slider-wrapper',] }]
};
return SliderComponent;
}());
export { SliderComponent };
if (false) {
/** @type {?} */
SliderComponent.prototype.prefixCls;
/** @type {?} */
SliderComponent.prototype.sliderLength;
/** @type {?} */
SliderComponent.prototype.sliderStart;
/** @type {?} */
SliderComponent.prototype.sliderCls;
/** @type {?} */
SliderComponent.prototype.offset;
/** @type {?} */
SliderComponent.prototype.length;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._min;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._max;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._step;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._value;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._defaultValue;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._marks;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._dots;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._included;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._handleStyle;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._trackStyle;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._railStyle;
/** @type {?} */
SliderComponent.prototype.onAfterChange;
/** @type {?} */
SliderComponent.prototype.onChange;
/** @type {?} */
SliderComponent.prototype.amSliderWrapper;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._ngModelOnChange;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._ngModelOnTouched;
/**
* @type {?}
* @private
*/
SliderComponent.prototype._elf;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"slider.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["slider/slider.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  OnInit,\n  Input,\n  Output,\n  EventEmitter,\n  ElementRef,\n  ViewEncapsulation,\n  HostBinding,\n  forwardRef\n} from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'Slider , nzm-slider',\n  templateUrl: './slider.component.html',\n  encapsulation: ViewEncapsulation.None,\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => SliderComponent),\n      multi: true\n    }\n  ]\n})\nexport class SliderComponent implements OnInit, ControlValueAccessor {\n  prefixCls = 'am-slider';\n  sliderLength: number;\n  sliderStart: number;\n  sliderCls: object;\n  offset: number = 0;\n  length: number = 0;\n\n  private _min: number = 0;\n  private _max: number = 100;\n  private _step: number = 1;\n  private _value: number;\n  private _defaultValue: number = 0;\n  private _disabled: boolean = false;\n  private _marks: object = {};\n  private _dots: boolean = false;\n  private _included: boolean = true;\n  private _handleStyle: object;\n  private _trackStyle: object = {};\n  private _railStyle: object;\n\n  @Input()\n  get min(): number {\n    return this._min;\n  }\n  set min(value: number) {\n    this._min = value;\n  }\n  @Input()\n  get max(): number {\n    return this._max;\n  }\n  set max(value: number) {\n    this._max = value;\n  }\n  @Input()\n  get step(): number {\n    return this._step;\n  }\n  set step(value: number) {\n    this._step = value;\n  }\n  @Input()\n  get value(): number {\n    return this._value;\n  }\n  set value(value: number) {\n    this.setValue(value);\n  }\n  @Input()\n  set defaultValue(value) {\n    this._defaultValue = value;\n    this.setValue(value);\n  }\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    this._disabled = value;\n    this.setCls();\n  }\n  @Input()\n  get marks(): object {\n    return this._marks;\n  }\n  set marks(value: object) {\n    this._marks = value;\n  }\n  @Input()\n  get dots(): boolean {\n    return this._dots;\n  }\n  set dots(value: boolean) {\n    this._dots = value;\n  }\n  @Input()\n  get included(): boolean {\n    return this._included;\n  }\n  set included(value: boolean) {\n    this._included = value;\n  }\n  @Input()\n  get handleStyle(): object {\n    return this._handleStyle;\n  }\n  set handleStyle(value: object) {\n    this._handleStyle = value;\n  }\n  @Input()\n  get trackStyle(): object {\n    return this._trackStyle;\n  }\n  set trackStyle(value: object) {\n    this._trackStyle = value;\n  }\n  @Input()\n  get railStyle(): object {\n    return this._railStyle;\n  }\n  set railStyle(value: object) {\n    this._railStyle = value;\n  }\n\n  @Output()\n  onAfterChange = new EventEmitter<any>();\n  @Output()\n  onChange = new EventEmitter<any>();\n\n  @HostBinding('class.am-slider-wrapper')\n  amSliderWrapper: boolean = true;\n\n  private _ngModelOnChange: (value: number) => void = () => {};\n  private _ngModelOnTouched: (value: number) => void = () => {};\n\n  constructor(private _elf: ElementRef) {}\n\n  setCls() {\n    this.sliderCls = {\n      [`${this.prefixCls}-disabled`]: this._disabled\n    };\n  }\n\n  handleChange(e) {\n    setTimeout(() => {\n      this.setTrack(e);\n      this._value = e;\n    }, 10);\n    this.onChange.emit(e);\n    this._ngModelOnChange(e);\n  }\n\n  handleAfterChange(e) {\n    setTimeout(() => {\n      this.setTrack(e);\n      this._value = e;\n    }, 10);\n    this.onAfterChange.emit(e);\n  }\n\n  valueRange() {\n    if (this._value < this._min) {\n      this._value = this._min;\n    }\n    if (this._value > this._max) {\n      this._value = this._max;\n    }\n  }\n\n  ngOnInit() {\n    this.setCls();\n    this.setValue(this._value);\n    const sliderCoords = this._elf.nativeElement.getElementsByClassName('am-slider')[0].getBoundingClientRect();\n    this.sliderLength = sliderCoords.width;\n    this.sliderStart = sliderCoords.left;\n  }\n\n  writeValue(value: number): void {\n    this.setValue(value, true);\n  }\n\n  setValue(value: number, isWriteValue = false) {\n    if (value === 0 || value) {\n      this._value = value;\n    } else {\n      this._value = this._defaultValue;\n    }\n    this.valueRange();\n    this.setTrack(this._value);\n    if (isWriteValue) {\n      this._ngModelOnChange(this._value);\n    } else {\n      this.onAfterChange.emit(this._value);\n    }\n  }\n\n  setTrack(e) {\n    this.offset = 0;\n    this.length = ((e - this._min) * 100) / (this._max - this._min);\n  }\n\n  registerOnChange(fn: (value: number) => void): void {\n    this._ngModelOnChange = fn;\n  }\n\n  registerOnTouched(fn: (value: number) => void): void {\n    this._ngModelOnTouched = fn;\n  }\n}\n"]}