appproject-components 0.0.2 → 0.0.5
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 +10 -5
- package/esm2020/lib/input-area/input-area.component.mjs +53 -0
- package/esm2020/lib/input-format/input-format.component.mjs +5 -4
- package/esm2020/lib/input-pesquisa/input-pesquisa.component.mjs +5 -5
- package/esm2020/lib/input-select/input-select.component.mjs +2 -2
- package/esm2020/lib/input-text/input-text.component.mjs +2 -2
- package/esm2020/lib/input-valor/input-valor.component.mjs +6 -3
- package/esm2020/public-api.mjs +2 -1
- package/fesm2015/appproject-components.mjs +74 -18
- package/fesm2015/appproject-components.mjs.map +1 -1
- package/fesm2020/appproject-components.mjs +73 -18
- package/fesm2020/appproject-components.mjs.map +1 -1
- package/lib/appproject-components.module.d.ts +6 -5
- package/lib/input-area/input-area.component.d.ts +21 -0
- package/package.json +1 -1
- package/public-api.d.ts +1 -0
|
@@ -11,6 +11,7 @@ import { InputSelectComponent } from './input-select/input-select.component';
|
|
|
11
11
|
import { InputPesquisaComponent } from './input-pesquisa/input-pesquisa.component';
|
|
12
12
|
import { ModelTreeviewComponent } from './model-treeview/model-treeview.component';
|
|
13
13
|
import { InputValorComponent } from './input-valor/input-valor.component';
|
|
14
|
+
import { InputAreaComponent } from './input-area/input-area.component';
|
|
14
15
|
import * as i0 from "@angular/core";
|
|
15
16
|
export const LibConfigService = new InjectionToken('LibConfig');
|
|
16
17
|
export class AppprojectComponentsModule {
|
|
@@ -34,7 +35,8 @@ AppprojectComponentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.
|
|
|
34
35
|
InputSelectComponent,
|
|
35
36
|
InputPesquisaComponent,
|
|
36
37
|
ModelTreeviewComponent,
|
|
37
|
-
InputValorComponent
|
|
38
|
+
InputValorComponent,
|
|
39
|
+
InputAreaComponent], imports: [CommonModule,
|
|
38
40
|
HttpClientModule,
|
|
39
41
|
IonicModule,
|
|
40
42
|
ReactiveFormsModule], exports: [AppprojectComponentsComponent,
|
|
@@ -43,7 +45,8 @@ AppprojectComponentsModule.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.
|
|
|
43
45
|
InputSelectComponent,
|
|
44
46
|
InputPesquisaComponent,
|
|
45
47
|
ModelTreeviewComponent,
|
|
46
|
-
InputValorComponent
|
|
48
|
+
InputValorComponent,
|
|
49
|
+
InputAreaComponent] });
|
|
47
50
|
AppprojectComponentsModule.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: AppprojectComponentsModule, imports: [CommonModule,
|
|
48
51
|
HttpClientModule,
|
|
49
52
|
IonicModule,
|
|
@@ -58,7 +61,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
|
|
|
58
61
|
InputSelectComponent,
|
|
59
62
|
InputPesquisaComponent,
|
|
60
63
|
ModelTreeviewComponent,
|
|
61
|
-
InputValorComponent
|
|
64
|
+
InputValorComponent,
|
|
65
|
+
InputAreaComponent
|
|
62
66
|
],
|
|
63
67
|
imports: [
|
|
64
68
|
CommonModule,
|
|
@@ -73,9 +77,10 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
|
|
|
73
77
|
InputSelectComponent,
|
|
74
78
|
InputPesquisaComponent,
|
|
75
79
|
ModelTreeviewComponent,
|
|
76
|
-
InputValorComponent
|
|
80
|
+
InputValorComponent,
|
|
81
|
+
InputAreaComponent
|
|
77
82
|
],
|
|
78
83
|
schemas: [CUSTOM_ELEMENTS_SCHEMA]
|
|
79
84
|
}]
|
|
80
85
|
}] });
|
|
81
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwcHJvamVjdC1jb21wb25lbnRzLm1vZHVsZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2FwcHByb2plY3QtY29tcG9uZW50cy9zcmMvbGliL2FwcHByb2plY3QtY29tcG9uZW50cy5tb2R1bGUudHMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQUEsT0FBTyxFQUFFLHNCQUFzQixFQUFFLGNBQWMsRUFBdUIsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQ3RHLE9BQU8sRUFBRSw2QkFBNkIsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ2xGLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxNQUFNLG1DQUFtQyxDQUFDO0FBQ3ZFLE9BQU8sRUFBRSxvQkFBb0IsRUFBRSxNQUFNLHVDQUF1QyxDQUFDO0FBRTdFLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQztBQUMvQyxPQUFPLEVBQUUsV0FBVyxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDN0MsT0FBTyxFQUFFLGdCQUFnQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFDeEQsT0FBTyxFQUFFLDJCQUEyQixFQUFFLE1BQU0saUNBQWlDLENBQUM7QUFDOUUsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFDckQsT0FBTyxFQUFFLG9CQUFvQixFQUFFLE1BQU0sdUNBQXVDLENBQUM7QUFDN0UsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLHNCQUFzQixFQUFFLE1BQU0sMkNBQTJDLENBQUM7QUFDbkYsT0FBTyxFQUFFLG1CQUFtQixFQUFFLE1BQU0scUNBQXFDLENBQUM7QUFDMUUsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7O0FBT3ZFLE1BQU0sQ0FBQyxNQUFNLGdCQUFnQixHQUFHLElBQUksY0FBYyxDQUFZLFdBQVcsQ0FBQyxDQUFDO0FBK0IzRSxNQUFNLE9BQU8sMEJBQTBCO0lBQ3JDLE1BQU0sQ0FBQyxPQUFPLENBQUMsTUFBaUI7UUFDOUIsT0FBTztZQUNMLFFBQVEsRUFBRSwwQkFBMEI7WUFDcEMsU0FBUyxFQUFFO2dCQUNULDJCQUEyQjtnQkFDM0I7b0JBQ0UsT0FBTyxFQUFFLGdCQUFnQjtvQkFDekIsUUFBUSxFQUFFLE1BQU07aUJBQ2pCO2FBQ0Y7U0FDRixDQUFBO0lBQ0gsQ0FBQzs7dUhBWlUsMEJBQTBCO3dIQUExQiwwQkFBMEIsaUJBM0JuQyw2QkFBNkI7UUFDN0Isa0JBQWtCO1FBQ2xCLG9CQUFvQjtRQUNwQixvQkFBb0I7UUFDcEIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QixtQkFBbUI7UUFDbkIsa0JBQWtCLGFBR2xCLFlBQVk7UUFDWixnQkFBZ0I7UUFDaEIsV0FBVztRQUNYLG1CQUFtQixhQUduQiw2QkFBNkI7UUFDN0Isa0JBQWtCO1FBQ2xCLG9CQUFvQjtRQUNwQixvQkFBb0I7UUFDcEIsc0JBQXNCO1FBQ3RCLHNCQUFzQjtRQUN0QixtQkFBbUI7UUFDbkIsa0JBQWtCO3dIQUlULDBCQUEwQixZQWpCbkMsWUFBWTtRQUNaLGdCQUFnQjtRQUNoQixXQUFXO1FBQ1gsbUJBQW1COzJGQWNWLDBCQUEwQjtrQkE3QnRDLFFBQVE7bUJBQUM7b0JBQ1IsWUFBWSxFQUFFO3dCQUNaLDZCQUE2Qjt3QkFDN0Isa0JBQWtCO3dCQUNsQixvQkFBb0I7d0JBQ3BCLG9CQUFvQjt3QkFDcEIsc0JBQXNCO3dCQUN0QixzQkFBc0I7d0JBQ3RCLG1CQUFtQjt3QkFDbkIsa0JBQWtCO3FCQUNuQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsWUFBWTt3QkFDWixnQkFBZ0I7d0JBQ2hCLFdBQVc7d0JBQ1gsbUJBQW1CO3FCQUNwQjtvQkFDRCxPQUFPLEVBQUU7d0JBQ1AsNkJBQTZCO3dCQUM3QixrQkFBa0I7d0JBQ2xCLG9CQUFvQjt3QkFDcEIsb0JBQW9CO3dCQUNwQixzQkFBc0I7d0JBQ3RCLHNCQUFzQjt3QkFDdEIsbUJBQW1CO3dCQUNuQixrQkFBa0I7cUJBQ25CO29CQUNELE9BQU8sRUFBRSxDQUFDLHNCQUFzQixDQUFDO2lCQUNsQyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENVU1RPTV9FTEVNRU5UU19TQ0hFTUEsIEluamVjdGlvblRva2VuLCBNb2R1bGVXaXRoUHJvdmlkZXJzLCBOZ01vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQXBwcHJvamVjdENvbXBvbmVudHNDb21wb25lbnQgfSBmcm9tICcuL2FwcHByb2plY3QtY29tcG9uZW50cy5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5wdXRUZXh0Q29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC10ZXh0L2lucHV0LXRleHQuY29tcG9uZW50JztcbmltcG9ydCB7IElucHV0Rm9ybWF0Q29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1mb3JtYXQvaW5wdXQtZm9ybWF0LmNvbXBvbmVudCc7XG5cbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBJb25pY01vZHVsZSB9IGZyb20gJ0Bpb25pYy9hbmd1bGFyJztcbmltcG9ydCB7IEh0dHBDbGllbnRNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XG5pbXBvcnQgeyBBcHBwcm9qZWN0Q29tcG9uZW50c1NlcnZpY2UgfSBmcm9tICcuL2FwcHByb2plY3QtY29tcG9uZW50cy5zZXJ2aWNlJztcbmltcG9ydCB7IFJlYWN0aXZlRm9ybXNNb2R1bGUgfSBmcm9tICdAYW5ndWxhci9mb3Jtcyc7XG5pbXBvcnQgeyBJbnB1dFNlbGVjdENvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtc2VsZWN0L2lucHV0LXNlbGVjdC5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5wdXRQZXNxdWlzYUNvbXBvbmVudCB9IGZyb20gJy4vaW5wdXQtcGVzcXVpc2EvaW5wdXQtcGVzcXVpc2EuY29tcG9uZW50JztcbmltcG9ydCB7IE1vZGVsVHJlZXZpZXdDb21wb25lbnQgfSBmcm9tICcuL21vZGVsLXRyZWV2aWV3L21vZGVsLXRyZWV2aWV3LmNvbXBvbmVudCc7XG5pbXBvcnQgeyBJbnB1dFZhbG9yQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC12YWxvci9pbnB1dC12YWxvci5jb21wb25lbnQnO1xuaW1wb3J0IHsgSW5wdXRBcmVhQ29tcG9uZW50IH0gZnJvbSAnLi9pbnB1dC1hcmVhL2lucHV0LWFyZWEuY29tcG9uZW50JztcblxuXG5leHBvcnQgaW50ZXJmYWNlIExpYkNvbmZpZyB7XG4gIGFwaVVybDogc3RyaW5nO1xufVxuXG5leHBvcnQgY29uc3QgTGliQ29uZmlnU2VydmljZSA9IG5ldyBJbmplY3Rpb25Ub2tlbjxMaWJDb25maWc+KCdMaWJDb25maWcnKTtcblxuQE5nTW9kdWxlKHtcbiAgZGVjbGFyYXRpb25zOiBbXG4gICAgQXBwcHJvamVjdENvbXBvbmVudHNDb21wb25lbnQsXG4gICAgSW5wdXRUZXh0Q29tcG9uZW50LFxuICAgIElucHV0Rm9ybWF0Q29tcG9uZW50LFxuICAgIElucHV0U2VsZWN0Q29tcG9uZW50LFxuICAgIElucHV0UGVzcXVpc2FDb21wb25lbnQsXG4gICAgTW9kZWxUcmVldmlld0NvbXBvbmVudCxcbiAgICBJbnB1dFZhbG9yQ29tcG9uZW50LFxuICAgIElucHV0QXJlYUNvbXBvbmVudFxuICBdLFxuICBpbXBvcnRzOiBbXG4gICAgQ29tbW9uTW9kdWxlLFxuICAgIEh0dHBDbGllbnRNb2R1bGUsXG4gICAgSW9uaWNNb2R1bGUsXG4gICAgUmVhY3RpdmVGb3Jtc01vZHVsZVxuICBdLFxuICBleHBvcnRzOiBbXG4gICAgQXBwcHJvamVjdENvbXBvbmVudHNDb21wb25lbnQsXG4gICAgSW5wdXRUZXh0Q29tcG9uZW50LFxuICAgIElucHV0Rm9ybWF0Q29tcG9uZW50LFxuICAgIElucHV0U2VsZWN0Q29tcG9uZW50LFxuICAgIElucHV0UGVzcXVpc2FDb21wb25lbnQsXG4gICAgTW9kZWxUcmVldmlld0NvbXBvbmVudCxcbiAgICBJbnB1dFZhbG9yQ29tcG9uZW50LFxuICAgIElucHV0QXJlYUNvbXBvbmVudFxuICBdLFxuICBzY2hlbWFzOiBbQ1VTVE9NX0VMRU1FTlRTX1NDSEVNQV1cbn0pXG5leHBvcnQgY2xhc3MgQXBwcHJvamVjdENvbXBvbmVudHNNb2R1bGUge1xuICBzdGF0aWMgZm9yUm9vdChjb25maWc6IExpYkNvbmZpZyk6IE1vZHVsZVdpdGhQcm92aWRlcnM8QXBwcHJvamVjdENvbXBvbmVudHNNb2R1bGU+IHtcbiAgICByZXR1cm4ge1xuICAgICAgbmdNb2R1bGU6IEFwcHByb2plY3RDb21wb25lbnRzTW9kdWxlLFxuICAgICAgcHJvdmlkZXJzOiBbXG4gICAgICAgIEFwcHByb2plY3RDb21wb25lbnRzU2VydmljZSxcbiAgICAgICAge1xuICAgICAgICAgIHByb3ZpZGU6IExpYkNvbmZpZ1NlcnZpY2UsXG4gICAgICAgICAgdXNlVmFsdWU6IGNvbmZpZ1xuICAgICAgICB9XG4gICAgICBdXG4gICAgfVxuICB9XG59XG4iXX0=
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { Component, Input } 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 InputAreaComponent extends BaseInputComponent {
|
|
8
|
+
constructor() {
|
|
9
|
+
super();
|
|
10
|
+
this.linhas = 5;
|
|
11
|
+
this.onChange = (data) => { };
|
|
12
|
+
this.onTouch = () => { };
|
|
13
|
+
this.disabled = false;
|
|
14
|
+
this.console = console;
|
|
15
|
+
}
|
|
16
|
+
writeValue(value) {
|
|
17
|
+
//console.log('write value', value);
|
|
18
|
+
this.onChange(value);
|
|
19
|
+
this.data = value;
|
|
20
|
+
}
|
|
21
|
+
registerOnChange(fn) {
|
|
22
|
+
this.onChange = fn;
|
|
23
|
+
}
|
|
24
|
+
registerOnTouched(fn) {
|
|
25
|
+
this.onTouch = fn;
|
|
26
|
+
}
|
|
27
|
+
setDisabledState(isDisabled) {
|
|
28
|
+
this.disabled = this.disabled;
|
|
29
|
+
}
|
|
30
|
+
ngOnInit() { }
|
|
31
|
+
onBlur() {
|
|
32
|
+
if (this.form) {
|
|
33
|
+
this.form.get(this.formControlName)?.markAsTouched();
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
}
|
|
37
|
+
InputAreaComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: InputAreaComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
38
|
+
InputAreaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "14.1.2", type: InputAreaComponent, selector: "kb-input-area", inputs: { linhas: "linhas" }, providers: [{
|
|
39
|
+
provide: NG_VALUE_ACCESSOR,
|
|
40
|
+
useExisting: InputAreaComponent,
|
|
41
|
+
multi: true
|
|
42
|
+
}], usesInheritance: true, ngImport: i0, template: "<div>\n <ion-item lines=\"none\" style=\"--background-focused: transparent;\">\n <ion-label position=\"{{ labelPosition }}\">{{ label }}</ion-label>\n <!-- formControlName=\"{{ formControlName }}\" -->\n <ion-textarea #inputArea\n type=\"{{type}}\" \n [placeholder]=\"placeholder\" \n maxlength=\"{{ max }}\"\n (ionBlur)=\"onBlur()\"\n [value]=\"data\"\n [rows]=\"linhas\" \n (input)=\"writeValue(inputArea.value)\"\n [disabled]=\"readonly\"></ion-textarea>\n </ion-item>\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n \n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n • {{ validation.message }}\n </div>\n </ng-container>\n \n </div>\n </div>", styles: ["ion-label{margin-bottom:4px!important}ion-textarea{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px}input:focus{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}.error-message{font-size:small;color:var(--error-text-color, red);margin-left:15px}\n"], dependencies: [{ 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.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: "component", type: i2.IonTextarea, selector: "ion-textarea", inputs: ["autoGrow", "autocapitalize", "autofocus", "clearOnEdit", "color", "cols", "debounce", "disabled", "enterkeyhint", "inputmode", "maxlength", "minlength", "mode", "name", "placeholder", "readonly", "required", "rows", "spellcheck", "value", "wrap"] }, { kind: "directive", type: i2.TextValueAccessor, selector: "ion-input:not([type=number]),ion-textarea,ion-searchbar" }] });
|
|
43
|
+
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: InputAreaComponent, decorators: [{
|
|
44
|
+
type: Component,
|
|
45
|
+
args: [{ selector: 'kb-input-area', providers: [{
|
|
46
|
+
provide: NG_VALUE_ACCESSOR,
|
|
47
|
+
useExisting: InputAreaComponent,
|
|
48
|
+
multi: true
|
|
49
|
+
}], template: "<div>\n <ion-item lines=\"none\" style=\"--background-focused: transparent;\">\n <ion-label position=\"{{ labelPosition }}\">{{ label }}</ion-label>\n <!-- formControlName=\"{{ formControlName }}\" -->\n <ion-textarea #inputArea\n type=\"{{type}}\" \n [placeholder]=\"placeholder\" \n maxlength=\"{{ max }}\"\n (ionBlur)=\"onBlur()\"\n [value]=\"data\"\n [rows]=\"linhas\" \n (input)=\"writeValue(inputArea.value)\"\n [disabled]=\"readonly\"></ion-textarea>\n </ion-item>\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n \n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n • {{ validation.message }}\n </div>\n </ng-container>\n \n </div>\n </div>", styles: ["ion-label{margin-bottom:4px!important}ion-textarea{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px}input:focus{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}.error-message{font-size:small;color:var(--error-text-color, red);margin-left:15px}\n"] }]
|
|
50
|
+
}], ctorParameters: function () { return []; }, propDecorators: { linhas: [{
|
|
51
|
+
type: Input
|
|
52
|
+
}] } });
|
|
53
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5wdXQtYXJlYS5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9hcHBwcm9qZWN0LWNvbXBvbmVudHMvc3JjL2xpYi9pbnB1dC1hcmVhL2lucHV0LWFyZWEuY29tcG9uZW50LnRzIiwiLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvYXBwcHJvamVjdC1jb21wb25lbnRzL3NyYy9saWIvaW5wdXQtYXJlYS9pbnB1dC1hcmVhLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFVLE1BQU0sZUFBZSxDQUFDO0FBQ3pELE9BQU8sRUFBd0IsaUJBQWlCLEVBQUUsTUFBTSxnQkFBZ0IsQ0FBQztBQUN6RSxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQzs7OztBQVkzRCxNQUFNLE9BQU8sa0JBQW1CLFNBQVEsa0JBQWtCO0lBd0J4RDtRQUNFLEtBQUssRUFBRSxDQUFDO1FBeEJELFdBQU0sR0FBVyxDQUFDLENBQUM7UUFJcEIsYUFBUSxHQUFhLENBQUMsSUFBWSxFQUFFLEVBQUUsR0FBRSxDQUFDLENBQUM7UUFDMUMsWUFBTyxHQUFhLEdBQUcsRUFBRSxHQUFFLENBQUMsQ0FBQztRQUM3QixhQUFRLEdBQVksS0FBSyxDQUFDO1FBQzNCLFlBQU8sR0FBRyxPQUFPLENBQUM7SUFrQnpCLENBQUM7SUFoQkQsVUFBVSxDQUFDLEtBQW1CO1FBQzVCLG9DQUFvQztRQUNwQyxJQUFJLENBQUMsUUFBUSxDQUFDLEtBQUssQ0FBQyxDQUFDO1FBQ3JCLElBQUksQ0FBQyxJQUFJLEdBQUcsS0FBSyxDQUFDO0lBQ3BCLENBQUM7SUFDRCxnQkFBZ0IsQ0FBQyxFQUFPO1FBQ3RCLElBQUksQ0FBQyxRQUFRLEdBQUcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFDRCxpQkFBaUIsQ0FBQyxFQUFPO1FBQ3ZCLElBQUksQ0FBQyxPQUFPLEdBQUcsRUFBRSxDQUFDO0lBQ3BCLENBQUM7SUFDRCxnQkFBZ0IsQ0FBRSxVQUFtQjtRQUNuQyxJQUFJLENBQUMsUUFBUSxHQUFHLElBQUksQ0FBQyxRQUFRLENBQUM7SUFDaEMsQ0FBQztJQUtRLFFBQVEsS0FBSSxDQUFDO0lBRXRCLE1BQU07UUFDSixJQUFJLElBQUksQ0FBQyxJQUFJLEVBQUU7WUFDYixJQUFJLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxJQUFJLENBQUMsZUFBZSxDQUFDLEVBQUUsYUFBYSxFQUFFLENBQUM7U0FDdEQ7SUFDSCxDQUFDOzsrR0FsQ1Usa0JBQWtCO21HQUFsQixrQkFBa0Isc0VBTmxCLENBQUM7WUFDVixPQUFPLEVBQUUsaUJBQWlCO1lBQzFCLFdBQVcsRUFBRSxrQkFBa0I7WUFDL0IsS0FBSyxFQUFFLElBQUk7U0FDWixDQUFDLGlEQ1pKLGkrQkF5QlE7MkZEWEssa0JBQWtCO2tCQVY5QixTQUFTOytCQUNFLGVBQWUsYUFHZCxDQUFDOzRCQUNWLE9BQU8sRUFBRSxpQkFBaUI7NEJBQzFCLFdBQVcsb0JBQW9COzRCQUMvQixLQUFLLEVBQUUsSUFBSTt5QkFDWixDQUFDOzBFQUdPLE1BQU07c0JBQWQsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7IENvbXBvbmVudCwgSW5wdXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29udHJvbFZhbHVlQWNjZXNzb3IsIE5HX1ZBTFVFX0FDQ0VTU09SIH0gZnJvbSAnQGFuZ3VsYXIvZm9ybXMnO1xuaW1wb3J0IHsgQmFzZUlucHV0Q29tcG9uZW50IH0gZnJvbSAnLi4vYmFzZUlucHV0Q29tcG9uZW50JztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAna2ItaW5wdXQtYXJlYScsXG4gIHRlbXBsYXRlVXJsOiAnLi9pbnB1dC1hcmVhLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vaW5wdXQtYXJlYS5jb21wb25lbnQuc2NzcyddLFxuICBwcm92aWRlcnM6IFt7XG4gICAgcHJvdmlkZTogTkdfVkFMVUVfQUNDRVNTT1IsXG4gICAgdXNlRXhpc3Rpbmc6IElucHV0QXJlYUNvbXBvbmVudCxcbiAgICBtdWx0aTogdHJ1ZVxuICB9XVxufSlcbmV4cG9ydCBjbGFzcyBJbnB1dEFyZWFDb21wb25lbnQgZXh0ZW5kcyBCYXNlSW5wdXRDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIENvbnRyb2xWYWx1ZUFjY2Vzc29yIHtcbiAgQElucHV0KCkgbGluaGFzOiBudW1iZXIgPSA1O1xuICBcbiAgLy9jb250cm9sIHZhbHVlIGFjZXNzb3JcbiAgcHVibGljIGRhdGE6IHN0cmluZyB8IGFueTtcbiAgcHJpdmF0ZSBvbkNoYW5nZTogRnVuY3Rpb24gPSAoZGF0YTogc3RyaW5nKSA9PiB7fTtcbiAgcHJpdmF0ZSBvblRvdWNoOiBGdW5jdGlvbiA9ICgpID0+IHt9O1xuICBwcml2YXRlIGRpc2FibGVkOiBib29sZWFuID0gZmFsc2U7XG4gIHB1YmxpYyBjb25zb2xlID0gY29uc29sZTtcblxuICB3cml0ZVZhbHVlKHZhbHVlOiBzdHJpbmcgfCBhbnkpOiB2b2lkIHtcbiAgICAvL2NvbnNvbGUubG9nKCd3cml0ZSB2YWx1ZScsIHZhbHVlKTtcbiAgICB0aGlzLm9uQ2hhbmdlKHZhbHVlKTtcbiAgICB0aGlzLmRhdGEgPSB2YWx1ZTtcbiAgfVxuICByZWdpc3Rlck9uQ2hhbmdlKGZuOiBhbnkpOiB2b2lkIHtcbiAgICB0aGlzLm9uQ2hhbmdlID0gZm47XG4gIH1cbiAgcmVnaXN0ZXJPblRvdWNoZWQoZm46IGFueSk6IHZvaWQge1xuICAgIHRoaXMub25Ub3VjaCA9IGZuO1xuICB9XG4gIHNldERpc2FibGVkU3RhdGU/KGlzRGlzYWJsZWQ6IGJvb2xlYW4pOiB2b2lkIHtcbiAgICB0aGlzLmRpc2FibGVkID0gdGhpcy5kaXNhYmxlZDtcbiAgfVxuICBjb25zdHJ1Y3RvcigpIHsgXG4gICAgc3VwZXIoKTtcbiAgfVxuXG4gIG92ZXJyaWRlIG5nT25Jbml0KCkge31cblxuICBvbkJsdXIoKSB7XG4gICAgaWYgKHRoaXMuZm9ybSkge1xuICAgICAgdGhpcy5mb3JtLmdldCh0aGlzLmZvcm1Db250cm9sTmFtZSk/Lm1hcmtBc1RvdWNoZWQoKTtcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXY+XG4gICAgPGlvbi1pdGVtIGxpbmVzPVwibm9uZVwiIHN0eWxlPVwiLS1iYWNrZ3JvdW5kLWZvY3VzZWQ6IHRyYW5zcGFyZW50O1wiPlxuICAgICAgPGlvbi1sYWJlbCBwb3NpdGlvbj1cInt7IGxhYmVsUG9zaXRpb24gfX1cIj57eyBsYWJlbCB9fTwvaW9uLWxhYmVsPlxuICAgICAgPCEtLSBmb3JtQ29udHJvbE5hbWU9XCJ7eyBmb3JtQ29udHJvbE5hbWUgfX1cIiAgLS0+XG4gICAgICA8aW9uLXRleHRhcmVhICNpbnB1dEFyZWFcbiAgICAgICAgdHlwZT1cInt7dHlwZX19XCIgXG4gICAgICAgIFtwbGFjZWhvbGRlcl09XCJwbGFjZWhvbGRlclwiICAgICAgIFxuICAgICAgICBtYXhsZW5ndGg9XCJ7eyBtYXggfX1cIlxuICAgICAgICAoaW9uQmx1cik9XCJvbkJsdXIoKVwiXG4gICAgICAgIFt2YWx1ZV09XCJkYXRhXCJcbiAgICAgICAgW3Jvd3NdPVwibGluaGFzXCIgICAgICBcbiAgICAgICAgKGlucHV0KT1cIndyaXRlVmFsdWUoaW5wdXRBcmVhLnZhbHVlKVwiXG4gICAgICAgIFtkaXNhYmxlZF09XCJyZWFkb25seVwiPjwvaW9uLXRleHRhcmVhPlxuICAgIDwvaW9uLWl0ZW0+XG4gIFxuICAgIDxkaXYgY2xhc3M9XCJ2YWxpZGF0aW9uLWVycm9yc1wiICpuZ0lmPVwiZm9ybVwiPlxuICBcbiAgICAgIDxuZy1jb250YWluZXIgKm5nRm9yPVwibGV0IHZhbGlkYXRpb24gb2YgdmFsaWRhdGlvbl9tZXNzYWdlc1wiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwiZXJyb3ItbWVzc2FnZVwiXG4gICAgICAgICAgKm5nSWY9XCJmb3JtLmdldChmb3JtQ29udHJvbE5hbWUpPy5oYXNFcnJvcih2YWxpZGF0aW9uLnR5cGUpICYmIChmb3JtLmdldChmb3JtQ29udHJvbE5hbWUpPy5kaXJ0eSB8fCBmb3JtLmdldChmb3JtQ29udHJvbE5hbWUpPy50b3VjaGVkKVwiPlxuICAgICAgICAgICYjODIyNjsge3sgdmFsaWRhdGlvbi5tZXNzYWdlIH19XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9uZy1jb250YWluZXI+XG4gIFxuICAgIDwvZGl2PlxuICA8L2Rpdj4iXX0=
|
|
@@ -38,7 +38,8 @@ export class InputFormatComponent extends BaseInputComponent {
|
|
|
38
38
|
|| (event.keyCode == 8)
|
|
39
39
|
|| (event.keyCode == 9)
|
|
40
40
|
|| (event.keyCode == 39)
|
|
41
|
-
|| (event.keyCode == 37)
|
|
41
|
+
|| (event.keyCode == 37)
|
|
42
|
+
|| (event.keyCode == 46)) {
|
|
42
43
|
//console.log(this.formControlName, this.form.get(this.formControlName).value);
|
|
43
44
|
setTimeout(() => {
|
|
44
45
|
if (this.form) {
|
|
@@ -112,17 +113,17 @@ InputFormatComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", v
|
|
|
112
113
|
provide: NG_VALUE_ACCESSOR,
|
|
113
114
|
useExisting: InputFormatComponent,
|
|
114
115
|
multi: true
|
|
115
|
-
}], 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" }] });
|
|
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:var(--error-text-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" }] });
|
|
116
117
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: InputFormatComponent, decorators: [{
|
|
117
118
|
type: Component,
|
|
118
119
|
args: [{ selector: 'kb-input-format', providers: [{
|
|
119
120
|
provide: NG_VALUE_ACCESSOR,
|
|
120
121
|
useExisting: InputFormatComponent,
|
|
121
122
|
multi: true
|
|
122
|
-
}], 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"] }]
|
|
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:var(--error-text-color, red);margin-left:15px}.item-inner{padding-right:0!important}\n"] }]
|
|
123
124
|
}], ctorParameters: function () { return []; }, propDecorators: { formato: [{
|
|
124
125
|
type: Input
|
|
125
126
|
}], keyEnter: [{
|
|
126
127
|
type: Input
|
|
127
128
|
}] } });
|
|
128
|
-
//# 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\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>"]}
|
|
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>"]}
|
|
@@ -81,9 +81,9 @@ export class InputPesquisaComponent extends BaseInputComponent {
|
|
|
81
81
|
}
|
|
82
82
|
onBlur(event) {
|
|
83
83
|
console.log('blur', event);
|
|
84
|
-
console.log(event.detail.relatedTarget);
|
|
84
|
+
//console.log(event.detail.relatedTarget);
|
|
85
85
|
if (event.detail.relatedTarget == null || event.detail.relatedTarget.id.indexOf(this.selectId + 'IonItem') == -1) {
|
|
86
|
-
console.log("true", event.detail.relatedTarget.id);
|
|
86
|
+
//console.log("true", event.detail.relatedTarget.id);
|
|
87
87
|
//pesquisar item na lista
|
|
88
88
|
if (!this.existeNaListaTexto(this.textoPesquisa, true)) {
|
|
89
89
|
this.limparClick();
|
|
@@ -484,14 +484,14 @@ InputPesquisaComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0",
|
|
|
484
484
|
provide: NG_VALUE_ACCESSOR,
|
|
485
485
|
useExisting: InputPesquisaComponent,
|
|
486
486
|
multi: true
|
|
487
|
-
}], viewQueries: [{ propertyName: "selectElement", first: true, predicate: ["selectElement"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div style=\"padding-inline-end: 0px;\">\n <ion-item lines=\"none\" style=\"--background: inherited; --background-focused: transparent; margin-top: 2px;\" [class]=\"itemClass\">\n <ion-label position=\"{{ labelPosition }}\" color=\"{{ labelColor }}\">{{ label }}</ion-label>\n <!-- formControlName=\"{{ campo }}\" -->\n <ion-spinner *ngIf=\"!podePesquisar\"\n style=\"--min-height: 0px !important; margin-inline-end: 5px !important; margin-top: 16px;\" \n slot=\"start\" name=\"lines\"></ion-spinner>\n <!-- (ionBlur)=\"verificarPesquisa()\" -->\n <!-- conflito com click da lista -->\n <ion-input #inputPesquisa\n type=\"{{type}}\" \n [placeholder]=\"placeholder\" \n maxlength=\"{{ max }}\" \n (ionBlur)=\"onBlur($event)\"\n [value]=\"textoPesquisa\" (input)=\"writePesquisa(inputPesquisa.value)\" \n (keyup)=\"showPesquisa($event)\"\n autocomplete=\"off\" style=\"--background:{{ inputBackgroungColor }};\"\n (click)=\"dropDownPesquisa(-1)\"\n [disabled]=\"readonly\" debounce=\"500\"></ion-input>\n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"limparClick()\">\n <ion-icon name=\"close-outline\"></ion-icon>\n </ion-button>\n \n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"pesquisarClick()\">\n <ion-icon color=\"primary\" name=\"search\"></ion-icon>\n </ion-button>\n \n </ion-item>\n \n <ion-list tabindex=\"-1\" [hidden]=\"!selectElementVisivel || !listaPesquisa || listaPesquisa.length == 0\" class=\"pesquisa-list\" style=\"max-height: 250px; overflow-y: auto;\">\n \n <ion-item tabindex=\"-1\" button *ngFor=\"let item of listaPesquisa\" \n (click)=\"selecionarComboClick(item)\" [id]=\"selectId + 'IonItem' + item['Index']\"\n class=\"pesquisa-item\">\n <!-- {{ item | json}} -->\n <span [class]=\"{'selected-item': item['Selected'] === true}\" [innerHTML]=\"highlight(item[campoDisplay])\"></span>\n </ion-item>\n \n </ion-list>\n \n <!--\n <ion-select interface=\"popover\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (ionChange)=\"selecionarComboChange($event.target.value)\">\n <ion-select-option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </ion-select-option>\n </ion-select>\n -->\n \n <!--\n <select [id]=\"selectId\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (change)=\"selecionarComboChange($event.target.value)\" class=\"pesquisa-select\">\n <option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </option>\n \n </select>\n -->\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n \n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n • {{ validation.message }}\n </div>\n </ng-container>\n \n </div>\n </div>", styles: ["ion-label{margin-bottom:4px!important;opacity:1!important}ion-input{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:29px}input:focus{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}.error-message{font-size:small;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-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.pesquisa-select{display:block;position:absolute;top:58px;left:20px;width:100%;z-index:800;font-size:16px;font-family:Roboto,Helvetica Neue,sans-serif;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.pesquisa-select option{overflow-y:hidden}.pesquisa-select option:hover,.pesquisa-select option:checked{background-color:#add8e6}.pesquisa-list{display:block;position:absolute;
|
|
487
|
+
}], viewQueries: [{ propertyName: "selectElement", first: true, predicate: ["selectElement"], descendants: true }], usesInheritance: true, ngImport: i0, template: "<div style=\"padding-inline-end: 0px;\">\n <ion-item lines=\"none\" style=\"--background: inherited; --background-focused: transparent; margin-top: 2px;\" [class]=\"itemClass\">\n <ion-label position=\"{{ labelPosition }}\" color=\"{{ labelColor }}\">{{ label }}</ion-label>\n <!-- formControlName=\"{{ campo }}\" -->\n <ion-spinner *ngIf=\"!podePesquisar\"\n style=\"--min-height: 0px !important; margin-inline-end: 5px !important; margin-top: 16px;\" \n slot=\"start\" name=\"lines\"></ion-spinner>\n <!-- (ionBlur)=\"verificarPesquisa()\" -->\n <!-- conflito com click da lista -->\n <ion-input #inputPesquisa\n type=\"{{type}}\" \n [placeholder]=\"placeholder\" \n maxlength=\"{{ max }}\" \n (ionBlur)=\"onBlur($event)\"\n [value]=\"textoPesquisa\" (input)=\"writePesquisa(inputPesquisa.value)\" \n (keyup)=\"showPesquisa($event)\"\n autocomplete=\"off\" style=\"--background:{{ inputBackgroungColor }};\"\n (click)=\"dropDownPesquisa(-1)\"\n [disabled]=\"readonly\" debounce=\"500\"></ion-input>\n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"limparClick()\">\n <ion-icon name=\"close-outline\"></ion-icon>\n </ion-button>\n \n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"pesquisarClick()\">\n <ion-icon color=\"primary\" name=\"search\"></ion-icon>\n </ion-button>\n \n </ion-item>\n \n <ion-list tabindex=\"-1\" [hidden]=\"!selectElementVisivel || !listaPesquisa || listaPesquisa.length == 0\" class=\"pesquisa-list\" style=\"max-height: 250px; overflow-y: auto;\">\n \n <ion-item tabindex=\"-1\" button *ngFor=\"let item of listaPesquisa\" \n (click)=\"selecionarComboClick(item)\" [id]=\"selectId + 'IonItem' + item['Index']\"\n class=\"pesquisa-item\">\n <!-- {{ item | json}} -->\n <span [class]=\"{'selected-item': item['Selected'] === true}\" [innerHTML]=\"highlight(item[campoDisplay])\"></span>\n </ion-item>\n \n </ion-list>\n \n <!--\n <ion-select interface=\"popover\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (ionChange)=\"selecionarComboChange($event.target.value)\">\n <ion-select-option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </ion-select-option>\n </ion-select>\n -->\n \n <!--\n <select [id]=\"selectId\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (change)=\"selecionarComboChange($event.target.value)\" class=\"pesquisa-select\">\n <option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </option>\n \n </select>\n -->\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n \n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n • {{ validation.message }}\n </div>\n </ng-container>\n \n </div>\n </div>", styles: ["ion-label{margin-bottom:4px!important;opacity:1!important}ion-input{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:29px}input:focus{border:1px solid lightblue!important}input:focus ion-label{--color: blue !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-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.pesquisa-select{display:block;position:absolute;top:58px;left:20px;width:100%;z-index:800;font-size:16px;font-family:Roboto,Helvetica Neue,sans-serif;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.pesquisa-select option{overflow-y:hidden}.pesquisa-select option:hover,.pesquisa-select option:checked{background-color:#add8e6}.pesquisa-list{display:block;position:absolute;margin-left:20px;margin-top:-4px;width:calc(100% - 50px);z-index:800;border:1px lightgrey solid;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:0}.pesquisa-item{--inner-padding-top: 0px;--inner-padding-bottom: 0px;--padding-top: 0px;--padding-bottom: 0px;--min-height: 30px !important;font-size:12px}.pesquisa-item button{padding:0}.selected-item{background-color:#add8e6}\n"], dependencies: [{ kind: "directive", type: i3.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i3.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.IonButton, selector: "ion-button", inputs: ["buttonType", "color", "disabled", "download", "expand", "fill", "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", "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: "component", type: i2.IonList, selector: "ion-list", inputs: ["inset", "lines", "mode"] }, { kind: "component", type: i2.IonSpinner, selector: "ion-spinner", inputs: ["color", "duration", "name", "paused"] }, { kind: "directive", type: i2.TextValueAccessor, selector: "ion-input:not([type=number]),ion-textarea,ion-searchbar" }] });
|
|
488
488
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImport: i0, type: InputPesquisaComponent, decorators: [{
|
|
489
489
|
type: Component,
|
|
490
490
|
args: [{ selector: 'kb-input-pesquisa', providers: [{
|
|
491
491
|
provide: NG_VALUE_ACCESSOR,
|
|
492
492
|
useExisting: InputPesquisaComponent,
|
|
493
493
|
multi: true
|
|
494
|
-
}], template: "<div style=\"padding-inline-end: 0px;\">\n <ion-item lines=\"none\" style=\"--background: inherited; --background-focused: transparent; margin-top: 2px;\" [class]=\"itemClass\">\n <ion-label position=\"{{ labelPosition }}\" color=\"{{ labelColor }}\">{{ label }}</ion-label>\n <!-- formControlName=\"{{ campo }}\" -->\n <ion-spinner *ngIf=\"!podePesquisar\"\n style=\"--min-height: 0px !important; margin-inline-end: 5px !important; margin-top: 16px;\" \n slot=\"start\" name=\"lines\"></ion-spinner>\n <!-- (ionBlur)=\"verificarPesquisa()\" -->\n <!-- conflito com click da lista -->\n <ion-input #inputPesquisa\n type=\"{{type}}\" \n [placeholder]=\"placeholder\" \n maxlength=\"{{ max }}\" \n (ionBlur)=\"onBlur($event)\"\n [value]=\"textoPesquisa\" (input)=\"writePesquisa(inputPesquisa.value)\" \n (keyup)=\"showPesquisa($event)\"\n autocomplete=\"off\" style=\"--background:{{ inputBackgroungColor }};\"\n (click)=\"dropDownPesquisa(-1)\"\n [disabled]=\"readonly\" debounce=\"500\"></ion-input>\n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"limparClick()\">\n <ion-icon name=\"close-outline\"></ion-icon>\n </ion-button>\n \n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"pesquisarClick()\">\n <ion-icon color=\"primary\" name=\"search\"></ion-icon>\n </ion-button>\n \n </ion-item>\n \n <ion-list tabindex=\"-1\" [hidden]=\"!selectElementVisivel || !listaPesquisa || listaPesquisa.length == 0\" class=\"pesquisa-list\" style=\"max-height: 250px; overflow-y: auto;\">\n \n <ion-item tabindex=\"-1\" button *ngFor=\"let item of listaPesquisa\" \n (click)=\"selecionarComboClick(item)\" [id]=\"selectId + 'IonItem' + item['Index']\"\n class=\"pesquisa-item\">\n <!-- {{ item | json}} -->\n <span [class]=\"{'selected-item': item['Selected'] === true}\" [innerHTML]=\"highlight(item[campoDisplay])\"></span>\n </ion-item>\n \n </ion-list>\n \n <!--\n <ion-select interface=\"popover\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (ionChange)=\"selecionarComboChange($event.target.value)\">\n <ion-select-option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </ion-select-option>\n </ion-select>\n -->\n \n <!--\n <select [id]=\"selectId\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (change)=\"selecionarComboChange($event.target.value)\" class=\"pesquisa-select\">\n <option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </option>\n \n </select>\n -->\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n \n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n • {{ validation.message }}\n </div>\n </ng-container>\n \n </div>\n </div>", styles: ["ion-label{margin-bottom:4px!important;opacity:1!important}ion-input{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:29px}input:focus{border:1px solid lightblue!important}input:focus ion-label{--color: blue !important}.error-message{font-size:small;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-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.pesquisa-select{display:block;position:absolute;top:58px;left:20px;width:100%;z-index:800;font-size:16px;font-family:Roboto,Helvetica Neue,sans-serif;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.pesquisa-select option{overflow-y:hidden}.pesquisa-select option:hover,.pesquisa-select option:checked{background-color:#add8e6}.pesquisa-list{display:block;position:absolute;
|
|
494
|
+
}], template: "<div style=\"padding-inline-end: 0px;\">\n <ion-item lines=\"none\" style=\"--background: inherited; --background-focused: transparent; margin-top: 2px;\" [class]=\"itemClass\">\n <ion-label position=\"{{ labelPosition }}\" color=\"{{ labelColor }}\">{{ label }}</ion-label>\n <!-- formControlName=\"{{ campo }}\" -->\n <ion-spinner *ngIf=\"!podePesquisar\"\n style=\"--min-height: 0px !important; margin-inline-end: 5px !important; margin-top: 16px;\" \n slot=\"start\" name=\"lines\"></ion-spinner>\n <!-- (ionBlur)=\"verificarPesquisa()\" -->\n <!-- conflito com click da lista -->\n <ion-input #inputPesquisa\n type=\"{{type}}\" \n [placeholder]=\"placeholder\" \n maxlength=\"{{ max }}\" \n (ionBlur)=\"onBlur($event)\"\n [value]=\"textoPesquisa\" (input)=\"writePesquisa(inputPesquisa.value)\" \n (keyup)=\"showPesquisa($event)\"\n autocomplete=\"off\" style=\"--background:{{ inputBackgroungColor }};\"\n (click)=\"dropDownPesquisa(-1)\"\n [disabled]=\"readonly\" debounce=\"500\"></ion-input>\n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"limparClick()\">\n <ion-icon name=\"close-outline\"></ion-icon>\n </ion-button>\n \n <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n (click)=\"pesquisarClick()\">\n <ion-icon color=\"primary\" name=\"search\"></ion-icon>\n </ion-button>\n \n </ion-item>\n \n <ion-list tabindex=\"-1\" [hidden]=\"!selectElementVisivel || !listaPesquisa || listaPesquisa.length == 0\" class=\"pesquisa-list\" style=\"max-height: 250px; overflow-y: auto;\">\n \n <ion-item tabindex=\"-1\" button *ngFor=\"let item of listaPesquisa\" \n (click)=\"selecionarComboClick(item)\" [id]=\"selectId + 'IonItem' + item['Index']\"\n class=\"pesquisa-item\">\n <!-- {{ item | json}} -->\n <span [class]=\"{'selected-item': item['Selected'] === true}\" [innerHTML]=\"highlight(item[campoDisplay])\"></span>\n </ion-item>\n \n </ion-list>\n \n <!--\n <ion-select interface=\"popover\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (ionChange)=\"selecionarComboChange($event.target.value)\">\n <ion-select-option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </ion-select-option>\n </ion-select>\n -->\n \n <!--\n <select [id]=\"selectId\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n (change)=\"selecionarComboChange($event.target.value)\" class=\"pesquisa-select\">\n <option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n {{ item[campoDisplay] }}\n </option>\n \n </select>\n -->\n \n <div class=\"validation-errors\" *ngIf=\"form\">\n \n <ng-container *ngFor=\"let validation of validation_messages\">\n <div class=\"error-message\"\n *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n • {{ validation.message }}\n </div>\n </ng-container>\n \n </div>\n </div>", styles: ["ion-label{margin-bottom:4px!important;opacity:1!important}ion-input{padding:4px;border:1px solid darkgray;border-radius:4px;width:100%;margin-top:2px;max-height:29px}input:focus{border:1px solid lightblue!important}input:focus ion-label{--color: blue !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-no-height{--inner-padding-end: 0px;--padding-start: 0px;--padding-bottom: 0px;--inner-padding-bottom: 0px}.padding-top{--padding-top: 0px}.pesquisa-select{display:block;position:absolute;top:58px;left:20px;width:100%;z-index:800;font-size:16px;font-family:Roboto,Helvetica Neue,sans-serif;border-bottom-left-radius:5px;border-bottom-right-radius:5px}.pesquisa-select option{overflow-y:hidden}.pesquisa-select option:hover,.pesquisa-select option:checked{background-color:#add8e6}.pesquisa-list{display:block;position:absolute;margin-left:20px;margin-top:-4px;width:calc(100% - 50px);z-index:800;border:1px lightgrey solid;border-bottom-left-radius:5px;border-bottom-right-radius:5px;padding:0}.pesquisa-item{--inner-padding-top: 0px;--inner-padding-bottom: 0px;--padding-top: 0px;--padding-bottom: 0px;--min-height: 30px !important;font-size:12px}.pesquisa-item button{padding:0}.selected-item{background-color:#add8e6}\n"] }]
|
|
495
495
|
}], ctorParameters: function () { return [{ type: i1.HttpClient }, { type: i2.ModalController }]; }, propDecorators: { textoPesquisa: [{
|
|
496
496
|
type: Input
|
|
497
497
|
}], max: [{
|
|
@@ -528,4 +528,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.1.2", ngImpor
|
|
|
528
528
|
}], loadInit: [{
|
|
529
529
|
type: Input
|
|
530
530
|
}] } });
|
|
531
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-pesquisa.component.js","sourceRoot":"","sources":["../../../../../projects/appproject-components/src/lib/input-pesquisa/input-pesquisa.component.ts","../../../../../projects/appproject-components/src/lib/input-pesquisa/input-pesquisa.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Component, Input, OnInit, Predicate, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IonSelect, ModalController } from '@ionic/angular';\nimport { Subject, Subscription, of } from 'rxjs';\nimport { BaseInputComponent } from '../baseInputComponent';\nimport { debounceTime, switchMap } from 'rxjs/operators'\nimport { ModelTreeviewComponent } from '../model-treeview/model-treeview.component';\n\n@Component({\n  selector: 'kb-input-pesquisa',\n  templateUrl: './input-pesquisa.component.html',\n  styleUrls: ['./input-pesquisa.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: InputPesquisaComponent,\n    multi: true\n  }]\n})\nexport class InputPesquisaComponent extends BaseInputComponent implements OnInit, ControlValueAccessor {\n\n  podePesquisar: boolean = true;\n  @Input() textoPesquisa: string = '';\n  selectElementVisivel: boolean = false;\n  listaPesquisa: any[] = [];\n  selectedItem: any;\n  @Input() override max: string = '30';\n  private pesquisaSubject: Subject<string> = new Subject();\n\n  @Input() filterFunction: Predicate<any> | null = null;\n  @Input() selectId: string = 'selectElement';\n  @Input() campoId: string = 'Id';\n  @Input() campoPaiId: string = 'PaiId';\n  @Input() campoDisplay: string = 'Descricao';\n  @Input() tipo: string = '';\n  //@ViewChild('selectElement', { read: ElementRef, static: true }) selectElement;\n  @ViewChild('selectElement', { static: false }) selectElement: IonSelect | null = null;\n\n  @Input() change?: Function;\n  @Input() pesquisaAction?: Function;\n  @Input() limpar?: Function;\n  //parametros para chamada API\n  //endpoint para pesquisa por digitação\n  @Input() url: string = '';\n  @Input() urlItem: string = '';\n  //endpoint para montar a arvore, se estiver vazia será usado o campo 'url'\n  @Input() urlTree: string = '';\n  @Input() empresa: number = 0;\n  @Input() loadInit: boolean = false;\n\n  //planoContas: number;\n\n  //control value acessor\n  public data: number | any;\n  private onChange: Function = (data: number) => { };\n  private onTouch: Function = () => { };\n  private disabled: boolean = false;\n  public console = console;\n\n  modelChanged: Subject<any> = new Subject<any>();\n  modelChangeSubscription?: Subscription;\n\n  writeValue(value: number | any): void {\n    //console.log('write value', value);\n    this.onChange(value);\n    this.data = value;\n    if (value == null || value == 0) {\n      this.writePesquisa('');\n      this.selectedItem = null;\n    } else {\n      if (this.loadInit == true) {\n        this.loadInit = false;\n        this.modelChanged.next(value);\n        //this.carregaItemIdParaLista(value);\n      } else {\n        //console.log(this.selectedItem);\n        if (!this.selectedItem || (this.selectedItem && this.selectedItem[this.campoId] != value)) {\n          console.log('Id diferente');\n          this.modelChanged.next(value);\n          //this.carregaItemIdParaLista(value);\n        }\n      }\n    }\n\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(private httpClient: HttpClient,\n    private modalCtrl: ModalController) {\n    super();\n\n    this.modelChangeSubscription = this.modelChanged\n      .pipe(debounceTime(500)\n      )\n      .subscribe(data => {\n        this.carregaItemIdParaLista(data);\n      });\n  }\n\n  onBlur(event: any) {\n    console.log('blur', event);\n    console.log(event.detail.relatedTarget);\n    if (event.detail.relatedTarget == null || event.detail.relatedTarget.id.indexOf(this.selectId + 'IonItem') == -1) {\n      console.log(\"true\", event.detail.relatedTarget.id);\n      //pesquisar item na lista\n      if (!this.existeNaListaTexto(this.textoPesquisa, true)) {\n        this.limparClick();\n      }\n\n      this.dropDownPesquisa(0);\n      if (this.form) {\n        this.form.get(this.formControlName)?.markAsTouched();\n      }\n    }\n  }\n\n  override ngOnInit() {\n    this.pesquisaSubject.pipe(switchMap((url) => {\n      this.console.log('subject url:', url);\n      if (!this.isEmpty(url))\n        return this.httpClient.get<any>(url);\n      else\n        return of([]);\n    }))\n      .subscribe({\n        next: (result: any) => {\n          //this.listaPesquisa = result;\n          this.console.log('subject subscribe result:', result);\n          this.listaPesquisa = [];\n\n          if (result && result.length > 0) {\n            if (this.filterFunction) {\n              result = result.filter(this.filterFunction);\n            }\n\n            result.forEach((ent: any, index: any) => {\n              this.listaPesquisa.push({ ...ent, Index: index, Selected: false });\n            });\n          }\n\n          this.podePesquisar = true;\n          if (this.listaPesquisa.length > 0) {\n            this.dropDownPesquisa(this.listaPesquisa.length);\n          }\n        }\n        , error: (error) => {\n          this.podePesquisar = true;\n          console.log('erro pesquisa', error);\n        }\n      });\n  }\n\n  writePesquisa(value: string | any): void {\n    //console.log('write pesquisa', value);\n    this.textoPesquisa = value;\n  }\n\n  showPesquisa(e: any): void {\n    //console.log('show pesquisa', e.keyCode);\n    var self = this;\n    if ((e.keyCode >= 48 && e.keyCode <= 57) ||\n      (e.keyCode >= 65 && e.keyCode <= 90) ||\n      (e.keyCode >= 96 && e.keyCode <= 105) ||\n      (e.keyCode == 8)) {\n      if (!self.podePesquisar) {\n        return;\n      }\n      let filtro = self.textoPesquisa;\n      if (filtro != null && filtro != '' && filtro.length >= 2) {\n        self.pesquisarEntidade(filtro);\n\n      }\n      else {\n        if (e.keyCode == 8 && !filtro) {\n          this.limparClick();\n        }\n      }\n    }\n\n    else {\n      if (e.keyCode == 40 || e.keyCode == 38) {\n        self.dropDownPesquisa(self.listaPesquisa.length);\n        if (self.selectElementVisivel == true) {\n          //let select = self.selectElement; //document.getElementById(self.TemplateSelect1Id());\n\n          //ion-list\n          //selecionado\n          //console.log(self.listaPesquisa);\n          let inc = e.keyCode == 40 ? 1 : -1;\n          let selected = self.listaPesquisa.find(s => s['Selected'] === true);\n          let cur = 0;\n          if (selected != null) {\n            cur = selected['Index'];\n            //desmarcar o atual\n            selected['Selected'] = false;\n            cur = cur + inc;\n          } else {\n            cur = 0;\n          }\n\n          if (cur < 0) {\n            cur = self.listaPesquisa.length - 1;\n          } else if (cur >= self.listaPesquisa.length) {\n            cur = 0;\n          }\n\n          let novoSelected = self.listaPesquisa.find(n => n['Index'] === cur);\n          if (novoSelected != null) {\n            novoSelected['Selected'] = true;\n            self.selectedItem = novoSelected;\n            self.textoPesquisa = novoSelected[self.campoDisplay];\n          }\n          /*\n          let select = document.getElementById(this.selectId) as any;\n          console.log('select Element', select)\n          if (select != null) {\n            let inc = e.keyCode == 40 ? 1 : -1;\n            let cur = select.selectedIndex;\n            if (cur == NaN) cur = -1;\n            select.selectedIndex = cur + inc;\n            if (select.selectedIndex >= 0 && select.selectedIndex < self.listaPesquisa.length) {\n              self.selectedItem = self.listaPesquisa[select.selectedIndex];\n              if (self.selectedItem != null) {\n                self.textoPesquisa = self.selectedItem[self.campoDisplay];\n              }\n            }\n          }\n          */\n        }\n\n      } else\n        if (e.keyCode == 13) {\n          console.log('enter key', e)\n          //self.selecionarComboClick(e);\n          self.selecionarComboClick(null);\n          //return false;\n        } else if (e.keyCode == 27) {\n          //ESC\n          self.dropDownPesquisa(0);\n        }\n    }\n\n  }\n\n  highlight(texto: string): string {\n    let index = texto.toLowerCase().indexOf(this.textoPesquisa.toLowerCase());\n    //console.log(index);\n    if (index >= 0) {\n      return texto.substring(0, index) + '<strong>' + texto.substring(index, index + this.textoPesquisa.length) + '</strong>' + texto.substring(index + this.textoPesquisa.length);  //texto.replace(this.textoPesquisa, `<strong>${this.textoPesquisa}</strong>`);\n    } else {\n      return texto;\n    }\n  }\n\n  selecionarComboClick(item: any) {\n    // console.log(item);\n    var self = this;\n    // console.log('combo click', self);\n\n    /*\n    let select = document.getElementById(this.selectId) as any;\n    if (select.selectedIndex >= 0) {\n      self.selectedItem = self.listaPesquisa[select.selectedIndex];\n    }\n    console.log('selected', this.selectedItem);\n    //self.selectedItem = this.listaPesquisa.find(i => i[this.campoId] == e);\n    if (self.selectedItem != null) {\n      self.textoPesquisa = self.selectedItem[self.campoDisplay];\n      self.writeValue(self.selectedItem[self.campoId]);\n      if (e != null) {\n        self.selectElementVisivel = false;\n        if (self.action != null) {\n          self.action(self.selectedItem(), e);\n        }\n      }\n    }\n    else {\n      self.selectElementVisivel = false;\n    }\n    */\n    // pesquisar selecionado\n    // console.log(this.listaPesquisa);\n    let selected = this.listaPesquisa.find(s => s['Selected'] === true);\n\n    // if (!selected) {\n    //   console.log(this.campoId, item);\n    //   selected = this.listaPesquisa.filter( s => s[this.campoId] == item[this.campoId]);\n    // }\n\n    //se o item form passado como parametro (click no ion-item)\n    if (item != null) {\n      if (selected != null) {\n        selected['Selected'] = false;\n      }\n      item['Selected'] = true;\n      selected = item;\n    }\n    if (selected != null) {\n      self.selectedItem = selected;\n      self.textoPesquisa = selected[self.campoDisplay];\n      self.writeValue(selected[self.campoId]);\n      self.selectElementVisivel = false;\n      console.log('action', self.change);\n      if (self.change != null) {\n        self.change(self.selectedItem);\n      }\n    } else {\n      self.selectElementVisivel = false;\n    }\n    // this.listaPesquisa.forEach( pesquisa => {\n    //   console.log(pesquisa, self.data);\n    // } );\n    // console.log(this.textoPesquisa);\n  }\n\n  selecionarComboChange(e: any) {\n    var self = this;\n    console.log('combo change', e);\n    self.selectedItem = this.listaPesquisa.find(i => i[this.campoId] == e);\n    if (self.selectedItem != null) {\n      self.writeValue(e);\n      self.textoPesquisa = self.selectedItem[self.campoDisplay];\n      if (e != null) {\n        self.selectElementVisivel = false;\n        if (self.change != null) {\n          self.change(self.selectedItem, e);\n        }\n      }\n    }\n    else {\n      self.selectElementVisivel = false;\n    }\n  }\n\n  dropDownPesquisa(length: number) {\n    var self = this;\n    if (self.listaPesquisa != null && self.listaPesquisa.length > 0) {\n      if (length == -1) {\n        length = self.listaPesquisa.length;\n      }\n      self.selectElementVisivel = length == 0 ? false : true;\n\n      //console.log(this.selectElement);\n      //this.selectElement.open();\n\n      /*\n      //let element = this.selectElement;\n      let element = document.getElementById(this.selectId);\n      console.log('dropDown', element);\n      (element as any).size = length + 1;\n      if (length == 0) {\n        self.selectElementVisivel = false;\n      } else {\n        self.selectElementVisivel = true;\n      }\n      */\n    }\n  }\n\n  pesquisarEntidade(filtro: string) {\n    let url = this.url.replace('<<FILTRO>>', filtro).replace('<<EMPRESA>>', this.empresa.toString());\n    console.log('pesquisarEntidade url', url);\n    this.podePesquisar = false;\n    this.pesquisaSubject.next(url);\n  }\n\n  pesquisarEntidadeOld(filtro: string) {\n    let url = this.url.replace('<<FILTRO>>', filtro).replace('<<EMPRESA>>', this.empresa.toString());\n    console.log('pesquisarEntidade url', url);\n    this.podePesquisar = false;\n    this.httpClient.get<any>(url)\n      .subscribe({ next: (result: any) => {\n        //this.listaPesquisa = result;\n        if (this.filterFunction) {\n          result = result.filter(this.filterFunction);\n        }\n        this.listaPesquisa = [];\n        result.forEach((ent: any, index: number) => {\n          this.listaPesquisa.push({ ...ent, Index: index, Selected: false });\n        });\n\n        this.podePesquisar = true;\n        if (this.listaPesquisa.length > 0) {\n          this.dropDownPesquisa(this.listaPesquisa.length);\n        }\n      }, error: error => {\n        console.log('erro pesquisa', error);\n        this.podePesquisar = true;\n      }});\n  }\n\n  existeNaLista(id: number, setRegistro: boolean = false): boolean {\n    if (this.listaPesquisa && this.listaPesquisa.length > 0) {\n      let existe = this.listaPesquisa.find(l => l[this.campoId] === id);\n      if (existe) {\n        if (setRegistro) {\n          this.selectedItem = existe;\n          this.selecionarComboClick(this.selectedItem);\n        }\n        return true;\n      } else {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  existeNaListaTexto(texto: string, setRegistro: boolean = false): boolean {\n    console.log(\"existe texto:\", texto, this.campoDisplay, this.listaPesquisa);\n    if (this.listaPesquisa && this.listaPesquisa.length > 0) {\n      let existe = this.listaPesquisa.find(l => l[this.campoDisplay].toUpperCase() === texto.toUpperCase());\n      if (existe) {\n        if (setRegistro) {\n          this.selectedItem = existe;\n          this.selecionarComboClick(this.selectedItem);\n        }\n        return true;\n      } else {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  validarItemSelecionado(setarRegistro: boolean = false): boolean {\n    console.log('validar selecionado');\n    //passar pela função de filtro\n    let valido = false;\n    if (this.selectedItem) {\n      if (this.filterFunction) {\n        let existe = [{ ...this.selectedItem }].filter(this.filterFunction);\n        if (existe != null && existe.length > 0) {\n          valido = true;\n        }\n      } else {\n        valido = true;\n      }\n      if (valido && setarRegistro) {\n        this.selecionarComboClick(this.selectedItem);\n      }\n\n      return valido;\n    } else {\n      return false;\n    }\n  }\n\n  carregaItemIdParaLista(id: number) {\n    let url = this.urlItem.replace('<<ID>>', id.toString());\n    console.log(this.urlItem);\n    console.log('pesquisar ID url', url);\n    this.podePesquisar = false;\n    this.httpClient.get<any>(url)\n      .subscribe({ next: (result: any) => {\n        this.listaPesquisa = [];\n        this.listaPesquisa.push({ ...result, Index: 0, Selected: true });\n        this.podePesquisar = true;\n        if (this.listaPesquisa.length > 0) {\n          this.selectedItem = this.listaPesquisa[0];\n          this.selecionarComboClick(this.selectedItem);\n        }\n      }, error:  error => {\n        console.log('erro pesquisa', error);\n        this.podePesquisar = true;\n      }});\n  }\n\n  limparClick() {\n    this.writeValue(null);\n    this.writePesquisa(null);\n    this.listaPesquisa = [];\n    this.dropDownPesquisa(0);\n    //this.podePesquisar = true;\n    this.pesquisaSubject.next('');\n    if (this.limpar) {\n      this.limpar();\n    }\n  }\n\n  verificarPesquisa() {\n    //TODO: verificar se o texto corresponde com um item da lista\n    this.selecionarComboClick(null);\n  }\n\n  async pesquisarClick() {\n    /*\n    if (this.pesquisaAction != null) {\n      this.pesquisaAction();\n    }\n    */\n    //pesquisaCategoria\n    console.log(this.filterFunction, this.url, this.urlTree);\n\n    const modal = await this.modalCtrl.create({\n      component: ModelTreeviewComponent,\n      componentProps: {\n        //campoId: this.campoId,\n        //campoPai: this.campoPaiId,\n        //campoLabel: this.campoDisplay,\n        filterFunction: this.filterFunction,\n        empresaSelecionadaId: this.empresa,\n        tipo: this.tipo,\n        //especifico\n        //planoContas: this.planoContas,\n        url: this.isEmpty(this.urlTree) ? this.url : this.urlTree\n      },\n      cssClass: 'my-custom-modal-pesquisa'\n    });\n\n    modal.onDidDismiss().then(data => {\n      let result = data['data'];\n      console.log(result);\n      if (result != null && result.Id > 0) {\n        this.carregaItemIdParaLista(result.Id);\n      }\n    });\n    modal.present();\n\n  }\n\n  isEmpty(valor: string | any) {\n    return valor == null || valor == undefined || valor == ''\n  }\n}\n","<div style=\"padding-inline-end: 0px;\">\n    <ion-item lines=\"none\" style=\"--background: inherited; --background-focused: transparent; margin-top: 2px;\" [class]=\"itemClass\">\n      <ion-label position=\"{{ labelPosition }}\" color=\"{{ labelColor }}\">{{ label }}</ion-label>\n      <!-- formControlName=\"{{ campo }}\"  -->\n      <ion-spinner *ngIf=\"!podePesquisar\"\n        style=\"--min-height: 0px !important; margin-inline-end: 5px !important; margin-top: 16px;\" \n        slot=\"start\" name=\"lines\"></ion-spinner>\n      <!-- (ionBlur)=\"verificarPesquisa()\" -->\n      <!-- conflito com click da lista -->\n      <ion-input #inputPesquisa\n        type=\"{{type}}\" \n        [placeholder]=\"placeholder\" \n        maxlength=\"{{ max }}\" \n        (ionBlur)=\"onBlur($event)\"\n        [value]=\"textoPesquisa\" (input)=\"writePesquisa(inputPesquisa.value)\" \n        (keyup)=\"showPesquisa($event)\"\n        autocomplete=\"off\" style=\"--background:{{ inputBackgroungColor }};\"\n        (click)=\"dropDownPesquisa(-1)\"\n        [disabled]=\"readonly\" debounce=\"500\"></ion-input>\n      <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n        style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n        (click)=\"limparClick()\">\n        <ion-icon name=\"close-outline\"></ion-icon>\n      </ion-button>\n  \n      <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n        style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n        (click)=\"pesquisarClick()\">\n        <ion-icon color=\"primary\" name=\"search\"></ion-icon>\n      </ion-button>\n      \n    </ion-item>\n  \n    <ion-list tabindex=\"-1\" [hidden]=\"!selectElementVisivel || !listaPesquisa || listaPesquisa.length == 0\" class=\"pesquisa-list\" style=\"max-height: 250px; overflow-y: auto;\">\n      \n      <ion-item tabindex=\"-1\" button *ngFor=\"let item of listaPesquisa\" \n      (click)=\"selecionarComboClick(item)\" [id]=\"selectId + 'IonItem' + item['Index']\"\n        class=\"pesquisa-item\">\n        <!-- {{ item | json}} -->\n        <span [class]=\"{'selected-item': item['Selected'] === true}\" [innerHTML]=\"highlight(item[campoDisplay])\"></span>\n      </ion-item>\n  \n    </ion-list>\n  \n    <!--\n    <ion-select interface=\"popover\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n      (ionChange)=\"selecionarComboChange($event.target.value)\">\n      <ion-select-option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n        {{ item[campoDisplay] }}\n      </ion-select-option>\n    </ion-select>\n    -->\n  \n    <!--\n    <select [id]=\"selectId\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n      (change)=\"selecionarComboChange($event.target.value)\" class=\"pesquisa-select\">\n      <option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n        {{ item[campoDisplay] }}\n      </option>\n  \n    </select>\n    -->\n  \n    <div class=\"validation-errors\" *ngIf=\"form\">\n  \n      <ng-container *ngFor=\"let validation of validation_messages\">\n        <div class=\"error-message\"\n          *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n          &#8226; {{ validation.message }}\n        </div>\n      </ng-container>\n  \n    </div>\n  </div>"]}
|
|
531
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-pesquisa.component.js","sourceRoot":"","sources":["../../../../../projects/appproject-components/src/lib/input-pesquisa/input-pesquisa.component.ts","../../../../../projects/appproject-components/src/lib/input-pesquisa/input-pesquisa.component.html"],"names":[],"mappings":"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","sourcesContent":["import { HttpClient } from '@angular/common/http';\nimport { Component, Input, OnInit, Predicate, ViewChild } from '@angular/core';\nimport { ControlValueAccessor, NG_VALUE_ACCESSOR } from '@angular/forms';\nimport { IonSelect, ModalController } from '@ionic/angular';\nimport { Subject, Subscription, of } from 'rxjs';\nimport { BaseInputComponent } from '../baseInputComponent';\nimport { debounceTime, switchMap } from 'rxjs/operators'\nimport { ModelTreeviewComponent } from '../model-treeview/model-treeview.component';\n\n@Component({\n  selector: 'kb-input-pesquisa',\n  templateUrl: './input-pesquisa.component.html',\n  styleUrls: ['./input-pesquisa.component.scss'],\n  providers: [{\n    provide: NG_VALUE_ACCESSOR,\n    useExisting: InputPesquisaComponent,\n    multi: true\n  }]\n})\nexport class InputPesquisaComponent extends BaseInputComponent implements OnInit, ControlValueAccessor {\n\n  podePesquisar: boolean = true;\n  @Input() textoPesquisa: string = '';\n  selectElementVisivel: boolean = false;\n  listaPesquisa: any[] = [];\n  selectedItem: any;\n  @Input() override max: string = '30';\n  private pesquisaSubject: Subject<string> = new Subject();\n\n  @Input() filterFunction: Predicate<any> | null = null;\n  @Input() selectId: string = 'selectElement';\n  @Input() campoId: string = 'Id';\n  @Input() campoPaiId: string = 'PaiId';\n  @Input() campoDisplay: string = 'Descricao';\n  @Input() tipo: string = '';\n  //@ViewChild('selectElement', { read: ElementRef, static: true }) selectElement;\n  @ViewChild('selectElement', { static: false }) selectElement: IonSelect | null = null;\n\n  @Input() change?: Function;\n  @Input() pesquisaAction?: Function;\n  @Input() limpar?: Function;\n  //parametros para chamada API\n  //endpoint para pesquisa por digitação\n  @Input() url: string = '';\n  @Input() urlItem: string = '';\n  //endpoint para montar a arvore, se estiver vazia será usado o campo 'url'\n  @Input() urlTree: string = '';\n  @Input() empresa: number = 0;\n  @Input() loadInit: boolean = false;\n\n  //planoContas: number;\n\n  //control value acessor\n  public data: number | any;\n  private onChange: Function = (data: number) => { };\n  private onTouch: Function = () => { };\n  private disabled: boolean = false;\n  public console = console;\n\n  modelChanged: Subject<any> = new Subject<any>();\n  modelChangeSubscription?: Subscription;\n\n  writeValue(value: number | any): void {\n    //console.log('write value', value);\n    this.onChange(value);\n    this.data = value;\n    if (value == null || value == 0) {\n      this.writePesquisa('');\n      this.selectedItem = null;\n    } else {\n      if (this.loadInit == true) {\n        this.loadInit = false;\n        this.modelChanged.next(value);\n        //this.carregaItemIdParaLista(value);\n      } else {\n        //console.log(this.selectedItem);\n        if (!this.selectedItem || (this.selectedItem && this.selectedItem[this.campoId] != value)) {\n          console.log('Id diferente');\n          this.modelChanged.next(value);\n          //this.carregaItemIdParaLista(value);\n        }\n      }\n    }\n\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(private httpClient: HttpClient,\n    private modalCtrl: ModalController) {\n    super();\n\n    this.modelChangeSubscription = this.modelChanged\n      .pipe(debounceTime(500)\n      )\n      .subscribe(data => {\n        this.carregaItemIdParaLista(data);\n      });\n  }\n\n  onBlur(event: any) {\n    console.log('blur', event);\n    //console.log(event.detail.relatedTarget);\n    if (event.detail.relatedTarget == null || event.detail.relatedTarget.id.indexOf(this.selectId + 'IonItem') == -1) {\n      //console.log(\"true\", event.detail.relatedTarget.id);\n      //pesquisar item na lista\n      if (!this.existeNaListaTexto(this.textoPesquisa, true)) {\n        this.limparClick();\n      }\n\n      this.dropDownPesquisa(0);\n      if (this.form) {\n        this.form.get(this.formControlName)?.markAsTouched();\n      }\n    }\n  }\n\n  override ngOnInit() {\n    this.pesquisaSubject.pipe(switchMap((url) => {\n      this.console.log('subject url:', url);\n      if (!this.isEmpty(url))\n        return this.httpClient.get<any>(url);\n      else\n        return of([]);\n    }))\n      .subscribe({\n        next: (result: any) => {\n          //this.listaPesquisa = result;\n          this.console.log('subject subscribe result:', result);\n          this.listaPesquisa = [];\n\n          if (result && result.length > 0) {\n            if (this.filterFunction) {\n              result = result.filter(this.filterFunction);\n            }\n\n            result.forEach((ent: any, index: any) => {\n              this.listaPesquisa.push({ ...ent, Index: index, Selected: false });\n            });\n          }\n\n          this.podePesquisar = true;\n          if (this.listaPesquisa.length > 0) {\n            this.dropDownPesquisa(this.listaPesquisa.length);\n          }\n        }\n        , error: (error) => {\n          this.podePesquisar = true;\n          console.log('erro pesquisa', error);\n        }\n      });\n  }\n\n  writePesquisa(value: string | any): void {\n    //console.log('write pesquisa', value);\n    this.textoPesquisa = value;\n  }\n\n  showPesquisa(e: any): void {\n    //console.log('show pesquisa', e.keyCode);\n    var self = this;\n    if ((e.keyCode >= 48 && e.keyCode <= 57) ||\n      (e.keyCode >= 65 && e.keyCode <= 90) ||\n      (e.keyCode >= 96 && e.keyCode <= 105) ||\n      (e.keyCode == 8)) {\n      if (!self.podePesquisar) {\n        return;\n      }\n      let filtro = self.textoPesquisa;\n      if (filtro != null && filtro != '' && filtro.length >= 2) {\n        self.pesquisarEntidade(filtro);\n\n      }\n      else {\n        if (e.keyCode == 8 && !filtro) {\n          this.limparClick();\n        }\n      }\n    }\n\n    else {\n      if (e.keyCode == 40 || e.keyCode == 38) {\n        self.dropDownPesquisa(self.listaPesquisa.length);\n        if (self.selectElementVisivel == true) {\n          //let select = self.selectElement; //document.getElementById(self.TemplateSelect1Id());\n\n          //ion-list\n          //selecionado\n          //console.log(self.listaPesquisa);\n          let inc = e.keyCode == 40 ? 1 : -1;\n          let selected = self.listaPesquisa.find(s => s['Selected'] === true);\n          let cur = 0;\n          if (selected != null) {\n            cur = selected['Index'];\n            //desmarcar o atual\n            selected['Selected'] = false;\n            cur = cur + inc;\n          } else {\n            cur = 0;\n          }\n\n          if (cur < 0) {\n            cur = self.listaPesquisa.length - 1;\n          } else if (cur >= self.listaPesquisa.length) {\n            cur = 0;\n          }\n\n          let novoSelected = self.listaPesquisa.find(n => n['Index'] === cur);\n          if (novoSelected != null) {\n            novoSelected['Selected'] = true;\n            self.selectedItem = novoSelected;\n            self.textoPesquisa = novoSelected[self.campoDisplay];\n          }\n          /*\n          let select = document.getElementById(this.selectId) as any;\n          console.log('select Element', select)\n          if (select != null) {\n            let inc = e.keyCode == 40 ? 1 : -1;\n            let cur = select.selectedIndex;\n            if (cur == NaN) cur = -1;\n            select.selectedIndex = cur + inc;\n            if (select.selectedIndex >= 0 && select.selectedIndex < self.listaPesquisa.length) {\n              self.selectedItem = self.listaPesquisa[select.selectedIndex];\n              if (self.selectedItem != null) {\n                self.textoPesquisa = self.selectedItem[self.campoDisplay];\n              }\n            }\n          }\n          */\n        }\n\n      } else\n        if (e.keyCode == 13) {\n          console.log('enter key', e)\n          //self.selecionarComboClick(e);\n          self.selecionarComboClick(null);\n          //return false;\n        } else if (e.keyCode == 27) {\n          //ESC\n          self.dropDownPesquisa(0);\n        }\n    }\n\n  }\n\n  highlight(texto: string): string {\n    let index = texto.toLowerCase().indexOf(this.textoPesquisa.toLowerCase());\n    //console.log(index);\n    if (index >= 0) {\n      return texto.substring(0, index) + '<strong>' + texto.substring(index, index + this.textoPesquisa.length) + '</strong>' + texto.substring(index + this.textoPesquisa.length);  //texto.replace(this.textoPesquisa, `<strong>${this.textoPesquisa}</strong>`);\n    } else {\n      return texto;\n    }\n  }\n\n  selecionarComboClick(item: any) {\n    // console.log(item);\n    var self = this;\n    // console.log('combo click', self);\n\n    /*\n    let select = document.getElementById(this.selectId) as any;\n    if (select.selectedIndex >= 0) {\n      self.selectedItem = self.listaPesquisa[select.selectedIndex];\n    }\n    console.log('selected', this.selectedItem);\n    //self.selectedItem = this.listaPesquisa.find(i => i[this.campoId] == e);\n    if (self.selectedItem != null) {\n      self.textoPesquisa = self.selectedItem[self.campoDisplay];\n      self.writeValue(self.selectedItem[self.campoId]);\n      if (e != null) {\n        self.selectElementVisivel = false;\n        if (self.action != null) {\n          self.action(self.selectedItem(), e);\n        }\n      }\n    }\n    else {\n      self.selectElementVisivel = false;\n    }\n    */\n    // pesquisar selecionado\n    // console.log(this.listaPesquisa);\n    let selected = this.listaPesquisa.find(s => s['Selected'] === true);\n\n    // if (!selected) {\n    //   console.log(this.campoId, item);\n    //   selected = this.listaPesquisa.filter( s => s[this.campoId] == item[this.campoId]);\n    // }\n\n    //se o item form passado como parametro (click no ion-item)\n    if (item != null) {\n      if (selected != null) {\n        selected['Selected'] = false;\n      }\n      item['Selected'] = true;\n      selected = item;\n    }\n    if (selected != null) {\n      self.selectedItem = selected;\n      self.textoPesquisa = selected[self.campoDisplay];\n      self.writeValue(selected[self.campoId]);\n      self.selectElementVisivel = false;\n      console.log('action', self.change);\n      if (self.change != null) {\n        self.change(self.selectedItem);\n      }\n    } else {\n      self.selectElementVisivel = false;\n    }\n    // this.listaPesquisa.forEach( pesquisa => {\n    //   console.log(pesquisa, self.data);\n    // } );\n    // console.log(this.textoPesquisa);\n  }\n\n  selecionarComboChange(e: any) {\n    var self = this;\n    console.log('combo change', e);\n    self.selectedItem = this.listaPesquisa.find(i => i[this.campoId] == e);\n    if (self.selectedItem != null) {\n      self.writeValue(e);\n      self.textoPesquisa = self.selectedItem[self.campoDisplay];\n      if (e != null) {\n        self.selectElementVisivel = false;\n        if (self.change != null) {\n          self.change(self.selectedItem, e);\n        }\n      }\n    }\n    else {\n      self.selectElementVisivel = false;\n    }\n  }\n\n  dropDownPesquisa(length: number) {\n    var self = this;\n    if (self.listaPesquisa != null && self.listaPesquisa.length > 0) {\n      if (length == -1) {\n        length = self.listaPesquisa.length;\n      }\n      self.selectElementVisivel = length == 0 ? false : true;\n\n      //console.log(this.selectElement);\n      //this.selectElement.open();\n\n      /*\n      //let element = this.selectElement;\n      let element = document.getElementById(this.selectId);\n      console.log('dropDown', element);\n      (element as any).size = length + 1;\n      if (length == 0) {\n        self.selectElementVisivel = false;\n      } else {\n        self.selectElementVisivel = true;\n      }\n      */\n    }\n  }\n\n  pesquisarEntidade(filtro: string) {\n    let url = this.url.replace('<<FILTRO>>', filtro).replace('<<EMPRESA>>', this.empresa.toString());\n    console.log('pesquisarEntidade url', url);\n    this.podePesquisar = false;\n    this.pesquisaSubject.next(url);\n  }\n\n  pesquisarEntidadeOld(filtro: string) {\n    let url = this.url.replace('<<FILTRO>>', filtro).replace('<<EMPRESA>>', this.empresa.toString());\n    console.log('pesquisarEntidade url', url);\n    this.podePesquisar = false;\n    this.httpClient.get<any>(url)\n      .subscribe({ next: (result: any) => {\n        //this.listaPesquisa = result;\n        if (this.filterFunction) {\n          result = result.filter(this.filterFunction);\n        }\n        this.listaPesquisa = [];\n        result.forEach((ent: any, index: number) => {\n          this.listaPesquisa.push({ ...ent, Index: index, Selected: false });\n        });\n\n        this.podePesquisar = true;\n        if (this.listaPesquisa.length > 0) {\n          this.dropDownPesquisa(this.listaPesquisa.length);\n        }\n      }, error: error => {\n        console.log('erro pesquisa', error);\n        this.podePesquisar = true;\n      }});\n  }\n\n  existeNaLista(id: number, setRegistro: boolean = false): boolean {\n    if (this.listaPesquisa && this.listaPesquisa.length > 0) {\n      let existe = this.listaPesquisa.find(l => l[this.campoId] === id);\n      if (existe) {\n        if (setRegistro) {\n          this.selectedItem = existe;\n          this.selecionarComboClick(this.selectedItem);\n        }\n        return true;\n      } else {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  existeNaListaTexto(texto: string, setRegistro: boolean = false): boolean {\n    console.log(\"existe texto:\", texto, this.campoDisplay, this.listaPesquisa);\n    if (this.listaPesquisa && this.listaPesquisa.length > 0) {\n      let existe = this.listaPesquisa.find(l => l[this.campoDisplay].toUpperCase() === texto.toUpperCase());\n      if (existe) {\n        if (setRegistro) {\n          this.selectedItem = existe;\n          this.selecionarComboClick(this.selectedItem);\n        }\n        return true;\n      } else {\n        return false;\n      }\n    } else {\n      return false;\n    }\n  }\n\n  validarItemSelecionado(setarRegistro: boolean = false): boolean {\n    console.log('validar selecionado');\n    //passar pela função de filtro\n    let valido = false;\n    if (this.selectedItem) {\n      if (this.filterFunction) {\n        let existe = [{ ...this.selectedItem }].filter(this.filterFunction);\n        if (existe != null && existe.length > 0) {\n          valido = true;\n        }\n      } else {\n        valido = true;\n      }\n      if (valido && setarRegistro) {\n        this.selecionarComboClick(this.selectedItem);\n      }\n\n      return valido;\n    } else {\n      return false;\n    }\n  }\n\n  carregaItemIdParaLista(id: number) {\n    let url = this.urlItem.replace('<<ID>>', id.toString());\n    console.log(this.urlItem);\n    console.log('pesquisar ID url', url);\n    this.podePesquisar = false;\n    this.httpClient.get<any>(url)\n      .subscribe({ next: (result: any) => {\n        this.listaPesquisa = [];\n        this.listaPesquisa.push({ ...result, Index: 0, Selected: true });\n        this.podePesquisar = true;\n        if (this.listaPesquisa.length > 0) {\n          this.selectedItem = this.listaPesquisa[0];\n          this.selecionarComboClick(this.selectedItem);\n        }\n      }, error:  error => {\n        console.log('erro pesquisa', error);\n        this.podePesquisar = true;\n      }});\n  }\n\n  limparClick() {\n    this.writeValue(null);\n    this.writePesquisa(null);\n    this.listaPesquisa = [];\n    this.dropDownPesquisa(0);\n    //this.podePesquisar = true;\n    this.pesquisaSubject.next('');\n    if (this.limpar) {\n      this.limpar();\n    }\n  }\n\n  verificarPesquisa() {\n    //TODO: verificar se o texto corresponde com um item da lista\n    this.selecionarComboClick(null);\n  }\n\n  async pesquisarClick() {\n    /*\n    if (this.pesquisaAction != null) {\n      this.pesquisaAction();\n    }\n    */\n    //pesquisaCategoria\n    console.log(this.filterFunction, this.url, this.urlTree);\n\n    const modal = await this.modalCtrl.create({\n      component: ModelTreeviewComponent,\n      componentProps: {\n        //campoId: this.campoId,\n        //campoPai: this.campoPaiId,\n        //campoLabel: this.campoDisplay,\n        filterFunction: this.filterFunction,\n        empresaSelecionadaId: this.empresa,\n        tipo: this.tipo,\n        //especifico\n        //planoContas: this.planoContas,\n        url: this.isEmpty(this.urlTree) ? this.url : this.urlTree\n      },\n      cssClass: 'my-custom-modal-pesquisa'\n    });\n\n    modal.onDidDismiss().then(data => {\n      let result = data['data'];\n      console.log(result);\n      if (result != null && result.Id > 0) {\n        this.carregaItemIdParaLista(result.Id);\n      }\n    });\n    modal.present();\n\n  }\n\n  isEmpty(valor: string | any) {\n    return valor == null || valor == undefined || valor == ''\n  }\n}\n","<div style=\"padding-inline-end: 0px;\">\n    <ion-item lines=\"none\" style=\"--background: inherited; --background-focused: transparent; margin-top: 2px;\" [class]=\"itemClass\">\n      <ion-label position=\"{{ labelPosition }}\" color=\"{{ labelColor }}\">{{ label }}</ion-label>\n      <!-- formControlName=\"{{ campo }}\"  -->\n      <ion-spinner *ngIf=\"!podePesquisar\"\n        style=\"--min-height: 0px !important; margin-inline-end: 5px !important; margin-top: 16px;\" \n        slot=\"start\" name=\"lines\"></ion-spinner>\n      <!-- (ionBlur)=\"verificarPesquisa()\" -->\n      <!-- conflito com click da lista -->\n      <ion-input #inputPesquisa\n        type=\"{{type}}\" \n        [placeholder]=\"placeholder\" \n        maxlength=\"{{ max }}\" \n        (ionBlur)=\"onBlur($event)\"\n        [value]=\"textoPesquisa\" (input)=\"writePesquisa(inputPesquisa.value)\" \n        (keyup)=\"showPesquisa($event)\"\n        autocomplete=\"off\" style=\"--background:{{ inputBackgroungColor }};\"\n        (click)=\"dropDownPesquisa(-1)\"\n        [disabled]=\"readonly\" debounce=\"500\"></ion-input>\n      <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n        style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n        (click)=\"limparClick()\">\n        <ion-icon name=\"close-outline\"></ion-icon>\n      </ion-button>\n  \n      <ion-button size=\"small\" slot=\"end\" tabindex=\"-1\"\n        style=\"margin-top: 25px; margin-inline-start: 4px !important; --padding-start:2px; --padding-end: 2px;\" fill=\"clear\" color=\"medium\"\n        (click)=\"pesquisarClick()\">\n        <ion-icon color=\"primary\" name=\"search\"></ion-icon>\n      </ion-button>\n      \n    </ion-item>\n  \n    <ion-list tabindex=\"-1\" [hidden]=\"!selectElementVisivel || !listaPesquisa || listaPesquisa.length == 0\" class=\"pesquisa-list\" style=\"max-height: 250px; overflow-y: auto;\">\n      \n      <ion-item tabindex=\"-1\" button *ngFor=\"let item of listaPesquisa\" \n      (click)=\"selecionarComboClick(item)\" [id]=\"selectId + 'IonItem' + item['Index']\"\n        class=\"pesquisa-item\">\n        <!-- {{ item | json}} -->\n        <span [class]=\"{'selected-item': item['Selected'] === true}\" [innerHTML]=\"highlight(item[campoDisplay])\"></span>\n      </ion-item>\n  \n    </ion-list>\n  \n    <!--\n    <ion-select interface=\"popover\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n      (ionChange)=\"selecionarComboChange($event.target.value)\">\n      <ion-select-option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n        {{ item[campoDisplay] }}\n      </ion-select-option>\n    </ion-select>\n    -->\n  \n    <!--\n    <select [id]=\"selectId\" #selectElement tabindex=\"-1\" [hidden]=\"!selectElementVisivel\"\n      (change)=\"selecionarComboChange($event.target.value)\" class=\"pesquisa-select\">\n      <option *ngFor=\"let item of listaPesquisa\" [value]=\"item[campoId]\" (click)=\"selecionarComboClick(item[campoId])\">\n        {{ item[campoDisplay] }}\n      </option>\n  \n    </select>\n    -->\n  \n    <div class=\"validation-errors\" *ngIf=\"form\">\n  \n      <ng-container *ngFor=\"let validation of validation_messages\">\n        <div class=\"error-message\"\n          *ngIf=\"form.get(formControlName)?.hasError(validation.type) && (form.get(formControlName)?.dirty || form.get(formControlName)?.touched)\">\n          &#8226; {{ validation.message }}\n        </div>\n      </ng-container>\n  \n    </div>\n  </div>"]}
|