@asi-ngtools/lib
Version:
This project is a little components library, simple to use, which will help you to simplify your project.
296 lines (295 loc) • 23.3 kB
JavaScript
/**
* @fileoverview added by tsickle
* @suppress {checkTypes,extraRequire,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { DefaultControlValueAccessor } from './../common/default-control-value-accessor';
import { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';
import { Component, forwardRef, Input, ElementRef, ViewChild, Renderer2 } from '@angular/core';
import { debounceTime } from 'rxjs/operators';
import { Subject } from 'rxjs';
var AsiInputNumberComponent = /** @class */ (function (_super) {
tslib_1.__extends(AsiInputNumberComponent, _super);
function AsiInputNumberComponent(renderer, elementRef) {
var _this = _super.call(this) || this;
_this.renderer = renderer;
_this.elementRef = elementRef;
/**
* Label position
*/
_this.labelPosition = 'top';
/**
* Increment value when click on + or -
*/
_this.step = 1;
/**
* Allow you to disable the input
*/
_this.disableInput = false;
/**
* Allow you to hide the action button
*/
_this.hideAction = false;
/**
* Delay before value change
*/
_this.delay = 0;
/**
* Number regex
*/
_this.pattern = new RegExp('^-?[0-9]*[,\.]{0,1}[0-9]{0,2}$');
/**
* pattern used to managed typed value, if this pattern is true the 'value' will be the last valide one
*/
_this.toleratePattern = new RegExp('^[0-9]*[,\.]{1}$');
/**
* use a non decimal pattern '^-?[0-9]*$'
*/
_this.noDecimal = false;
_this.inputControl = new FormControl();
_this.outputDelayValue = new Subject();
return _this;
}
/**
* @return {?}
*/
AsiInputNumberComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
var _this = this;
if (this.noDecimal) {
this.pattern = new RegExp('^-?[0-9]*$');
}
this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);
this.inputControl.valueChanges.subscribe(function (value) {
if (value === '' || value == null) {
_this.outputDelayValue.next(null);
_this.oldValideValue = null;
return;
}
/** @type {?} */
var tolerateValue = !_this.noDecimal && _this.toleratePattern.test(value);
/** @type {?} */
var minusPossible = (_this.min == null || _this.min < 0) && value.length === 1 && value.indexOf('-') !== -1;
value = value.replace(',', '\.');
if (_this.pattern.test(value)) {
if (!isNaN(Number(value))) {
// The value is a number
if (!(_this.max != null && value > _this.max)
&& !(_this.min != null && value < _this.min) && !tolerateValue) {
_this.outputDelayValue.next(Number(value));
if (Number(value) !== 0) {
_this.oldValideValue = value;
}
else {
_this.oldValideValue = 0;
}
return;
}
}
else if (minusPossible) {
_this.outputDelayValue.next(null);
_this.oldValideValue = value;
return;
}
}
if (!tolerateValue && !minusPossible) {
_this.inputControl.setValue(_this.oldValideValue, { emitEvent: false });
}
else {
_this.oldValideValue = value;
_this.inputControl.setValue(value, { emitEvent: false });
}
});
this.outputDelayValue.pipe(debounceTime(this.delay)).subscribe(function (value) {
_this.value = value;
});
if (this.stepIncrease == null) {
this.stepIncrease = this.step;
}
if (this.stepDecrease == null) {
this.stepDecrease = this.step;
}
};
/**
* @return {?}
*/
AsiInputNumberComponent.prototype.increase = /**
* @return {?}
*/
function () {
if (this.inputControl.value == null || this.inputControl.value === '') {
this.inputControl.setValue(this.stepIncrease + '');
}
else {
/** @type {?} */
var number = Number(this.inputControl.value);
this.inputControl.setValue(number + this.stepIncrease + '');
}
};
/**
* @return {?}
*/
AsiInputNumberComponent.prototype.decrease = /**
* @return {?}
*/
function () {
if (this.inputControl.value == null || this.inputControl.value === '') {
this.inputControl.setValue(-this.stepDecrease + '');
}
else {
/** @type {?} */
var number = Number(this.inputControl.value);
this.inputControl.setValue(number - this.stepDecrease + '');
}
};
/**
* @param {?} value
* @return {?}
*/
AsiInputNumberComponent.prototype.writeValue = /**
* @param {?} value
* @return {?}
*/
function (value) {
if (value != null && this.pattern.test(value)) {
this.inputControl.setValue(value, { emitEvent: false });
this._value = value;
}
else {
this.inputControl.setValue(null, { emitEvent: false });
this._value = null;
}
this.oldValideValue = this._value;
};
AsiInputNumberComponent.decorators = [
{ type: Component, args: [{
selector: 'asi-input-number',
host: { 'class': 'asi-component asi-input-number' },
template: "<label class=\"input-label\" *ngIf=\"label != null\">{{label | translate}}</label>\n<div class=\"number-select\">\n <asi-button *ngIf=\"!hideAction\" class=\"minus\" size=\"mini\" [disabled]=\"disabled\" type=\"button\" (click)=\"decrease()\">-</asi-button>\n <input #input [attr.disabled]=\"disabled || disableInput ? '' : null\"\n [attr.id]=\"id\" [attr.name]=\"name\" type=\"text\" class=\"asi-focus-error\" [formControl]=\"inputControl\" />\n <asi-button *ngIf=\"!hideAction\" class=\"plus\" size=\"mini\" [disabled]=\"disabled\" type=\"button\" (click)=\"increase()\">+</asi-button>\n</div>\n",
providers: [
{
provide: NG_VALUE_ACCESSOR,
useExisting: forwardRef(function () { return AsiInputNumberComponent; }),
multi: true
}
]
}] }
];
/** @nocollapse */
AsiInputNumberComponent.ctorParameters = function () { return [
{ type: Renderer2 },
{ type: ElementRef }
]; };
AsiInputNumberComponent.propDecorators = {
id: [{ type: Input }],
name: [{ type: Input }],
label: [{ type: Input }],
labelPosition: [{ type: Input }],
step: [{ type: Input }],
stepIncrease: [{ type: Input }],
stepDecrease: [{ type: Input }],
disableInput: [{ type: Input }],
hideAction: [{ type: Input }],
min: [{ type: Input }],
max: [{ type: Input }],
delay: [{ type: Input }],
pattern: [{ type: Input }],
toleratePattern: [{ type: Input }],
noDecimal: [{ type: Input }],
inputElm: [{ type: ViewChild, args: ['input',] }]
};
return AsiInputNumberComponent;
}(DefaultControlValueAccessor));
export { AsiInputNumberComponent };
if (false) {
/**
* html id
* @type {?}
*/
AsiInputNumberComponent.prototype.id;
/**
* html name
* @type {?}
*/
AsiInputNumberComponent.prototype.name;
/**
* Label to display (is translated)
* @type {?}
*/
AsiInputNumberComponent.prototype.label;
/**
* Label position
* @type {?}
*/
AsiInputNumberComponent.prototype.labelPosition;
/**
* Increment value when click on + or -
* @type {?}
*/
AsiInputNumberComponent.prototype.step;
/**
* Increment value when click on +
* @type {?}
*/
AsiInputNumberComponent.prototype.stepIncrease;
/**
* Decrement value when click on -
* @type {?}
*/
AsiInputNumberComponent.prototype.stepDecrease;
/**
* Allow you to disable the input
* @type {?}
*/
AsiInputNumberComponent.prototype.disableInput;
/**
* Allow you to hide the action button
* @type {?}
*/
AsiInputNumberComponent.prototype.hideAction;
/**
* Min value
* @type {?}
*/
AsiInputNumberComponent.prototype.min;
/**
* Max value
* @type {?}
*/
AsiInputNumberComponent.prototype.max;
/**
* Delay before value change
* @type {?}
*/
AsiInputNumberComponent.prototype.delay;
/**
* Number regex
* @type {?}
*/
AsiInputNumberComponent.prototype.pattern;
/**
* pattern used to managed typed value, if this pattern is true the 'value' will be the last valide one
* @type {?}
*/
AsiInputNumberComponent.prototype.toleratePattern;
/**
* use a non decimal pattern '^-?[0-9]*$'
* @type {?}
*/
AsiInputNumberComponent.prototype.noDecimal;
/** @type {?} */
AsiInputNumberComponent.prototype.inputElm;
/** @type {?} */
AsiInputNumberComponent.prototype.inputControl;
/** @type {?} */
AsiInputNumberComponent.prototype.oldValideValue;
/** @type {?} */
AsiInputNumberComponent.prototype.outputDelayValue;
/** @type {?} */
AsiInputNumberComponent.prototype.renderer;
/** @type {?} */
AsiInputNumberComponent.prototype.elementRef;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"asi-input-number.component.js","sourceRoot":"ng://@asi-ngtools/lib/","sources":["lib/components/asi-input-number/asi-input-number.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { DefaultControlValueAccessor } from './../common/default-control-value-accessor';\nimport { NG_VALUE_ACCESSOR, FormControl } from '@angular/forms';\nimport { Component, forwardRef, Input, ElementRef, OnInit, ViewChild, Renderer2 } from '@angular/core';\nimport { debounceTime } from 'rxjs/operators';\nimport { Subject } from 'rxjs';\n\n\n@Component({\n  selector: 'asi-input-number',\n  host: { 'class': 'asi-component asi-input-number' },\n  templateUrl: 'asi-input-number.component.html',\n  providers: [\n    {\n      provide: NG_VALUE_ACCESSOR,\n      useExisting: forwardRef(() => AsiInputNumberComponent),\n      multi: true\n    }\n  ]\n})\nexport class AsiInputNumberComponent extends DefaultControlValueAccessor implements OnInit {\n\n  /** html id */\n  @Input() id: string;\n  /** html name */\n  @Input() name: string;\n\n  /** Label to display (is translated) */\n  @Input() label: string;\n  /** Label position */\n  @Input() labelPosition: 'top' | 'left' | 'right' | 'bottom' | 'bottom-center' | 'top-center' = 'top';\n\n  /** Increment value when click on + or - */\n  @Input() step = 1;\n\n  /** Increment value when click on + */\n  @Input() stepIncrease: number;\n\n  /** Decrement value when click on - */\n  @Input() stepDecrease: number;\n\n  /** Allow you to disable the input */\n  @Input() disableInput = false;\n\n  /** Allow you to hide the action button */\n  @Input() hideAction = false;\n\n  /** Min value */\n  @Input() min: number;\n\n  /** Max value */\n  @Input() max: number;\n\n  /** Delay before value change */\n  @Input() delay = 0;\n\n  /** Number regex */\n  @Input() pattern = new RegExp('^-?[0-9]*[,\\.]{0,1}[0-9]{0,2}$');\n\n  /** pattern used to managed typed value, if this pattern is true the 'value' will be the last valide one */\n  @Input() toleratePattern = new RegExp('^[0-9]*[,\\.]{1}$');\n\n  /** use a non decimal pattern '^-?[0-9]*$' */\n  @Input() noDecimal = false;\n\n  @ViewChild('input') inputElm: ElementRef;\n\n  inputControl = new FormControl();\n  private oldValideValue: any;\n\n  outputDelayValue = new Subject<number>();\n\n  constructor(private renderer: Renderer2,\n    private elementRef: ElementRef) {\n    super();\n  }\n\n  ngOnInit() {\n    if (this.noDecimal) {\n      this.pattern = new RegExp('^-?[0-9]*$');\n    }\n\n    this.renderer.addClass(this.elementRef.nativeElement, 'label-' + this.labelPosition);\n\n    this.inputControl.valueChanges.subscribe((value) => {\n      if (value === '' || value == null) {\n        this.outputDelayValue.next(null);\n        this.oldValideValue = null;\n        return;\n      }\n\n      const tolerateValue = !this.noDecimal && this.toleratePattern.test(value);\n      // If the value is a minus and is authorized\n      const minusPossible = (this.min == null || this.min < 0) && value.length === 1 && value.indexOf('-') !== -1;\n\n      value = value.replace(',', '\\.');\n\n      if (this.pattern.test(value)) {\n        if (!isNaN(Number(value))) {\n          // The value is a number\n          if (!(this.max != null && value > this.max)\n            && !(this.min != null && value < this.min) && !tolerateValue) {\n            this.outputDelayValue.next(Number(value));\n            if (Number(value) !== 0) {\n              this.oldValideValue = value;\n            } else {\n              this.oldValideValue = 0;\n            }\n            return;\n          }\n        } else if (minusPossible) {\n          this.outputDelayValue.next(null);\n          this.oldValideValue = value;\n          return;\n        }\n      }\n\n      if (!tolerateValue && !minusPossible) {\n        this.inputControl.setValue(this.oldValideValue, { emitEvent: false });\n      } else {\n        this.oldValideValue = value;\n        this.inputControl.setValue(value, { emitEvent: false });\n      }\n    });\n\n    this.outputDelayValue.pipe(debounceTime(this.delay)).subscribe((value) => {\n      this.value = value;\n    });\n\n    if (this.stepIncrease == null) {\n      this.stepIncrease = this.step\n    }\n\n    if (this.stepDecrease == null) {\n      this.stepDecrease = this.step;\n    }\n  }\n\n  increase() {\n    if (this.inputControl.value == null || this.inputControl.value === '') {\n      this.inputControl.setValue(this.stepIncrease + '');\n    } else {\n      const number = Number(this.inputControl.value);\n      this.inputControl.setValue(number + this.stepIncrease + '');\n    }\n  }\n\n  decrease() {\n    if (this.inputControl.value == null || this.inputControl.value === '') {\n      this.inputControl.setValue(-this.stepDecrease + '');\n    } else {\n      const number = Number(this.inputControl.value);\n      this.inputControl.setValue(number - this.stepDecrease + '');\n    }\n  }\n\n  writeValue(value: any) {\n    if (value != null && this.pattern.test(value)) {\n      this.inputControl.setValue(value, { emitEvent: false });\n      this._value = value;\n    } else {\n      this.inputControl.setValue(null, { emitEvent: false });\n      this._value = null;\n    }\n    this.oldValideValue = this._value;\n  }\n}\n"]}