ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
441 lines • 31.9 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import { Component, Input, Output, EventEmitter, HostBinding, forwardRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
export class StepperComponent {
constructor() {
this.prefixCls = 'am-stepper';
this._max = Infinity;
this._min = -Infinity;
this._step = 1;
this._disabled = false;
this._readOnly = false;
this._showNumber = false;
this._upDisabled = false;
this._downDisabled = false;
this._isUpClick = false;
this._isDownClick = false;
this.onChange = new EventEmitter();
this.clsStepper = true;
this.clsStpDisabled = this._disabled;
this.clsShowNum = this._showNumber;
this.onChangeFn = (/**
* @return {?}
*/
() => { });
this.onTouchFn = (/**
* @return {?}
*/
() => { });
}
/**
* @return {?}
*/
get max() {
return this._max;
}
/**
* @param {?} value
* @return {?}
*/
set max(value) {
this._max = value;
}
/**
* @return {?}
*/
get min() {
return this._min;
}
/**
* @param {?} value
* @return {?}
*/
set min(value) {
this._min = value;
}
/**
* @return {?}
*/
get value() {
return this._value;
}
/**
* @param {?} v
* @return {?}
*/
set value(v) {
this._value = v;
}
/**
* @param {?} value
* @return {?}
*/
set step(value) {
this._step = value;
}
/**
* @param {?} value
* @return {?}
*/
set defaultValue(value) {
if (value) {
this._defaultValue = value;
this._value = value;
}
}
/**
* @return {?}
*/
get disabled() {
return this._disabled;
}
/**
* @param {?} value
* @return {?}
*/
set disabled(value) {
if (value) {
this._downDisabled = value;
this._upDisabled = value;
}
this._disabled = value;
this.clsStpDisabled = value;
}
/**
* @return {?}
*/
get readOnly() {
return this._readOnly;
}
/**
* @param {?} value
* @return {?}
*/
set readOnly(value) {
this._readOnly = value;
}
/**
* @param {?} value
* @return {?}
*/
set showNumber(value) {
this._showNumber = value;
this.clsShowNum = value;
}
/**
* @return {?}
*/
onIncrease() {
if (!this._upDisabled) {
this._value = this.plus(this._value, this._step);
this.onChange.emit(this._value);
this.onChangeFn(this._value);
if (this.plus(this._value, this._step) > this._max) {
this._upDisabled = true;
}
if (this.minus(this._value, this._step) >= this._min) {
this._downDisabled = false;
}
this._isUpClick = true;
this.setCls();
setTimeout((/**
* @return {?}
*/
() => {
this._isUpClick = false;
this.setCls();
}), 100);
}
}
/**
* @return {?}
*/
onDecrease() {
if (!this._downDisabled) {
this._value = this.minus(this._value, this._step);
this.onChange.emit(this._value);
this.onChangeFn(this._value);
if (this.minus(this._value, this._step) < this._min) {
this._downDisabled = true;
}
if (this.plus(this._value, this._step) <= this._max) {
this._upDisabled = false;
}
this._isDownClick = true;
this.setCls();
setTimeout((/**
* @return {?}
*/
() => {
this._isDownClick = false;
this.setCls();
}), 100);
}
}
/**
* @param {?} event
* @return {?}
*/
inputChange(event) {
/** @type {?} */
const value = event;
this._value = value ? +value : 0;
if (this._value < this._min) {
this._value = this._min;
}
if (this._value > this._max) {
this._value = this._max;
}
this._upDisabled = this.plus(this._value, this._step) > this._max ? true : false;
this._downDisabled = this.minus(this._value, this._step) < this._min ? true : false;
this.setCls();
this.onChange.emit(this._value);
this.onChangeFn(this._value);
}
/**
* @return {?}
*/
setCls() {
this.upDisableCls = {
[`${this.prefixCls}-handler-up-disabled`]: this._upDisabled,
[`${this.prefixCls}-handler-active`]: this._isUpClick
};
this.downDisableCls = {
[`${this.prefixCls}-handler-down-disabled`]: this._downDisabled,
[`${this.prefixCls}-handler-active`]: this._isDownClick
};
}
/**
* @return {?}
*/
ngOnChanges() {
if (this._disabled) {
this._downDisabled = true;
this._upDisabled = true;
}
else {
this._upDisabled = this.plus(this._value, this._step) > this._max ? true : false;
this._downDisabled = this.minus(this._value, this._step) < this._min ? true : false;
}
this.setCls();
}
/**
* @param {?} value
* @return {?}
*/
writeValue(value) {
this._value = value;
this.ngOnChanges();
}
/**
* @param {?} fn
* @return {?}
*/
registerOnChange(fn) {
this.onChangeFn = fn;
}
/**
* @param {?} fn
* @return {?}
*/
registerOnTouched(fn) {
this.onTouchFn = fn;
}
/**
* @param {?} num1
* @param {?} num2
* @return {?}
*/
plus(num1, num2) {
if (num1 === undefined || num1 === null || num2 === undefined || num2 === null) {
return;
}
/** @type {?} */
const baseNum = Math.pow(10, Math.max(this.digitLength(num1), this.digitLength(num2)));
return (this.times(num1, baseNum) + this.times(num2, baseNum)) / baseNum;
}
/**
* @param {?} num1
* @param {?} num2
* @return {?}
*/
minus(num1, num2) {
if (num1 === undefined || num1 === null || num2 === undefined || num2 === null) {
return;
}
/** @type {?} */
const baseNum = Math.pow(10, Math.max(this.digitLength(num1), this.digitLength(num2)));
return (this.times(num1, baseNum) - this.times(num2, baseNum)) / baseNum;
}
/**
* @param {?} num
* @return {?}
*/
digitLength(num) {
/** @type {?} */
const eSplit = num.toString().split(/[eE]/);
/** @type {?} */
const len = (eSplit[0].split('.')[1] || '').length - +(eSplit[1] || 0);
return len > 0 ? len : 0;
}
/**
* @param {?} num1
* @param {?} num2
* @return {?}
*/
times(num1, num2) {
/** @type {?} */
const num1Changed = this.floatToFixed(num1);
/** @type {?} */
const num2Changed = this.floatToFixed(num2);
/** @type {?} */
const baseNum = this.digitLength(num1) + this.digitLength(num2);
/** @type {?} */
const leftValue = num1Changed * num2Changed;
return leftValue / Math.pow(10, baseNum);
}
/**
* @param {?} num
* @return {?}
*/
floatToFixed(num) {
if (num.toString().indexOf('e') === -1) {
return Number(num.toString().replace('.', ''));
}
/** @type {?} */
const dLen = this.digitLength(num);
return dLen > 0 ? this.strip(num * Math.pow(10, dLen)) : num;
}
/**
* @param {?} num
* @param {?=} precision
* @return {?}
*/
strip(num, precision = 12) {
return +parseFloat(num.toPrecision(precision));
}
}
StepperComponent.decorators = [
{ type: Component, args: [{
selector: 'Stepper, nzm-stepper',
template: "<div class=\"{{ prefixCls }}-handler-wrap\">\n <span\n role=\"button\"\n class=\"{{ prefixCls }}-handler {{ prefixCls }}-handler-up\"\n style=\"line-height:28px;\"\n [ngClass]=\"upDisableCls\"\n (click)=\"onIncrease()\"\n >\n <Icon [type]=\"'plus'\" [size]=\"'xxs'\"> </Icon>\n </span>\n <span\n role=\"button\"\n class=\"{{ prefixCls }}-handler {{ prefixCls }}-handler-down\"\n style=\"line-height:28px;\"\n [ngClass]=\"downDisableCls\"\n (click)=\"onDecrease()\"\n >\n <Icon [type]=\"'minus'\" [size]=\"'xxs'\"> </Icon>\n </span>\n</div>\n<div class=\"{{ prefixCls }}-input-wrap\">\n <input\n class=\"{{ prefixCls }}-input\"\n style=\"outline:none\"\n [disabled]=\"disabled\"\n [readonly]=\"readOnly\"\n [autocomplete]=\"'off'\"\n [max]=\"max\"\n [min]=\"min\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"inputChange($event)\"\n />\n</div>\n",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef((/**
* @return {?}
*/
() => StepperComponent)),
multi: true
}
]
}] }
];
/** @nocollapse */
StepperComponent.ctorParameters = () => [];
StepperComponent.propDecorators = {
max: [{ type: Input }],
min: [{ type: Input }],
value: [{ type: Input }],
step: [{ type: Input }],
defaultValue: [{ type: Input }],
disabled: [{ type: Input }],
readOnly: [{ type: Input }],
showNumber: [{ type: Input }],
onChange: [{ type: Output }],
clsStepper: [{ type: HostBinding, args: ['class.am-stepper',] }],
clsStpDisabled: [{ type: HostBinding, args: ['class.am-stepper-disabled',] }],
clsShowNum: [{ type: HostBinding, args: ['class.showNumber',] }]
};
if (false) {
/** @type {?} */
StepperComponent.prototype.prefixCls;
/** @type {?} */
StepperComponent.prototype.upDisableCls;
/** @type {?} */
StepperComponent.prototype.downDisableCls;
/** @type {?} */
StepperComponent.prototype.stepperCls;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._max;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._min;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._value;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._step;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._defaultValue;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._disabled;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._readOnly;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._showNumber;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._upDisabled;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._downDisabled;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._isUpClick;
/**
* @type {?}
* @private
*/
StepperComponent.prototype._isDownClick;
/** @type {?} */
StepperComponent.prototype.onChange;
/** @type {?} */
StepperComponent.prototype.clsStepper;
/** @type {?} */
StepperComponent.prototype.clsStpDisabled;
/** @type {?} */
StepperComponent.prototype.clsShowNum;
/**
* @type {?}
* @private
*/
StepperComponent.prototype.onChangeFn;
/**
* @type {?}
* @private
*/
StepperComponent.prototype.onTouchFn;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"ng://ng-zorro-antd-mobile/","sources":["stepper/stepper.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, Input, Output, EventEmitter, OnChanges, HostBinding, forwardRef } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\n\n@Component({\n  selector: 'Stepper, nzm-stepper',\n  templateUrl: './stepper.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => StepperComponent),\n      multi: true\n    }\n  ]\n})\nexport class StepperComponent implements OnChanges, ControlValueAccessor {\n  prefixCls: string = 'am-stepper';\n  upDisableCls: object;\n  downDisableCls: object;\n  stepperCls: object;\n\n  private _max: number = Infinity;\n  private _min: number = -Infinity;\n  private _value: number;\n  private _step: number = 1;\n  private _defaultValue: number;\n  private _disabled: boolean = false;\n  private _readOnly: boolean = false;\n  private _showNumber: boolean = false;\n  private _upDisabled: boolean = false;\n  private _downDisabled: boolean = false;\n  private _isUpClick: boolean = false;\n  private _isDownClick: boolean = false;\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 min(): number {\n    return this._min;\n  }\n  set min(value: number) {\n    this._min = value;\n  }\n  @Input()\n  get value(): number {\n    return this._value;\n  }\n  set value(v: number) {\n    this._value = v;\n  }\n  @Input()\n  set step(value) {\n    this._step = value;\n  }\n  @Input()\n  set defaultValue(value) {\n    if (value) {\n      this._defaultValue = value;\n      this._value = value;\n    }\n  }\n  @Input()\n  get disabled(): boolean {\n    return this._disabled;\n  }\n  set disabled(value: boolean) {\n    if (value) {\n      this._downDisabled = value;\n      this._upDisabled = value;\n    }\n    this._disabled = value;\n    this.clsStpDisabled = value;\n  }\n  @Input()\n  get readOnly(): boolean {\n    return this._readOnly;\n  }\n  set readOnly(value: boolean) {\n    this._readOnly = value;\n  }\n  @Input()\n  set showNumber(value: boolean) {\n    this._showNumber = value;\n    this.clsShowNum = value;\n  }\n  @Output()\n  onChange = new EventEmitter<any>();\n\n  @HostBinding('class.am-stepper')\n  clsStepper: boolean = true;\n  @HostBinding('class.am-stepper-disabled')\n  clsStpDisabled: boolean = this._disabled;\n  @HostBinding('class.showNumber')\n  clsShowNum: boolean = this._showNumber;\n  private onChangeFn: (value: number) => void = () => {};\n  private onTouchFn: (value: number) => void = () => {};\n\n  constructor() {}\n\n  onIncrease() {\n    if (!this._upDisabled) {\n      this._value = this.plus(this._value, this._step);\n      this.onChange.emit(this._value);\n      this.onChangeFn(this._value);\n      if (this.plus(this._value, this._step) > this._max) {\n        this._upDisabled = true;\n      }\n      if (this.minus(this._value, this._step) >= this._min) {\n        this._downDisabled = false;\n      }\n      this._isUpClick = true;\n      this.setCls();\n      setTimeout(() => {\n        this._isUpClick = false;\n        this.setCls();\n      }, 100);\n    }\n  }\n\n  onDecrease() {\n    if (!this._downDisabled) {\n      this._value = this.minus(this._value, this._step);\n      this.onChange.emit(this._value);\n      this.onChangeFn(this._value);\n      if (this.minus(this._value, this._step) < this._min) {\n        this._downDisabled = true;\n      }\n      if (this.plus(this._value, this._step) <= this._max) {\n        this._upDisabled = false;\n      }\n      this._isDownClick = true;\n      this.setCls();\n      setTimeout(() => {\n        this._isDownClick = false;\n        this.setCls();\n      }, 100);\n    }\n  }\n\n  inputChange(event) {\n    const value = event;\n    this._value = value ? +value : 0;\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    this._upDisabled = this.plus(this._value, this._step) > this._max ? true : false;\n    this._downDisabled = this.minus(this._value, this._step) < this._min ? true : false;\n    this.setCls();\n    this.onChange.emit(this._value);\n    this.onChangeFn(this._value);\n  }\n\n  setCls() {\n    this.upDisableCls = {\n      [`${this.prefixCls}-handler-up-disabled`]: this._upDisabled,\n      [`${this.prefixCls}-handler-active`]: this._isUpClick\n    };\n    this.downDisableCls = {\n      [`${this.prefixCls}-handler-down-disabled`]: this._downDisabled,\n      [`${this.prefixCls}-handler-active`]: this._isDownClick\n    };\n  }\n\n  ngOnChanges() {\n    if (this._disabled) {\n      this._downDisabled = true;\n      this._upDisabled = true;\n    } else {\n      this._upDisabled = this.plus(this._value, this._step) > this._max ? true : false;\n      this._downDisabled = this.minus(this._value, this._step) < this._min ? true : false;\n    }\n    this.setCls();\n  }\n\n  writeValue(value: number): void {\n    this._value = value;\n    this.ngOnChanges();\n  }\n\n  registerOnChange(fn: (value: number) => void): void {\n    this.onChangeFn = fn;\n  }\n\n  registerOnTouched(fn: (value: number) => void): void {\n    this.onTouchFn = fn;\n  }\n\n  plus(num1: number, num2: number): number {\n    if (num1 === undefined || num1 === null || num2 === undefined || num2 === null) {\n      return;\n    }\n    const baseNum = Math.pow(10, Math.max(this.digitLength(num1), this.digitLength(num2)));\n    return (this.times(num1, baseNum) + this.times(num2, baseNum)) / baseNum;\n  }\n\n  minus(num1: number, num2: number): number {\n    if (num1 === undefined || num1 === null || num2 === undefined || num2 === null) {\n      return;\n    }\n    const baseNum = Math.pow(10, Math.max(this.digitLength(num1), this.digitLength(num2)));\n    return (this.times(num1, baseNum) - this.times(num2, baseNum)) / baseNum;\n  }\n\n  digitLength(num: number): number {\n    const eSplit = num.toString().split(/[eE]/);\n    const len = (eSplit[0].split('.')[1] || '').length - +(eSplit[1] || 0);\n    return len > 0 ? len : 0;\n  }\n\n  times(num1: number, num2: number): number {\n    const num1Changed = this.floatToFixed(num1);\n    const num2Changed = this.floatToFixed(num2);\n    const baseNum = this.digitLength(num1) + this.digitLength(num2);\n    const leftValue = num1Changed * num2Changed;\n    return leftValue / Math.pow(10, baseNum);\n  }\n\n  floatToFixed(num: number): number {\n    if (num.toString().indexOf('e') === -1) {\n      return Number(num.toString().replace('.', ''));\n    }\n    const dLen = this.digitLength(num);\n    return dLen > 0 ? this.strip(num * Math.pow(10, dLen)) : num;\n  }\n\n  strip(num: number, precision = 12): number {\n    return +parseFloat(num.toPrecision(precision));\n  }\n}\n"]}