appproject-components 0.0.31 → 1.0.0

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.
Files changed (46) hide show
  1. package/{esm2020 → esm2022}/appproject-components.mjs +4 -4
  2. package/{esm2020 → esm2022}/lib/appproject-components.component.mjs +15 -15
  3. package/{esm2020 → esm2022}/lib/appproject-components.module.mjs +96 -96
  4. package/{esm2020 → esm2022}/lib/appproject-components.service.mjs +14 -14
  5. package/esm2022/lib/baseInputComponent.mjs +66 -0
  6. package/esm2022/lib/input-area/input-area.component.mjs +53 -0
  7. package/esm2022/lib/input-arquivo/input-arquivo.component.mjs +115 -0
  8. package/esm2022/lib/input-cep/input-cep.component.mjs +180 -0
  9. package/esm2022/lib/input-format/input-format.component.mjs +138 -0
  10. package/esm2022/lib/input-pesquisa/input-pesquisa.component.mjs +548 -0
  11. package/esm2022/lib/input-select/input-select.component.mjs +88 -0
  12. package/esm2022/lib/input-text/input-text.component.mjs +76 -0
  13. package/esm2022/lib/input-valor/input-valor.component.mjs +158 -0
  14. package/{esm2020 → esm2022}/lib/model-treeview/model-treeview.component.mjs +14 -14
  15. package/{esm2020 → esm2022}/public-api.mjs +18 -18
  16. package/fesm2022/appproject-components.mjs +1511 -0
  17. package/fesm2022/appproject-components.mjs.map +1 -0
  18. package/index.d.ts +5 -5
  19. package/lib/appproject-components.component.d.ts +8 -8
  20. package/lib/appproject-components.module.d.ts +26 -26
  21. package/lib/appproject-components.service.d.ts +6 -6
  22. package/lib/baseInputComponent.d.ts +27 -27
  23. package/lib/input-area/input-area.component.d.ts +21 -21
  24. package/lib/input-arquivo/input-arquivo.component.d.ts +34 -34
  25. package/lib/input-cep/input-cep.component.d.ts +29 -29
  26. package/lib/input-format/input-format.component.d.ts +27 -25
  27. package/lib/input-pesquisa/input-pesquisa.component.d.ts +68 -68
  28. package/lib/input-select/input-select.component.d.ts +29 -28
  29. package/lib/input-text/input-text.component.d.ts +29 -25
  30. package/lib/input-valor/input-valor.component.d.ts +28 -25
  31. package/lib/model-treeview/model-treeview.component.d.ts +8 -8
  32. package/package.json +8 -14
  33. package/public-api.d.ts +13 -13
  34. package/esm2020/lib/baseInputComponent.mjs +0 -65
  35. package/esm2020/lib/input-area/input-area.component.mjs +0 -53
  36. package/esm2020/lib/input-arquivo/input-arquivo.component.mjs +0 -114
  37. package/esm2020/lib/input-cep/input-cep.component.mjs +0 -180
  38. package/esm2020/lib/input-format/input-format.component.mjs +0 -129
  39. package/esm2020/lib/input-pesquisa/input-pesquisa.component.mjs +0 -540
  40. package/esm2020/lib/input-select/input-select.component.mjs +0 -80
  41. package/esm2020/lib/input-text/input-text.component.mjs +0 -65
  42. package/esm2020/lib/input-valor/input-valor.component.mjs +0 -125
  43. package/fesm2015/appproject-components.mjs +0 -1456
  44. package/fesm2015/appproject-components.mjs.map +0 -1
  45. package/fesm2020/appproject-components.mjs +0 -1441
  46. package/fesm2020/appproject-components.mjs.map +0 -1
