ngx-sp-infra 0.2.75 → 0.3.76

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.
@@ -25,9 +25,12 @@ import { LimitToPipe } from './widgets/combobox/pipes/limit-to.pipe';
25
25
  import { SearchTreePipe } from './widgets/tree/pipes/search-tree.pipe';
26
26
  import { ClickOutsideDirective } from './widgets/click-outside/clickoutside.directive';
27
27
  import { OrderingComponent } from './widgets/ordering/ordering.component';
28
+ import { SearchComboboxComponent } from './widgets/search-combobox/search-combobox.component';
29
+ import { TooltipModule } from 'ngx-bootstrap/tooltip';
28
30
  import * as i0 from "@angular/core";
29
31
  import * as i1 from "ngx-bootstrap/modal";
30
32
  import * as i2 from "ngx-bootstrap/accordion";
33
+ import * as i3 from "ngx-bootstrap/tooltip";
31
34
  export class InfraModule {
32
35
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: InfraModule, deps: [], target: i0.ɵɵFactoryTarget.NgModule }); }
33
36
  static { this.ɵmod = i0.ɵɵngDeclareNgModule({ minVersion: "14.0.0", version: "17.3.11", ngImport: i0, type: InfraModule, declarations: [LoadingComponent,
@@ -50,7 +53,8 @@ export class InfraModule {
50
53
  LimitToPipe,
51
54
  SearchTreePipe,
52
55
  ClickOutsideDirective,
53
- OrderingComponent], imports: [CommonModule, i1.ModalModule, i2.AccordionModule, FormsModule,
56
+ OrderingComponent,
57
+ SearchComboboxComponent], imports: [CommonModule, i1.ModalModule, i2.AccordionModule, i3.TooltipModule, FormsModule,
54
58
  ReactiveFormsModule,
55
59
  RouterModule], exports: [LoadingComponent,
56
60
  FieldControlErrorComponent,
@@ -69,10 +73,12 @@ export class InfraModule {
69
73
  ToUrlPipe,
70
74
  CpfCnpjPipe,
71
75
  ClickOutsideDirective,
72
- OrderingComponent] }); }
76
+ OrderingComponent,
77
+ SearchComboboxComponent] }); }
73
78
  static { this.ɵinj = i0.ɵɵngDeclareInjector({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: InfraModule, imports: [CommonModule,
74
79
  ModalModule.forRoot(),
75
80
  AccordionModule.forRoot(),
81
+ TooltipModule.forRoot(),
76
82
  FormsModule,
77
83
  ReactiveFormsModule,
78
84
  RouterModule] }); }
@@ -101,12 +107,14 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
101
107
  LimitToPipe,
102
108
  SearchTreePipe,
103
109
  ClickOutsideDirective,
104
- OrderingComponent
110
+ OrderingComponent,
111
+ SearchComboboxComponent
105
112
  ],
106
113
  imports: [
107
114
  CommonModule,
108
115
  ModalModule.forRoot(),
109
116
  AccordionModule.forRoot(),
117
+ TooltipModule.forRoot(),
110
118
  FormsModule,
111
119
  ReactiveFormsModule,
112
120
  RouterModule
@@ -130,8 +138,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
130
138
  CpfCnpjPipe,
131
139
  ClickOutsideDirective,
132
140
  OrderingComponent,
141
+ SearchComboboxComponent
133
142
  ],
134
143
  providers: [],
135
144
  }]
136
145
  }] });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infra.module.js","sourceRoot":"","sources":["../../../../projects/ngx-sp-infra/src/lib/infra.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { RouterModule } from '@angular/router';\r\n\r\nimport { AccordionModule } from 'ngx-bootstrap/accordion';\r\nimport { ModalModule } from 'ngx-bootstrap/modal';\r\n\r\nimport { AlertComponent } from './message/alert/alert.component';\r\nimport { ConfirmComponent } from './message/confirm/confirm.component';\r\nimport { ConfirmModalComponent } from './message/confirm-modal/confirm-modal.component';\r\nimport { SaveComponent } from './message/save/save.component';\r\nimport { InfraBreadcrumbItemComponent } from './widgets/breadcrumb/infra-breadcrumb-item/infra-breadcrumb-item.component';\r\nimport { InfraBreadcrumbComponent } from './widgets/breadcrumb/infra-breadcrumb/infra-breadcrumb.component';\r\nimport { BreadcrumbComponent } from './widgets/breadcrumb/portalrh-breadcrumb/breadcrumb.component';\r\nimport { ComboboxComponent } from './widgets/combobox/combobox.component';\r\nimport { FieldControlErrorComponent } from './widgets/field-control-error/field-control-error.component';\r\nimport { FieldErrorMessageComponent } from './widgets/field-error-message/field-error-message.component';\r\nimport { LoadingButtonComponent } from './widgets/loading-button/loading-button.component';\r\nimport { LoadingComponent } from './widgets/loading/loading.component';\r\nimport { TreeComponent } from './widgets/tree/tree.component';\r\nimport { SvgStorageComponent } from './widgets/svg-storage/svg-storage.component';\r\nimport { ToUrlPipe } from './pipes/to-url.pipe';\r\nimport { CpfCnpjPipe } from './pipes/cpf-cnpj.pipe';\r\nimport { FilterByPipe } from './widgets/combobox/pipes/filter-by.pipe';\r\nimport { LimitToPipe } from './widgets/combobox/pipes/limit-to.pipe';\r\nimport { SearchTreePipe } from './widgets/tree/pipes/search-tree.pipe';\r\nimport { ClickOutsideDirective } from './widgets/click-outside/clickoutside.directive';\r\nimport { OrderingComponent } from './widgets/ordering/ordering.component';\r\n\r\n@NgModule({\r\n  declarations: [\r\n    LoadingComponent,\r\n    FieldControlErrorComponent,\r\n    FieldErrorMessageComponent,\r\n    LoadingButtonComponent,\r\n    AlertComponent,\r\n    ConfirmComponent,\r\n    ConfirmModalComponent,\r\n    SaveComponent,\r\n    InfraBreadcrumbComponent,\r\n    InfraBreadcrumbItemComponent,\r\n    BreadcrumbComponent,\r\n    ComboboxComponent,\r\n    SvgStorageComponent,\r\n    TreeComponent,\r\n    ToUrlPipe,\r\n    CpfCnpjPipe,\r\n    FilterByPipe,\r\n    LimitToPipe,\r\n    SearchTreePipe,\r\n    ClickOutsideDirective,\r\n    OrderingComponent\r\n  ],\r\n  imports: [\r\n    CommonModule,\r\n    ModalModule.forRoot(),\r\n    AccordionModule.forRoot(),\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    RouterModule\r\n  ],\r\n  exports: [\r\n    LoadingComponent,\r\n    FieldControlErrorComponent,\r\n    FieldErrorMessageComponent,\r\n    LoadingButtonComponent,\r\n    AlertComponent,\r\n    ConfirmComponent,\r\n    ConfirmModalComponent,\r\n    SaveComponent,\r\n    InfraBreadcrumbComponent,\r\n    InfraBreadcrumbItemComponent,\r\n    BreadcrumbComponent,\r\n    ComboboxComponent,\r\n    SvgStorageComponent,\r\n    TreeComponent,\r\n    ToUrlPipe,\r\n    CpfCnpjPipe,\r\n    ClickOutsideDirective,\r\n    OrderingComponent,\r\n  ],\r\n  providers: [],\r\n})\r\nexport class InfraModule { }\r\n"]}
