@experteam-mx/ngx-input-number
Version:
Angular input number for Experteam apps
181 lines • 24.3 kB
JavaScript
import { Component, Input, ViewChild } from '@angular/core';
import { IMaskDirective } from 'angular-imask';
import * as i0 from "@angular/core";
import * as i1 from "./ngx-input-number.service";
import * as i2 from "@angular/forms";
import * as i3 from "angular-imask";
export class NgxInputNumberComponent {
_ChangeDetectorRef;
_NgxInputNumberService;
inputElement;
iMaskDir;
control;
negative;
autofocus = false;
decimals;
max;
idForLabel = '';
tabIndex;
addClass = 'form-control-sm';
groupSeparator;
radixPoint;
lblKeyInvalid;
lblKeyInvalidRender;
imask;
placeholder = '0';
resetControl = false;
prevValue = '';
validateError = false;
constructor(_ChangeDetectorRef, _NgxInputNumberService) {
this._ChangeDetectorRef = _ChangeDetectorRef;
this._NgxInputNumberService = _NgxInputNumberService;
}
ngAfterViewInit() {
this.iMaskDir.maskRef?.updateValue();
if (this.autofocus) {
setTimeout(() => {
this.inputElement.nativeElement.focus();
});
}
}
render() {
this.control.setValue(String(this.control.value).replace('.', this._NgxInputNumberService.radixPoint));
this._ChangeDetectorRef.detectChanges();
this.lblKeyInvalidRender = this._NgxInputNumberService.lblKeyInvalid;
this.imask = {
mask: Number,
scale: this._NgxInputNumberService.decimals,
thousandsSeparator: this._NgxInputNumberService.groupSeparator,
padFractionalZeros: true,
normalizeZeros: true,
radix: this._NgxInputNumberService.radixPoint,
max: this._NgxInputNumberService.max,
min: this._NgxInputNumberService.negative ? -999999999999999999999999999999999 : 0,
format: (x) => {
if (typeof x !== 'string' && x === null && !this.resetControl) {
this.resetControl = true;
this.inputElement.nativeElement.value = null;
this.iMaskDir.maskRef?.updateValue();
setTimeout(() => {
this.iMaskDir.maskRef?.updateControl();
this.control.setValue(null);
this.resetControl = false;
});
return null;
}
return Number(x).toFixed(this._NgxInputNumberService.decimals);
}
};
if (this.lblKeyInvalid !== undefined) {
this.lblKeyInvalidRender = this.lblKeyInvalid;
}
if (this.negative !== undefined) {
this.imask.min = this.negative ? -999999999999999999999999999999999 : 0;
}
if (this.max !== undefined) {
this.imask.max = this.max;
}
if (this.groupSeparator !== undefined) {
this.imask.thousandsSeparator = this.groupSeparator;
}
if (this.radixPoint !== undefined) {
this.imask.radix = this.radixPoint;
}
if (this.decimals !== undefined) {
this.imask.scale = this.decimals;
}
setTimeout(() => {
if (this.inputElement.nativeElement.value == '' && (this.control.value === null || this.control.value === '' || this.control.value === 0)) {
this.control.setValue('');
}
});
}
ngOnInit() {
this._NgxInputNumberService.getChangeEvent().subscribe((configs) => {
if (configs) {
this.render();
}
});
}
ngOnChanges() {
this.render();
}
onKeydown(e) {
this.prevValue = e.target.value;
}
onBlur() {
this.validateError = false;
}
onFocus() {
setTimeout(() => {
this.validateError = true;
}, 1000);
}
onKeyup(e) {
if (!this.validateError)
return;
let scapeKeys = [
'ArrowLeft',
'ArrowRight',
'ArrowUp',
'ArrowDown',
'Escape',
'Backspace',
'Delete',
'.',
',',
'-',
'Tab',
];
if (e.target.value == ''
&&
!scapeKeys.includes(e.key)) {
this.control.setValue('');
}
if (!scapeKeys.includes(e.key)
&&
this.prevValue === e.target.value
&&
e.key != this.prevValue) {
this.inputElement.nativeElement.classList.add('key-invalid');
setTimeout(() => {
this.inputElement.nativeElement.classList.remove('key-invalid');
}, 1000);
}
}
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NgxInputNumberComponent, deps: [{ token: i0.ChangeDetectorRef }, { token: i1.NgxInputNumberService }], target: i0.ɵɵFactoryTarget.Component });
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: NgxInputNumberComponent, selector: "app-input-number", inputs: { control: "control", negative: "negative", autofocus: "autofocus", decimals: "decimals", max: "max", idForLabel: "idForLabel", tabIndex: "tabIndex", addClass: "addClass", groupSeparator: "groupSeparator", radixPoint: "radixPoint", lblKeyInvalid: "lblKeyInvalid" }, viewQueries: [{ propertyName: "inputElement", first: true, predicate: ["inputElement"], descendants: true }, { propertyName: "iMaskDir", first: true, predicate: IMaskDirective, descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div class=\"position-relative\">\r\n <input\r\n #inputElement\r\n type=\"text\"\r\n class=\"text-end form-control {{ addClass }}\"\r\n [class.is-invalid]=\"control.touched && control.invalid\"\r\n [formControl]=\"control\"\r\n [tabindex]=\"tabIndex\"\r\n [id]=\"idForLabel\"\r\n [imask]=\"imask\"\r\n [unmask]=\"'typed'\"\r\n (keyup)=\"onKeyup($event)\"\r\n (keydown)=\"onKeydown($event)\"\r\n (blur)=\"onBlur()\"\r\n (focus)=\"onFocus()\"\r\n >\r\n <label class=\"lbl-key-invalid position-absolute top-100 end-0 p-2 d-none\" [innerHTML]=\"lblKeyInvalidRender\"></label>\r\n</div>\r\n", styles: ["input.key-invalid{border-color:#dc3545!important;box-shadow:0 0 0 .25rem #dc354540!important}input.key-invalid+.lbl-key-invalid{background-color:#dc3545;color:#fff;display:block!important;z-index:1}\n"], dependencies: [{ 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.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.FormControlDirective, selector: "[formControl]", inputs: ["formControl", "disabled", "ngModel"], outputs: ["ngModelChange"], exportAs: ["ngForm"] }, { kind: "directive", type: i3.IMaskDirective, selector: "[imask]", inputs: ["imask", "unmask", "imaskElement"], outputs: ["accept", "complete"], exportAs: ["imask"] }] });
}
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: NgxInputNumberComponent, decorators: [{
type: Component,
args: [{ selector: 'app-input-number', template: "<div class=\"position-relative\">\r\n <input\r\n #inputElement\r\n type=\"text\"\r\n class=\"text-end form-control {{ addClass }}\"\r\n [class.is-invalid]=\"control.touched && control.invalid\"\r\n [formControl]=\"control\"\r\n [tabindex]=\"tabIndex\"\r\n [id]=\"idForLabel\"\r\n [imask]=\"imask\"\r\n [unmask]=\"'typed'\"\r\n (keyup)=\"onKeyup($event)\"\r\n (keydown)=\"onKeydown($event)\"\r\n (blur)=\"onBlur()\"\r\n (focus)=\"onFocus()\"\r\n >\r\n <label class=\"lbl-key-invalid position-absolute top-100 end-0 p-2 d-none\" [innerHTML]=\"lblKeyInvalidRender\"></label>\r\n</div>\r\n", styles: ["input.key-invalid{border-color:#dc3545!important;box-shadow:0 0 0 .25rem #dc354540!important}input.key-invalid+.lbl-key-invalid{background-color:#dc3545;color:#fff;display:block!important;z-index:1}\n"] }]
}], ctorParameters: () => [{ type: i0.ChangeDetectorRef }, { type: i1.NgxInputNumberService }], propDecorators: { inputElement: [{
type: ViewChild,
args: ['inputElement']
}], iMaskDir: [{
type: ViewChild,
args: [IMaskDirective, { static: false }]
}], control: [{
type: Input
}], negative: [{
type: Input
}], autofocus: [{
type: Input
}], decimals: [{
type: Input
}], max: [{
type: Input
}], idForLabel: [{
type: Input
}], tabIndex: [{
type: Input
}], addClass: [{
type: Input
}], groupSeparator: [{
type: Input
}], radixPoint: [{
type: Input
}], lblKeyInvalid: [{
type: Input
}] } });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ngx-input-number.component.js","sourceRoot":"","sources":["../../../../../projects/experteam-mx/ngx-input-number/src/lib/ngx-input-number.component.ts","../../../../../projects/experteam-mx/ngx-input-number/src/lib/ngx-input-number.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  ChangeDetectorRef,\r\n  Component,\r\n  ElementRef,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  ViewChild\r\n} from '@angular/core'\r\nimport { FormControl } from '@angular/forms'\r\nimport { NgxInputNumberService } from './ngx-input-number.service'\r\nimport { IMaskDirective } from 'angular-imask'\r\nimport { MaskedNumber } from 'imask'\r\n\r\n@Component({\r\n  selector: 'app-input-number',\r\n  templateUrl: './ngx-input-number.component.html',\r\n  styleUrls: ['./ngx-input-number.component.sass']\r\n})\r\nexport class NgxInputNumberComponent implements OnInit, OnChanges, AfterViewInit {\r\n\r\n  @ViewChild('inputElement') inputElement!: ElementRef\r\n  @ViewChild(IMaskDirective, { static: false }) iMaskDir!: IMaskDirective<MaskedNumber>\r\n  @Input() control!: FormControl\r\n  @Input() negative!: any\r\n  @Input() autofocus: any = false\r\n  @Input() decimals: any\r\n  @Input() max: any\r\n  @Input() idForLabel: any = ''\r\n  @Input() tabIndex: any\r\n  @Input() addClass: any = 'form-control-sm'\r\n  @Input() groupSeparator: any\r\n  @Input() radixPoint: any\r\n  @Input() lblKeyInvalid: any\r\n  lblKeyInvalidRender: any\r\n  imask: any\r\n  placeholder = '0'\r\n  resetControl = false\r\n  prevValue: any = ''\r\n  validateError: boolean = false\r\n\r\n  constructor (\r\n    private _ChangeDetectorRef: ChangeDetectorRef,\r\n    private _NgxInputNumberService: NgxInputNumberService,\r\n  ) { }\r\n\r\n  ngAfterViewInit (): void {\r\n    this.iMaskDir.maskRef?.updateValue()\r\n\r\n    if (this.autofocus) {\r\n      setTimeout(() => {\r\n        this.inputElement.nativeElement.focus()\r\n      })\r\n    }\r\n  }\r\n\r\n  render () {\r\n    this.control.setValue(String(this.control.value).replace('.', this._NgxInputNumberService.radixPoint))\r\n\r\n    this._ChangeDetectorRef.detectChanges()\r\n\r\n    this.lblKeyInvalidRender = this._NgxInputNumberService.lblKeyInvalid\r\n\r\n    this.imask = {\r\n      mask: Number,\r\n      scale: this._NgxInputNumberService.decimals,\r\n      thousandsSeparator: this._NgxInputNumberService.groupSeparator,\r\n      padFractionalZeros: true,\r\n      normalizeZeros: true,\r\n      radix: this._NgxInputNumberService.radixPoint,\r\n      max: this._NgxInputNumberService.max,\r\n      min: this._NgxInputNumberService.negative ? -999999999999999999999999999999999 : 0,\r\n      format: (x: any) => {\r\n        if (typeof x !== 'string' && x === null && !this.resetControl) {\r\n          this.resetControl = true\r\n          this.inputElement.nativeElement.value = null\r\n          this.iMaskDir.maskRef?.updateValue()\r\n          setTimeout(\r\n            () => {\r\n              this.iMaskDir.maskRef?.updateControl()\r\n              this.control.setValue(null)\r\n              this.resetControl = false\r\n            }\r\n          )\r\n\r\n          return null\r\n        }\r\n\r\n        return Number(x).toFixed(this._NgxInputNumberService.decimals)\r\n      }\r\n    }\r\n\r\n    if (this.lblKeyInvalid !== undefined) {\r\n      this.lblKeyInvalidRender = this.lblKeyInvalid\r\n    }\r\n\r\n    if (this.negative !== undefined) {\r\n      this.imask.min = this.negative ? -999999999999999999999999999999999 : 0\r\n    }\r\n\r\n    if (this.max !== undefined) {\r\n      this.imask.max = this.max\r\n    }\r\n\r\n    if (this.groupSeparator !== undefined) {\r\n      this.imask.thousandsSeparator = this.groupSeparator\r\n    }\r\n    if (this.radixPoint !== undefined) {\r\n      this.imask.radix = this.radixPoint\r\n    }\r\n\r\n    if (this.decimals !== undefined) {\r\n      this.imask.scale = this.decimals\r\n    }\r\n\r\n    setTimeout(\r\n      () => {\r\n        if (this.inputElement.nativeElement.value == '' && (this.control.value === null || this.control.value === '' || this.control.value === 0)) {\r\n          this.control.setValue('')\r\n        }\r\n      }\r\n    )\r\n  }\r\n\r\n  ngOnInit (): void {\r\n    this._NgxInputNumberService.getChangeEvent().subscribe(\r\n      (configs) => {\r\n        if (configs) {\r\n          this.render()\r\n        }\r\n      }\r\n    )\r\n  }\r\n\r\n  ngOnChanges (): void {\r\n    this.render()\r\n  }\r\n\r\n  onKeydown (e: any) {\r\n    this.prevValue = e.target.value\r\n  }\r\n\r\n  onBlur () {\r\n    this.validateError = false\r\n  }\r\n\r\n  onFocus () {\r\n    setTimeout(\r\n      () => {\r\n        this.validateError = true\r\n      },\r\n      1000\r\n    )\r\n  }\r\n\r\n  onKeyup (e: any) {\r\n    if (!this.validateError) return\r\n\r\n    let scapeKeys: any[] = [\r\n      'ArrowLeft',\r\n      'ArrowRight',\r\n      'ArrowUp',\r\n      'ArrowDown',\r\n      'Escape',\r\n      'Backspace',\r\n      'Delete',\r\n      '.',\r\n      ',',\r\n      '-',\r\n      'Tab',\r\n    ]\r\n\r\n    if(\r\n      e.target.value == ''\r\n      &&\r\n      !scapeKeys.includes(e.key)\r\n    ){\r\n      this.control.setValue('')\r\n    }\r\n\r\n    if(\r\n      !scapeKeys.includes(e.key)\r\n      &&\r\n      this.prevValue === e.target.value\r\n      &&\r\n      e.key != this.prevValue\r\n    ){\r\n      this.inputElement.nativeElement.classList.add('key-invalid')\r\n      setTimeout(\r\n        () => {\r\n          this.inputElement.nativeElement.classList.remove('key-invalid')\r\n        },\r\n        1000\r\n      )\r\n    }\r\n  }\r\n}\r\n","<div class=\"position-relative\">\r\n    <input\r\n        #inputElement\r\n        type=\"text\"\r\n        class=\"text-end form-control {{ addClass }}\"\r\n        [class.is-invalid]=\"control.touched && control.invalid\"\r\n        [formControl]=\"control\"\r\n        [tabindex]=\"tabIndex\"\r\n        [id]=\"idForLabel\"\r\n        [imask]=\"imask\"\r\n        [unmask]=\"'typed'\"\r\n        (keyup)=\"onKeyup($event)\"\r\n        (keydown)=\"onKeydown($event)\"\r\n        (blur)=\"onBlur()\"\r\n        (focus)=\"onFocus()\"\r\n    >\r\n    <label class=\"lbl-key-invalid position-absolute top-100 end-0 p-2 d-none\" [innerHTML]=\"lblKeyInvalidRender\"></label>\r\n</div>\r\n"]}