appproject-components 0.0.1 → 0.0.4
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/esm2020/lib/appproject-components.module.mjs +25 -5
- package/esm2020/lib/input-format/input-format.component.mjs +123 -8
- package/esm2020/lib/input-pesquisa/input-pesquisa.component.mjs +531 -0
- package/esm2020/lib/input-select/input-select.component.mjs +80 -0
- package/esm2020/lib/input-valor/input-valor.component.mjs +125 -0
- package/esm2020/lib/model-treeview/model-treeview.component.mjs +14 -0
- package/esm2020/public-api.mjs +5 -1
- package/fesm2015/appproject-components.mjs +876 -11
- package/fesm2015/appproject-components.mjs.map +1 -1
- package/fesm2020/appproject-components.mjs +867 -11
- package/fesm2020/appproject-components.mjs.map +1 -1
- package/lib/appproject-components.module.d.ts +9 -5
- package/lib/input-format/input-format.component.d.ts +19 -2
- package/lib/input-pesquisa/input-pesquisa.component.d.ts +65 -0
- package/lib/input-select/input-select.component.d.ts +28 -0
- package/lib/input-valor/input-valor.component.d.ts +25 -0
- package/lib/model-treeview/model-treeview.component.d.ts +8 -0
- package/package.json +1 -1
- package/public-api.d.ts +4 -0
|
@@ -7,6 +7,10 @@ import { IonicModule } from '@ionic/angular';
|
|
|
7
7
|
import { HttpClientModule } from '@angular/common/http';
|
|
8
8
|
import { AppprojectComponentsService } from './appproject-components.service';
|
|
9
9
|
import { ReactiveFormsModule } from '@angular/forms';
|
|
10
|
+
import { InputSelectComponent } from './input-select/input-select.component';
|
|
11
|
+
import { InputPesquisaComponent } from './input-pesquisa/input-pesquisa.component';
|
|
12
|
+
import { ModelTreeviewComponent } from './model-treeview/model-treeview.component';
|
|
13
|
+
import { InputValorComponent } from './input-valor/input-valor.component';
|
|
10
14
|
import * as i0 from "@angular/core";
|
|
11
15
|
export const LibConfigService = new InjectionToken('LibConfig');
|
|
12
16
|
export class AppprojectComponentsModule {
|
|
@@ -26,12 +30,20 @@ export class AppprojectComponentsModule {
|
|
|
26
30
|
AppprojectComponentsModule.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: AppprojectComponentsModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule });
|
|
27
31
|
AppprojectComponentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "14.1.2", ngImport: i0, type: AppprojectComponentsModule, declarations: [AppprojectComponentsComponent,
|
|
28
32
|
InputTextComponent,
|
|
29
|
-
InputFormatComponent
|
|
33
|
+
InputFormatComponent,
|
|
34
|
+
InputSelectComponent,
|
|
35
|
+
InputPesquisaComponent,
|
|
36
|
+
ModelTreeviewComponent,
|
|
37
|
+
InputValorComponent], imports: [CommonModule,
|
|
30
38
|
HttpClientModule,
|
|
31
39
|
IonicModule,
|
|
32
40
|
ReactiveFormsModule], exports: [AppprojectComponentsComponent,
|
|
33
41
|
InputTextComponent,
|
|
34
|
-
InputFormatComponent
|
|
42
|
+
InputFormatComponent,
|
|
43
|
+
InputSelectComponent,
|
|
44
|
+
InputPesquisaComponent,
|
|
45
|
+
ModelTreeviewComponent,
|
|
46
|
+
InputValorComponent] });
|
|
35
47
|
AppprojectComponentsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: AppprojectComponentsModule, imports: [CommonModule,
|
|
36
48
|
HttpClientModule,
|
|
37
49
|
IonicModule,
|
|
@@ -42,7 +54,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
|
|
|
42
54
|
declarations: [
|
|
43
55
|
AppprojectComponentsComponent,
|
|
44
56
|
InputTextComponent,
|
|
45
|
-
InputFormatComponent
|
|
57
|
+
InputFormatComponent,
|
|
58
|
+
InputSelectComponent,
|
|
59
|
+
InputPesquisaComponent,
|
|
60
|
+
ModelTreeviewComponent,
|
|
61
|
+
InputValorComponent
|
|
46
62
|
],
|
|
47
63
|
imports: [
|
|
48
64
|
CommonModule,
|
|
@@ -53,9 +69,13 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
|
|
|
53
69
|
exports: [
|
|
54
70
|
AppprojectComponentsComponent,
|
|
55
71
|
InputTextComponent,
|
|
56
|
-
InputFormatComponent
|
|
72
|
+
InputFormatComponent,
|
|
73
|
+
InputSelectComponent,
|
|
74
|
+
InputPesquisaComponent,
|
|
75
|
+
ModelTreeviewComponent,
|
|
76
|
+
InputValorComponent
|
|
57
77
|
],
|
|
58
78
|
schemas: [CUSTOM_ELEMENTS_SCHEMA]
|
|
59
79
|
}]
|
|
60
80
|
}] });
|
|
61
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
81
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwcHJvamVjdC1jb21wb25lbnRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FwcHByb2plY3QtY29tcG9uZW50cy9zcmMvbGliL2FwcHByb2plY3QtY29tcG9uZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLGNBQWMsRUFBdUIsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RHLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRTdFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDOUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUNBQXFDLENBQUM7O0FBTzFFLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksY0FBYyxDQUFZLFdBQVcsQ0FBQyxDQUFDO0FBNkIzRSxNQUFNLE9BQU8sMEJBQTBCO0lBQ3JDLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBaUI7UUFDOUIsT0FBTztZQUNMLFFBQVEsRUFBRSwwQkFBMEI7WUFDcEMsU0FBUyxFQUFFO2dCQUNULDJCQUEyQjtnQkFDM0I7b0JBQ0UsT0FBTyxFQUFFLGdCQUFnQjtvQkFDekIsUUFBUSxFQUFFLE1BQU07aUJBQ2pCO2FBQ0Y7U0FDRixDQUFBO0lBQ0gsQ0FBQzs7dUhBWlUsMEJBQTBCO3dIQUExQiwwQkFBMEIsaUJBekJuQyw2QkFBNkI7UUFDN0Isa0JBQWtCO1FBQ2xCLG9CQUFvQjtRQUNwQixvQkFBb0I7UUFDcEIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QixtQkFBbUIsYUFHbkIsWUFBWTtRQUNaLGdCQUFnQjtRQUNoQixXQUFXO1FBQ1gsbUJBQW1CLGFBR25CLDZCQUE2QjtRQUM3QixrQkFBa0I7UUFDbEIsb0JBQW9CO1FBQ3BCLG9CQUFvQjtRQUNwQixzQkFBc0I7UUFDdEIsc0JBQXNCO1FBQ3RCLG1CQUFtQjt3SEFJViwwQkFBMEIsWUFoQm5DLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsV0FBVztRQUNYLG1CQUFtQjsyRkFhViwwQkFBMEI7a0JBM0J0QyxRQUFRO21CQUFDO29CQUNSLFlBQVksRUFBRTt3QkFDWiw2QkFBNkI7d0JBQzdCLGtCQUFrQjt3QkFDbEIsb0JBQW9CO3dCQUNwQixvQkFBb0I7d0JBQ3BCLHNCQUFzQjt3QkFDdEIsc0JBQXNCO3dCQUN0QixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRTt3QkFDUCxZQUFZO3dCQUNaLGdCQUFnQjt3QkFDaEIsV0FBVzt3QkFDWCxtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRTt3QkFDUCw2QkFBNkI7d0JBQzdCLGtCQUFrQjt3QkFDbEIsb0JBQW9CO3dCQUNwQixvQkFBb0I7d0JBQ3BCLHNCQUFzQjt3QkFDdEIsc0JBQXNCO3dCQUN0QixtQkFBbUI7cUJBQ3BCO29CQUNELE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIEluamVjdGlvblRva2VuLCBNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQXBwcHJvamVjdENvbXBvbmVudHNDb21wb25lbnQgfSBmcm9tICcuL2FwcHByb2plY3QtY29tcG9uZW50cy5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5wdXRUZXh0Q29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC10ZXh0L2lucHV0LXRleHQuY29tcG9uZW50JztcbmltcG9ydCB7IElucHV0Rm9ybWF0Q29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1mb3JtYXQvaW5wdXQtZm9ybWF0LmNvbXBvbmVudCc7XG5cbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBJb25pY01vZHVsZSB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyJztcbmltcG9ydCB7IEh0dHBDbGllbnRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBBcHBwcm9qZWN0Q29tcG9uZW50c1NlcnZpY2UgfSBmcm9tICcuL2FwcHByb2plY3QtY29tcG9uZW50cy5zZXJ2aWNlJztcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBJbnB1dFNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtc2VsZWN0L2lucHV0LXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5wdXRQZXNxdWlzYUNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtcGVzcXVpc2EvaW5wdXQtcGVzcXVpc2EuY29tcG9uZW50JztcbmltcG9ydCB7IE1vZGVsVHJlZXZpZXdDb21wb25lbnQgfSBmcm9tICcuL21vZGVsLXRyZWV2aWV3L21vZGVsLXRyZWV2aWV3LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJbnB1dFZhbG9yQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC12YWxvci9pbnB1dC12YWxvci5jb21wb25lbnQnO1xuXG5cbmV4cG9ydCBpbnRlcmZhY2UgTGliQ29uZmlnIHtcbiAgYXBpVXJsOiBzdHJpbmc7XG59XG5cbmV4cG9ydCBjb25zdCBMaWJDb25maWdTZXJ2aWNlID0gbmV3IEluamVjdGlvblRva2VuPExpYkNvbmZpZz4oJ0xpYkNvbmZpZycpO1xuXG5ATmdNb2R1bGUoe1xuICBkZWNsYXJhdGlvbnM6IFtcbiAgICBBcHBwcm9qZWN0Q29tcG9uZW50c0NvbXBvbmVudCxcbiAgICBJbnB1dFRleHRDb21wb25lbnQsXG4gICAgSW5wdXRGb3JtYXRDb21wb25lbnQsXG4gICAgSW5wdXRTZWxlY3RDb21wb25lbnQsXG4gICAgSW5wdXRQZXNxdWlzYUNvbXBvbmVudCxcbiAgICBNb2RlbFRyZWV2aWV3Q29tcG9uZW50LFxuICAgIElucHV0VmFsb3JDb21wb25lbnRcbiAgXSxcbiAgaW1wb3J0czogW1xuICAgIENvbW1vbk1vZHVsZSxcbiAgICBIdHRwQ2xpZW50TW9kdWxlLFxuICAgIElvbmljTW9kdWxlLFxuICAgIFJlYWN0aXZlRm9ybXNNb2R1bGVcbiAgXSxcbiAgZXhwb3J0czogW1xuICAgIEFwcHByb2plY3RDb21wb25lbnRzQ29tcG9uZW50LFxuICAgIElucHV0VGV4dENvbXBvbmVudCxcbiAgICBJbnB1dEZvcm1hdENvbXBvbmVudCxcbiAgICBJbnB1dFNlbGVjdENvbXBvbmVudCxcbiAgICBJbnB1dFBlc3F1aXNhQ29tcG9uZW50LFxuICAgIE1vZGVsVHJlZXZpZXdDb21wb25lbnQsXG4gICAgSW5wdXRWYWxvckNvbXBvbmVudFxuICBdLFxuICBzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQV1cbn0pXG5leHBvcnQgY2xhc3MgQXBwcHJvamVjdENvbXBvbmVudHNNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdChjb25maWc6IExpYkNvbmZpZyk6IE1vZHVsZVdpdGhQcm92aWRlcnM8QXBwcHJvamVjdENvbXBvbmVudHNNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IEFwcHByb2plY3RDb21wb25lbnRzTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIEFwcHByb2plY3RDb21wb25lbnRzU2VydmljZSxcbiAgICAgICAge1xuICAgICAgICAgIHByb3ZpZGU6IExpYkNvbmZpZ1NlcnZpY2UsXG4gICAgICAgICAgdXNlVmFsdWU6IGNvbmZpZ1xuICAgICAgICB9XG4gICAgICBdXG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -1,14 +1,129 @@
|
|
|
1
|
-
import { Component } from '@angular/core';
|
|
1
|
+
import { Component, Input } from '@angular/core';
|
|
2
|
+
import { NG_VALUE_ACCESSOR } from '@angular/forms';
|
|
3
|
+
import { BaseInputComponent } from '../baseInputComponent';
|
|
2
4
|
import * as i0 from "@angular/core";
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
5
|
+
import * as i1 from "@angular/common";
|
|
6
|
+
import * as i2 from "@ionic/angular";
|
|
7
|
+
export class InputFormatComponent extends BaseInputComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
super();
|
|
10
|
+
this.formato = null;
|
|
11
|
+
this.keyEnter = null;
|
|
12
|
+
//control value acessor
|
|
13
|
+
this.data = null;
|
|
14
|
+
this.onChange = (data) => { };
|
|
15
|
+
this.onTouch = () => { };
|
|
16
|
+
this.disabled = false;
|
|
17
|
+
this.console = console;
|
|
18
|
+
}
|
|
19
|
+
writeValue(value) {
|
|
20
|
+
//console.log('write value', value);
|
|
21
|
+
this.onChange(value);
|
|
22
|
+
this.data = value;
|
|
23
|
+
}
|
|
24
|
+
registerOnChange(fn) {
|
|
25
|
+
this.onChange = fn;
|
|
26
|
+
}
|
|
27
|
+
registerOnTouched(fn) {
|
|
28
|
+
this.onTouch = fn;
|
|
29
|
+
}
|
|
30
|
+
setDisabledState(isDisabled) {
|
|
31
|
+
this.disabled = this.disabled;
|
|
32
|
+
}
|
|
33
|
+
ngOnInit() { }
|
|
34
|
+
digitarFormatado(event) {
|
|
35
|
+
console.log(event);
|
|
36
|
+
if ((event.keyCode >= 48 && event.keyCode <= 57)
|
|
37
|
+
|| (event.keyCode >= 96 && event.keyCode <= 105)
|
|
38
|
+
|| (event.keyCode == 8)
|
|
39
|
+
|| (event.keyCode == 9)
|
|
40
|
+
|| (event.keyCode == 39)
|
|
41
|
+
|| (event.keyCode == 37)
|
|
42
|
+
|| (event.keyCode == 46)) {
|
|
43
|
+
//console.log(this.formControlName, this.form.get(this.formControlName).value);
|
|
44
|
+
setTimeout(() => {
|
|
45
|
+
if (this.form) {
|
|
46
|
+
this.form.patchValue({
|
|
47
|
+
[this.formControlName]: this.formataCampoValor(this.form.get(this.formControlName)?.value, this.formato ?? '', event)
|
|
48
|
+
});
|
|
49
|
+
}
|
|
50
|
+
else {
|
|
51
|
+
this.data = this.formataCampoValor(this.data ?? '', this.formato ?? '', event);
|
|
52
|
+
this.writeValue(this.data);
|
|
53
|
+
}
|
|
54
|
+
}, 100);
|
|
55
|
+
return true;
|
|
56
|
+
}
|
|
57
|
+
else {
|
|
58
|
+
return false;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
onKeyEnter() {
|
|
62
|
+
if (this.keyEnter != null) {
|
|
63
|
+
this.keyEnter();
|
|
64
|
+
}
|
|
65
|
+
}
|
|
66
|
+
onBlur() {
|
|
67
|
+
if (this.form) {
|
|
68
|
+
this.form.get(this.formControlName)?.markAsTouched();
|
|
69
|
+
}
|
|
70
|
+
if (this.blur) {
|
|
71
|
+
this.blur(this.blurArgs);
|
|
72
|
+
}
|
|
73
|
+
}
|
|
74
|
+
formataCampoValor(valor, Mascara, evento) {
|
|
75
|
+
console.log(valor);
|
|
76
|
+
if (!valor)
|
|
77
|
+
return null;
|
|
78
|
+
//console.log(evento);
|
|
79
|
+
//if (!this.keypressInteiro(evento))
|
|
80
|
+
// return;
|
|
81
|
+
var boleanoMascara;
|
|
82
|
+
var Digitato = evento != null ? evento.keyCode : 0;
|
|
83
|
+
let exp = /\-|\.|\/|\(|\)| /g;
|
|
84
|
+
let campoSoNumeros = valor.replace(exp, "");
|
|
85
|
+
var posicaoCampo = 0;
|
|
86
|
+
var NovoValorCampo = "";
|
|
87
|
+
var TamanhoMascara = campoSoNumeros.length;
|
|
88
|
+
;
|
|
89
|
+
if (Digitato != 8) { // backspace
|
|
90
|
+
for (let i = 0; i <= TamanhoMascara; i++) {
|
|
91
|
+
boleanoMascara = ((Mascara.charAt(i) == "-") || (Mascara.charAt(i) == ".")
|
|
92
|
+
|| (Mascara.charAt(i) == "/"));
|
|
93
|
+
boleanoMascara = boleanoMascara || ((Mascara.charAt(i) == "(")
|
|
94
|
+
|| (Mascara.charAt(i) == ")") || (Mascara.charAt(i) == " "));
|
|
95
|
+
if (boleanoMascara) {
|
|
96
|
+
NovoValorCampo += Mascara.charAt(i);
|
|
97
|
+
TamanhoMascara++;
|
|
98
|
+
}
|
|
99
|
+
else {
|
|
100
|
+
NovoValorCampo += campoSoNumeros.charAt(posicaoCampo);
|
|
101
|
+
posicaoCampo++;
|
|
102
|
+
}
|
|
103
|
+
}
|
|
104
|
+
return NovoValorCampo;
|
|
105
|
+
}
|
|
106
|
+
else {
|
|
107
|
+
return valor;
|
|
108
|
+
}
|
|
6
109
|
}
|
|
7
110
|
}
|
|
8
111
|
InputFormatComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: InputFormatComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
9
|
-
InputFormatComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: InputFormatComponent, selector: "kb-input-format",
|
|
112
|
+
InputFormatComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: InputFormatComponent, selector: "kb-input-format", inputs: { formato: "formato", keyEnter: "keyEnter" }, providers: [{
|
|
113
|
+
provide: NG_VALUE_ACCESSOR,
|
|
114
|
+
useExisting: InputFormatComponent,
|
|
115
|
+
multi: true
|
|
116
|
+
}], usesInheritance: true, ngImport: i0, template: "<!--\n<div [formGroup]=\"form\">\n-->\n<!--comando --inner-padding-end: utilizado pra remover padding desnecess\u00E1rios-->\n<div>\n <ion-item lines=\"none\" style=\"--background: inherited;--background-focused: transparent;--inner-padding-end: 0px;\"\n [ngClass]=\"form?.get(formControlName)?.errors && (form?.get(formControlName)?.dirty || form?.get(formControlName)?.touched) ? 'error-shake' : '' \"\n >\n <ion-label [position]=\"labelPosition\">{{ label }}</ion-label>\n <!-- formControlName={{formControlName}} -->\n <ion-input #inputFormat\n type=\"tel\" \n [placeholder]=\"placeholder\"\n maxlength=\"{{ max }}\" \n (keydown)=\"digitarFormatado($event)\" \n (keyup.enter)=\"onKeyEnter()\"\n (ionBlur)=\"onBlur()\"\n [value]=\"data\"\n (input)=\"writeValue(inputFormat.value)\"\n [disabled]=\"readonly\"></ion-input>\n \n </ion-item>\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form && form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n • {{ validation.message }}\n </div>\n </ng-container>\n </div>\n </div>", styles: ["@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-shake ion-label{color:red!important}.error-shake ion-input{animation:shake .4s 1 linear;border:1px solid red!important}.has-focus{border:1px solid var(--ion-color-bluetool)}ion-label{margin-bottom:4px!important}ion-input{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:29px}.error-message{font-size:small;color:red;margin-left:15px}.item-inner{padding-right:0!important}\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", "debounce", "disabled", "enterkeyhint", "inputmode", "max", "maxlength", "min", "minlength", "mode", "multiple", "name", "pattern", "placeholder", "readonly", "required", "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" }] });
|
|
10
117
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: InputFormatComponent, decorators: [{
|
|
11
118
|
type: Component,
|
|
12
|
-
args: [{ selector: 'kb-input-format',
|
|
13
|
-
|
|
14
|
-
|
|
119
|
+
args: [{ selector: 'kb-input-format', providers: [{
|
|
120
|
+
provide: NG_VALUE_ACCESSOR,
|
|
121
|
+
useExisting: InputFormatComponent,
|
|
122
|
+
multi: true
|
|
123
|
+
}], template: "<!--\n<div [formGroup]=\"form\">\n-->\n<!--comando --inner-padding-end: utilizado pra remover padding desnecess\u00E1rios-->\n<div>\n <ion-item lines=\"none\" style=\"--background: inherited;--background-focused: transparent;--inner-padding-end: 0px;\"\n [ngClass]=\"form?.get(formControlName)?.errors && (form?.get(formControlName)?.dirty || form?.get(formControlName)?.touched) ? 'error-shake' : '' \"\n >\n <ion-label [position]=\"labelPosition\">{{ label }}</ion-label>\n <!-- formControlName={{formControlName}} -->\n <ion-input #inputFormat\n type=\"tel\" \n [placeholder]=\"placeholder\"\n maxlength=\"{{ max }}\" \n (keydown)=\"digitarFormatado($event)\" \n (keyup.enter)=\"onKeyEnter()\"\n (ionBlur)=\"onBlur()\"\n [value]=\"data\"\n (input)=\"writeValue(inputFormat.value)\"\n [disabled]=\"readonly\"></ion-input>\n \n </ion-item>\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form && form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n • {{ validation.message }}\n </div>\n </ng-container>\n </div>\n </div>", styles: ["@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-shake ion-label{color:red!important}.error-shake ion-input{animation:shake .4s 1 linear;border:1px solid red!important}.has-focus{border:1px solid var(--ion-color-bluetool)}ion-label{margin-bottom:4px!important}ion-input{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:29px}.error-message{font-size:small;color:red;margin-left:15px}.item-inner{padding-right:0!important}\n"] }]
|
|
124
|
+
}], ctorParameters: function () { return []; }, propDecorators: { formato: [{
|
|
125
|
+
type: Input
|
|
126
|
+
}], keyEnter: [{
|
|
127
|
+
type: Input
|
|
128
|
+
}] } });
|
|
129
|
+
//# 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, Input, OnInit } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { BaseInputComponent } from '../baseInputComponent';\n\n@Component({\n  selector: 'kb-input-format',\n  templateUrl: './input-format.component.html',\n  styleUrls: ['./input-format.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: InputFormatComponent,\n    multi: true\n  }]\n})\nexport class InputFormatComponent extends BaseInputComponent implements OnInit, ControlValueAccessor {\n\n  @Input() formato: string | null = null;\n  @Input() keyEnter: 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  public console = console;\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  constructor() { \n    super();\n  }\n\n  override ngOnInit() { }\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    }\n  }\n\n  onBlur() {\n    if (this.form) {\n      this.form.get(this.formControlName)?.markAsTouched();\n    }\n    if (this.blur) {\n      this.blur(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","<!--\n<div [formGroup]=\"form\">\n-->\n<!--comando --inner-padding-end: utilizado pra remover padding desnecessários-->\n<div>\n    <ion-item lines=\"none\" style=\"--background: inherited;--background-focused: transparent;--inner-padding-end: 0px;\"\n    [ngClass]=\"form?.get(formControlName)?.errors && (form?.get(formControlName)?.dirty || form?.get(formControlName)?.touched) ? 'error-shake' : '' \"\n    >\n      <ion-label [position]=\"labelPosition\">{{ label }}</ion-label>\n      <!-- formControlName={{formControlName}} -->\n      <ion-input #inputFormat\n      type=\"tel\" \n      [placeholder]=\"placeholder\"\n      maxlength=\"{{ max }}\" \n      (keydown)=\"digitarFormatado($event)\" \n      (keyup.enter)=\"onKeyEnter()\"\n      (ionBlur)=\"onBlur()\"\n      [value]=\"data\"\n      (input)=\"writeValue(inputFormat.value)\"\n      [disabled]=\"readonly\"></ion-input>\n  \n    </ion-item>\n  \n    <div class=\"validation-errors\" *ngIf=\"form\">\n      <ng-container *ngFor=\"let validation of validation_messages\">\n        <div class=\"error-message\"\n          *ngIf=\"form && form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n          &#8226; {{ validation.message }}\n        </div>\n      </ng-container>\n    </div>\n  </div>"]}
|