146
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"infra.module.js","sourceRoot":"","sources":["../../../../projects/ngx-sp-infra/src/lib/infra.module.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { NgModule } from '@angular/core';\r\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\r\nimport { RouterModule } from '@angular/router';\r\n\r\nimport { AccordionModule } from 'ngx-bootstrap/accordion';\r\nimport { ModalModule } from 'ngx-bootstrap/modal';\r\n\r\nimport { AlertComponent } from './message/alert/alert.component';\r\nimport { ConfirmComponent } from './message/confirm/confirm.component';\r\nimport { ConfirmModalComponent } from './message/confirm-modal/confirm-modal.component';\r\nimport { SaveComponent } from './message/save/save.component';\r\nimport { InfraBreadcrumbItemComponent } from './widgets/breadcrumb/infra-breadcrumb-item/infra-breadcrumb-item.component';\r\nimport { InfraBreadcrumbComponent } from './widgets/breadcrumb/infra-breadcrumb/infra-breadcrumb.component';\r\nimport { BreadcrumbComponent } from './widgets/breadcrumb/portalrh-breadcrumb/breadcrumb.component';\r\nimport { ComboboxComponent } from './widgets/combobox/combobox.component';\r\nimport { FieldControlErrorComponent } from './widgets/field-control-error/field-control-error.component';\r\nimport { FieldErrorMessageComponent } from './widgets/field-error-message/field-error-message.component';\r\nimport { LoadingButtonComponent } from './widgets/loading-button/loading-button.component';\r\nimport { LoadingComponent } from './widgets/loading/loading.component';\r\nimport { TreeComponent } from './widgets/tree/tree.component';\r\nimport { SvgStorageComponent } from './widgets/svg-storage/svg-storage.component';\r\nimport { ToUrlPipe } from './pipes/to-url.pipe';\r\nimport { CpfCnpjPipe } from './pipes/cpf-cnpj.pipe';\r\nimport { FilterByPipe } from './widgets/combobox/pipes/filter-by.pipe';\r\nimport { LimitToPipe } from './widgets/combobox/pipes/limit-to.pipe';\r\nimport { SearchTreePipe } from './widgets/tree/pipes/search-tree.pipe';\r\nimport { ClickOutsideDirective } from './widgets/click-outside/clickoutside.directive';\r\nimport { OrderingComponent } from './widgets/ordering/ordering.component';\r\nimport { SearchComboboxComponent } from './widgets/search-combobox/search-combobox.component';\r\nimport { TooltipModule } from 'ngx-bootstrap/tooltip';\r\n\r\n@NgModule({\r\n  declarations: [\r\n    LoadingComponent,\r\n    FieldControlErrorComponent,\r\n    FieldErrorMessageComponent,\r\n    LoadingButtonComponent,\r\n    AlertComponent,\r\n    ConfirmComponent,\r\n    ConfirmModalComponent,\r\n    SaveComponent,\r\n    InfraBreadcrumbComponent,\r\n    InfraBreadcrumbItemComponent,\r\n    BreadcrumbComponent,\r\n    ComboboxComponent,\r\n    SvgStorageComponent,\r\n    TreeComponent,\r\n    ToUrlPipe,\r\n    CpfCnpjPipe,\r\n    FilterByPipe,\r\n    LimitToPipe,\r\n    SearchTreePipe,\r\n    ClickOutsideDirective,\r\n    OrderingComponent,\r\n    SearchComboboxComponent\r\n  ],\r\n  imports: [\r\n    CommonModule,\r\n    ModalModule.forRoot(),\r\n    AccordionModule.forRoot(),\r\n    TooltipModule.forRoot(),\r\n    FormsModule,\r\n    ReactiveFormsModule,\r\n    RouterModule\r\n  ],\r\n  exports: [\r\n    LoadingComponent,\r\n    FieldControlErrorComponent,\r\n    FieldErrorMessageComponent,\r\n    LoadingButtonComponent,\r\n    AlertComponent,\r\n    ConfirmComponent,\r\n    ConfirmModalComponent,\r\n    SaveComponent,\r\n    InfraBreadcrumbComponent,\r\n    InfraBreadcrumbItemComponent,\r\n    BreadcrumbComponent,\r\n    ComboboxComponent,\r\n    SvgStorageComponent,\r\n    TreeComponent,\r\n    ToUrlPipe,\r\n    CpfCnpjPipe,\r\n    ClickOutsideDirective,\r\n    OrderingComponent,\r\n    SearchComboboxComponent\r\n  ],\r\n  providers: [],\r\n})\r\nexport class InfraModule { }\r\n"]}
@@ -0,0 +1,15 @@
1
+ export class RecordCombobox {
2
+ constructor() {
3
+ this.ID = 0;
4
+ this.LABEL = "";
5
+ this.AdditionalStringProperty1 = "";
6
+ this.AdditionalStringProperty2 = "";
7
+ this.AdditionalLongProperty1 = 0;
8
+ this.AdditionalLongProperty2 = 0;
9
+ this.AdditionalBooleanProperty1 = false;
10
+ this.AdditionalBooleanProperty2 = false;
11
+ this.IS_SELECTED = false;
12
+ }
13
+ }
14
+ // #endregion Interface IRecordsCombobox
15
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicmVjb3JkLWNvbWJvYm94LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNwLWluZnJhL3NyYy9saWIvbW9kZWxzL2NvbWJvYm94L3JlY29yZC1jb21ib2JveC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxNQUFNLE9BQU8sY0FBYztJQUEzQjtRQUNXLE9BQUUsR0FBb0IsQ0FBQyxDQUFDO1FBQ3hCLFVBQUssR0FBVyxFQUFFLENBQUM7UUFFbkIsOEJBQXlCLEdBQVksRUFBRSxDQUFDO1FBQ3hDLDhCQUF5QixHQUFZLEVBQUUsQ0FBQztRQUN4Qyw0QkFBdUIsR0FBWSxDQUFDLENBQUM7UUFDckMsNEJBQXVCLEdBQVksQ0FBQyxDQUFDO1FBQ3JDLCtCQUEwQixHQUFhLEtBQUssQ0FBQztRQUM3QywrQkFBMEIsR0FBYSxLQUFLLENBQUM7UUFFN0MsZ0JBQVcsR0FBb0IsS0FBSyxDQUFDO0lBQ2hELENBQUM7Q0FBQTtBQVFELHdDQUF3QyIsInNvdXJjZXNDb250ZW50IjpbImV4cG9ydCBjbGFzcyBSZWNvcmRDb21ib2JveCBpbXBsZW1lbnRzIElSZWNvcmRzQ29tYm9ib3gge1xyXG4gICAgcHVibGljIElEOiBzdHJpbmcgfCBudW1iZXIgPSAwO1xyXG4gICAgcHVibGljIExBQkVMOiBzdHJpbmcgPSBcIlwiO1xyXG5cclxuICAgIHB1YmxpYyBBZGRpdGlvbmFsU3RyaW5nUHJvcGVydHkxPzogc3RyaW5nID0gXCJcIjtcclxuICAgIHB1YmxpYyBBZGRpdGlvbmFsU3RyaW5nUHJvcGVydHkyPzogc3RyaW5nID0gXCJcIjtcclxuICAgIHB1YmxpYyBBZGRpdGlvbmFsTG9uZ1Byb3BlcnR5MT86IG51bWJlciA9IDA7XHJcbiAgICBwdWJsaWMgQWRkaXRpb25hbExvbmdQcm9wZXJ0eTI/OiBudW1iZXIgPSAwO1xyXG4gICAgcHVibGljIEFkZGl0aW9uYWxCb29sZWFuUHJvcGVydHkxPzogYm9vbGVhbiA9IGZhbHNlO1xyXG4gICAgcHVibGljIEFkZGl0aW9uYWxCb29sZWFuUHJvcGVydHkyPzogYm9vbGVhbiA9IGZhbHNlO1xyXG5cclxuICAgIHB1YmxpYyBJU19TRUxFQ1RFRD86IGJvb2xlYW4gfCBudWxsID0gZmFsc2U7XHJcbn1cclxuXHJcblxyXG4vLyAjcmVnaW9uIEludGVyZmFjZSBJUmVjb3Jkc0NvbWJvYm94XHJcbmV4cG9ydCBpbnRlcmZhY2UgSVJlY29yZHNDb21ib2JveCB7XHJcbiAgICBJRDogc3RyaW5nIHwgbnVtYmVyO1xyXG4gICAgTEFCRUw6IHN0cmluZztcclxufVxyXG4vLyAjZW5kcmVnaW9uIEludGVyZmFjZSBJUmVjb3Jkc0NvbWJvYm94Il19
@@ -1,7 +1,8 @@
1
1
  import { Component, EventEmitter, Input, Output } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
