ngx-sumax-erp-components 1.0.45 → 1.0.46
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/esm2022/lib/date-picker/date-picker.component.mjs +57 -7
- package/esm2022/lib/date-time-picker/date-time-picker.component.mjs +59 -19
- package/esm2022/lib/date-time-picker-editable/date-time-picker-editable.component.mjs +63 -15
- package/esm2022/lib/dialog-ag-grid-search/dialog-ag-grid-search.component.mjs +26 -1
- package/esm2022/lib/error-message/error-message.component.mjs +1 -1
- package/esm2022/lib/input-number/input-number.component.mjs +101 -1
- package/esm2022/lib/input-text/input-text.component.mjs +131 -1
- package/esm2022/lib/ng-select-multiple/ng-select-multiple.component.mjs +183 -2
- package/esm2022/lib/ng-select-simple/ng-select-simple.component.mjs +191 -1
- package/esm2022/lib/sc-ag-grid/sc-ag-grid-customizable/sc-ag-grid-customizable.component.mjs +3 -3
- package/esm2022/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.component.mjs +11 -1
- package/esm2022/lib/text-area/text-area.component.mjs +91 -1
- package/esm2022/lib/tooltip-message/tooltip-message.component.mjs +1 -1
- package/fesm2022/ngx-sumax-erp-components.mjs +906 -42
- package/fesm2022/ngx-sumax-erp-components.mjs.map +1 -1
- package/lib/date-picker/date-picker.component.d.ts +78 -10
- package/lib/date-time-picker/date-time-picker.component.d.ts +71 -23
- package/lib/date-time-picker-editable/date-time-picker-editable.component.d.ts +71 -15
- package/lib/dialog-ag-grid-search/dialog-ag-grid-search.component.d.ts +25 -0
- package/lib/error-message/error-message.component.d.ts +25 -0
- package/lib/input-number/input-number.component.d.ts +120 -0
- package/lib/input-text/input-text.component.d.ts +150 -0
- package/lib/ng-select-multiple/ng-select-multiple.component.d.ts +219 -0
- package/lib/ng-select-simple/ng-select-simple.component.d.ts +215 -0
- package/lib/sc-ag-grid/cell-render/sc-cell-render-config.d.ts +1 -1
- package/lib/sc-ag-grid/sc-ag-grid-customizable/sc-ag-grid-customizable.component.d.ts +2 -2
- package/lib/sc-ag-grid/sc-ag-grid-pagination/sc-ag-grid-pagination.component.d.ts +15 -0
- package/lib/text-area/text-area.component.d.ts +110 -0
- package/lib/tooltip-message/tooltip-message.component.d.ts +25 -0
- package/package.json +1 -1
|
@@ -15,31 +15,161 @@ export class InputTextComponent {
|
|
|
15
15
|
this.messageUtilService = messageUtilService;
|
|
16
16
|
this.inputTextService = inputTextService;
|
|
17
17
|
this._render = _render;
|
|
18
|
+
/**
|
|
19
|
+
* @description Formato de texto (M: mayúsculas, m: minúsculas, null: sin formato)
|
|
20
|
+
* @default "M"
|
|
21
|
+
* @type string
|
|
22
|
+
*/
|
|
18
23
|
this.format = "M";
|
|
24
|
+
/**
|
|
25
|
+
* @description Tipo de input (texto, contraseña, email)
|
|
26
|
+
* @default "text"
|
|
27
|
+
* @type Type
|
|
28
|
+
*/
|
|
19
29
|
this.type = "text";
|
|
30
|
+
/**
|
|
31
|
+
* @description Controla la visualización del texto superior (label)
|
|
32
|
+
* @default true
|
|
33
|
+
* @type boolean
|
|
34
|
+
*/
|
|
20
35
|
this.showLabel = true;
|
|
36
|
+
/**
|
|
37
|
+
* @description Texto a mostrar como etiqueta del campo
|
|
38
|
+
* @default ""
|
|
39
|
+
* @type any
|
|
40
|
+
*/
|
|
21
41
|
this.label = "";
|
|
42
|
+
/**
|
|
43
|
+
* @description Habilita el botón para activar el campo
|
|
44
|
+
* @default false
|
|
45
|
+
* @type boolean
|
|
46
|
+
*/
|
|
22
47
|
this.btnEnable = false;
|
|
48
|
+
/**
|
|
49
|
+
* @description Valor para el atributo autocomplete del input
|
|
50
|
+
* @default "no-autocomplete-input-text"
|
|
51
|
+
* @type string
|
|
52
|
+
*/
|
|
23
53
|
this.autocomplete = "no-autocomplete-input-text";
|
|
54
|
+
/**
|
|
55
|
+
* @description Aplica estilo negrita al texto
|
|
56
|
+
* @default false
|
|
57
|
+
* @type boolean
|
|
58
|
+
*/
|
|
24
59
|
this.bold = false;
|
|
60
|
+
/**
|
|
61
|
+
* @description Máscara para el input (formato específico)
|
|
62
|
+
* @default null
|
|
63
|
+
* @type string | null
|
|
64
|
+
*/
|
|
25
65
|
this.inputMask = null;
|
|
66
|
+
/**
|
|
67
|
+
* @description Muestra la máscara mientras se escribe
|
|
68
|
+
* @default false
|
|
69
|
+
* @type boolean
|
|
70
|
+
*/
|
|
26
71
|
this.showMaskTyped = false;
|
|
72
|
+
/**
|
|
73
|
+
* @description Indica si el campo es obligatorio
|
|
74
|
+
* @default false
|
|
75
|
+
* @type boolean
|
|
76
|
+
*/
|
|
27
77
|
this.required = false;
|
|
78
|
+
/**
|
|
79
|
+
* @description Alinea el texto a la derecha
|
|
80
|
+
* @default false
|
|
81
|
+
* @type boolean
|
|
82
|
+
*/
|
|
28
83
|
this.textRight = false;
|
|
84
|
+
/**
|
|
85
|
+
* @description Deshabilita el control
|
|
86
|
+
* @default false
|
|
87
|
+
* @type boolean
|
|
88
|
+
*/
|
|
29
89
|
this.disabled = false;
|
|
90
|
+
/**
|
|
91
|
+
* @description Establece el control como solo lectura
|
|
92
|
+
* @default false
|
|
93
|
+
* @type boolean
|
|
94
|
+
*/
|
|
30
95
|
this.readonly = false;
|
|
96
|
+
/**
|
|
97
|
+
* @description Muestra mensajes de validación
|
|
98
|
+
* @default false
|
|
99
|
+
* @type boolean
|
|
100
|
+
*/
|
|
31
101
|
this.validatorMessage = false;
|
|
102
|
+
/**
|
|
103
|
+
* @description Muestra mensajes de ayuda como tooltips
|
|
104
|
+
* @default true
|
|
105
|
+
* @type boolean
|
|
106
|
+
*/
|
|
32
107
|
this.tooltipMessage = true;
|
|
108
|
+
/**
|
|
109
|
+
* @description Longitud máxima permitida para el texto
|
|
110
|
+
* @default null
|
|
111
|
+
* @type any
|
|
112
|
+
*/
|
|
33
113
|
this.maxLength = null;
|
|
114
|
+
/**
|
|
115
|
+
* @description Indica si el formulario ha sido enviado para mostrar validaciones
|
|
116
|
+
* @default true
|
|
117
|
+
* @type boolean
|
|
118
|
+
*/
|
|
34
119
|
this.submitted = true;
|
|
120
|
+
/**
|
|
121
|
+
* @description Muestra alertas de validación
|
|
122
|
+
* @default false
|
|
123
|
+
* @type boolean
|
|
124
|
+
*/
|
|
35
125
|
this.validatorAlert = false;
|
|
126
|
+
/**
|
|
127
|
+
* @description Clases CSS adicionales para el componente
|
|
128
|
+
* @default ""
|
|
129
|
+
* @type string
|
|
130
|
+
*/
|
|
36
131
|
this.setNgClass = "";
|
|
132
|
+
/**
|
|
133
|
+
* @description Patrones de validación para el campo
|
|
134
|
+
* @default ""
|
|
135
|
+
* @type any
|
|
136
|
+
*/
|
|
37
137
|
this.patterns = "";
|
|
138
|
+
/**
|
|
139
|
+
* @description Texto de placeholder para el input
|
|
140
|
+
* @default ""
|
|
141
|
+
* @type string
|
|
142
|
+
*/
|
|
38
143
|
this.placeholder = "";
|
|
144
|
+
/**
|
|
145
|
+
* @description Habilita información adicional para la etiqueta
|
|
146
|
+
* @default false
|
|
147
|
+
* @type boolean
|
|
148
|
+
*/
|
|
39
149
|
this.labelInfo = false;
|
|
150
|
+
/**
|
|
151
|
+
* @description Texto informativo adicional para la etiqueta
|
|
152
|
+
* @default ""
|
|
153
|
+
* @type string
|
|
154
|
+
*/
|
|
40
155
|
this.textLabelInfo = "";
|
|
156
|
+
/**
|
|
157
|
+
* @description Habilita la limpieza y reemplazo de caracteres especiales
|
|
158
|
+
* @default false
|
|
159
|
+
* @type boolean
|
|
160
|
+
*/
|
|
41
161
|
this.controlCharClearReplace = false;
|
|
162
|
+
/**
|
|
163
|
+
* @description Mapa de caracteres a reemplazar
|
|
164
|
+
* @default {}
|
|
165
|
+
* @type {[key:string]: string}
|
|
166
|
+
*/
|
|
42
167
|
this.replaceRegex = {};
|
|
168
|
+
/**
|
|
169
|
+
* @description Expresión regular para limpiar caracteres
|
|
170
|
+
* @default ""
|
|
171
|
+
* @type string
|
|
172
|
+
*/
|
|
43
173
|
this.clearRegex = "";
|
|
44
174
|
this.onNext = new EventEmitter();
|
|
45
175
|
this.onBack = new EventEmitter();
|
|
@@ -342,4 +472,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
342
472
|
type: ViewChild,
|
|
343
473
|
args: ["inputText"]
|
|
344
474
|
}] } });
|
|
345
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sumax-erp-component/src/lib/input-text/input-text.component.ts","../../../../../projects/ngx-sumax-erp-component/src/lib/input-text/input-text.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  forwardRef,\r\n} from \"@angular/core\";\r\nimport { AbstractControl, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors } from \"@angular/forms\";\r\nimport { InputTextService } from \"./input-text.service\";\r\nimport { MessageUtilService } from \"../utils/message-util.service\";\r\nimport { SharedComponentsUtil } from \"../utils/SharedComponentsUtil\";\r\n\r\nexport type Type = \"text\" | \"password\" | \"email\";\r\n\r\n@Component({\r\n  selector: \"input-text\",\r\n  templateUrl: \"./input-text.component.html\",\r\n  styleUrls: [\"./input-text.component.scss\"],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputTextComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useExisting: forwardRef(() => InputTextComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputTextComponent implements OnInit, OnChanges, AfterViewInit, ControlValueAccessor {\r\n  @Input() format: string = \"M\";\r\n  @Input() type: Type = \"text\";\r\n  @Input() showLabel: boolean = true;\r\n  @Input() label: any = \"\";\r\n  @Input() btnEnable: boolean = false;\r\n  @Input() autocomplete: string = \"no-autocomplete-input-text\";\r\n  @Input() bold: boolean = false;\r\n  @Input() inputMask: string | null = null;\r\n  @Input() showMaskTyped: boolean = false;\r\n  @Input() next: any;\r\n  @Input() nextIsDisable: any;\r\n  @Input() back: any;\r\n  @Input() backIsDisable: any;\r\n  @Input() required: boolean = false;\r\n  @Input() textRight: boolean = false;\r\n  @Input() disabled: boolean = false;\r\n  @Input() readonly: boolean = false;\r\n  @Input() validatorMessage: boolean = false;\r\n  @Input() tooltipMessage: boolean = true;\r\n  @Input() maxLength: any = null;\r\n  @Input() submitted: boolean = true;\r\n  @Input() validatorAlert: boolean = false;\r\n  @Input() setNgClass: string = \"\";\r\n  @Input() patterns: any = \"\";\r\n  @Input() placeholder: string = \"\";\r\n  @Input() labelInfo: boolean = false;\r\n  @Input() textLabelInfo: string = \"\";\r\n  @Input() controlCharClearReplace: boolean = false;\r\n  @Input() replaceRegex: {[key:string]: string} = {};\r\n  @Input() clearRegex: string = \"\";\r\n  @Output() onNext: EventEmitter<any> = new EventEmitter();\r\n  @Output() onBack: EventEmitter<any> = new EventEmitter();\r\n  @Output() change: EventEmitter<any> = new EventEmitter();\r\n  @Output() blur: EventEmitter<any> = new EventEmitter();\r\n  @Output() onfocus: EventEmitter<any> = new EventEmitter();\r\n  @Output() onchange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onfocusout: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild(\"inputText\") _inputText!: ElementRef<HTMLInputElement>;\r\n\r\n  controls: AbstractControl | null = null;\r\n  value: any;\r\n  sharedComponentsUtil = new SharedComponentsUtil();\r\n  _initValue = false;\r\n\r\n  showPassword = false;\r\n\r\n  constructor(\r\n    private messageUtilService: MessageUtilService,\r\n    private inputTextService: InputTextService,\r\n    private _render: Renderer2\r\n  ) {\r\n    this.format = this.inputTextService.getFormat();\r\n    this.showLabel = this.inputTextService.getShowLabel();\r\n    this.btnEnable = this.inputTextService.getBtnEnable();\r\n    this.bold = this.inputTextService.getBold();\r\n    this.textRight = this.inputTextService.getTextRight();\r\n    this.validatorMessage = this.inputTextService.getValidatorMessage();\r\n    this.tooltipMessage = this.inputTextService.getTooltipMessage();\r\n    this.submitted = this.inputTextService.getSubmitted();\r\n    this.validatorAlert = this.inputTextService.getValidatorAlert();\r\n    this.controlCharClearReplace = this.inputTextService.getControlCharClearReplace();\r\n    this.replaceRegex = this.inputTextService.getReplaceRegex();\r\n    this.clearRegex = this.inputTextService.getClearRegex();\r\n  }\r\n\r\n  ngOnChanges (changes: SimpleChanges): void {\r\n    if (changes[\"submitted\"]) {\r\n      if (this.controls != null && changes[\"submitted\"].currentValue) {\r\n        this.controls.markAsDirty();\r\n        this.controls.markAsTouched();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit () { }\r\n\r\n  ngAfterViewInit (): void { }\r\n\r\n  get nativeElement (): HTMLInputElement {\r\n    return this._inputText.nativeElement;\r\n  }\r\n\r\n  onChange = (_: any) => { };\r\n  onValidationChange = () => { };\r\n  onTouch = () => { };\r\n  focus = () => {\r\n    this.nativeElement?.focus();\r\n    this.nativeElement?.select();\r\n  };\r\n\r\n  onBlur (value: string): void {\r\n    this.onTouch();\r\n    this.blur.emit(this.formatInput(value));\r\n  }\r\n\r\n  onFocus (value: string): void {\r\n    if (value.trim() !== \"\") {\r\n      this.nativeElement?.select();\r\n      this.onfocus.emit(value.trim());\r\n    }\r\n  }\r\n\r\n  onInput (value: string): void {\r\n    const newValue = this.formatInput(value);\r\n\r\n    this.onTouch();\r\n    this.onChange(newValue);\r\n    this.onValidationChange();\r\n    this.onchange.emit(newValue);\r\n    this.change.emit(newValue);\r\n  }\r\n\r\n  writeValue (value: any): void {\r\n    if (value) {\r\n      this.value = this.formatInput(value);\r\n      if (this.controls) {\r\n        this._render.setProperty(this.controls, \"value\", this.value);\r\n      }\r\n    } else {\r\n      this.value = null;\r\n    }\r\n  }\r\n\r\n  registerOnChange (fn: (v: any) => void): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched (fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  setDisabledState (isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  validate (control: AbstractControl): ValidationErrors | any {\r\n    this.controls = control;\r\n    if (!this._initValue) {\r\n      if (this.value) {\r\n        this._render.setProperty(this.controls, \"value\", this.value);\r\n      }\r\n      this._initValue = true;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  registerOnValidatorChange?(fn: () => void): void {\r\n    this.onValidationChange = fn;\r\n  }\r\n\r\n  formatInput (value: string): string {\r\n    if (value !== null && value.toString().trim() !== \"\") {\r\n      let newValue = value.toString().trim();\r\n      if (this.format === \"M\") newValue = newValue.toUpperCase();\r\n      if (this.format === \"m\") newValue = newValue.toLowerCase();\r\n\r\n      if (this.controlCharClearReplace) {\r\n        newValue = this.clearCharacters(newValue);\r\n        newValue = this.replaceCharacters(newValue);\r\n      }\r\n      return newValue;\r\n    }\r\n\r\n    return value;\r\n  }\r\n\r\n  enterKeyUp () {\r\n    if (!this.disabled) {\r\n      this.writeValue(this.value);\r\n      let validator = this.sharedComponentsUtil.stopByValidator(this.controls, this.validatorAlert, this.label);\r\n      if (validator.error) {\r\n        this.messageUtilService.getMessageError(\"000046\", \"Error\", validator.message);\r\n        return;\r\n      }\r\n    }\r\n    if (this.next != undefined) {\r\n      if (this.next.disabled || this.next.readonly) {\r\n        if (this.nextIsDisable != undefined) {\r\n          this.nextIsDisable.focus();\r\n        }\r\n      } else {\r\n        this.next.focus();\r\n      }\r\n    } else {\r\n      if (this.nextIsDisable != undefined) {\r\n        this.nextIsDisable.focus();\r\n      } else {\r\n        this.onNext.emit();\r\n      }\r\n    }\r\n  }\r\n\r\n  arrowUpKeyUp () {\r\n    if (!this.disabled) {\r\n      let validator = this.sharedComponentsUtil.stopByValidator(this.controls, this.validatorAlert, this.label);\r\n      if (validator.error) {\r\n        this.messageUtilService.getMessageError(\"000046\", \"Error\", validator.message);\r\n        return;\r\n      }\r\n    }\r\n    if (this.back != undefined) {\r\n      if (this.back.disabled || this.back.readonly) {\r\n        if (this.backIsDisable != undefined) {\r\n          this.backIsDisable.focus();\r\n        }\r\n      } else {\r\n        this.back.focus();\r\n      }\r\n    } else {\r\n      if (this.backIsDisable != undefined) {\r\n        this.backIsDisable.focus();\r\n      } else {\r\n        this.onBack.emit();\r\n      }\r\n    }\r\n  }\r\n\r\n  onFocusOut (evt: any) {\r\n    this.onfocusout.emit(evt);\r\n    if (this.btnEnable) {\r\n      this.disabled = true;\r\n    }\r\n  }\r\n\r\n  clickEnable () {\r\n    this.disabled = false;\r\n    this.readonly = false;\r\n    setTimeout(() => {\r\n      this.focus();\r\n    }, 150);\r\n  }\r\n\r\n  clickShowPassword (): void {\r\n    this.showPassword = !this.showPassword;\r\n  }\r\n\r\n  clearCharacters(text: string): string {\r\n    if (!text) return text;\r\n    const regexPattern = `[${this.clearRegex}]`;\r\n    let formattedString = text.replace(new RegExp(regexPattern, 'g'), '');\r\n    return formattedString;\r\n  }\r\n\r\n  replaceCharacters(text: string): string {\r\n    if (!text) return text;\r\n    const regexReplace = Object.keys(this.replaceRegex).join('');\r\n    const regexPattern = `[${regexReplace}]`;\r\n    return text.replace(new RegExp(regexPattern, 'g'), (char) => this.replaceRegex[char] || char);\r\n  }\r\n}\r\n\r\n","<label *ngIf=\"label != null && label != '' && showLabel\" class=\"d-flex sumax-label mb-0 p-0\"\r\n  ><span [title]=\"label\" style=\"white-space: nowrap; overflow: hidden; text-overflow: ellipsis\">{{ label }}</span>\r\n  <span *ngIf=\"required\" class=\"ml-1\" [class.text-danger]=\"controls?.errors != null\"> *</span>\r\n  <span *ngIf=\"labelInfo\">\r\n    <i class=\"fa fa-exclamation-circle text-info ms-2\" [matTooltip]=\"textLabelInfo\" matTooltipClass=\"bg-info\"></i>\r\n  </span>\r\n</label>\r\n<div\r\n  [class.input-icon]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n  [class.right]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\">\r\n  <div class=\"d-flex\">\r\n    <div class=\"w-100 position-relative\">\r\n      <tooltip-message\r\n        [label]=\"label\"\r\n        [controls]=\"controls\"\r\n        [validatorMessage]=\"validatorMessage\"\r\n        [submitted]=\"submitted\"\r\n        [tooltipMessage]=\"tooltipMessage\"></tooltip-message>\r\n\r\n      <input\r\n        *ngIf=\"inputMask != null\"\r\n        #inputText\r\n        type=\"text\"\r\n        class=\"form-control form-control-sm\"\r\n        [class.text-uppercase]=\"format === 'M'\"\r\n        [class.text-lowercase]=\"format === 'm'\"\r\n        [class.text-end]=\"textRight\"\r\n        [attr.autocomplete]=\"autocomplete\"\r\n        [placeholder]=\"placeholder\"\r\n        [class.is-invalid]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n        [disabled]=\"disabled\"\r\n        [readonly]=\"readonly\"\r\n        [mask]=\"inputMask\"\r\n        [showMaskTyped]=\"showMaskTyped\"\r\n        [patterns]=\"patterns\"\r\n        (blur)=\"onBlur($any($event.target).value)\"\r\n        (input)=\"onInput($any($event.target).value)\"\r\n        (focusout)=\"onFocusOut($any($event.target).value)\"\r\n        (focus)=\"onFocus($any($event.target).value)\"\r\n        (keyup.enter)=\"enterKeyUp()\"\r\n        (keyup.ArrowUp)=\"arrowUpKeyUp()\"\r\n        [ngClass]=\"setNgClass\"\r\n        [(ngModel)]=\"value\"\r\n        [class.bold]=\"bold\" />\r\n      <input\r\n        *ngIf=\"inputMask == null\"\r\n        #inputText\r\n        [type]=\"type === 'password' ? (showPassword ? 'text' : 'password') : type\"\r\n        class=\"form-control form-control-sm\"\r\n        [class.text-uppercase]=\"format === 'M'\"\r\n        [class.text-lowercase]=\"format === 'm'\"\r\n        [class.text-end]=\"textRight\"\r\n        [attr.autocomplete]=\"autocomplete\"\r\n        [placeholder]=\"placeholder\"\r\n        [class.is-invalid]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n        [disabled]=\"disabled\"\r\n        [readonly]=\"readonly\"\r\n        [attr.maxLength]=\"maxLength\"\r\n        (blur)=\"onBlur($any($event.target).value)\"\r\n        (input)=\"onInput($any($event.target).value)\"\r\n        (focusout)=\"onFocusOut($any($event.target).value)\"\r\n        (focus)=\"onFocus($any($event.target).value)\"\r\n        (keyup.enter)=\"enterKeyUp()\"\r\n        (keyup.ArrowUp)=\"arrowUpKeyUp()\"\r\n        [ngClass]=\"setNgClass\"\r\n        [(ngModel)]=\"value\"\r\n        [class.bold]=\"bold\" />\r\n    </div>\r\n    <div class=\"bd-highlight\" *ngIf=\"type === 'password'\">\r\n      <button type=\"button\" class=\"btn btn-info p-0 rounded-0 h-100\" (click)=\"clickShowPassword()\">\r\n        <i\r\n          [class.fa-eye]=\"showPassword\"\r\n          [class.fa-eye-slash]=\"!showPassword\"\r\n          class=\"far px-1\"\r\n          [matTooltip]=\"!showPassword ? 'Mostrar' : 'Ocultar'\"\r\n          matTooltipClass=\"bg-info\"></i>\r\n      </button>\r\n    </div>\r\n    <div class=\"bd-highlight\" *ngIf=\"btnEnable\">\r\n      <button type=\"button\" class=\"btn btn-info p-0 rounded-0 h-100\" (click)=\"clickEnable()\">\r\n        <i class=\"fa fa-check text-white px-1\" [matTooltip]=\"'Habilitar'\" matTooltipClass=\"bg-info\"></i>\r\n      </button>\r\n    </div>\r\n    <ng-content select=\"[more-buttons]\"></ng-content>\r\n  </div>\r\n</div>\r\n<error-message\r\n  [label]=\"label\"\r\n  [controls]=\"controls\"\r\n  [validatorMessage]=\"validatorMessage\"\r\n  [submitted]=\"submitted\"\r\n  [tooltipMessage]=\"tooltipMessage\"></error-message>\r\n"]}
|
|
475
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-text.component.js","sourceRoot":"","sources":["../../../../../projects/ngx-sumax-erp-component/src/lib/input-text/input-text.component.ts","../../../../../projects/ngx-sumax-erp-component/src/lib/input-text/input-text.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEL,SAAS,EAET,YAAY,EACZ,KAAK,EAGL,MAAM,EAGN,SAAS,EACT,UAAU,GACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAyC,aAAa,EAAE,iBAAiB,EAAoB,MAAM,gBAAgB,CAAC;AAG3H,OAAO,EAAE,oBAAoB,EAAE,MAAM,+BAA+B,CAAC;;;;;;;;;;AAqBrE,MAAM,OAAO,kBAAkB;IAmO7B,YACU,kBAAsC,EACtC,gBAAkC,EAClC,OAAkB;QAFlB,uBAAkB,GAAlB,kBAAkB,CAAoB;QACtC,qBAAgB,GAAhB,gBAAgB,CAAkB;QAClC,YAAO,GAAP,OAAO,CAAW;QArO5B;;;;WAIG;QACM,WAAM,GAAW,GAAG,CAAC;QAE9B;;;;WAIG;QACM,SAAI,GAAS,MAAM,CAAC;QAE7B;;;;WAIG;QACM,cAAS,GAAY,IAAI,CAAC;QAEnC;;;;WAIG;QACM,UAAK,GAAQ,EAAE,CAAC;QAEzB;;;;WAIG;QACM,cAAS,GAAY,KAAK,CAAC;QAEpC;;;;WAIG;QACM,iBAAY,GAAW,4BAA4B,CAAC;QAE7D;;;;WAIG;QACM,SAAI,GAAY,KAAK,CAAC;QAE/B;;;;WAIG;QACM,cAAS,GAAkB,IAAI,CAAC;QAEzC;;;;WAIG;QACM,kBAAa,GAAY,KAAK,CAAC;QA8BxC;;;;WAIG;QACM,aAAQ,GAAY,KAAK,CAAC;QAEnC;;;;WAIG;QACM,cAAS,GAAY,KAAK,CAAC;QAEpC;;;;WAIG;QACM,aAAQ,GAAY,KAAK,CAAC;QAEnC;;;;WAIG;QACM,aAAQ,GAAY,KAAK,CAAC;QAEnC;;;;WAIG;QACM,qBAAgB,GAAY,KAAK,CAAC;QAE3C;;;;WAIG;QACM,mBAAc,GAAY,IAAI,CAAC;QAExC;;;;WAIG;QACM,cAAS,GAAQ,IAAI,CAAC;QAE/B;;;;WAIG;QACM,cAAS,GAAY,IAAI,CAAC;QAEnC;;;;WAIG;QACM,mBAAc,GAAY,KAAK,CAAC;QAEzC;;;;WAIG;QACM,eAAU,GAAW,EAAE,CAAC;QAEjC;;;;WAIG;QACM,aAAQ,GAAQ,EAAE,CAAC;QAE5B;;;;WAIG;QACM,gBAAW,GAAW,EAAE,CAAC;QAElC;;;;WAIG;QACM,cAAS,GAAY,KAAK,CAAC;QAEpC;;;;WAIG;QACM,kBAAa,GAAW,EAAE,CAAC;QAEpC;;;;WAIG;QACM,4BAAuB,GAAY,KAAK,CAAC;QAElD;;;;WAIG;QACM,iBAAY,GAA2B,EAAE,CAAC;QAEnD;;;;WAIG;QACM,eAAU,GAAW,EAAE,CAAC;QACvB,WAAM,GAAsB,IAAI,YAAY,EAAE,CAAC;QAC/C,WAAM,GAAsB,IAAI,YAAY,EAAE,CAAC;QAC/C,WAAM,GAAsB,IAAI,YAAY,EAAE,CAAC;QAC/C,SAAI,GAAsB,IAAI,YAAY,EAAE,CAAC;QAC7C,YAAO,GAAsB,IAAI,YAAY,EAAE,CAAC;QAChD,aAAQ,GAAsB,IAAI,YAAY,EAAE,CAAC;QACjD,eAAU,GAAsB,IAAI,YAAY,EAAE,CAAC;QAI7D,aAAQ,GAA2B,IAAI,CAAC;QAExC,yBAAoB,GAAG,IAAI,oBAAoB,EAAE,CAAC;QAClD,eAAU,GAAG,KAAK,CAAC;QAEnB,iBAAY,GAAG,KAAK,CAAC;QAsCrB,aAAQ,GAAG,CAAC,CAAM,EAAE,EAAE,GAAG,CAAC,CAAC;QAC3B,uBAAkB,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC;QAC/B,YAAO,GAAG,GAAG,EAAE,GAAG,CAAC,CAAC;QACpB,UAAK,GAAG,GAAG,EAAE;YACX,IAAI,CAAC,aAAa,EAAE,KAAK,EAAE,CAAC;YAC5B,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC;QAC/B,CAAC,CAAC;QArCA,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,SAAS,EAAE,CAAC;QAChD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC;QACtD,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC;QACtD,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,gBAAgB,CAAC,OAAO,EAAE,CAAC;QAC5C,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC;QACtD,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,gBAAgB,CAAC,mBAAmB,EAAE,CAAC;QACpE,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;QAChE,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,gBAAgB,CAAC,YAAY,EAAE,CAAC;QACtD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,gBAAgB,CAAC,iBAAiB,EAAE,CAAC;QAChE,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC,gBAAgB,CAAC,0BAA0B,EAAE,CAAC;QAClF,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,gBAAgB,CAAC,eAAe,EAAE,CAAC;QAC5D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,gBAAgB,CAAC,aAAa,EAAE,CAAC;IAC1D,CAAC;IAED,WAAW,CAAE,OAAsB;QACjC,IAAI,OAAO,CAAC,WAAW,CAAC,EAAE,CAAC;YACzB,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,IAAI,OAAO,CAAC,WAAW,CAAC,CAAC,YAAY,EAAE,CAAC;gBAC/D,IAAI,CAAC,QAAQ,CAAC,WAAW,EAAE,CAAC;gBAC5B,IAAI,CAAC,QAAQ,CAAC,aAAa,EAAE,CAAC;YAChC,CAAC;QACH,CAAC;IACH,CAAC;IAED,QAAQ,KAAM,CAAC;IAEf,eAAe,KAAY,CAAC;IAE5B,IAAI,aAAa;QACf,OAAO,IAAI,CAAC,UAAU,CAAC,aAAa,CAAC;IACvC,CAAC;IAUD,MAAM,CAAE,KAAa;QACnB,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC,CAAC;IAC1C,CAAC;IAED,OAAO,CAAE,KAAa;QACpB,IAAI,KAAK,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;YACxB,IAAI,CAAC,aAAa,EAAE,MAAM,EAAE,CAAC;YAC7B,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,KAAK,CAAC,IAAI,EAAE,CAAC,CAAC;QAClC,CAAC;IACH,CAAC;IAED,OAAO,CAAE,KAAa;QACpB,MAAM,QAAQ,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;QAEzC,IAAI,CAAC,OAAO,EAAE,CAAC;QACf,IAAI,CAAC,QAAQ,CAAC,QAAQ,CAAC,CAAC;QACxB,IAAI,CAAC,kBAAkB,EAAE,CAAC;QAC1B,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;QAC7B,IAAI,CAAC,MAAM,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC7B,CAAC;IAED,UAAU,CAAE,KAAU;QACpB,IAAI,KAAK,EAAE,CAAC;YACV,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,CAAC;YACrC,IAAI,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAClB,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/D,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC;QACpB,CAAC;IACH,CAAC;IAED,gBAAgB,CAAE,EAAoB;QACpC,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IAED,iBAAiB,CAAE,EAAO;QACxB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IAED,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,UAAU,CAAC;IAC7B,CAAC;IAED,QAAQ,CAAE,OAAwB;QAChC,IAAI,CAAC,QAAQ,GAAG,OAAO,CAAC;QACxB,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE,CAAC;YACrB,IAAI,IAAI,CAAC,KAAK,EAAE,CAAC;gBACf,IAAI,CAAC,OAAO,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,EAAE,OAAO,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YAC/D,CAAC;YACD,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC;QACzB,CAAC;QACD,OAAO,IAAI,CAAC;IACd,CAAC;IAED,yBAAyB,CAAE,EAAc;QACvC,IAAI,CAAC,kBAAkB,GAAG,EAAE,CAAC;IAC/B,CAAC;IAED,WAAW,CAAE,KAAa;QACxB,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC;YACrD,IAAI,QAAQ,GAAG,KAAK,CAAC,QAAQ,EAAE,CAAC,IAAI,EAAE,CAAC;YACvC,IAAI,IAAI,CAAC,MAAM,KAAK,GAAG;gBAAE,QAAQ,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;YAC3D,IAAI,IAAI,CAAC,MAAM,KAAK,GAAG;gBAAE,QAAQ,GAAG,QAAQ,CAAC,WAAW,EAAE,CAAC;YAE3D,IAAI,IAAI,CAAC,uBAAuB,EAAE,CAAC;gBACjC,QAAQ,GAAG,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC,CAAC;gBAC1C,QAAQ,GAAG,IAAI,CAAC,iBAAiB,CAAC,QAAQ,CAAC,CAAC;YAC9C,CAAC;YACD,OAAO,QAAQ,CAAC;QAClB,CAAC;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED,UAAU;QACR,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;YAC5B,IAAI,SAAS,GAAG,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1G,IAAI,SAAS,CAAC,KAAK,EAAE,CAAC;gBACpB,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,QAAQ,EAAE,OAAO,EAAE,SAAS,CAAC,OAAO,CAAC,CAAC;gBAC9E,OAAO;YACT,CAAC;QACH,CAAC;QACD,IAAI,IAAI,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC;YAC3B,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAC7C,IAAI,IAAI,CAAC,aAAa,IAAI,SAAS,EAAE,CAAC;oBACpC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAC7B,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YACpB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,aAAa,IAAI,SAAS,EAAE,CAAC;gBACpC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAC7B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YACrB,CAAC;QACH,CAAC;IACH,CAAC;IAED,YAAY;QACV,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;YACnB,IAAI,SAAS,GAAG,IAAI,CAAC,oBAAoB,CAAC,eAAe,CAAC,IAAI,CAAC,QAAQ,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,KAAK,CAAC,CAAC;YAC1G,IAAI,SAAS,CAAC,KAAK,EAAE,CAAC;gBACpB,IAAI,CAAC,kBAAkB,CAAC,eAAe,CAAC,QAAQ,EAAE,OAAO,EAAE,SAAS,CAAC,OAAO,CAAC,CAAC;gBAC9E,OAAO;YACT,CAAC;QACH,CAAC;QACD,IAAI,IAAI,CAAC,IAAI,IAAI,SAAS,EAAE,CAAC;YAC3B,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE,CAAC;gBAC7C,IAAI,IAAI,CAAC,aAAa,IAAI,SAAS,EAAE,CAAC;oBACpC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;gBAC7B,CAAC;YACH,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,IAAI,CAAC,KAAK,EAAE,CAAC;YACpB,CAAC;QACH,CAAC;aAAM,CAAC;YACN,IAAI,IAAI,CAAC,aAAa,IAAI,SAAS,EAAE,CAAC;gBACpC,IAAI,CAAC,aAAa,CAAC,KAAK,EAAE,CAAC;YAC7B,CAAC;iBAAM,CAAC;gBACN,IAAI,CAAC,MAAM,CAAC,IAAI,EAAE,CAAC;YACrB,CAAC;QACH,CAAC;IACH,CAAC;IAED,UAAU,CAAE,GAAQ;QAClB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;QAC1B,IAAI,IAAI,CAAC,SAAS,EAAE,CAAC;YACnB,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC;QACvB,CAAC;IACH,CAAC;IAED,WAAW;QACT,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,IAAI,CAAC,QAAQ,GAAG,KAAK,CAAC;QACtB,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,KAAK,EAAE,CAAC;QACf,CAAC,EAAE,GAAG,CAAC,CAAC;IACV,CAAC;IAED,iBAAiB;QACf,IAAI,CAAC,YAAY,GAAG,CAAC,IAAI,CAAC,YAAY,CAAC;IACzC,CAAC;IAED,eAAe,CAAC,IAAY;QAC1B,IAAI,CAAC,IAAI;YAAE,OAAO,IAAI,CAAC;QACvB,MAAM,YAAY,GAAG,IAAI,IAAI,CAAC,UAAU,GAAG,CAAC;QAC5C,IAAI,eAAe,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,YAAY,EAAE,GAAG,CAAC,EAAE,EAAE,CAAC,CAAC;QACtE,OAAO,eAAe,CAAC;IACzB,CAAC;IAED,iBAAiB,CAAC,IAAY;QAC5B,IAAI,CAAC,IAAI;YAAE,OAAO,IAAI,CAAC;QACvB,MAAM,YAAY,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,YAAY,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC;QAC7D,MAAM,YAAY,GAAG,IAAI,YAAY,GAAG,CAAC;QACzC,OAAO,IAAI,CAAC,OAAO,CAAC,IAAI,MAAM,CAAC,YAAY,EAAE,GAAG,CAAC,EAAE,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,IAAI,IAAI,CAAC,CAAC;IAChG,CAAC;+GA7aU,kBAAkB;mGAAlB,kBAAkB,08BAblB;YACT;gBACE,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;gBACjD,KAAK,EAAE,IAAI;aACZ;YACD;gBACE,OAAO,EAAE,aAAa;gBACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,kBAAkB,CAAC;gBACjD,KAAK,EAAE,IAAI;aACZ;SACF,wJCpCH,uvIA4FA;;4FDtDa,kBAAkB;kBAjB9B,SAAS;+BACE,YAAY,aAGX;wBACT;4BACE,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;4BACjD,KAAK,EAAE,IAAI;yBACZ;wBACD;4BACE,OAAO,EAAE,aAAa;4BACtB,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,mBAAmB,CAAC;4BACjD,KAAK,EAAE,IAAI;yBACZ;qBACF;8IAQQ,MAAM;sBAAd,KAAK;gBAOG,IAAI;sBAAZ,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,KAAK;sBAAb,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,YAAY;sBAApB,KAAK;gBAOG,IAAI;sBAAZ,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,aAAa;sBAArB,KAAK;gBAOG,IAAI;sBAAZ,KAAK;gBAOG,aAAa;sBAArB,KAAK;gBAOG,IAAI;sBAAZ,KAAK;gBAOG,aAAa;sBAArB,KAAK;gBAOG,QAAQ;sBAAhB,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,QAAQ;sBAAhB,KAAK;gBAOG,QAAQ;sBAAhB,KAAK;gBAOG,gBAAgB;sBAAxB,KAAK;gBAOG,cAAc;sBAAtB,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,cAAc;sBAAtB,KAAK;gBAOG,UAAU;sBAAlB,KAAK;gBAOG,QAAQ;sBAAhB,KAAK;gBAOG,WAAW;sBAAnB,KAAK;gBAOG,SAAS;sBAAjB,KAAK;gBAOG,aAAa;sBAArB,KAAK;gBAOG,uBAAuB;sBAA/B,KAAK;gBAOG,YAAY;sBAApB,KAAK;gBAOG,UAAU;sBAAlB,KAAK;gBACI,MAAM;sBAAf,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,MAAM;sBAAf,MAAM;gBACG,IAAI;sBAAb,MAAM;gBACG,OAAO;sBAAhB,MAAM;gBACG,QAAQ;sBAAjB,MAAM;gBACG,UAAU;sBAAnB,MAAM;gBAEiB,UAAU;sBAAjC,SAAS;uBAAC,WAAW","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  ElementRef,\r\n  EventEmitter,\r\n  Input,\r\n  OnChanges,\r\n  OnInit,\r\n  Output,\r\n  Renderer2,\r\n  SimpleChanges,\r\n  ViewChild,\r\n  forwardRef,\r\n} from \"@angular/core\";\r\nimport { AbstractControl, ControlValueAccessor, NG_VALIDATORS, NG_VALUE_ACCESSOR, ValidationErrors } from \"@angular/forms\";\r\nimport { InputTextService } from \"./input-text.service\";\r\nimport { MessageUtilService } from \"../utils/message-util.service\";\r\nimport { SharedComponentsUtil } from \"../utils/SharedComponentsUtil\";\r\n\r\nexport type Type = \"text\" | \"password\" | \"email\";\r\n\r\n@Component({\r\n  selector: \"input-text\",\r\n  templateUrl: \"./input-text.component.html\",\r\n  styleUrls: [\"./input-text.component.scss\"],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      useExisting: forwardRef(() => InputTextComponent),\r\n      multi: true,\r\n    },\r\n    {\r\n      provide: NG_VALIDATORS,\r\n      useExisting: forwardRef(() => InputTextComponent),\r\n      multi: true,\r\n    },\r\n  ],\r\n})\r\nexport class InputTextComponent implements OnInit, OnChanges, AfterViewInit, ControlValueAccessor {\r\n  /**\r\n   * @description Formato de texto (M: mayúsculas, m: minúsculas, null: sin formato)\r\n   * @default \"M\"\r\n   * @type string\r\n   */\r\n  @Input() format: string = \"M\";\r\n  \r\n  /**\r\n   * @description Tipo de input (texto, contraseña, email)\r\n   * @default \"text\"\r\n   * @type Type\r\n   */\r\n  @Input() type: Type = \"text\";\r\n  \r\n  /**\r\n   * @description Controla la visualización del texto superior (label)\r\n   * @default true\r\n   * @type boolean\r\n   */\r\n  @Input() showLabel: boolean = true;\r\n  \r\n  /**\r\n   * @description Texto a mostrar como etiqueta del campo\r\n   * @default \"\"\r\n   * @type any\r\n   */\r\n  @Input() label: any = \"\";\r\n  \r\n  /**\r\n   * @description Habilita el botón para activar el campo\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() btnEnable: boolean = false;\r\n  \r\n  /**\r\n   * @description Valor para el atributo autocomplete del input\r\n   * @default \"no-autocomplete-input-text\"\r\n   * @type string\r\n   */\r\n  @Input() autocomplete: string = \"no-autocomplete-input-text\";\r\n  \r\n  /**\r\n   * @description Aplica estilo negrita al texto\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() bold: boolean = false;\r\n  \r\n  /**\r\n   * @description Máscara para el input (formato específico)\r\n   * @default null\r\n   * @type string | null\r\n   */\r\n  @Input() inputMask: string | null = null;\r\n  \r\n  /**\r\n   * @description Muestra la máscara mientras se escribe\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() showMaskTyped: boolean = false;\r\n  \r\n  /**\r\n   * @description Referencia al siguiente control para navegación\r\n   * @default undefined\r\n   * @type any\r\n   */\r\n  @Input() next: any;\r\n  \r\n  /**\r\n   * @description Referencia al control alternativo cuando el siguiente está deshabilitado\r\n   * @default undefined\r\n   * @type any\r\n   */\r\n  @Input() nextIsDisable: any;\r\n  \r\n  /**\r\n   * @description Referencia al control anterior para navegación\r\n   * @default undefined\r\n   * @type any\r\n   */\r\n  @Input() back: any;\r\n  \r\n  /**\r\n   * @description Referencia al control alternativo cuando el anterior está deshabilitado\r\n   * @default undefined\r\n   * @type any\r\n   */\r\n  @Input() backIsDisable: any;\r\n  \r\n  /**\r\n   * @description Indica si el campo es obligatorio\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() required: boolean = false;\r\n  \r\n  /**\r\n   * @description Alinea el texto a la derecha\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() textRight: boolean = false;\r\n  \r\n  /**\r\n   * @description Deshabilita el control\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() disabled: boolean = false;\r\n  \r\n  /**\r\n   * @description Establece el control como solo lectura\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() readonly: boolean = false;\r\n  \r\n  /**\r\n   * @description Muestra mensajes de validación\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() validatorMessage: boolean = false;\r\n  \r\n  /**\r\n   * @description Muestra mensajes de ayuda como tooltips\r\n   * @default true\r\n   * @type boolean\r\n   */\r\n  @Input() tooltipMessage: boolean = true;\r\n  \r\n  /**\r\n   * @description Longitud máxima permitida para el texto\r\n   * @default null\r\n   * @type any\r\n   */\r\n  @Input() maxLength: any = null;\r\n  \r\n  /**\r\n   * @description Indica si el formulario ha sido enviado para mostrar validaciones\r\n   * @default true\r\n   * @type boolean\r\n   */\r\n  @Input() submitted: boolean = true;\r\n  \r\n  /**\r\n   * @description Muestra alertas de validación\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() validatorAlert: boolean = false;\r\n  \r\n  /**\r\n   * @description Clases CSS adicionales para el componente\r\n   * @default \"\"\r\n   * @type string\r\n   */\r\n  @Input() setNgClass: string = \"\";\r\n  \r\n  /**\r\n   * @description Patrones de validación para el campo\r\n   * @default \"\"\r\n   * @type any\r\n   */\r\n  @Input() patterns: any = \"\";\r\n  \r\n  /**\r\n   * @description Texto de placeholder para el input\r\n   * @default \"\"\r\n   * @type string\r\n   */\r\n  @Input() placeholder: string = \"\";\r\n  \r\n  /**\r\n   * @description Habilita información adicional para la etiqueta\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() labelInfo: boolean = false;\r\n  \r\n  /**\r\n   * @description Texto informativo adicional para la etiqueta\r\n   * @default \"\"\r\n   * @type string\r\n   */\r\n  @Input() textLabelInfo: string = \"\";\r\n  \r\n  /**\r\n   * @description Habilita la limpieza y reemplazo de caracteres especiales\r\n   * @default false\r\n   * @type boolean\r\n   */\r\n  @Input() controlCharClearReplace: boolean = false;\r\n  \r\n  /**\r\n   * @description Mapa de caracteres a reemplazar\r\n   * @default {}\r\n   * @type {[key:string]: string}\r\n   */\r\n  @Input() replaceRegex: {[key:string]: string} = {};\r\n  \r\n  /**\r\n   * @description Expresión regular para limpiar caracteres\r\n   * @default \"\"\r\n   * @type string\r\n   */\r\n  @Input() clearRegex: string = \"\";\r\n  @Output() onNext: EventEmitter<any> = new EventEmitter();\r\n  @Output() onBack: EventEmitter<any> = new EventEmitter();\r\n  @Output() change: EventEmitter<any> = new EventEmitter();\r\n  @Output() blur: EventEmitter<any> = new EventEmitter();\r\n  @Output() onfocus: EventEmitter<any> = new EventEmitter();\r\n  @Output() onchange: EventEmitter<any> = new EventEmitter();\r\n  @Output() onfocusout: EventEmitter<any> = new EventEmitter();\r\n\r\n  @ViewChild(\"inputText\") _inputText!: ElementRef<HTMLInputElement>;\r\n\r\n  controls: AbstractControl | null = null;\r\n  value: any;\r\n  sharedComponentsUtil = new SharedComponentsUtil();\r\n  _initValue = false;\r\n\r\n  showPassword = false;\r\n\r\n  constructor(\r\n    private messageUtilService: MessageUtilService,\r\n    private inputTextService: InputTextService,\r\n    private _render: Renderer2\r\n  ) {\r\n    this.format = this.inputTextService.getFormat();\r\n    this.showLabel = this.inputTextService.getShowLabel();\r\n    this.btnEnable = this.inputTextService.getBtnEnable();\r\n    this.bold = this.inputTextService.getBold();\r\n    this.textRight = this.inputTextService.getTextRight();\r\n    this.validatorMessage = this.inputTextService.getValidatorMessage();\r\n    this.tooltipMessage = this.inputTextService.getTooltipMessage();\r\n    this.submitted = this.inputTextService.getSubmitted();\r\n    this.validatorAlert = this.inputTextService.getValidatorAlert();\r\n    this.controlCharClearReplace = this.inputTextService.getControlCharClearReplace();\r\n    this.replaceRegex = this.inputTextService.getReplaceRegex();\r\n    this.clearRegex = this.inputTextService.getClearRegex();\r\n  }\r\n\r\n  ngOnChanges (changes: SimpleChanges): void {\r\n    if (changes[\"submitted\"]) {\r\n      if (this.controls != null && changes[\"submitted\"].currentValue) {\r\n        this.controls.markAsDirty();\r\n        this.controls.markAsTouched();\r\n      }\r\n    }\r\n  }\r\n\r\n  ngOnInit () { }\r\n\r\n  ngAfterViewInit (): void { }\r\n\r\n  get nativeElement (): HTMLInputElement {\r\n    return this._inputText.nativeElement;\r\n  }\r\n\r\n  onChange = (_: any) => { };\r\n  onValidationChange = () => { };\r\n  onTouch = () => { };\r\n  focus = () => {\r\n    this.nativeElement?.focus();\r\n    this.nativeElement?.select();\r\n  };\r\n\r\n  onBlur (value: string): void {\r\n    this.onTouch();\r\n    this.blur.emit(this.formatInput(value));\r\n  }\r\n\r\n  onFocus (value: string): void {\r\n    if (value.trim() !== \"\") {\r\n      this.nativeElement?.select();\r\n      this.onfocus.emit(value.trim());\r\n    }\r\n  }\r\n\r\n  onInput (value: string): void {\r\n    const newValue = this.formatInput(value);\r\n\r\n    this.onTouch();\r\n    this.onChange(newValue);\r\n    this.onValidationChange();\r\n    this.onchange.emit(newValue);\r\n    this.change.emit(newValue);\r\n  }\r\n\r\n  writeValue (value: any): void {\r\n    if (value) {\r\n      this.value = this.formatInput(value);\r\n      if (this.controls) {\r\n        this._render.setProperty(this.controls, \"value\", this.value);\r\n      }\r\n    } else {\r\n      this.value = null;\r\n    }\r\n  }\r\n\r\n  registerOnChange (fn: (v: any) => void): void {\r\n    this.onChange = fn;\r\n  }\r\n\r\n  registerOnTouched (fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n\r\n  setDisabledState (isDisabled: boolean): void {\r\n    this.disabled = isDisabled;\r\n  }\r\n\r\n  validate (control: AbstractControl): ValidationErrors | any {\r\n    this.controls = control;\r\n    if (!this._initValue) {\r\n      if (this.value) {\r\n        this._render.setProperty(this.controls, \"value\", this.value);\r\n      }\r\n      this._initValue = true;\r\n    }\r\n    return null;\r\n  }\r\n\r\n  registerOnValidatorChange?(fn: () => void): void {\r\n    this.onValidationChange = fn;\r\n  }\r\n\r\n  formatInput (value: string): string {\r\n    if (value !== null && value.toString().trim() !== \"\") {\r\n      let newValue = value.toString().trim();\r\n      if (this.format === \"M\") newValue = newValue.toUpperCase();\r\n      if (this.format === \"m\") newValue = newValue.toLowerCase();\r\n\r\n      if (this.controlCharClearReplace) {\r\n        newValue = this.clearCharacters(newValue);\r\n        newValue = this.replaceCharacters(newValue);\r\n      }\r\n      return newValue;\r\n    }\r\n\r\n    return value;\r\n  }\r\n\r\n  enterKeyUp () {\r\n    if (!this.disabled) {\r\n      this.writeValue(this.value);\r\n      let validator = this.sharedComponentsUtil.stopByValidator(this.controls, this.validatorAlert, this.label);\r\n      if (validator.error) {\r\n        this.messageUtilService.getMessageError(\"000046\", \"Error\", validator.message);\r\n        return;\r\n      }\r\n    }\r\n    if (this.next != undefined) {\r\n      if (this.next.disabled || this.next.readonly) {\r\n        if (this.nextIsDisable != undefined) {\r\n          this.nextIsDisable.focus();\r\n        }\r\n      } else {\r\n        this.next.focus();\r\n      }\r\n    } else {\r\n      if (this.nextIsDisable != undefined) {\r\n        this.nextIsDisable.focus();\r\n      } else {\r\n        this.onNext.emit();\r\n      }\r\n    }\r\n  }\r\n\r\n  arrowUpKeyUp () {\r\n    if (!this.disabled) {\r\n      let validator = this.sharedComponentsUtil.stopByValidator(this.controls, this.validatorAlert, this.label);\r\n      if (validator.error) {\r\n        this.messageUtilService.getMessageError(\"000046\", \"Error\", validator.message);\r\n        return;\r\n      }\r\n    }\r\n    if (this.back != undefined) {\r\n      if (this.back.disabled || this.back.readonly) {\r\n        if (this.backIsDisable != undefined) {\r\n          this.backIsDisable.focus();\r\n        }\r\n      } else {\r\n        this.back.focus();\r\n      }\r\n    } else {\r\n      if (this.backIsDisable != undefined) {\r\n        this.backIsDisable.focus();\r\n      } else {\r\n        this.onBack.emit();\r\n      }\r\n    }\r\n  }\r\n\r\n  onFocusOut (evt: any) {\r\n    this.onfocusout.emit(evt);\r\n    if (this.btnEnable) {\r\n      this.disabled = true;\r\n    }\r\n  }\r\n\r\n  clickEnable () {\r\n    this.disabled = false;\r\n    this.readonly = false;\r\n    setTimeout(() => {\r\n      this.focus();\r\n    }, 150);\r\n  }\r\n\r\n  clickShowPassword (): void {\r\n    this.showPassword = !this.showPassword;\r\n  }\r\n\r\n  clearCharacters(text: string): string {\r\n    if (!text) return text;\r\n    const regexPattern = `[${this.clearRegex}]`;\r\n    let formattedString = text.replace(new RegExp(regexPattern, 'g'), '');\r\n    return formattedString;\r\n  }\r\n\r\n  replaceCharacters(text: string): string {\r\n    if (!text) return text;\r\n    const regexReplace = Object.keys(this.replaceRegex).join('');\r\n    const regexPattern = `[${regexReplace}]`;\r\n    return text.replace(new RegExp(regexPattern, 'g'), (char) => this.replaceRegex[char] || char);\r\n  }\r\n}\r\n\r\n","<label *ngIf=\"label != null && label != '' && showLabel\" class=\"d-flex sumax-label mb-0 p-0\"\r\n  ><span [title]=\"label\" style=\"white-space: nowrap; overflow: hidden; text-overflow: ellipsis\">{{ label }}</span>\r\n  <span *ngIf=\"required\" class=\"ml-1\" [class.text-danger]=\"controls?.errors != null\"> *</span>\r\n  <span *ngIf=\"labelInfo\">\r\n    <i class=\"fa fa-exclamation-circle text-info ms-2\" [matTooltip]=\"textLabelInfo\" matTooltipClass=\"bg-info\"></i>\r\n  </span>\r\n</label>\r\n<div\r\n  [class.input-icon]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n  [class.right]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\">\r\n  <div class=\"d-flex\">\r\n    <div class=\"w-100 position-relative\">\r\n      <tooltip-message\r\n        [label]=\"label\"\r\n        [controls]=\"controls\"\r\n        [validatorMessage]=\"validatorMessage\"\r\n        [submitted]=\"submitted\"\r\n        [tooltipMessage]=\"tooltipMessage\"></tooltip-message>\r\n\r\n      <input\r\n        *ngIf=\"inputMask != null\"\r\n        #inputText\r\n        type=\"text\"\r\n        class=\"form-control form-control-sm\"\r\n        [class.text-uppercase]=\"format === 'M'\"\r\n        [class.text-lowercase]=\"format === 'm'\"\r\n        [class.text-end]=\"textRight\"\r\n        [attr.autocomplete]=\"autocomplete\"\r\n        [placeholder]=\"placeholder\"\r\n        [class.is-invalid]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n        [disabled]=\"disabled\"\r\n        [readonly]=\"readonly\"\r\n        [mask]=\"inputMask\"\r\n        [showMaskTyped]=\"showMaskTyped\"\r\n        [patterns]=\"patterns\"\r\n        (blur)=\"onBlur($any($event.target).value)\"\r\n        (input)=\"onInput($any($event.target).value)\"\r\n        (focusout)=\"onFocusOut($any($event.target).value)\"\r\n        (focus)=\"onFocus($any($event.target).value)\"\r\n        (keyup.enter)=\"enterKeyUp()\"\r\n        (keyup.ArrowUp)=\"arrowUpKeyUp()\"\r\n        [ngClass]=\"setNgClass\"\r\n        [(ngModel)]=\"value\"\r\n        [class.bold]=\"bold\" />\r\n      <input\r\n        *ngIf=\"inputMask == null\"\r\n        #inputText\r\n        [type]=\"type === 'password' ? (showPassword ? 'text' : 'password') : type\"\r\n        class=\"form-control form-control-sm\"\r\n        [class.text-uppercase]=\"format === 'M'\"\r\n        [class.text-lowercase]=\"format === 'm'\"\r\n        [class.text-end]=\"textRight\"\r\n        [attr.autocomplete]=\"autocomplete\"\r\n        [placeholder]=\"placeholder\"\r\n        [class.is-invalid]=\"controls?.errors != null && (controls?.dirty || controls?.touched) && submitted\"\r\n        [disabled]=\"disabled\"\r\n        [readonly]=\"readonly\"\r\n        [attr.maxLength]=\"maxLength\"\r\n        (blur)=\"onBlur($any($event.target).value)\"\r\n        (input)=\"onInput($any($event.target).value)\"\r\n        (focusout)=\"onFocusOut($any($event.target).value)\"\r\n        (focus)=\"onFocus($any($event.target).value)\"\r\n        (keyup.enter)=\"enterKeyUp()\"\r\n        (keyup.ArrowUp)=\"arrowUpKeyUp()\"\r\n        [ngClass]=\"setNgClass\"\r\n        [(ngModel)]=\"value\"\r\n        [class.bold]=\"bold\" />\r\n    </div>\r\n    <div class=\"bd-highlight\" *ngIf=\"type === 'password'\">\r\n      <button type=\"button\" class=\"btn btn-info p-0 rounded-0 h-100\" (click)=\"clickShowPassword()\">\r\n        <i\r\n          [class.fa-eye]=\"showPassword\"\r\n          [class.fa-eye-slash]=\"!showPassword\"\r\n          class=\"far px-1\"\r\n          [matTooltip]=\"!showPassword ? 'Mostrar' : 'Ocultar'\"\r\n          matTooltipClass=\"bg-info\"></i>\r\n      </button>\r\n    </div>\r\n    <div class=\"bd-highlight\" *ngIf=\"btnEnable\">\r\n      <button type=\"button\" class=\"btn btn-info p-0 rounded-0 h-100\" (click)=\"clickEnable()\">\r\n        <i class=\"fa fa-check text-white px-1\" [matTooltip]=\"'Habilitar'\" matTooltipClass=\"bg-info\"></i>\r\n      </button>\r\n    </div>\r\n    <ng-content select=\"[more-buttons]\"></ng-content>\r\n  </div>\r\n</div>\r\n<error-message\r\n  [label]=\"label\"\r\n  [controls]=\"controls\"\r\n  [validatorMessage]=\"validatorMessage\"\r\n  [submitted]=\"submitted\"\r\n  [tooltipMessage]=\"tooltipMessage\"></error-message>\r\n"]}
|