@@ -0,0 +1,180 @@
1
+ import { Component, Input } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { Observable } from 'rxjs';
4
+ import { BaseInputComponent } from '../baseInputComponent';
5
+ import * as i0 from "@angular/core";
6
+ import * as i1 from "@angular/common";
7
+ import * as i2 from "@ionic/angular";
8
+ export class InputCepComponent extends BaseInputComponent {
9
+ constructor() {
10
+ super();
11
+ this.formato = '00000-000';
12
+ this.keyEnter = null;
13
+ this.getResultados = null;
14
+ //control value acessor
15
+ this.data = null;
16
+ this.onChange = (data) => { };
17
+ this.onTouch = () => { };
18
+ this.disabled = false;
19
+ }
20
+ writeValue(value) {
21
+ //console.log('write value', value);
22
+ this.onChange(value);
23
+ this.data = value;
24
+ }
25
+ registerOnChange(fn) {
26
+ this.onChange = fn;
27
+ }
28
+ registerOnTouched(fn) {
29
+ this.onTouch = fn;
30
+ }
31
+ setDisabledState(isDisabled) {
32
+ this.disabled = this.disabled;
33
+ }
34
+ ngOnInit() {
35
+ }
36
+ digitarFormatado(event) {
37
+ console.log(event);
38
+ if ((event.keyCode >= 48 && event.keyCode <= 57)
39
+ || (event.keyCode >= 96 && event.keyCode <= 105)
40
+ || (event.keyCode == 8)
41
+ || (event.keyCode == 9)
42
+ || (event.keyCode == 39)
43
+ || (event.keyCode == 37)
44
+ || (event.keyCode == 46)) {
45
+ //console.log(this.formControlName, this.form.get(this.formControlName).value);
46
+ setTimeout(() => {
47
+ if (this.form) {
48
+ this.form.patchValue({
49
+ [this.formControlName]: this.formataCampoValor(this.form.get(this.formControlName)?.value, this.formato ?? '', event)
50
+ });
51
+ }
52
+ else {
53
+ this.data = this.formataCampoValor(this.data ?? '', this.formato ?? '', event);
54
+ this.writeValue(this.data);
55
+ }
56
+ }, 100);
57
+ return true;
58
+ }
59
+ else {
60
+ return false;
61
+ }
62
+ }
63
+ onKeyEnter() {
64
+ if (this.keyEnter != null) {
65
+ this.keyEnter();
66
+ }
67
+ else {
68
+ if (this.getResultados != null) {
69
+ this.pesquisarClick();
70
+ }
71
+ }
72
+ }
73
+ onBlur() {
74
+ if (this.form) {
75
+ this.form.get(this.formControlName)?.markAsTouched();
76
+ }
77
+ if (this.blur) {
78
+ this.blur.emit(this.blurArgs);
79
+ }
80
+ }
81
+ formataCampoValor(valor, Mascara, evento) {
82
+ console.log(valor);
83
+ if (!valor)
84
+ return null;
85
+ //console.log(evento);
86
+ //if (!this.keypressInteiro(evento))
87
+ // return;
88
+ var boleanoMascara;
89
+ var Digitato = evento != null ? evento.keyCode : 0;
90
+ let exp = /\-|\.|\/|\(|\)| /g;
91
+ let campoSoNumeros = valor.replace(exp, "");
92
+ var posicaoCampo = 0;
93
+ var NovoValorCampo = "";
94
+ var TamanhoMascara = campoSoNumeros.length;
95
+ ;
96
+ if (Digitato != 8) { // backspace
97
+ for (let i = 0; i <= TamanhoMascara; i++) {
98
+ boleanoMascara = ((Mascara.charAt(i) == "-") || (Mascara.charAt(i) == ".")
99
+ || (Mascara.charAt(i) == "/"));
100
+ boleanoMascara = boleanoMascara || ((Mascara.charAt(i) == "(")
101
+ || (Mascara.charAt(i) == ")") || (Mascara.charAt(i) == " "));
102
+ if (boleanoMascara) {
103
+ NovoValorCampo += Mascara.charAt(i);
104
+ TamanhoMascara++;
105
+ }
106
+ else {
107
+ NovoValorCampo += campoSoNumeros.charAt(posicaoCampo);
108
+ posicaoCampo++;
109
+ }
110
+ }
111
+ return NovoValorCampo;
112
+ }
113
+ else {
114
+ return valor;
115
+ }
116
+ }
117
+ pesquisarClick() {
118
+ const cep = this.data;
119
+ //se não estiver informado o cep, não fazer a pesquisa
120
+ if (cep == null || cep == "") {
121
+ return;
122
+ }
123
+ this.getEnderecoPeloCep(cep).subscribe({
124
+ next: (result) => {
125
+ console.log('result CEP', result);
126
+ let cidadePesquisa = result.localidade;
127
+ cidadePesquisa = this.converteCaracteresEspeciais(cidadePesquisa.toUpperCase());
128
+ if (this.getResultados) {
129
+ this.getResultados(result);
130
+ }
131
+ }, error: (error) => {
132
+ }
133
+ });
134
+ }
135
+ //substituição de caracteres
136
+ converteCaracteresEspeciais(nome) {
137
+ var res = nome.replace(/Ã/g, "A");
138
+ res = res.replace(/Á/g, "A");
139
+ res = res.replace(/Ç/g, "C");
140
+ res = res.replace(/É/g, "E");
141
+ res = res.replace(/Â/g, "A");
142
+ res = res.replace(/Ô/g, "O");
143
+ res = res.replace(/Ó/g, "O");
144
+ res = res.replace(/Ú/g, "U");
145
+ res = res.replace(/Í/g, "I");
146
+ return res;
147
+ }
148
+ getEnderecoPeloCep(cep) {
149
+ return new Observable((x) => {
150
+ var request = new XMLHttpRequest();
151
+ request.open('get', `https://viacep.com.br/ws/${cep}/json/`, true);
152
+ request.send();
153
+ request.onload = function () {
154
+ var data = JSON.parse(this.response);
155
+ x.next(data);
156
+ };
157
+ });
158
+ }
159
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: InputCepComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
160
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.7", type: InputCepComponent, selector: "kb-input-cep", inputs: { formato: "formato", keyEnter: "keyEnter", getResultados: "getResultados" }, providers: [{
161
+ provide: NG_VALUE_ACCESSOR,
162
+ useExisting: InputCepComponent,
163
+ multi: true
164
+ }], usesInheritance: true, ngImport: i0, template: "<!--\r\n<div [formGroup]=\"form\">\r\n-->\r\n<!--comando --inner-padding-end: utilizado pra remover padding desnecess\u00E1rios-->\r\n<div>\r\n <ion-item lines=\"none\" style=\"--background: inherited;--background-focused: transparent;--inner-padding-end: 0px;\" [class]=\"itemClass\"\r\n [ngClass]=\"form?.get(formControlName)?.errors && (form?.get(formControlName)?.dirty || form?.get(formControlName)?.touched) ? 'error-shake' : '' \"\r\n >\r\n <ion-label [position]=\"labelPosition\">{{ label }}</ion-label>\r\n <!-- formControlName={{formControlName}} -->\r\n <ion-input #inputCep\r\n type=\"tel\" \r\n [placeholder]=\"placeholder\"\r\n maxlength=\"{{ max }}\" \r\n (keydown)=\"digitarFormatado($event)\" \r\n (keyup.enter)=\"onKeyEnter()\"\r\n (ionBlur)=\"onBlur()\"\r\n [value]=\"data\"\r\n (input)=\"writeValue(inputCep.value)\"\r\n [disabled]=\"readonly\"></ion-input>\r\n\r\n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\r\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\r\n (click)=\"pesquisarClick()\">\r\n <ion-icon color=\"primary\" name=\"search\"></ion-icon>\r\n </ion-button>\r\n \r\n </ion-item>\r\n \r\n <div class=\"validation-errors\" *ngIf=\"form\">\r\n <ng-container *ngFor=\"let validation of validation_messages\">\r\n <div class=\"error-message\"\r\n *ngIf=\"form && form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\r\n &#8226; {{ validation.message }}\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>", styles: ["", "@charset \"UTF-8\";ion-label{margin-bottom:4px!important}ion-item ion-label{overflow:initial!important}ion-input{padding:var(--input-padding, 8px)!important;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:var(--input-max-height, 29px);transition:.2s ease}.has-focus{border:1px solid var(--ion-color-bluetool, #1f477d)}input:focus ion-input,input:focus ion-textarea{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}input:disabled{opacity:.9!important}.error-message{font-size:small;color:var(--error-text-color, red);margin-left:15px}.padding{padding:auto}.no-padding{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px;height:55px!important}.no-padding-end{--inner-padding-end: 0px}.no-padding-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.item-inner{padding-right:0!important}.label-right ion-label{transform-origin:right top;align-self:flex-end;margin-bottom:4%!important}.align-to-right ion-label{position:relative;left:25%;text-align:end}.error-input ion-input,.error-shake ion-input{animation:shake .4s 1 linear;border:1px solid var(--error-text-color, red)!important}@keyframes shake{0%{transform:translate(20px)}20%{transform:translate(-20px)}40%{transform:translate(10px)}60%{transform:translate(-10px)}80%{transform:translate(4px)}to{transform:translate(0)}}.error-input ion-label,.error-shake ion-label{color:var(--error-text-color, red)!important}.error-input ion-input,.error-shake ion-input{border:1px solid red!important}.error-shake ion-input{animation:shake .4s 1 linear}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "form", "href", "mode", "rel", "routerAnimation", "routerDirection", "shape", "size", "strong", "target", "type"] }, { kind: "component", type: i2.IonIcon, selector: "ion-icon", inputs: ["color", "flipRtl", "icon", "ios", "lazy", "md", "mode", "name", "sanitize", "size", "src"] }, { kind: "component", type: i2.IonInput, selector: "ion-input", inputs: ["accept", "autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearOnEdit", "color", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "legacy", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "shape", "size", "spellcheck", "step", "type", "value"] }, { kind: "component", type: i2.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { kind: "component", type: i2.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "directive", type: i2.TextValueAccessor, selector: "ion-input:not([type=number]),ion-textarea,ion-searchbar" }] }); }
165
+ }
166
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: InputCepComponent, decorators: [{
167
+ type: Component,
168
+ args: [{ selector: 'kb-input-cep', providers: [{
169
+ provide: NG_VALUE_ACCESSOR,
170
+ useExisting: InputCepComponent,
171
+ multi: true
172
+ }], template: "<!--\r\n<div [formGroup]=\"form\">\r\n-->\r\n<!--comando --inner-padding-end: utilizado pra remover padding desnecess\u00E1rios-->\r\n<div>\r\n <ion-item lines=\"none\" style=\"--background: inherited;--background-focused: transparent;--inner-padding-end: 0px;\" [class]=\"itemClass\"\r\n [ngClass]=\"form?.get(formControlName)?.errors && (form?.get(formControlName)?.dirty || form?.get(formControlName)?.touched) ? 'error-shake' : '' \"\r\n >\r\n <ion-label [position]=\"labelPosition\">{{ label }}</ion-label>\r\n <!-- formControlName={{formControlName}} -->\r\n <ion-input #inputCep\r\n type=\"tel\" \r\n [placeholder]=\"placeholder\"\r\n maxlength=\"{{ max }}\" \r\n (keydown)=\"digitarFormatado($event)\" \r\n (keyup.enter)=\"onKeyEnter()\"\r\n (ionBlur)=\"onBlur()\"\r\n [value]=\"data\"\r\n (input)=\"writeValue(inputCep.value)\"\r\n [disabled]=\"readonly\"></ion-input>\r\n\r\n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\r\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\r\n (click)=\"pesquisarClick()\">\r\n <ion-icon color=\"primary\" name=\"search\"></ion-icon>\r\n </ion-button>\r\n \r\n </ion-item>\r\n \r\n <div class=\"validation-errors\" *ngIf=\"form\">\r\n <ng-container *ngFor=\"let validation of validation_messages\">\r\n <div class=\"error-message\"\r\n *ngIf=\"form && form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\r\n &#8226; {{ validation.message }}\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>", styles: ["@charset \"UTF-8\";ion-label{margin-bottom:4px!important}ion-item ion-label{overflow:initial!important}ion-input{padding:var(--input-padding, 8px)!important;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:var(--input-max-height, 29px);transition:.2s ease}.has-focus{border:1px solid var(--ion-color-bluetool, #1f477d)}input:focus ion-input,input:focus ion-textarea{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}input:disabled{opacity:.9!important}.error-message{font-size:small;color:var(--error-text-color, red);margin-left:15px}.padding{padding:auto}.no-padding{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px;height:55px!important}.no-padding-end{--inner-padding-end: 0px}.no-padding-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.item-inner{padding-right:0!important}.label-right ion-label{transform-origin:right top;align-self:flex-end;margin-bottom:4%!important}.align-to-right ion-label{position:relative;left:25%;text-align:end}.error-input ion-input,.error-shake ion-input{animation:shake .4s 1 linear;border:1px solid var(--error-text-color, red)!important}@keyframes shake{0%{transform:translate(20px)}20%{transform:translate(-20px)}40%{transform:translate(10px)}60%{transform:translate(-10px)}80%{transform:translate(4px)}to{transform:translate(0)}}.error-input ion-label,.error-shake ion-label{color:var(--error-text-color, red)!important}.error-input ion-input,.error-shake ion-input{border:1px solid red!important}.error-shake ion-input{animation:shake .4s 1 linear}\n"] }]
173
+ }], ctorParameters: () => [], propDecorators: { formato: [{
174
+ type: Input
175
+ }], keyEnter: [{
176
+ type: Input
177
+ }], getResultados: [{
178
+ type: Input
179
+ }] } });
180
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-cep.component.js","sourceRoot":"","sources":["../../../../../projects/appproject-components/src/lib/input-cep/input-cep.component.ts","../../../../../projects/appproject-components/src/lib/input-cep/input-cep.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,KAAK,EAAU,MAAM,eAAe,CAAC;AACzD,OAAO,EAAwB,iBAAiB,EAAE,MAAM,gBAAgB,CAAC;AACzE,OAAO,EAAE,UAAU,EAAE,MAAM,MAAM,CAAC;AAClC,OAAO,EAAE,kBAAkB,EAAE,MAAM,uBAAuB,CAAC;;;;AAY3D,MAAM,OAAO,iBAAkB,SAAQ,kBAAkB;IAWvD;QACE,KAAK,EAAE,CAAC;QAVD,YAAO,GAAkB,WAAW,CAAC;QACrC,aAAQ,GAAoB,IAAI,CAAC;QACjC,kBAAa,GAAoB,IAAI,CAAC;QAE/C,uBAAuB;QAChB,SAAI,GAAiB,IAAI,CAAC;QACzB,aAAQ,GAAa,CAAC,IAAY,EAAE,EAAE,GAAG,CAAC,CAAC;QAC3C,YAAO,GAAa,GAAG,EAAE,GAAG,CAAC,CAAC;QAC9B,aAAQ,GAAY,KAAK,CAAC;IAGlC,CAAC;IAED,UAAU,CAAC,KAAmB;QAC5B,oCAAoC;QACpC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,CAAC;QACrB,IAAI,CAAC,IAAI,GAAG,KAAK,CAAC;IACpB,CAAC;IACD,gBAAgB,CAAC,EAAO;QACtB,IAAI,CAAC,QAAQ,GAAG,EAAE,CAAC;IACrB,CAAC;IACD,iBAAiB,CAAC,EAAO;QACvB,IAAI,CAAC,OAAO,GAAG,EAAE,CAAC;IACpB,CAAC;IACD,gBAAgB,CAAE,UAAmB;QACnC,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC;IAChC,CAAC;IAEQ,QAAQ;IACjB,CAAC;IAED,gBAAgB,CAAC,KAAU;QACzB,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,IAAI,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,IAAI,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC;eAC3C,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,IAAI,KAAK,CAAC,OAAO,IAAI,GAAG,CAAC;eAC7C,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,CAAC;eACpB,CAAC,KAAK,CAAC,OAAO,IAAI,CAAC,CAAC;eACpB,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC;eACrB,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC;eACrB,CAAC,KAAK,CAAC,OAAO,IAAI,EAAE,CAAC,EAAE;YAE1B,+EAA+E;YAE/E,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,IAAI,CAAC,IAAI,EAAE;oBACb,IAAI,CAAC,IAAI,CAAC,UAAU,CAAC;wBACnB,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,KAAK,EAAE,IAAI,CAAC,OAAO,IAAI,EAAE,EAAE,KAAK,CAAC;qBACtH,CAAC,CAAC;iBACJ;qBAAM;oBACL,IAAI,CAAC,IAAI,GAAG,IAAI,CAAC,iBAAiB,CAAC,IAAI,CAAC,IAAI,IAAI,EAAE,EAAE,IAAI,CAAC,OAAO,IAAI,EAAE,EAAE,KAAK,CAAC,CAAC;oBAC/E,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;iBAC5B;YACH,CAAC,EAAE,GAAG,CAAC,CAAC;YAER,OAAO,IAAI,CAAC;SACb;aACI;YACH,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IAED,UAAU;QACR,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,EAAE;YACzB,IAAI,CAAC,QAAQ,EAAE,CAAC;SACjB;aAAM;YACL,IAAI,IAAI,CAAC,aAAa,IAAI,IAAI,EAAE;gBAC9B,IAAI,CAAC,cAAc,EAAE,CAAC;aACvB;SACF;IACH,CAAC;IAED,MAAM;QACJ,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,CAAC,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,eAAe,CAAC,EAAE,aAAa,EAAE,CAAC;SACtD;QACD,IAAI,IAAI,CAAC,IAAI,EAAE;YACb,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SAC/B;IACH,CAAC;IAED,iBAAiB,CAAC,KAAa,EAAE,OAAe,EAAE,MAAW;QAC3D,OAAO,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;QACnB,IAAI,CAAC,KAAK;YACR,OAAO,IAAI,CAAC;QACd,sBAAsB;QAEtB,oCAAoC;QACpC,WAAW;QAEX,IAAI,cAAc,CAAC;QAEnB,IAAI,QAAQ,GAAG,MAAM,IAAI,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC;QACnD,IAAI,GAAG,GAAG,mBAAmB,CAAA;QAC7B,IAAI,cAAc,GAAG,KAAK,CAAC,OAAO,CAAC,GAAG,EAAE,EAAE,CAAC,CAAC;QAE5C,IAAI,YAAY,GAAG,CAAC,CAAC;QACrB,IAAI,cAAc,GAAG,EAAE,CAAC;QACxB,IAAI,cAAc,GAAG,cAAc,CAAC,MAAM,CAAC;QAAA,CAAC;QAE5C,IAAI,QAAQ,IAAI,CAAC,EAAE,EAAE,aAAa;YAChC,KAAK,IAAI,CAAC,GAAG,CAAC,EAAE,CAAC,IAAI,cAAc,EAAE,CAAC,EAAE,EAAE;gBACxC,cAAc,GAAG,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC;uBACrE,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAA;gBAChC,cAAc,GAAG,cAAc,IAAI,CAAC,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC;uBACzD,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,GAAG,CAAC,CAAC,CAAA;gBAC9D,IAAI,cAAc,EAAE;oBAClB,cAAc,IAAI,OAAO,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC;oBACpC,cAAc,EAAE,CAAC;iBAClB;qBAAM;oBACL,cAAc,IAAI,cAAc,CAAC,MAAM,CAAC,YAAY,CAAC,CAAC;oBACtD,YAAY,EAAE,CAAC;iBAChB;aACF;YACD,OAAO,cAAc,CAAC;SACvB;aAAM;YACL,OAAO,KAAK,CAAC;SACd;IACH,CAAC;IAED,cAAc;QACZ,MAAM,GAAG,GAAG,IAAI,CAAC,IAAI,CAAC;QACtB,sDAAsD;QACtD,IAAI,GAAG,IAAI,IAAI,IAAI,GAAG,IAAI,EAAE,EAAE;YAC5B,OAAO;SACR;QAED,IAAI,CAAC,kBAAkB,CAAC,GAAG,CAAC,CAAC,SAAS,CAAC;YACrC,IAAI,EAAE,CAAC,MAAM,EAAE,EAAE;gBACf,OAAO,CAAC,GAAG,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;gBAElC,IAAI,cAAc,GAAW,MAAM,CAAC,UAAU,CAAC;gBAC/C,cAAc,GAAG,IAAI,CAAC,2BAA2B,CAAC,cAAc,CAAC,WAAW,EAAE,CAAC,CAAC;gBAEhF,IAAI,IAAI,CAAC,aAAa,EAAE;oBACtB,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;iBAC5B;YAEH,CAAC,EAAE,KAAK,EAAE,CAAC,KAAK,EAAE,EAAE;YAEpB,CAAC;SACF,CAAC,CAAC;IACL,CAAC;IAED,4BAA4B;IAC5B,2BAA2B,CAAC,IAAY;QACtC,IAAI,GAAG,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAClC,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC7B,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC7B,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC7B,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC7B,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC7B,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC7B,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC7B,GAAG,GAAG,GAAG,CAAC,OAAO,CAAC,IAAI,EAAE,GAAG,CAAC,CAAC;QAC7B,OAAO,GAAG,CAAC;IACb,CAAC;IAED,kBAAkB,CAAC,GAAQ;QACzB,OAAO,IAAI,UAAU,CAAC,CAAC,CAAC,EAAE,EAAE;YAC1B,IAAI,OAAO,GAAG,IAAI,cAAc,EAAE,CAAC;YACnC,OAAO,CAAC,IAAI,CAAC,KAAK,EAAE,4BAA4B,GAAG,QAAQ,EAAE,IAAI,CAAC,CAAC;YACnE,OAAO,CAAC,IAAI,EAAE,CAAC;YACf,OAAO,CAAC,MAAM,GAAG;gBACf,IAAI,IAAI,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBACrC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAA;YACd,CAAC,CAAA;QACH,CAAC,CAAC,CAAA;IACJ,CAAC;8GAzKU,iBAAiB;kGAAjB,iBAAiB,6HANjB,CAAC;gBACV,OAAO,EAAE,iBAAiB;gBAC1B,WAAW,EAAE,iBAAiB;gBAC9B,KAAK,EAAE,IAAI;aACZ,CAAC,iDCbJ,6uDAqCQ;;2FDtBK,iBAAiB;kBAV7B,SAAS;+BACE,cAAc,aAGb,CAAC;4BACV,OAAO,EAAE,iBAAiB;4BAC1B,WAAW,mBAAmB;4BAC9B,KAAK,EAAE,IAAI;yBACZ,CAAC;wDAIO,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,aAAa;sBAArB,KAAK","sourcesContent":["import { Component, Input, OnInit } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { Observable } from 'rxjs';\nimport { BaseInputComponent } from '../baseInputComponent';\n\n@Component({\n  selector: 'kb-input-cep',\n  templateUrl: './input-cep.component.html',\n  styleUrls: ['./input-cep.component.scss', './../baseComponent.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: InputCepComponent,\n    multi: true\n  }]\n})\nexport class InputCepComponent extends BaseInputComponent implements OnInit, ControlValueAccessor {\n\n  @Input() formato: string | null = '00000-000';\n  @Input() keyEnter: Function | null = null;\n  @Input() getResultados: Function | null = null;\n\n  //control value acessor\n  public data: string | any = null;\n  private onChange: Function = (data: string) => { };\n  private onTouch: Function = () => { };\n  private disabled: boolean = false;\n  constructor() {\n    super();\n  }\n\n  writeValue(value: string | any): void {\n    //console.log('write value', value);\n    this.onChange(value);\n    this.data = value;\n  }\n  registerOnChange(fn: any): void {\n    this.onChange = fn;\n  }\n  registerOnTouched(fn: any): void {\n    this.onTouch = fn;\n  }\n  setDisabledState?(isDisabled: boolean): void {\n    this.disabled = this.disabled;\n  }\n\n  override ngOnInit(): void {\n  }\n\n  digitarFormatado(event: any) {\n    console.log(event);\n    if ((event.keyCode >= 48 && event.keyCode <= 57)\n      || (event.keyCode >= 96 && event.keyCode <= 105)\n      || (event.keyCode == 8)\n      || (event.keyCode == 9)\n      || (event.keyCode == 39)\n      || (event.keyCode == 37)\n      || (event.keyCode == 46)) {\n\n      //console.log(this.formControlName, this.form.get(this.formControlName).value);\n\n      setTimeout(() => {\n        if (this.form) {\n          this.form.patchValue({\n            [this.formControlName]: this.formataCampoValor(this.form.get(this.formControlName)?.value, this.formato ?? '', event)\n          });\n        } else {\n          this.data = this.formataCampoValor(this.data ?? '', this.formato ?? '', event);\n          this.writeValue(this.data);\n        }\n      }, 100);\n\n      return true;\n    }\n    else {\n      return false;\n    }\n  }\n\n  onKeyEnter() {\n    if (this.keyEnter != null) {\n      this.keyEnter();\n    } else {\n      if (this.getResultados != null) {\n        this.pesquisarClick();\n      }\n    }\n  }\n\n  onBlur() {\n    if (this.form) {\n      this.form.get(this.formControlName)?.markAsTouched();\n    }\n    if (this.blur) {\n      this.blur.emit(this.blurArgs);\n    }\n  }\n\n  formataCampoValor(valor: string, Mascara: string, evento: any) {\n    console.log(valor);\n    if (!valor)\n      return null;\n    //console.log(evento);\n\n    //if (!this.keypressInteiro(evento))\n    //  return;\n\n    var boleanoMascara;\n\n    var Digitato = evento != null ? evento.keyCode : 0;\n    let exp = /\\-|\\.|\\/|\\(|\\)| /g\n    let campoSoNumeros = valor.replace(exp, \"\");\n\n    var posicaoCampo = 0;\n    var NovoValorCampo = \"\";\n    var TamanhoMascara = campoSoNumeros.length;;\n\n    if (Digitato != 8) { // backspace \n      for (let i = 0; i <= TamanhoMascara; i++) {\n        boleanoMascara = ((Mascara.charAt(i) == \"-\") || (Mascara.charAt(i) == \".\")\n          || (Mascara.charAt(i) == \"/\"))\n        boleanoMascara = boleanoMascara || ((Mascara.charAt(i) == \"(\")\n          || (Mascara.charAt(i) == \")\") || (Mascara.charAt(i) == \" \"))\n        if (boleanoMascara) {\n          NovoValorCampo += Mascara.charAt(i);\n          TamanhoMascara++;\n        } else {\n          NovoValorCampo += campoSoNumeros.charAt(posicaoCampo);\n          posicaoCampo++;\n        }\n      }\n      return NovoValorCampo;\n    } else {\n      return valor;\n    }\n  }\n\n  pesquisarClick() {\n    const cep = this.data;\n    //se não estiver informado o cep, não fazer a pesquisa\n    if (cep == null || cep == \"\") {\n      return;\n    }\n\n    this.getEnderecoPeloCep(cep).subscribe({\n      next: (result) => {\n        console.log('result CEP', result);\n\n        let cidadePesquisa: string = result.localidade;\n        cidadePesquisa = this.converteCaracteresEspeciais(cidadePesquisa.toUpperCase());\n\n        if (this.getResultados) {\n          this.getResultados(result);\n        }\n\n      }, error: (error) => {\n\n      }\n    });\n  }\n\n  //substituição de caracteres\n  converteCaracteresEspeciais(nome: string): string {\n    var res = nome.replace(/Ã/g, \"A\");\n    res = res.replace(/Á/g, \"A\");\n    res = res.replace(/Ç/g, \"C\");\n    res = res.replace(/É/g, \"E\");\n    res = res.replace(/Â/g, \"A\");\n    res = res.replace(/Ô/g, \"O\");\n    res = res.replace(/Ó/g, \"O\");\n    res = res.replace(/Ú/g, \"U\");\n    res = res.replace(/Í/g, \"I\");\n    return res;\n  }\n\n  getEnderecoPeloCep(cep: any): Observable<any> {\n    return new Observable((x) => {\n      var request = new XMLHttpRequest();\n      request.open('get', `https://viacep.com.br/ws/${cep}/json/`, true);\n      request.send();\n      request.onload = function () {\n        var data = JSON.parse(this.response);\n        x.next(data)\n      }\n    })\n  }\n}\n","<!--\r\n<div [formGroup]=\"form\">\r\n-->\r\n<!--comando --inner-padding-end: utilizado pra remover padding desnecessários-->\r\n<div>\r\n    <ion-item lines=\"none\" style=\"--background: inherited;--background-focused: transparent;--inner-padding-end: 0px;\" [class]=\"itemClass\"\r\n    [ngClass]=\"form?.get(formControlName)?.errors && (form?.get(formControlName)?.dirty || form?.get(formControlName)?.touched) ? 'error-shake' : '' \"\r\n    >\r\n      <ion-label [position]=\"labelPosition\">{{ label }}</ion-label>\r\n      <!-- formControlName={{formControlName}} -->\r\n      <ion-input #inputCep\r\n      type=\"tel\" \r\n      [placeholder]=\"placeholder\"\r\n      maxlength=\"{{ max }}\" \r\n      (keydown)=\"digitarFormatado($event)\" \r\n      (keyup.enter)=\"onKeyEnter()\"\r\n      (ionBlur)=\"onBlur()\"\r\n      [value]=\"data\"\r\n      (input)=\"writeValue(inputCep.value)\"\r\n      [disabled]=\"readonly\"></ion-input>\r\n\r\n      <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\r\n        style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\r\n        (click)=\"pesquisarClick()\">\r\n        <ion-icon color=\"primary\" name=\"search\"></ion-icon>\r\n      </ion-button>\r\n  \r\n    </ion-item>\r\n  \r\n    <div class=\"validation-errors\" *ngIf=\"form\">\r\n      <ng-container *ngFor=\"let validation of validation_messages\">\r\n        <div class=\"error-message\"\r\n          *ngIf=\"form && form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\r\n          &#8226; {{ validation.message }}\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>"]}
@@ -0,0 +1,138 @@
1
+ import { Component, ElementRef, EventEmitter, Input, ViewChild } from '@angular/core';
2
+ import { NG_VALUE_ACCESSOR } from '@angular/forms';
3
+ import { BaseInputComponent } from '../baseInputComponent';
4
+ import * as i0 from "@angular/core";
5
+ import * as i1 from "@angular/common";
6
+ import * as i2 from "@ionic/angular";
7
+ export class InputFormatComponent extends BaseInputComponent {
8
+ writeValue(value) {
9
+ //console.log('write value', value);
10
+ this.onChange(value);
11
+ this.data = value;
12
+ }
13
+ registerOnChange(fn) {
14
+ this.onChange = fn;
15
+ }
16
+ registerOnTouched(fn) {
17
+ this.onTouch = fn;
18
+ }
19
+ setDisabledState(isDisabled) {
20
+ this.disabled = this.disabled;
21
+ }
22
+ constructor() {
23
+ super();
24
+ this.formato = null;
25
+ this.keyEnter = new EventEmitter();
26
+ //control value acessor
27
+ this.data = null;
28
+ this.onChange = (data) => { };
29
+ this.onTouch = () => { };
30
+ this.disabled = false;
31
+ this.console = console;
32
+ }
33
+ ngOnInit() { }
34
+ digitarFormatado(event) {
35
+ //console.log(event);
36
+ const index = event.target.selectionStart >= 1 ? (event.target.selectionStart - 1) : 0;
37
+ const keyAt = event.target.value.charCodeAt(index);
38
+ if ((event.keyCode >= 48 && event.keyCode <= 57)
39
+ || (keyAt >= 48 && keyAt <= 57)
40
+ || (event.keyCode >= 96 && event.keyCode <= 105)
41
+ || (event.keyCode == 8)
42
+ || (event.keyCode == 9)
43
+ || (event.keyCode == 39)
44
+ || (event.keyCode == 37)
45
+ || (event.keyCode == 46)) {
46
+ //console.log(this.formControlName, this.form.get(this.formControlName).value);
47
+ setTimeout(() => {
48
+ if (this.form) {
49
+ this.form.patchValue({
50
+ [this.formControlName]: this.formataCampoValor(this.form.get(this.formControlName)?.value, this.formato ?? '', event)
51
+ });
52
+ }
53
+ else {
54
+ this.data = this.formataCampoValor(this.data ?? '', this.formato ?? '', event);
55
+ this.writeValue(this.data);
56
+ }
57
+ }, 100);
58
+ return true;
59
+ }
60
+ else {
61
+ return false;
62
+ }
63
+ }
64
+ onKeyEnter() {
65
+ if (this.keyEnter != null) {
66
+ this.keyEnter.emit();
67
+ }
68
+ }
69
+ onBlur() {
70
+ if (this.form) {
71
+ this.form.get(this.formControlName)?.markAsTouched();
72
+ }
73
+ if (this.blur) {
74
+ this.blur.emit(this.blurArgs);
75
+ }
76
+ }
77
+ setFocus() {
78
+ this.inputFormatEdit.nativeElement.setFocus();
79
+ }
80
+ formataCampoValor(valor, Mascara, evento) {
81
+ console.log(valor);
82
+ if (!valor)
83
+ return null;
84
+ //console.log(evento);
85
+ //if (!this.keypressInteiro(evento))
86
+ // return;
87
+ var boleanoMascara;
88
+ var Digitato = evento != null ? evento.keyCode : 0;
89
+ let exp = /\-|\.|\/|\(|\)| /g;
90
+ let campoSoNumeros = valor.replace(exp, "");
91
+ var posicaoCampo = 0;
92
+ var NovoValorCampo = "";
93
+ var TamanhoMascara = campoSoNumeros.length;
94
+ ;
95
+ if (Digitato != 8) { // backspace
96
+ for (let i = 0; i <= TamanhoMascara; i++) {
97
+ boleanoMascara = ((Mascara.charAt(i) == "-") || (Mascara.charAt(i) == ".")
98
+ || (Mascara.charAt(i) == "/"));
99
+ boleanoMascara = boleanoMascara || ((Mascara.charAt(i) == "(")
100
+ || (Mascara.charAt(i) == ")") || (Mascara.charAt(i) == " "));
101
+ if (boleanoMascara) {
102
+ NovoValorCampo += Mascara.charAt(i);
103
+ TamanhoMascara++;
104
+ }
105
+ else {
106
+ NovoValorCampo += campoSoNumeros.charAt(posicaoCampo);
107
+ posicaoCampo++;
108
+ }
109
+ }
110
+ return NovoValorCampo;
111
+ }
112
+ else {
113
+ return valor;
114
+ }
115
+ }
116
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: InputFormatComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
117
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.0.7", type: InputFormatComponent, selector: "kb-input-format", inputs: { formato: "formato", keyEnter: "keyEnter" }, providers: [{
118
+ provide: NG_VALUE_ACCESSOR,
119
+ useExisting: InputFormatComponent,
120
+ multi: true
121
+ }], viewQueries: [{ propertyName: "inputFormatEdit", first: true, predicate: ["inputFormat"], descendants: true, read: ElementRef, static: true }], usesInheritance: true, ngImport: i0, template: "<!--\r\n<div [formGroup]=\"form\">\r\n-->\r\n<!--comando --inner-padding-end: utilizado pra remover padding desnecess\u00E1rios-->\r\n<div>\r\n <ion-item lines=\"none\" style=\"--background: inherited;--background-focused: transparent;--inner-padding-end: 0px;\" [class]=\"itemClass\"\r\n [ngClass]=\"form?.get(formControlName)?.errors && (form?.get(formControlName)?.dirty || form?.get(formControlName)?.touched) ? 'error-shake' : '' \"\r\n >\r\n <ion-label [position]=\"labelPosition\">{{ label }}</ion-label>\r\n <!-- formControlName={{formControlName}} -->\r\n <ion-input #inputFormat\r\n type=\"tel\" \r\n [placeholder]=\"placeholder\"\r\n maxlength=\"{{ max }}\" \r\n (keydown)=\"digitarFormatado($event)\" \r\n (keyup.enter)=\"onKeyEnter()\"\r\n (ionBlur)=\"onBlur()\"\r\n [value]=\"data\"\r\n (input)=\"writeValue(inputFormat.value)\"\r\n [disabled]=\"readonly\"></ion-input>\r\n \r\n </ion-item>\r\n \r\n <div class=\"validation-errors\" *ngIf=\"form\">\r\n <ng-container *ngFor=\"let validation of validation_messages\">\r\n <div class=\"error-message\"\r\n *ngIf=\"form && form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\r\n &#8226; {{ validation.message }}\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>", styles: [".item-inner{padding-right:0!important}\n", "@charset \"UTF-8\";ion-label{margin-bottom:4px!important}ion-item ion-label{overflow:initial!important}ion-input{padding:var(--input-padding, 8px)!important;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:var(--input-max-height, 29px);transition:.2s ease}.has-focus{border:1px solid var(--ion-color-bluetool, #1f477d)}input:focus ion-input,input:focus ion-textarea{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}input:disabled{opacity:.9!important}.error-message{font-size:small;color:var(--error-text-color, red);margin-left:15px}.padding{padding:auto}.no-padding{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px;height:55px!important}.no-padding-end{--inner-padding-end: 0px}.no-padding-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.item-inner{padding-right:0!important}.label-right ion-label{transform-origin:right top;align-self:flex-end;margin-bottom:4%!important}.align-to-right ion-label{position:relative;left:25%;text-align:end}.error-input ion-input,.error-shake ion-input{animation:shake .4s 1 linear;border:1px solid var(--error-text-color, red)!important}@keyframes shake{0%{transform:translate(20px)}20%{transform:translate(-20px)}40%{transform:translate(10px)}60%{transform:translate(-10px)}80%{transform:translate(4px)}to{transform:translate(0)}}.error-input ion-label,.error-shake ion-label{color:var(--error-text-color, red)!important}.error-input ion-input,.error-shake ion-input{border:1px solid red!important}.error-shake ion-input{animation:shake .4s 1 linear}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IonInput, selector: "ion-input", inputs: ["accept", "autocapitalize", "autocomplete", "autocorrect", "autofocus", "clearInput", "clearOnEdit", "color", "counter", "counterFormatter", "debounce", "disabled", "enterkeyhint", "errorText", "fill", "helperText", "inputmode", "label", "labelPlacement", "legacy", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "shape", "size", "spellcheck", "step", "type", "value"] }, { kind: "component", type: i2.IonItem, selector: "ion-item", inputs: ["button", "color", "counter", "counterFormatter", "detail", "detailIcon", "disabled", "download", "fill", "href", "lines", "mode", "rel", "routerAnimation", "routerDirection", "shape", "target", "type"] }, { kind: "component", type: i2.IonLabel, selector: "ion-label", inputs: ["color", "mode", "position"] }, { kind: "directive", type: i2.TextValueAccessor, selector: "ion-input:not([type=number]),ion-textarea,ion-searchbar" }] }); }
122
+ }
123
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.0.7", ngImport: i0, type: InputFormatComponent, decorators: [{
124
+ type: Component,
125
+ args: [{ selector: 'kb-input-format', providers: [{
126
+ provide: NG_VALUE_ACCESSOR,
127
+ useExisting: InputFormatComponent,
128
+ multi: true
129
+ }], template: "<!--\r\n<div [formGroup]=\"form\">\r\n-->\r\n<!--comando --inner-padding-end: utilizado pra remover padding desnecess\u00E1rios-->\r\n<div>\r\n <ion-item lines=\"none\" style=\"--background: inherited;--background-focused: transparent;--inner-padding-end: 0px;\" [class]=\"itemClass\"\r\n [ngClass]=\"form?.get(formControlName)?.errors && (form?.get(formControlName)?.dirty || form?.get(formControlName)?.touched) ? 'error-shake' : '' \"\r\n >\r\n <ion-label [position]=\"labelPosition\">{{ label }}</ion-label>\r\n <!-- formControlName={{formControlName}} -->\r\n <ion-input #inputFormat\r\n type=\"tel\" \r\n [placeholder]=\"placeholder\"\r\n maxlength=\"{{ max }}\" \r\n (keydown)=\"digitarFormatado($event)\" \r\n (keyup.enter)=\"onKeyEnter()\"\r\n (ionBlur)=\"onBlur()\"\r\n [value]=\"data\"\r\n (input)=\"writeValue(inputFormat.value)\"\r\n [disabled]=\"readonly\"></ion-input>\r\n \r\n </ion-item>\r\n \r\n <div class=\"validation-errors\" *ngIf=\"form\">\r\n <ng-container *ngFor=\"let validation of validation_messages\">\r\n <div class=\"error-message\"\r\n *ngIf=\"form && form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\r\n &#8226; {{ validation.message }}\r\n </div>\r\n </ng-container>\r\n </div>\r\n </div>", styles: [".item-inner{padding-right:0!important}\n", "@charset \"UTF-8\";ion-label{margin-bottom:4px!important}ion-item ion-label{overflow:initial!important}ion-input{padding:var(--input-padding, 8px)!important;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:var(--input-max-height, 29px);transition:.2s ease}.has-focus{border:1px solid var(--ion-color-bluetool, #1f477d)}input:focus ion-input,input:focus ion-textarea{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}input:disabled{opacity:.9!important}.error-message{font-size:small;color:var(--error-text-color, red);margin-left:15px}.padding{padding:auto}.no-padding{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px;height:55px!important}.no-padding-end{--inner-padding-end: 0px}.no-padding-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.item-inner{padding-right:0!important}.label-right ion-label{transform-origin:right top;align-self:flex-end;margin-bottom:4%!important}.align-to-right ion-label{position:relative;left:25%;text-align:end}.error-input ion-input,.error-shake ion-input{animation:shake .4s 1 linear;border:1px solid var(--error-text-color, red)!important}@keyframes shake{0%{transform:translate(20px)}20%{transform:translate(-20px)}40%{transform:translate(10px)}60%{transform:translate(-10px)}80%{transform:translate(4px)}to{transform:translate(0)}}.error-input ion-label,.error-shake ion-label{color:var(--error-text-color, red)!important}.error-input ion-input,.error-shake ion-input{border:1px solid red!important}.error-shake ion-input{animation:shake .4s 1 linear}\n"] }]
130
+ }], ctorParameters: () => [], propDecorators: { formato: [{
131
+ type: Input
132
+ }], keyEnter: [{
133
+ type: Input
134
+ }], inputFormatEdit: [{
135
+ type: ViewChild,
136
+ args: ['inputFormat', { read: ElementRef, static: true }]
137
+ }] } });
138
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-format.component.js","sourceRoot":"","sources":["../../../../../projects/appproject-components/src/lib/input-format/input-format.component.ts","../../../../../projects/appproject-components/src/lib/input-format/input-format.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, ElementRef, EventEmitter, Input, OnInit, ViewChild } from '@angular/core';\r\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { BaseInputComponent } from '../baseInputComponent';\r\n\r\n@Component({\r\n  selector: 'kb-input-format',\r\n  templateUrl: './input-format.component.html',\r\n  styleUrls: ['./input-format.component.scss', './../baseComponent.scss'],\r\n  providers: [{\r\n    provide: NG_VALUE_ACCESSOR,\r\n    useExisting: InputFormatComponent,\r\n    multi: true\r\n  }]\r\n})\r\nexport class InputFormatComponent extends BaseInputComponent implements OnInit, ControlValueAccessor {\r\n\r\n  @Input() formato: string | null = null;\r\n  @Input() keyEnter = new EventEmitter();\r\n  @ViewChild('inputFormat', { read: ElementRef, static: true}) inputFormatEdit;\r\n  \r\n  //control value acessor\r\n  public data: string | any = null;\r\n  private onChange: Function = (data: string) => {};\r\n  private onTouch: Function = () => {};\r\n  private disabled: boolean = false;\r\n  public console = console;\r\n\r\n  writeValue(value: string | any): void {\r\n    //console.log('write value', value);\r\n    this.onChange(value);\r\n    this.data = value;\r\n  }\r\n  registerOnChange(fn: any): void {\r\n    this.onChange = fn;\r\n  }\r\n  registerOnTouched(fn: any): void {\r\n    this.onTouch = fn;\r\n  }\r\n  setDisabledState?(isDisabled: boolean): void {\r\n    this.disabled = this.disabled;\r\n  }\r\n\r\n  constructor() { \r\n    super();\r\n  }\r\n\r\n  override ngOnInit() { }\r\n\r\n  digitarFormatado(event: any) {\r\n    //console.log(event);\r\n    const index = event.target.selectionStart >= 1 ? (event.target.selectionStart - 1) : 0;\r\n    const keyAt = event.target.value.charCodeAt(index);\r\n    if ((event.keyCode >= 48 && event.keyCode <= 57)\r\n     || (keyAt >= 48 && keyAt <= 57)\r\n     || (event.keyCode >= 96 && event.keyCode <= 105)\r\n     || (event.keyCode == 8)\r\n     || (event.keyCode == 9)\r\n     || (event.keyCode == 39)\r\n     || (event.keyCode == 37) \r\n     || (event.keyCode == 46)) {\r\n\r\n      //console.log(this.formControlName, this.form.get(this.formControlName).value);\r\n\r\n      setTimeout(() => {\r\n        if (this.form) {\r\n          this.form.patchValue({\r\n            [this.formControlName]: this.formataCampoValor(this.form.get(this.formControlName)?.value, this.formato ?? '', event)\r\n          });\r\n        } else {\r\n          this.data = this.formataCampoValor(this.data ?? '', this.formato ?? '', event);\r\n          this.writeValue(this.data);\r\n        }\r\n      }, 100);\r\n\r\n      return true;\r\n    }\r\n    else {\r\n      return false;\r\n    }        \r\n  }\r\n\r\n  onKeyEnter() {\r\n    if (this.keyEnter != null) {\r\n      this.keyEnter.emit();\r\n    }\r\n  }\r\n\r\n  onBlur() {\r\n    if (this.form) {\r\n      this.form.get(this.formControlName)?.markAsTouched();\r\n    }\r\n    if (this.blur) {\r\n      this.blur.emit(this.blurArgs);\r\n    }\r\n  }\r\n\r\n  setFocus() {\r\n    this.inputFormatEdit.nativeElement.setFocus();\r\n  }\r\n\r\n  formataCampoValor(valor: string, Mascara: string, evento: any) {\r\n    console.log(valor);\r\n    if (!valor)\r\n      return null;\r\n    //console.log(evento);\r\n\r\n    //if (!this.keypressInteiro(evento))\r\n    //  return;\r\n\r\n    var boleanoMascara;\r\n\r\n    var Digitato = evento != null ? evento.keyCode : 0;\r\n    let exp = /\\-|\\.|\\/|\\(|\\)| /g\r\n    let campoSoNumeros = valor.replace(exp, \"\");\r\n\r\n    var posicaoCampo = 0;\r\n    var NovoValorCampo = \"\";\r\n    var TamanhoMascara = campoSoNumeros.length;;\r\n\r\n    if (Digitato != 8) { // backspace \r\n      for (let i = 0; i <= TamanhoMascara; i++) {\r\n        boleanoMascara = ((Mascara.charAt(i) == \"-\") || (Mascara.charAt(i) == \".\")\r\n          || (Mascara.charAt(i) == \"/\"))\r\n        boleanoMascara = boleanoMascara || ((Mascara.charAt(i) == \"(\")\r\n          || (Mascara.charAt(i) == \")\") || (Mascara.charAt(i) == \" \"))\r\n        if (boleanoMascara) {\r\n          NovoValorCampo += Mascara.charAt(i);\r\n          TamanhoMascara++;\r\n        } else {\r\n          NovoValorCampo += campoSoNumeros.charAt(posicaoCampo);\r\n          posicaoCampo++;\r\n        }\r\n      }\r\n      return NovoValorCampo;\r\n    } else {\r\n      return valor;\r\n    }\r\n  }\r\n}\r\n","<!--\r\n<div [formGroup]=\"form\">\r\n-->\r\n<!--comando --inner-padding-end: utilizado pra remover padding desnecessários-->\r\n<div>\r\n    <ion-item lines=\"none\" style=\"--background: inherited;--background-focused: transparent;--inner-padding-end: 0px;\" [class]=\"itemClass\"\r\n    [ngClass]=\"form?.get(formControlName)?.errors && (form?.get(formControlName)?.dirty || form?.get(formControlName)?.touched) ? 'error-shake' : '' \"\r\n    >\r\n      <ion-label [position]=\"labelPosition\">{{ label }}</ion-label>\r\n      <!-- formControlName={{formControlName}} -->\r\n      <ion-input #inputFormat\r\n      type=\"tel\" \r\n      [placeholder]=\"placeholder\"\r\n      maxlength=\"{{ max }}\" \r\n      (keydown)=\"digitarFormatado($event)\" \r\n      (keyup.enter)=\"onKeyEnter()\"\r\n      (ionBlur)=\"onBlur()\"\r\n      [value]=\"data\"\r\n      (input)=\"writeValue(inputFormat.value)\"\r\n      [disabled]=\"readonly\"></ion-input>\r\n  \r\n    </ion-item>\r\n  \r\n    <div class=\"validation-errors\" *ngIf=\"form\">\r\n      <ng-container *ngFor=\"let validation of validation_messages\">\r\n        <div class=\"error-message\"\r\n          *ngIf=\"form && form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\r\n          &#8226; {{ validation.message }}\r\n        </div>\r\n      </ng-container>\r\n    </div>\r\n  </div>"]}