3
  import * as i1 from "@angular/common";
4
- import * as i2 from "../svg-storage/svg-storage.component";
4
+ import * as i2 from "ngx-bootstrap/tooltip";
5
+ import * as i3 from "../svg-storage/svg-storage.component";
5
6
  export class OrderingComponent {
6
7
  // Função chamada quando o botão de ordenação é clicado
7
8
  sort() {
@@ -37,7 +38,7 @@ export class OrderingComponent {
37
38
  this.sortDirection = '';
38
39
  }
39
40
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: OrderingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
40
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: OrderingComponent, selector: "app-ordering", inputs: { isColumnClicked: "isColumnClicked", sortDirection: "sortDirection", sortAttributes: "sortAttributes" }, outputs: { sortDirectionChange: "sortDirectionChange", sortChange: "sortChange" }, ngImport: i0, template: "<ng-template [ngIf]=\"sortDirection !== 'desc'\">\n <app-svg-storage\n (click)=\"sort()\"\n [svgName]=\"'arrow-up'\"\n [class.rotate]=\"sortDirection !== ''\"\n [svgColor]=\"getSvgColor()\"\n tooltip=\"'Ascendente'\"\n style=\"cursor: pointer;\"\n ></app-svg-storage>\n <!-- Ordenar Ascendente -->\n</ng-template>\n\n<ng-template [ngIf]=\"sortDirection === 'desc'\">\n <app-svg-storage\n (click)=\"sort()\"\n [svgName]=\"'arrow-down'\"\n [class.rotate]=\"true\"\n [svgColor]=\"'blue'\"\n tooltip=\"'Descendente'\"\n style=\"cursor: pointer;\"\n ></app-svg-storage>\n <!-- Ordenar Descendente -->\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "component", type: i2.SvgStorageComponent, selector: "app-svg-storage", inputs: ["svgName", "svgColor", "svgFill", "svgSize", "svgStrokeWidth"] }] }); }
41
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: OrderingComponent, selector: "app-ordering", inputs: { isColumnClicked: "isColumnClicked", sortDirection: "sortDirection", sortAttributes: "sortAttributes" }, outputs: { sortDirectionChange: "sortDirectionChange", sortChange: "sortChange" }, ngImport: i0, template: "<ng-template [ngIf]=\"sortDirection !== 'desc'\">\n <app-svg-storage\n (click)=\"sort()\"\n [svgName]=\"'arrow-up'\"\n [class.rotate]=\"sortDirection !== ''\"\n [svgColor]=\"getSvgColor()\"\n tooltip=\"'Ascendente'\"\n style=\"cursor: pointer;\"\n ></app-svg-storage>\n <!-- Ordenar Ascendente -->\n</ng-template>\n\n<ng-template [ngIf]=\"sortDirection === 'desc'\">\n <app-svg-storage\n (click)=\"sort()\"\n [svgName]=\"'arrow-down'\"\n [class.rotate]=\"true\"\n [svgColor]=\"'blue'\"\n tooltip=\"'Descendente'\"\n style=\"cursor: pointer;\"\n ></app-svg-storage>\n <!-- Ordenar Descendente -->\n</ng-template>\n", styles: [""], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }, { kind: "component", type: i3.SvgStorageComponent, selector: "app-svg-storage", inputs: ["svgName", "svgColor", "svgFill", "svgSize", "svgStrokeWidth"] }] }); }
41
42
  }
42
43
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: OrderingComponent, decorators: [{
43
44
  type: Component,
@@ -53,4 +54,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
53
54
  }], sortChange: [{
54
55
  type: Output
55
56
  }] } });
