ng-zorro-antd-mobile
Version:
An enterprise-class mobile UI components based on Ant Design and Angular
288 lines • 39 kB
JavaScript
import { Component, Input, Output, EventEmitter, HostBinding, forwardRef } from '@angular/core';
import { NG_VALUE_ACCESSOR } from '@angular/forms';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@angular/forms";
import * as i3 from "ng-zorro-antd-mobile/icon";
export class StepperComponent {
get max() {
return this._max;
}
set max(value) {
this._max = value;
}
get min() {
return this._min;
}
set min(value) {
this._min = value;
}
get value() {
return this._value;
}
set value(v) {
this._value = v;
}
set step(value) {
this._step = value;
}
set defaultValue(value) {
if (value) {
this._defaultValue = value;
this._value = value;
}
}
get disabled() {
return this._disabled;
}
set disabled(value) {
if (value) {
this._downDisabled = value;
this._upDisabled = value;
}
this._disabled = value;
this.clsStpDisabled = value;
}
get readOnly() {
return this._readOnly;
}
set readOnly(value) {
this._readOnly = value;
}
set showNumber(value) {
this._showNumber = value;
this.clsShowNum = value;
}
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._inputLock = false;
this.onChange = new EventEmitter();
this.clsStepper = true;
this.clsStpDisabled = this._disabled;
this.clsShowNum = this._showNumber;
this.onChangeFn = () => { };
this.onTouchFn = () => { };
}
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(() => {
this._isUpClick = false;
this.setCls();
}, 100);
}
}
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(() => {
this._isDownClick = false;
this.setCls();
}, 100);
}
}
compositionStart() {
this._inputLock = true;
}
compositionEnd() {
this._inputLock = false;
}
inputChange(event) {
// 'compositionend' is earlier than ngModelChange, Therefore use timer to make ngModelChange runs after 'compositionend' event
setTimeout(() => {
if (this._inputLock) {
return;
}
const allowDecimal = this._step % 1 !== 0;
const allowNegative = this._min < 0;
let decimalFlag = false;
let negativeFlag = false;
if (!event)
event = '';
let value = event.toString().replace(/\D/g, (match, index, str) => {
if (allowDecimal && match === '.' && !decimalFlag) {
decimalFlag = true;
return '.';
}
if (allowNegative && match === '-' && !negativeFlag) {
negativeFlag = true;
return '-';
}
return '';
});
if (negativeFlag && value.indexOf('-') > 0) {
value = value.replace(/-/g, '');
}
if (!isNaN(value)) {
this._value = +value;
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);
}, 0);
}
inputBlur() {
let value = +this._value;
if (+this._value === -0) {
value = 0;
}
if (this._value < this._min) {
value = this._min;
}
else if (this._value > this._max) {
value = this._max;
}
const len = this._step.toString().length - this._step.toString().indexOf('.') - 1;
value = +value.toFixed(len);
if (value !== this._value) {
this._value = value;
this.onChange.emit(this._value);
this.onChangeFn(this._value);
}
}
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
};
}
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();
}
writeValue(value) {
this._value = value;
this.ngOnChanges();
}
registerOnChange(fn) {
this.onChangeFn = fn;
}
registerOnTouched(fn) {
this.onTouchFn = fn;
}
plus(num1, num2) {
if (num1 === undefined || num1 === null || num2 === undefined || num2 === null) {
return;
}
const baseNum = Math.pow(10, Math.max(this.digitLength(num1), this.digitLength(num2)));
return (this.times(num1, baseNum) + this.times(num2, baseNum)) / baseNum;
}
minus(num1, num2) {
if (num1 === undefined || num1 === null || num2 === undefined || num2 === null) {
return;
}
const baseNum = Math.pow(10, Math.max(this.digitLength(num1), this.digitLength(num2)));
return (this.times(num1, baseNum) - this.times(num2, baseNum)) / baseNum;
}
digitLength(num) {
const eSplit = num.toString().split(/[eE]/);
const len = (eSplit[0].split('.')[1] || '').length - +(eSplit[1] || 0);
return len > 0 ? len : 0;
}
times(num1, num2) {
const num1Changed = this.floatToFixed(num1);
const num2Changed = this.floatToFixed(num2);
const baseNum = this.digitLength(num1) + this.digitLength(num2);
const leftValue = num1Changed * num2Changed;
return leftValue / Math.pow(10, baseNum);
}
floatToFixed(num) {
if (num.toString().indexOf('e') === -1) {
return Number(num.toString().replace('.', ''));
}
const dLen = this.digitLength(num);
return dLen > 0 ? this.strip(num * Math.pow(10, dLen)) : num;
}
strip(num, precision = 12) {
return +parseFloat(num.toPrecision(precision));
}
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: StepperComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.8", type: StepperComponent, selector: "Stepper, nzm-stepper", inputs: { max: "max", min: "min", value: "value", step: "step", defaultValue: "defaultValue", disabled: "disabled", readOnly: "readOnly", showNumber: "showNumber" }, outputs: { onChange: "onChange" }, host: { properties: { "class.am-stepper": "this.clsStepper", "class.am-stepper-disabled": "this.clsStpDisabled", "class.showNumber": "this.clsShowNum" } }, providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => StepperComponent),
multi: true
}
], usesOnChanges: true, ngImport: i0, 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 type=\"number\"\n pattern=\"\\-?\\d+(\\.\\d+)?\"\n style=\"outline:none\"\n class=\"{{ prefixCls }}-input\"\n [disabled]=\"disabled\"\n [readonly]=\"readOnly\"\n [autocomplete]=\"'off'\"\n [max]=\"max\"\n [min]=\"min\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"inputChange($event)\"\n (compositionstart)=\"compositionStart()\"\n (compositionend)=\"compositionEnd()\"\n (blur)=\"inputBlur()\"\n />\n</div>\n", dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NumberValueAccessor, selector: "input[type=number][formControlName],input[type=number][formControl],input[type=number][ngModel]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.PatternValidator, selector: "[pattern][formControlName],[pattern][formControl],[pattern][ngModel]", inputs: ["pattern"] }, { kind: "directive", type: i2.MinValidator, selector: "input[type=number][min][formControlName],input[type=number][min][formControl],input[type=number][min][ngModel]", inputs: ["min"] }, { kind: "directive", type: i2.MaxValidator, selector: "input[type=number][max][formControlName],input[type=number][max][formControl],input[type=number][max][ngModel]", inputs: ["max"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i3.IconComponent, selector: "Icon, nzm-icon", inputs: ["color", "type", "src", "size"] }] }); }
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.8", ngImport: i0, type: StepperComponent, decorators: [{
type: Component,
args: [{ selector: 'Stepper, nzm-stepper', providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(() => StepperComponent),
multi: true
}
], 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 type=\"number\"\n pattern=\"\\-?\\d+(\\.\\d+)?\"\n style=\"outline:none\"\n class=\"{{ prefixCls }}-input\"\n [disabled]=\"disabled\"\n [readonly]=\"readOnly\"\n [autocomplete]=\"'off'\"\n [max]=\"max\"\n [min]=\"min\"\n [(ngModel)]=\"value\"\n (ngModelChange)=\"inputChange($event)\"\n (compositionstart)=\"compositionStart()\"\n (compositionend)=\"compositionEnd()\"\n (blur)=\"inputBlur()\"\n />\n</div>\n" }]
}], ctorParameters: () => [], 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']
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"stepper.component.js","sourceRoot":"","sources":["../../../components/stepper/stepper.component.ts","../../../components/stepper/stepper.component.html"],"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  private _inputLock = 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();\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  compositionStart() {\n    this._inputLock = true;\n  }\n\n  compositionEnd() {\n    this._inputLock = false;\n  }\n\n  inputChange(event) {\n    // 'compositionend' is earlier than ngModelChange, Therefore use timer to make ngModelChange runs after 'compositionend' event\n    setTimeout(() => {\n      if (this._inputLock) {\n        return;\n      }\n\n      const allowDecimal = this._step % 1 !== 0;\n      const allowNegative = this._min < 0;\n      let decimalFlag = false;\n      let negativeFlag = false;\n      if (!event) event = '';\n      let value = event.toString().replace(/\\D/g, (match, index, str) => {\n        if (allowDecimal && match === '.' && !decimalFlag) {\n          decimalFlag = true;\n          return '.';\n        }\n        if (allowNegative && match === '-' && !negativeFlag) {\n          negativeFlag = true;\n          return '-';\n        }\n        return '';\n      });\n      if (negativeFlag && value.indexOf('-') > 0) {\n        value = value.replace(/-/g, '');\n      }\n\n      if (!isNaN(value)) {\n        this._value = +value;\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\n      this.setCls();\n      this.onChange.emit(this._value);\n      this.onChangeFn(this._value);\n    }, 0);\n  }\n\n  inputBlur() {\n    let value = +this._value;\n    if (+this._value === -0) {\n      value = 0;\n    }\n    if (this._value < this._min) {\n      value = this._min;\n    } else if (this._value > this._max) {\n      value = this._max;\n    }\n\n    const len = this._step.toString().length - this._step.toString().indexOf('.') - 1;\n    value = +value.toFixed(len);\n\n    if (value !== this._value) {\n      this._value = value;\n      this.onChange.emit(this._value);\n      this.onChangeFn(this._value);\n    }\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","<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    type=\"number\"\n    pattern=\"\\-?\\d+(\\.\\d+)?\"\n    style=\"outline:none\"\n    class=\"{{ prefixCls }}-input\"\n    [disabled]=\"disabled\"\n    [readonly]=\"readOnly\"\n    [autocomplete]=\"'off'\"\n    [max]=\"max\"\n    [min]=\"min\"\n    [(ngModel)]=\"value\"\n    (ngModelChange)=\"inputChange($event)\"\n    (compositionstart)=\"compositionStart()\"\n    (compositionend)=\"compositionEnd()\"\n    (blur)=\"inputBlur()\"\n  />\n</div>\n"]}