UNPKG

@experteam-mx/ngx-input-number

Version:

Angular input number for Experteam apps

181 lines 24.1 kB
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 String(x); } }; 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.11", 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.11", 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.11", 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 String(x)\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"]}