56
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JkZXJpbmcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNwLWluZnJhL3NyYy9saWIvd2lkZ2V0cy9vcmRlcmluZy9vcmRlcmluZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3AtaW5mcmEvc3JjL2xpYi93aWRnZXRzL29yZGVyaW5nL29yZGVyaW5nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7QUFPL0UsTUFBTSxPQUFPLGlCQUFpQjtJQWU1Qix1REFBdUQ7SUFDdkQsSUFBSTtRQUNGLHVDQUF1QztRQUN2QyxJQUFJLElBQUksQ0FBQyxhQUFhLEtBQUssS0FBSyxFQUFFLENBQUM7WUFDakMsSUFBSSxDQUFDLGFBQWEsR0FBRyxNQUFNLENBQUM7UUFDOUIsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLENBQUMsYUFBYSxHQUFHLEtBQUssQ0FBQztRQUM3QixDQUFDO1FBRUQsaURBQWlEO1FBQ2pELElBQUksQ0FBQyxtQkFBbUIsQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBRWxELG1GQUFtRjtRQUNuRixJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxFQUFFLFNBQVMsRUFBRSxJQUFJLENBQUMsYUFBYSxFQUFFLE1BQU0sRUFBRSxJQUFJLENBQUMsY0FBYyxFQUFFLENBQUMsQ0FBQztJQUN2RixDQUFDO0lBRUQsOERBQThEO0lBQzlELFdBQVc7UUFDVCxPQUFPLElBQUksQ0FBQyxhQUFhLEtBQUssS0FBSyxDQUFDLENBQUMsQ0FBQyxNQUFNLENBQUMsQ0FBQyxDQUFDLFdBQVcsQ0FBQztJQUM3RCxDQUFDO0lBRUQ7UUFsQ1Msb0JBQWUsR0FBWSxLQUFLLENBQUM7UUFDMUMsc0RBQXNEO1FBQzdDLGtCQUFhLEdBQVcsRUFBRSxDQUFDO1FBRXBDLHlCQUF5QjtRQUNoQixtQkFBYyxHQUFzQixFQUFFLENBQUM7UUFFaEQsMERBQTBEO1FBQ2hELHdCQUFtQixHQUFHLElBQUksWUFBWSxFQUFVLENBQUM7UUFFM0Qsd0RBQXdEO1FBQzlDLGVBQVUsR0FBRyxJQUFJLFlBQVksRUFBb0QsQ0FBQztJQXVCN0UsQ0FBQztJQUVoQixRQUFRO1FBQ04sbURBQW1EO1FBQ25ELElBQUksQ0FBQyxhQUFhLEdBQUcsRUFBRSxDQUFDO0lBQzFCLENBQUM7K0dBekNVLGlCQUFpQjttR0FBakIsaUJBQWlCLHlQQ1A5QixpcEJBdUJBOzs0RkRoQmEsaUJBQWlCO2tCQUw3QixTQUFTOytCQUNFLGNBQWM7d0RBTWYsZUFBZTtzQkFBdkIsS0FBSztnQkFFRyxhQUFhO3NCQUFyQixLQUFLO2dCQUdHLGNBQWM7c0JBQXRCLEtBQUs7Z0JBR0ksbUJBQW1CO3NCQUE1QixNQUFNO2dCQUdHLFVBQVU7c0JBQW5CLE1BQU0iLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIEV2ZW50RW1pdHRlciwgSW5wdXQsIE9uSW5pdCwgT3V0cHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2FwcC1vcmRlcmluZycsXG4gIHRlbXBsYXRlVXJsOiAnLi9vcmRlcmluZy5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL29yZGVyaW5nLmNvbXBvbmVudC5zY3NzJ11cbn0pXG5leHBvcnQgY2xhc3MgT3JkZXJpbmdDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQge1xuXG4gIEBJbnB1dCgpIGlzQ29sdW1uQ2xpY2tlZDogYm9vbGVhbiA9IGZhbHNlO1xuICAvLyBEaXJlw6fDo28gYXR1YWwgZGEgb3JkZW5hw6fDo28gKCdhc2MnLCAnZGVzYycgb3UgdmF6aW8pXG4gIEBJbnB1dCgpIHNvcnREaXJlY3Rpb246IHN0cmluZyA9ICcnO1xuXG4gIC8vIEF0cmlidXRvcyBkZSBvcmRlbmHDp8Ojb1xuICBASW5wdXQoKSBzb3J0QXR0cmlidXRlczogc3RyaW5nIHwgc3RyaW5nW10gPSBbXTtcblxuICAvLyBFdmVudG8gZW1pdGlkbyBxdWFuZG8gYSBkaXJlw6fDo28gZGUgb3JkZW5hw6fDo28gw6kgYWx0ZXJhZGFcbiAgQE91dHB1dCgpIHNvcnREaXJlY3Rpb25DaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPHN0cmluZz4oKTtcblxuICAvLyBFdmVudG8gZW1pdGlkbyBxdWFuZG8gb2NvcnJlIHVtYSBtdWRhbsOnYSBuYSBvcmRlbmHDp8Ojb1xuICBAT3V0cHV0KCkgc29ydENoYW5nZSA9IG5ldyBFdmVudEVtaXR0ZXI8eyBkaXJlY3Rpb246IHN0cmluZywgY29sdW1uOiBzdHJpbmcgfCBzdHJpbmdbXSB9PigpO1xuXG4gIC8vIEZ1bsOnw6NvIGNoYW1hZGEgcXVhbmRvIG8gYm90w6NvIGRlIG9yZGVuYcOnw6NvIMOpIGNsaWNhZG9cbiAgc29ydCgpIHtcbiAgICAvLyBJbnZlcnRlIGEgZGlyZcOnw6NvIGRlIG9yZGVuYcOnw6NvIGF0dWFsXG4gICAgaWYgKHRoaXMuc29ydERpcmVjdGlvbiA9PT0gJ2FzYycpIHtcbiAgICAgIHRoaXMuc29ydERpcmVjdGlvbiA9ICdkZXNjJztcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5zb3J0RGlyZWN0aW9uID0gJ2FzYyc7XG4gICAgfVxuXG4gICAgLy8gRW1pdGUgbyBldmVudG8gY29tIGEgbm92YSBkaXJlw6fDo28gZGUgb3JkZW5hw6fDo29cbiAgICB0aGlzLnNvcnREaXJlY3Rpb25DaGFuZ2UuZW1pdCh0aGlzLnNvcnREaXJlY3Rpb24pO1xuXG4gICAgLy8gRW1pdGUgbyBldmVudG8gZGUgbXVkYW7Dp2EgbmEgb3JkZW5hw6fDo28gY29tIGEgZGlyZcOnw6NvIGUgb3MgYXRyaWJ1dG9zIGRlIG9yZGVuYcOnw6NvXG4gICAgdGhpcy5zb3J0Q2hhbmdlLmVtaXQoeyBkaXJlY3Rpb246IHRoaXMuc29ydERpcmVjdGlvbiwgY29sdW1uOiB0aGlzLnNvcnRBdHRyaWJ1dGVzIH0pO1xuICB9XG5cbiAgLy8gT2J0w6ltIGEgY29yIGRvIMOtY29uZSBjb20gYmFzZSBuYSBkaXJlw6fDo28gZGUgb3JkZW5hw6fDo28gYXR1YWxcbiAgZ2V0U3ZnQ29sb3IoKTogc3RyaW5nIHtcbiAgICByZXR1cm4gdGhpcy5zb3J0RGlyZWN0aW9uID09PSAnYXNjJyA/ICdibHVlJyA6ICdsaWdodGdyYXknO1xuICB9XG5cbiAgY29uc3RydWN0b3IoKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIC8vIERlZmluZSBhIGRpcmXDp8OjbyBkZSBvcmRlbmHDp8OjbyBpbmljaWFsIGNvbW8gdmF6aW9cbiAgICB0aGlzLnNvcnREaXJlY3Rpb24gPSAnJztcbiAgfVxufVxuIiwiPG5nLXRlbXBsYXRlIFtuZ0lmXT1cInNvcnREaXJlY3Rpb24gIT09ICdkZXNjJ1wiPlxuICA8YXBwLXN2Zy1zdG9yYWdlXG4gICAgKGNsaWNrKT1cInNvcnQoKVwiXG4gICAgW3N2Z05hbWVdPVwiJ2Fycm93LXVwJ1wiXG4gICAgW2NsYXNzLnJvdGF0ZV09XCJzb3J0RGlyZWN0aW9uICE9PSAnJ1wiXG4gICAgW3N2Z0NvbG9yXT1cImdldFN2Z0NvbG9yKClcIlxuICAgIHRvb2x0aXA9XCInQXNjZW5kZW50ZSdcIlxuICAgIHN0eWxlPVwiY3Vyc29yOiBwb2ludGVyO1wiXG4gID48L2FwcC1zdmctc3RvcmFnZT5cbiAgPCEtLSBPcmRlbmFyIEFzY2VuZGVudGUgLS0+XG48L25nLXRlbXBsYXRlPlxuXG48bmctdGVtcGxhdGUgW25nSWZdPVwic29ydERpcmVjdGlvbiA9PT0gJ2Rlc2MnXCI+XG4gIDxhcHAtc3ZnLXN0b3JhZ2VcbiAgICAoY2xpY2spPVwic29ydCgpXCJcbiAgICBbc3ZnTmFtZV09XCInYXJyb3ctZG93bidcIlxuICAgIFtjbGFzcy5yb3RhdGVdPVwidHJ1ZVwiXG4gICAgW3N2Z0NvbG9yXT1cIidibHVlJ1wiXG4gICAgdG9vbHRpcD1cIidEZXNjZW5kZW50ZSdcIlxuICAgIHN0eWxlPVwiY3Vyc29yOiBwb2ludGVyO1wiXG4gID48L2FwcC1zdmctc3RvcmFnZT5cbiAgPCEtLSBPcmRlbmFyIERlc2NlbmRlbnRlIC0tPlxuPC9uZy10ZW1wbGF0ZT5cbiJdfQ==
57
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoib3JkZXJpbmcuY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbmd4LXNwLWluZnJhL3NyYy9saWIvd2lkZ2V0cy9vcmRlcmluZy9vcmRlcmluZy5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3AtaW5mcmEvc3JjL2xpYi93aWRnZXRzL29yZGVyaW5nL29yZGVyaW5nLmNvbXBvbmVudC5odG1sIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUFBLE9BQU8sRUFBRSxTQUFTLEVBQUUsWUFBWSxFQUFFLEtBQUssRUFBVSxNQUFNLEVBQUUsTUFBTSxlQUFlLENBQUM7Ozs7O0FBTy9FLE1BQU0sT0FBTyxpQkFBaUI7SUFlNUIsdURBQXVEO0lBQ3ZELElBQUk7UUFDRix1Q0FBdUM7UUFDdkMsSUFBSSxJQUFJLENBQUMsYUFBYSxLQUFLLEtBQUssRUFBRSxDQUFDO1lBQ2pDLElBQUksQ0FBQyxhQUFhLEdBQUcsTUFBTSxDQUFDO1FBQzlCLENBQUM7YUFBTSxDQUFDO1lBQ04sSUFBSSxDQUFDLGFBQWEsR0FBRyxLQUFLLENBQUM7UUFDN0IsQ0FBQztRQUVELGlEQUFpRDtRQUNqRCxJQUFJLENBQUMsbUJBQW1CLENBQUMsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQztRQUVsRCxtRkFBbUY7UUFDbkYsSUFBSSxDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsRUFBRSxTQUFTLEVBQUUsSUFBSSxDQUFDLGFBQWEsRUFBRSxNQUFNLEVBQUUsSUFBSSxDQUFDLGNBQWMsRUFBRSxDQUFDLENBQUM7SUFDdkYsQ0FBQztJQUVELDhEQUE4RDtJQUM5RCxXQUFXO1FBQ1QsT0FBTyxJQUFJLENBQUMsYUFBYSxLQUFLLEtBQUssQ0FBQyxDQUFDLENBQUMsTUFBTSxDQUFDLENBQUMsQ0FBQyxXQUFXLENBQUM7SUFDN0QsQ0FBQztJQUVEO1FBbENTLG9CQUFlLEdBQVksS0FBSyxDQUFDO1FBQzFDLHNEQUFzRDtRQUM3QyxrQkFBYSxHQUFXLEVBQUUsQ0FBQztRQUVwQyx5QkFBeUI7UUFDaEIsbUJBQWMsR0FBc0IsRUFBRSxDQUFDO1FBRWhELDBEQUEwRDtRQUNoRCx3QkFBbUIsR0FBRyxJQUFJLFlBQVksRUFBVSxDQUFDO1FBRTNELHdEQUF3RDtRQUM5QyxlQUFVLEdBQUcsSUFBSSxZQUFZLEVBQW9ELENBQUM7SUF1QjdFLENBQUM7SUFFaEIsUUFBUTtRQUNOLG1EQUFtRDtRQUNuRCxJQUFJLENBQUMsYUFBYSxHQUFHLEVBQUUsQ0FBQztJQUMxQixDQUFDOytHQXpDVSxpQkFBaUI7bUdBQWpCLGlCQUFpQix5UENQOUIsaXBCQXVCQTs7NEZEaEJhLGlCQUFpQjtrQkFMN0IsU0FBUzsrQkFDRSxjQUFjO3dEQU1mLGVBQWU7c0JBQXZCLEtBQUs7Z0JBRUcsYUFBYTtzQkFBckIsS0FBSztnQkFHRyxjQUFjO3NCQUF0QixLQUFLO2dCQUdJLG1CQUFtQjtzQkFBNUIsTUFBTTtnQkFHRyxVQUFVO3NCQUFuQixNQUFNIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBFdmVudEVtaXR0ZXIsIElucHV0LCBPbkluaXQsIE91dHB1dCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtb3JkZXJpbmcnLFxuICB0ZW1wbGF0ZVVybDogJy4vb3JkZXJpbmcuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybHM6IFsnLi9vcmRlcmluZy5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIE9yZGVyaW5nQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0IHtcblxuICBASW5wdXQoKSBpc0NvbHVtbkNsaWNrZWQ6IGJvb2xlYW4gPSBmYWxzZTtcbiAgLy8gRGlyZcOnw6NvIGF0dWFsIGRhIG9yZGVuYcOnw6NvICgnYXNjJywgJ2Rlc2MnIG91IHZhemlvKVxuICBASW5wdXQoKSBzb3J0RGlyZWN0aW9uOiBzdHJpbmcgPSAnJztcblxuICAvLyBBdHJpYnV0b3MgZGUgb3JkZW5hw6fDo29cbiAgQElucHV0KCkgc29ydEF0dHJpYnV0ZXM6IHN0cmluZyB8IHN0cmluZ1tdID0gW107XG5cbiAgLy8gRXZlbnRvIGVtaXRpZG8gcXVhbmRvIGEgZGlyZcOnw6NvIGRlIG9yZGVuYcOnw6NvIMOpIGFsdGVyYWRhXG4gIEBPdXRwdXQoKSBzb3J0RGlyZWN0aW9uQ2hhbmdlID0gbmV3IEV2ZW50RW1pdHRlcjxzdHJpbmc+KCk7XG5cbiAgLy8gRXZlbnRvIGVtaXRpZG8gcXVhbmRvIG9jb3JyZSB1bWEgbXVkYW7Dp2EgbmEgb3JkZW5hw6fDo29cbiAgQE91dHB1dCgpIHNvcnRDaGFuZ2UgPSBuZXcgRXZlbnRFbWl0dGVyPHsgZGlyZWN0aW9uOiBzdHJpbmcsIGNvbHVtbjogc3RyaW5nIHwgc3RyaW5nW10gfT4oKTtcblxuICAvLyBGdW7Dp8OjbyBjaGFtYWRhIHF1YW5kbyBvIGJvdMOjbyBkZSBvcmRlbmHDp8OjbyDDqSBjbGljYWRvXG4gIHNvcnQoKSB7XG4gICAgLy8gSW52ZXJ0ZSBhIGRpcmXDp8OjbyBkZSBvcmRlbmHDp8OjbyBhdHVhbFxuICAgIGlmICh0aGlzLnNvcnREaXJlY3Rpb24gPT09ICdhc2MnKSB7XG4gICAgICB0aGlzLnNvcnREaXJlY3Rpb24gPSAnZGVzYyc7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuc29ydERpcmVjdGlvbiA9ICdhc2MnO1xuICAgIH1cblxuICAgIC8vIEVtaXRlIG8gZXZlbnRvIGNvbSBhIG5vdmEgZGlyZcOnw6NvIGRlIG9yZGVuYcOnw6NvXG4gICAgdGhpcy5zb3J0RGlyZWN0aW9uQ2hhbmdlLmVtaXQodGhpcy5zb3J0RGlyZWN0aW9uKTtcblxuICAgIC8vIEVtaXRlIG8gZXZlbnRvIGRlIG11ZGFuw6dhIG5hIG9yZGVuYcOnw6NvIGNvbSBhIGRpcmXDp8OjbyBlIG9zIGF0cmlidXRvcyBkZSBvcmRlbmHDp8Ojb1xuICAgIHRoaXMuc29ydENoYW5nZS5lbWl0KHsgZGlyZWN0aW9uOiB0aGlzLnNvcnREaXJlY3Rpb24sIGNvbHVtbjogdGhpcy5zb3J0QXR0cmlidXRlcyB9KTtcbiAgfVxuXG4gIC8vIE9idMOpbSBhIGNvciBkbyDDrWNvbmUgY29tIGJhc2UgbmEgZGlyZcOnw6NvIGRlIG9yZGVuYcOnw6NvIGF0dWFsXG4gIGdldFN2Z0NvbG9yKCk6IHN0cmluZyB7XG4gICAgcmV0dXJuIHRoaXMuc29ydERpcmVjdGlvbiA9PT0gJ2FzYycgPyAnYmx1ZScgOiAnbGlnaHRncmF5JztcbiAgfVxuXG4gIGNvbnN0cnVjdG9yKCkge31cblxuICBuZ09uSW5pdCgpOiB2b2lkIHtcbiAgICAvLyBEZWZpbmUgYSBkaXJlw6fDo28gZGUgb3JkZW5hw6fDo28gaW5pY2lhbCBjb21vIHZhemlvXG4gICAgdGhpcy5zb3J0RGlyZWN0aW9uID0gJyc7XG4gIH1cbn1cbiIsIjxuZy10ZW1wbGF0ZSBbbmdJZl09XCJzb3J0RGlyZWN0aW9uICE9PSAnZGVzYydcIj5cbiAgPGFwcC1zdmctc3RvcmFnZVxuICAgIChjbGljayk9XCJzb3J0KClcIlxuICAgIFtzdmdOYW1lXT1cIidhcnJvdy11cCdcIlxuICAgIFtjbGFzcy5yb3RhdGVdPVwic29ydERpcmVjdGlvbiAhPT0gJydcIlxuICAgIFtzdmdDb2xvcl09XCJnZXRTdmdDb2xvcigpXCJcbiAgICB0b29sdGlwPVwiJ0FzY2VuZGVudGUnXCJcbiAgICBzdHlsZT1cImN1cnNvcjogcG9pbnRlcjtcIlxuICA+PC9hcHAtc3ZnLXN0b3JhZ2U+XG4gIDwhLS0gT3JkZW5hciBBc2NlbmRlbnRlIC0tPlxuPC9uZy10ZW1wbGF0ZT5cblxuPG5nLXRlbXBsYXRlIFtuZ0lmXT1cInNvcnREaXJlY3Rpb24gPT09ICdkZXNjJ1wiPlxuICA8YXBwLXN2Zy1zdG9yYWdlXG4gICAgKGNsaWNrKT1cInNvcnQoKVwiXG4gICAgW3N2Z05hbWVdPVwiJ2Fycm93LWRvd24nXCJcbiAgICBbY2xhc3Mucm90YXRlXT1cInRydWVcIlxuICAgIFtzdmdDb2xvcl09XCInYmx1ZSdcIlxuICAgIHRvb2x0aXA9XCInRGVzY2VuZGVudGUnXCJcbiAgICBzdHlsZT1cImN1cnNvcjogcG9pbnRlcjtcIlxuICA+PC9hcHAtc3ZnLXN0b3JhZ2U+XG4gIDwhLS0gT3JkZW5hciBEZXNjZW5kZW50ZSAtLT5cbjwvbmctdGVtcGxhdGU+XG4iXX0=
@@ -0,0 +1,134 @@
1
+ import { Component, EventEmitter, Input, Output } from "@angular/core";
2
+ import { FormUtils } from "../../utils/form-utils";
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "@angular/forms";
5
+ import * as i2 from "@angular/common";
6
+ import * as i3 from "ngx-bootstrap/tooltip";
7
+ import * as i4 from "../svg-storage/svg-storage.component";
8
+ /**
9
+ * @file search-combobox.component.ts
10
+ * @description Este arquivo contém a implementação do componente SearchComboboxComponent, que é um componente de interface do usuário
11
+ * para realizar pesquisas e seleções em uma lista de opções apresentada em um combobox.
12
+ *
13
+ * @component SearchComboboxComponent
14
+ * @selector search-combobox
15
+ * @standalone true
16
+ * @imports CommonModule, ProjectModule
17
+ * @templateUrl ./search-combobox.component.html
18
+ * @styleUrl ./search-combobox.component.scss
19
+ *
20
+ * @description
21
+ * O componente SearchComboboxComponent é projetado para fornecer aos usuários uma interface para pesquisar e selecionar itens de uma lista.
22
+ * Ele suporta a filtragem de itens com base na entrada do usuário, permitindo uma seleção mais fácil em listas extensas.
23
+ *
24
+ * ## Funcionalidades:
25
+ * - Pesquisa e filtragem de itens na lista do combobox.
26
+ * - Seleção de itens com feedback visual.
27
+ * - Emissão de eventos personalizados para interações do usuário, como recarregar a lista ou selecionar um item.
28
+ *
29
+ * ## Inputs:
30
+ * - `comboboxList`: Array de objetos representando os itens disponíveis para seleção.
31
+ * - `labelText`: Texto de etiqueta associado ao combobox.
32
+ * - `colorTheme`: Tema de cores para o componente.
33
+ * - `inputGroupIconName`: Nome do ícone a ser exibido no grupo de entrada.
34
+ * - `inputGroupIconTooltip`: Texto de dica de ferramenta para o ícone do grupo de entrada.
35
+ * - `mainInputPlaceholder`: Texto de espaço reservado para o input principal.
36
+ * - `searchInputPlaceholder`: Texto de espaço reservado para o input de pesquisa.
37
+ *
38
+ * ## Outputs:
39
+ * - `onReloadList`: Evento emitido quando a lista precisa ser recarregada.
40
+ * - `onSelectItem`: Evento emitido quando um item é selecionado.
41
+ *
42
+ * ## Métodos Públicos:
43
+ * - `reloadList(search: string)`: Método para recarregar a lista de itens com base na pesquisa fornecida.
44
+ * - `setFilterValue(id: string | number, label: string)`: Método para definir o valor do filtro.
45
+ *
46
+ * ## Propriedades:
47
+ * - `selectedItem`: Getter e Setter para o item selecionado atualmente.
48
+ * - `FormUtils`: Getter para utilitários de formulário.
49
+ * - `_searchInput`: Getter para o valor do input de pesquisa.
50
+ *
51
+ * ## Eventos:
52
+ * - `ngOnInit()`: Inicializa o componente.
53
+ * - `ngOnChanges(changes: SimpleChanges)`: Responde a mudanças nas propriedades de entrada.
54
+ *
55
+ * ## Utilitários:
56
+ * - `createFilterForm()`: Cria o formulário de filtro para a pesquisa.
57
+ * - `mapComboboxList()`: Mapeia a lista de combobox para o formato necessário.
58
+ *
59
+ * @note Este componente é marcado como `standalone`, permitindo seu uso sem a necessidade de importá-lo em um módulo.
60
+ */
61
+ export class SearchComboboxComponent {
62
+ constructor(_formBuilder) {
63
+ this._formBuilder = _formBuilder;
64
+ this.colorTheme = "primary";
65
+ this.inputGroupIconTooltip = "";
66
+ this.mainInputPlaceholder = "Selecione uma opção...";
67
+ this.searchInputPlaceholder = "Pesquisa...";
68
+ this.onReloadList = new EventEmitter();
69
+ this.onSelectItem = new EventEmitter();
70
+ this.mappedComboboxList = [];
71
+ this.searchCombobox = "";
72
+ }
73
+ ngOnInit() {
74
+ this.createFilterForm();
75
+ }
76
+ ngOnChanges(changes) {
77
+ if (changes["comboboxList"] != undefined && changes["comboboxList"].currentValue != undefined) {
78
+ this.mappedComboboxList = this.comboboxList;
79
+ }
80
+ }
81
+ get selectedItem() { return this._selectedItem; }
82
+ set selectedItem(value) {
83
+ this._selectedItem = value;
84
+ this.onSelectItem.emit(value);
85
+ }
86
+ get FormUtils() { return FormUtils; }
87
+ // #region FORM DATA
88
+ get _searchInput() { return this.filterForm.get("_searchInput")?.value; }
89
+ // #endregion FORM DATA
90
+ // #region FORM VALIDATORS
91
+ createFilterForm() {
92
+ this.filterForm = this._formBuilder.group({
93
+ _searchInput: [""]
94
+ });
95
+ }
96
+ // #endregion FORM VALIDATORS
97
+ // #endregion ==========> FORM BUILDER <==========
98
+ // #region ==========> UTILITIES <==========
99
+ setFilterValue(id, label) {
100
+ this.filterForm.controls["_searchInput"].setValue(`${id} - ${label}`);
101
+ this.selectedText = label;
102
+ this.selectedItem = { ID: id, LABEL: label, AdditionalStringProperty1: "", IS_SELECTED: true };
103
+ }
104
+ reloadList(search) {
105
+ this.onReloadList.emit(search);
106
+ }
107
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SearchComboboxComponent, deps: [{ token: i1.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
108
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SearchComboboxComponent, selector: "lib-search-combobox", inputs: { comboboxList: "comboboxList", labelText: "labelText", colorTheme: "colorTheme", inputGroupIconName: "inputGroupIconName", inputGroupIconTooltip: "inputGroupIconTooltip", mainInputPlaceholder: "mainInputPlaceholder", searchInputPlaceholder: "searchInputPlaceholder" }, outputs: { onReloadList: "onReloadList", onSelectItem: "onSelectItem" }, usesOnChanges: true, ngImport: i0, template: "<label class=\"form-label\">{{ labelText }}</label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n <button *ngIf=\"inputGroupIconName\" class=\"btn btn-{{colorTheme}}\" type=\"button\" [tooltip]=\"inputGroupIconTooltip\">\r\n <app-svg-storage [svgName]=\"inputGroupIconName\" svgSize=\"medium-small\" />\r\n </button>\r\n\r\n <input class=\"form-select text-start rounded-end\" type=\"text\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\" [placeholder]=\"mainInputPlaceholder\" [(ngModel)]=\"selectedText\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly>\r\n <ul class=\"dropdown-menu p-2 w-100 glb-max-height-350px overflow-y-scroll\">\r\n <div class=\"input-group mb-2\">\r\n <input #searchInput type=\"text\" id=\"searchInput\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchInputPlaceholder\" (keyup.enter)=\"reloadList(searchInput.value)\">\r\n <button class=\"btn btn-{{colorTheme}}\" (click)=\"reloadList(searchInput.value)\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> Pesquisar </button>\r\n </div>\r\n\r\n <ng-container *ngIf=\"mappedComboboxList; else loadingList\">\r\n <ng-container *ngIf=\"mappedComboboxList.length > 0; else emptyItemList\">\r\n <li *ngIf=\"selectedItem && selectedItem.ID\" class=\"dropdown-item\" (click)=\"setFilterValue('', '')\"> <span class=\"fw-bold\">Limpar op\u00E7\u00E3o selecionada</span> </li>\r\n <li class=\"dropdown-item\" *ngFor=\"let item of mappedComboboxList\" (click)=\"setFilterValue(item.ID, item.LABEL); selectedItem = item\">\r\n <span *ngIf=\"item.AdditionalStringProperty1 || item.AdditionalStringProperty1 != ''\" class=\"glb-fs-12 fw-bold d-inline-block w-125\">{{ item.AdditionalStringProperty1 }}</span> {{ item.LABEL }}\r\n </li>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-template #loadingList> <li class=\"dropdown-item text-center\"> <div class=\"spinner-border\" role=\"status\"><span class=\"visually-hidden\">Carregando dados...</span></div> </li> </ng-template>\r\n <ng-template #emptyItemList> <li class=\"dropdown-item fst-italic\">Nenhum registro encontrado com esta pesquisa...</li> </ng-template>\r\n </ul>\r\n</div>\r\n", styles: [""], dependencies: [{ kind: "directive", type: i2.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i2.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i3.TooltipDirective, selector: "[tooltip], [tooltipHtml]", inputs: ["adaptivePosition", "tooltip", "placement", "triggers", "container", "containerClass", "boundariesElement", "isOpen", "isDisabled", "delay", "tooltipHtml", "tooltipPlacement", "tooltipIsOpen", "tooltipEnable", "tooltipAppendToBody", "tooltipAnimation", "tooltipClass", "tooltipContext", "tooltipPopupDelay", "tooltipFadeDuration", "tooltipTrigger"], outputs: ["tooltipChange", "onShown", "onHidden", "tooltipStateChanged"], exportAs: ["bs-tooltip"] }, { kind: "directive", type: i1.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i1.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i1.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: i4.SvgStorageComponent, selector: "app-svg-storage", inputs: ["svgName", "svgColor", "svgFill", "svgSize", "svgStrokeWidth"] }] }); }
109
+ }
110
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SearchComboboxComponent, decorators: [{
111
+ type: Component,
112
+ args: [{ selector: 'lib-search-combobox', template: "<label class=\"form-label\">{{ labelText }}</label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n <button *ngIf=\"inputGroupIconName\" class=\"btn btn-{{colorTheme}}\" type=\"button\" [tooltip]=\"inputGroupIconTooltip\">\r\n <app-svg-storage [svgName]=\"inputGroupIconName\" svgSize=\"medium-small\" />\r\n </button>\r\n\r\n <input class=\"form-select text-start rounded-end\" type=\"text\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\" [placeholder]=\"mainInputPlaceholder\" [(ngModel)]=\"selectedText\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly>\r\n <ul class=\"dropdown-menu p-2 w-100 glb-max-height-350px overflow-y-scroll\">\r\n <div class=\"input-group mb-2\">\r\n <input #searchInput type=\"text\" id=\"searchInput\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchInputPlaceholder\" (keyup.enter)=\"reloadList(searchInput.value)\">\r\n <button class=\"btn btn-{{colorTheme}}\" (click)=\"reloadList(searchInput.value)\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> Pesquisar </button>\r\n </div>\r\n\r\n <ng-container *ngIf=\"mappedComboboxList; else loadingList\">\r\n <ng-container *ngIf=\"mappedComboboxList.length > 0; else emptyItemList\">\r\n <li *ngIf=\"selectedItem && selectedItem.ID\" class=\"dropdown-item\" (click)=\"setFilterValue('', '')\"> <span class=\"fw-bold\">Limpar op\u00E7\u00E3o selecionada</span> </li>\r\n <li class=\"dropdown-item\" *ngFor=\"let item of mappedComboboxList\" (click)=\"setFilterValue(item.ID, item.LABEL); selectedItem = item\">\r\n <span *ngIf=\"item.AdditionalStringProperty1 || item.AdditionalStringProperty1 != ''\" class=\"glb-fs-12 fw-bold d-inline-block w-125\">{{ item.AdditionalStringProperty1 }}</span> {{ item.LABEL }}\r\n </li>\r\n </ng-container>\r\n </ng-container>\r\n\r\n <ng-template #loadingList> <li class=\"dropdown-item text-center\"> <div class=\"spinner-border\" role=\"status\"><span class=\"visually-hidden\">Carregando dados...</span></div> </li> </ng-template>\r\n <ng-template #emptyItemList> <li class=\"dropdown-item fst-italic\">Nenhum registro encontrado com esta pesquisa...</li> </ng-template>\r\n </ul>\r\n</div>\r\n" }]
113
+ }], ctorParameters: () => [{ type: i1.FormBuilder }], propDecorators: { comboboxList: [{
114
+ type: Input,
115
+ args: [{ required: true }]
116
+ }], labelText: [{
117
+ type: Input,
118
+ args: [{ required: true }]
119
+ }], colorTheme: [{
120
+ type: Input
121
+ }], inputGroupIconName: [{
122
+ type: Input
123
+ }], inputGroupIconTooltip: [{
124
+ type: Input
125
+ }], mainInputPlaceholder: [{
126
+ type: Input
127
+ }], searchInputPlaceholder: [{
128
+ type: Input
129
+ }], onReloadList: [{
130
+ type: Output
131
+ }], onSelectItem: [{
132
+ type: Output
133
+ }] } });
134
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"search-combobox.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/search-combobox/search-combobox.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/search-combobox/search-combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges } from \"@angular/core\";\r\nimport { FormBuilder, FormGroup } from \"@angular/forms\";\r\n\r\nimport { FormUtils } from \"../../utils/form-utils\";\r\n\r\nimport { RecordCombobox } from \"../../models/combobox/record-combobox\";\r\n\r\n\r\n/**\r\n * @file search-combobox.component.ts\r\n * @description Este arquivo contém a implementação do componente SearchComboboxComponent, que é um componente de interface do usuário\r\n * para realizar pesquisas e seleções em uma lista de opções apresentada em um combobox.\r\n * \r\n * @component SearchComboboxComponent\r\n * @selector search-combobox\r\n * @standalone true\r\n * @imports CommonModule, ProjectModule\r\n * @templateUrl ./search-combobox.component.html\r\n * @styleUrl ./search-combobox.component.scss\r\n * \r\n * @description\r\n * O componente SearchComboboxComponent é projetado para fornecer aos usuários uma interface para pesquisar e selecionar itens de uma lista.\r\n * Ele suporta a filtragem de itens com base na entrada do usuário, permitindo uma seleção mais fácil em listas extensas.\r\n * \r\n * ## Funcionalidades:\r\n * - Pesquisa e filtragem de itens na lista do combobox.\r\n * - Seleção de itens com feedback visual.\r\n * - Emissão de eventos personalizados para interações do usuário, como recarregar a lista ou selecionar um item.\r\n * \r\n * ## Inputs:\r\n * - `comboboxList`: Array de objetos representando os itens disponíveis para seleção.\r\n * - `labelText`: Texto de etiqueta associado ao combobox.\r\n * - `colorTheme`: Tema de cores para o componente.\r\n * - `inputGroupIconName`: Nome do ícone a ser exibido no grupo de entrada.\r\n * - `inputGroupIconTooltip`: Texto de dica de ferramenta para o ícone do grupo de entrada.\r\n * - `mainInputPlaceholder`: Texto de espaço reservado para o input principal.\r\n * - `searchInputPlaceholder`: Texto de espaço reservado para o input de pesquisa.\r\n * \r\n * ## Outputs:\r\n * - `onReloadList`: Evento emitido quando a lista precisa ser recarregada.\r\n * - `onSelectItem`: Evento emitido quando um item é selecionado.\r\n * \r\n * ## Métodos Públicos:\r\n * - `reloadList(search: string)`: Método para recarregar a lista de itens com base na pesquisa fornecida.\r\n * - `setFilterValue(id: string | number, label: string)`: Método para definir o valor do filtro.\r\n * \r\n * ## Propriedades:\r\n * - `selectedItem`: Getter e Setter para o item selecionado atualmente.\r\n * - `FormUtils`: Getter para utilitários de formulário.\r\n * - `_searchInput`: Getter para o valor do input de pesquisa.\r\n * \r\n * ## Eventos:\r\n * - `ngOnInit()`: Inicializa o componente.\r\n * - `ngOnChanges(changes: SimpleChanges)`: Responde a mudanças nas propriedades de entrada.\r\n * \r\n * ## Utilitários:\r\n * - `createFilterForm()`: Cria o formulário de filtro para a pesquisa.\r\n * - `mapComboboxList()`: Mapeia a lista de combobox para o formato necessário.\r\n * \r\n * @note Este componente é marcado como `standalone`, permitindo seu uso sem a necessidade de importá-lo em um módulo.\r\n */\r\n@Component({\r\n  selector: 'lib-search-combobox',\r\n  templateUrl: './search-combobox.component.html',\r\n  styleUrl: './search-combobox.component.scss'\r\n})\r\nexport class SearchComboboxComponent implements OnInit, OnChanges {\r\n  constructor(\r\n    private _formBuilder: FormBuilder\r\n  ) {}\r\n\r\n  public ngOnInit(): void {\r\n    this.createFilterForm();\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes[\"comboboxList\"] != undefined && changes[\"comboboxList\"].currentValue != undefined) {\r\n      this.mappedComboboxList = this.comboboxList;\r\n    }\r\n  }\r\n\r\n  // #region ==========> PROPERTIES <==========\r\n\r\n  // #region PRIVATE\r\n  private _selectedItem: RecordCombobox;\r\n  // #endregion PRIVATE\r\n\r\n  // #region PUBLIC\r\n  @Input({ required: true }) public comboboxList: RecordCombobox[];\r\n  @Input({ required: true }) public labelText: string;\r\n  \r\n  @Input() public colorTheme: string = \"primary\";\r\n  @Input() public inputGroupIconName: string;\r\n  @Input() public inputGroupIconTooltip: string = \"\";\r\n  @Input() public mainInputPlaceholder: string = \"Selecione uma opção...\";\r\n  @Input() public searchInputPlaceholder: string = \"Pesquisa...\";\r\n\r\n  @Output() public onReloadList: EventEmitter<string> = new EventEmitter<string>();\r\n  @Output() public onSelectItem: EventEmitter<any> = new EventEmitter<any>();\r\n\r\n  public mappedComboboxList: RecordCombobox[] = [];\r\n  public searchCombobox: string = \"\";\r\n\r\n  public selectedText: string;\r\n\r\n  public get selectedItem(): RecordCombobox { return this._selectedItem; }\r\n  public set selectedItem(value: RecordCombobox) {\r\n    this._selectedItem = value;\r\n    this.onSelectItem.emit(value);\r\n  }\r\n  // #endregion PUBLIC\r\n\r\n  // #endregion ==========> PROPERTIES <==========\r\n\r\n\r\n  // #region ==========> FORM BUILDER <==========\r\n  public filterForm: FormGroup;\r\n  public get FormUtils(): typeof FormUtils { return FormUtils; }\r\n\r\n  // #region FORM DATA\r\n  public get _searchInput(): string { return this.filterForm.get(\"_searchInput\")?.value; }\r\n  // #endregion FORM DATA\r\n\r\n  // #region FORM VALIDATORS\r\n  private createFilterForm(): void {\r\n    this.filterForm = this._formBuilder.group({\r\n      _searchInput: [ \"\" ]\r\n    });\r\n  }\r\n  // #endregion FORM VALIDATORS\r\n\r\n  // #endregion ==========> FORM BUILDER <==========\r\n\r\n\r\n  // #region ==========> UTILITIES <==========\r\n  public setFilterValue(id: string | number, label: string): void {\r\n    this.filterForm.controls[\"_searchInput\"].setValue(`${id as string} - ${label}`);\r\n    this.selectedText = label;\r\n\r\n    this.selectedItem = { ID: id, LABEL: label, AdditionalStringProperty1: \"\", IS_SELECTED: true };\r\n  }\r\n\r\n\r\n  public reloadList(search: string): void {\r\n    this.onReloadList.emit(search);\r\n  }\r\n  // #endregion ==========> UTILITIES <==========\r\n\r\n\r\n  // #region ==========> MODALS <==========\r\n  // [...]\r\n  // #endregion ==========> MODALS <==========\r\n\r\n}\r\n","<label class=\"form-label\">{{ labelText }}</label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n   <button *ngIf=\"inputGroupIconName\" class=\"btn btn-{{colorTheme}}\" type=\"button\" [tooltip]=\"inputGroupIconTooltip\">\r\n      <app-svg-storage [svgName]=\"inputGroupIconName\" svgSize=\"medium-small\" />\r\n   </button>\r\n\r\n   <input class=\"form-select text-start rounded-end\" type=\"text\" data-bs-toggle=\"dropdown\" aria-expanded=\"false\" [placeholder]=\"mainInputPlaceholder\" [(ngModel)]=\"selectedText\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly>\r\n   <ul class=\"dropdown-menu p-2 w-100 glb-max-height-350px overflow-y-scroll\">\r\n      <div class=\"input-group mb-2\">\r\n         <input #searchInput type=\"text\" id=\"searchInput\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchInputPlaceholder\" (keyup.enter)=\"reloadList(searchInput.value)\">\r\n         <button class=\"btn btn-{{colorTheme}}\" (click)=\"reloadList(searchInput.value)\"> <app-svg-storage svgName=\"lupa\" svgSize=\"medium-small\" /> Pesquisar </button>\r\n      </div>\r\n\r\n      <ng-container *ngIf=\"mappedComboboxList; else loadingList\">\r\n         <ng-container *ngIf=\"mappedComboboxList.length > 0; else emptyItemList\">\r\n            <li *ngIf=\"selectedItem && selectedItem.ID\" class=\"dropdown-item\" (click)=\"setFilterValue('', '')\"> <span class=\"fw-bold\">Limpar opção selecionada</span> </li>\r\n            <li class=\"dropdown-item\" *ngFor=\"let item of mappedComboboxList\" (click)=\"setFilterValue(item.ID, item.LABEL); selectedItem = item\">\r\n               <span *ngIf=\"item.AdditionalStringProperty1 || item.AdditionalStringProperty1 != ''\" class=\"glb-fs-12 fw-bold d-inline-block w-125\">{{ item.AdditionalStringProperty1 }}</span> {{ item.LABEL }}\r\n            </li>\r\n         </ng-container>\r\n      </ng-container>\r\n\r\n      <ng-template #loadingList> <li class=\"dropdown-item text-center\"> <div class=\"spinner-border\" role=\"status\"><span class=\"visually-hidden\">Carregando dados...</span></div> </li> </ng-template>\r\n      <ng-template #emptyItemList> <li class=\"dropdown-item fst-italic\">Nenhum registro encontrado com esta pesquisa...</li> </ng-template>\r\n   </ul>\r\n</div>\r\n"]}