ngx-sp-infra 0.3.78 → 0.3.79
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.
|
@@ -3,8 +3,7 @@ import { FormUtils } from "../../utils/form-utils";
|
|
|
3
3
|
import * as i0 from "@angular/core";
|
|
4
4
|
import * as i1 from "@angular/forms";
|
|
5
5
|
import * as i2 from "@angular/common";
|
|
6
|
-
import * as i3 from "
|
|
7
|
-
import * as i4 from "../svg-storage/svg-storage.component";
|
|
6
|
+
import * as i3 from "../svg-storage/svg-storage.component";
|
|
8
7
|
/**
|
|
9
8
|
* @file search-combobox.component.ts
|
|
10
9
|
* @description Este arquivo contém a implementação do componente SearchComboboxComponent, que é um componente de interface do usuário
|
|
@@ -70,6 +69,9 @@ export class SearchComboboxComponent {
|
|
|
70
69
|
}
|
|
71
70
|
ngOnInit() {
|
|
72
71
|
this.createFilterForm();
|
|
72
|
+
if (this.initializedValueID) {
|
|
73
|
+
this.initializeSelectedValue();
|
|
74
|
+
}
|
|
73
75
|
}
|
|
74
76
|
ngOnChanges(changes) {
|
|
75
77
|
if (changes["currentSelectedOption"] != undefined && changes["currentSelectedOption"].currentValue != undefined) {
|
|
@@ -79,7 +81,10 @@ export class SearchComboboxComponent {
|
|
|
79
81
|
get selectedItem() { return this._selectedItem; }
|
|
80
82
|
set selectedItem(value) {
|
|
81
83
|
this._selectedItem = value;
|
|
82
|
-
|
|
84
|
+
console.log("public set selectedItem");
|
|
85
|
+
if (!this.initializedValueID) {
|
|
86
|
+
this.onSelectItem.emit(value);
|
|
87
|
+
}
|
|
83
88
|
}
|
|
84
89
|
get FormUtils() { return FormUtils; }
|
|
85
90
|
// #region FORM DATA
|
|
@@ -100,26 +105,28 @@ export class SearchComboboxComponent {
|
|
|
100
105
|
this.selectedItem = { ID: id, LABEL: label, AdditionalStringProperty1: "", IS_SELECTED: true };
|
|
101
106
|
}
|
|
102
107
|
initializeSelectedValue() {
|
|
103
|
-
|
|
104
|
-
|
|
108
|
+
let initializedValue = this.comboboxList.find(item => item.ID == this.initializedValueID);
|
|
109
|
+
if (this.comboboxList && initializedValue) {
|
|
110
|
+
this.selectedText = initializedValue.LABEL;
|
|
111
|
+
this.selectedItem = { ID: initializedValue.ID, LABEL: initializedValue.LABEL, AdditionalStringProperty1: "", IS_SELECTED: true };
|
|
105
112
|
}
|
|
106
113
|
}
|
|
107
114
|
reloadList(search) {
|
|
108
115
|
this.onReloadList.emit(search);
|
|
109
116
|
}
|
|
110
117
|
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 }); }
|
|
111
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SearchComboboxComponent, selector: "lib-search-combobox", inputs: { comboboxList: "comboboxList", labelText: "labelText",
|
|
118
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SearchComboboxComponent, selector: "lib-search-combobox", inputs: { comboboxList: "comboboxList", labelText: "labelText", initializedValueID: "initializedValueID", colorTheme: "colorTheme", inputGroupIconName: "inputGroupIconName", inputGroupIconTooltip: "inputGroupIconTooltip", mainInputPlaceholder: "mainInputPlaceholder", searchInputPlaceholder: "searchInputPlaceholder" }, outputs: { onReloadList: "onReloadList", onSelectItem: "onSelectItem" }, usesOnChanges: true, ngImport: i0, template: "<label class=\"form-label fw-bold\" [innerHTML]=\"labelText\"></label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n\r\n <!-- Este elemento ng-content com o atributo [btnLeft] permite que o usu\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\r\n Ao usar o atributo [btnLeft], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\r\n <ng-content select=\"[btnLeft]\"></ng-content>\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=\"comboboxList; else loadingList\">\r\n <ng-container *ngIf=\"comboboxList.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 comboboxList\" (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\r\n <!-- Este elemento ng-content com o atributo [btnRight] permite que o usu\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado direito do combobox de pesquisa.\r\n Ao usar o atributo [btnRight], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\r\n <ng-content select=\"[btnRight]\"></ng-content>\r\n\r\n</div>\r\n", styles: [".glb-max-height-350px{max-height:350px!important}\n"], 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: 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: i3.SvgStorageComponent, selector: "app-svg-storage", inputs: ["svgName", "svgColor", "svgFill", "svgSize", "svgStrokeWidth"] }] }); }
|
|
112
119
|
}
|
|
113
120
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SearchComboboxComponent, decorators: [{
|
|
114
121
|
type: Component,
|
|
115
|
-
args: [{ selector: 'lib-search-combobox', template: "<label class=\"form-label\" [innerHTML]=\"labelText\"></label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n
|
|
122
|
+
args: [{ selector: 'lib-search-combobox', template: "<label class=\"form-label fw-bold\" [innerHTML]=\"labelText\"></label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n\r\n <!-- Este elemento ng-content com o atributo [btnLeft] permite que o usu\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\r\n Ao usar o atributo [btnLeft], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\r\n <ng-content select=\"[btnLeft]\"></ng-content>\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=\"comboboxList; else loadingList\">\r\n <ng-container *ngIf=\"comboboxList.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 comboboxList\" (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\r\n <!-- Este elemento ng-content com o atributo [btnRight] permite que o usu\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado direito do combobox de pesquisa.\r\n Ao usar o atributo [btnRight], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\r\n <ng-content select=\"[btnRight]\"></ng-content>\r\n\r\n</div>\r\n", styles: [".glb-max-height-350px{max-height:350px!important}\n"] }]
|
|
116
123
|
}], ctorParameters: () => [{ type: i1.FormBuilder }], propDecorators: { comboboxList: [{
|
|
117
124
|
type: Input,
|
|
118
125
|
args: [{ required: true }]
|
|
119
126
|
}], labelText: [{
|
|
120
127
|
type: Input,
|
|
121
128
|
args: [{ required: true }]
|
|
122
|
-
}],
|
|
129
|
+
}], initializedValueID: [{
|
|
123
130
|
type: Input
|
|
124
131
|
}], colorTheme: [{
|
|
125
132
|
type: Input
|
|
@@ -136,4 +143,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImpo
|
|
|
136
143
|
}], onSelectItem: [{
|
|
137
144
|
type: Output
|
|
138
145
|
}] } });
|
|
139
|
-
//# 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[\"currentSelectedOption\"] != undefined && changes[\"currentSelectedOption\"].currentValue != undefined) {\r\n      this.initializeSelectedValue();\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 currentSelectedOption: string | number;\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 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  private initializeSelectedValue(): void {\r\n    if (this.comboboxList && this.comboboxList.find(item => item.ID == this.currentSelectedOption)) {\r\n      this.selectedText = this.comboboxList.find(item => item.ID == this.currentSelectedOption)!.LABEL;\r\n    }\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\" [innerHTML]=\"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=\"comboboxList; else loadingList\">\r\n         <ng-container *ngIf=\"comboboxList.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 comboboxList\" (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"]}
|
|
146
|
+
//# 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    if (this.initializedValueID) { this.initializeSelectedValue() }\r\n  }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes[\"currentSelectedOption\"] != undefined && changes[\"currentSelectedOption\"].currentValue != undefined) {\r\n      this.initializeSelectedValue();\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 initializedValueID: string | number;\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 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\r\n    console.log(\"public set selectedItem\");\r\n    if (!this.initializedValueID) { 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  private initializeSelectedValue(): void {\r\n    let initializedValue = this.comboboxList.find(item => item.ID == this.initializedValueID);\r\n\r\n    if (this.comboboxList && initializedValue) {\r\n      this.selectedText = initializedValue.LABEL;\r\n      this.selectedItem = { ID: initializedValue.ID, LABEL: initializedValue.LABEL, AdditionalStringProperty1: \"\", IS_SELECTED: true };\r\n    }\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 fw-bold\" [innerHTML]=\"labelText\"></label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n\r\n   <!-- Este elemento ng-content com o atributo [btnLeft] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\r\n   Ao usar o atributo [btnLeft], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\r\n   <ng-content select=\"[btnLeft]\"></ng-content>\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=\"comboboxList; else loadingList\">\r\n         <ng-container *ngIf=\"comboboxList.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 comboboxList\" (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\r\n   <!-- Este elemento ng-content com o atributo [btnRight] permite que o usuário final forneça conteúdo personalizado para ser exibido no lado direito do combobox de pesquisa.\r\n   Ao usar o atributo [btnRight], o usuário pode facilmente adicionar botões ou outros elementos para melhorar a funcionalidade ou aparência do combobox de pesquisa. -->\r\n   <ng-content select=\"[btnRight]\"></ng-content>\r\n\r\n</div>\r\n"]}
|
|
@@ -5,13 +5,13 @@ import { Component, Input, EventEmitter, Output, Pipe, forwardRef, ViewChildren,
|
|
|
5
5
|
import * as i2 from '@angular/forms';
|
|
6
6
|
import { NG_VALUE_ACCESSOR, UntypedFormGroup, UntypedFormArray, FormsModule, ReactiveFormsModule, NG_VALIDATORS } from '@angular/forms';
|
|
7
7
|
import { RouterModule } from '@angular/router';
|
|
8
|
-
import * as i2$
|
|
8
|
+
import * as i2$2 from 'ngx-bootstrap/accordion';
|
|
9
9
|
import { AccordionModule } from 'ngx-bootstrap/accordion';
|
|
10
10
|
import * as i1 from 'ngx-bootstrap/modal';
|
|
11
11
|
import { ModalModule } from 'ngx-bootstrap/modal';
|
|
12
12
|
import { Subject } from 'rxjs';
|
|
13
13
|
import * as i1$2 from '@angular/platform-browser';
|
|
14
|
-
import * as
|
|
14
|
+
import * as i2$1 from 'ngx-bootstrap/tooltip';
|
|
15
15
|
import { TooltipModule } from 'ngx-bootstrap/tooltip';
|
|
16
16
|
import { take } from 'rxjs/operators';
|
|
17
17
|
import * as i1$3 from '@angular/common/http';
|
|
@@ -1449,7 +1449,7 @@ class OrderingComponent {
|
|
|
1449
1449
|
this.sortDirection = '';
|
|
1450
1450
|
}
|
|
1451
1451
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: OrderingComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1452
|
-
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$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type:
|
|
1452
|
+
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$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2$1.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: SvgStorageComponent, selector: "app-svg-storage", inputs: ["svgName", "svgColor", "svgFill", "svgSize", "svgStrokeWidth"] }] }); }
|
|
1453
1453
|
}
|
|
1454
1454
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: OrderingComponent, decorators: [{
|
|
1455
1455
|
type: Component,
|
|
@@ -1531,6 +1531,9 @@ class SearchComboboxComponent {
|
|
|
1531
1531
|
}
|
|
1532
1532
|
ngOnInit() {
|
|
1533
1533
|
this.createFilterForm();
|
|
1534
|
+
if (this.initializedValueID) {
|
|
1535
|
+
this.initializeSelectedValue();
|
|
1536
|
+
}
|
|
1534
1537
|
}
|
|
1535
1538
|
ngOnChanges(changes) {
|
|
1536
1539
|
if (changes["currentSelectedOption"] != undefined && changes["currentSelectedOption"].currentValue != undefined) {
|
|
@@ -1540,7 +1543,10 @@ class SearchComboboxComponent {
|
|
|
1540
1543
|
get selectedItem() { return this._selectedItem; }
|
|
1541
1544
|
set selectedItem(value) {
|
|
1542
1545
|
this._selectedItem = value;
|
|
1543
|
-
|
|
1546
|
+
console.log("public set selectedItem");
|
|
1547
|
+
if (!this.initializedValueID) {
|
|
1548
|
+
this.onSelectItem.emit(value);
|
|
1549
|
+
}
|
|
1544
1550
|
}
|
|
1545
1551
|
get FormUtils() { return FormUtils; }
|
|
1546
1552
|
// #region FORM DATA
|
|
@@ -1561,26 +1567,28 @@ class SearchComboboxComponent {
|
|
|
1561
1567
|
this.selectedItem = { ID: id, LABEL: label, AdditionalStringProperty1: "", IS_SELECTED: true };
|
|
1562
1568
|
}
|
|
1563
1569
|
initializeSelectedValue() {
|
|
1564
|
-
|
|
1565
|
-
|
|
1570
|
+
let initializedValue = this.comboboxList.find(item => item.ID == this.initializedValueID);
|
|
1571
|
+
if (this.comboboxList && initializedValue) {
|
|
1572
|
+
this.selectedText = initializedValue.LABEL;
|
|
1573
|
+
this.selectedItem = { ID: initializedValue.ID, LABEL: initializedValue.LABEL, AdditionalStringProperty1: "", IS_SELECTED: true };
|
|
1566
1574
|
}
|
|
1567
1575
|
}
|
|
1568
1576
|
reloadList(search) {
|
|
1569
1577
|
this.onReloadList.emit(search);
|
|
1570
1578
|
}
|
|
1571
1579
|
static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SearchComboboxComponent, deps: [{ token: i2.FormBuilder }], target: i0.ɵɵFactoryTarget.Component }); }
|
|
1572
|
-
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SearchComboboxComponent, selector: "lib-search-combobox", inputs: { comboboxList: "comboboxList", labelText: "labelText",
|
|
1580
|
+
static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.3.11", type: SearchComboboxComponent, selector: "lib-search-combobox", inputs: { comboboxList: "comboboxList", labelText: "labelText", initializedValueID: "initializedValueID", colorTheme: "colorTheme", inputGroupIconName: "inputGroupIconName", inputGroupIconTooltip: "inputGroupIconTooltip", mainInputPlaceholder: "mainInputPlaceholder", searchInputPlaceholder: "searchInputPlaceholder" }, outputs: { onReloadList: "onReloadList", onSelectItem: "onSelectItem" }, usesOnChanges: true, ngImport: i0, template: "<label class=\"form-label fw-bold\" [innerHTML]=\"labelText\"></label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n\r\n <!-- Este elemento ng-content com o atributo [btnLeft] permite que o usu\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\r\n Ao usar o atributo [btnLeft], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\r\n <ng-content select=\"[btnLeft]\"></ng-content>\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=\"comboboxList; else loadingList\">\r\n <ng-container *ngIf=\"comboboxList.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 comboboxList\" (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\r\n <!-- Este elemento ng-content com o atributo [btnRight] permite que o usu\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado direito do combobox de pesquisa.\r\n Ao usar o atributo [btnRight], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\r\n <ng-content select=\"[btnRight]\"></ng-content>\r\n\r\n</div>\r\n", styles: [".glb-max-height-350px{max-height:350px!important}\n"], dependencies: [{ kind: "directive", type: i1$1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1$1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.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: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "component", type: SvgStorageComponent, selector: "app-svg-storage", inputs: ["svgName", "svgColor", "svgFill", "svgSize", "svgStrokeWidth"] }] }); }
|
|
1573
1581
|
}
|
|
1574
1582
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.11", ngImport: i0, type: SearchComboboxComponent, decorators: [{
|
|
1575
1583
|
type: Component,
|
|
1576
|
-
args: [{ selector: 'lib-search-combobox', template: "<label class=\"form-label\" [innerHTML]=\"labelText\"></label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n
|
|
1584
|
+
args: [{ selector: 'lib-search-combobox', template: "<label class=\"form-label fw-bold\" [innerHTML]=\"labelText\"></label>\r\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\r\n\r\n <!-- Este elemento ng-content com o atributo [btnLeft] permite que o usu\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado esquerdo do combobox de pesquisa.\r\n Ao usar o atributo [btnLeft], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\r\n <ng-content select=\"[btnLeft]\"></ng-content>\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=\"comboboxList; else loadingList\">\r\n <ng-container *ngIf=\"comboboxList.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 comboboxList\" (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\r\n <!-- Este elemento ng-content com o atributo [btnRight] permite que o usu\u00E1rio final forne\u00E7a conte\u00FAdo personalizado para ser exibido no lado direito do combobox de pesquisa.\r\n Ao usar o atributo [btnRight], o usu\u00E1rio pode facilmente adicionar bot\u00F5es ou outros elementos para melhorar a funcionalidade ou apar\u00EAncia do combobox de pesquisa. -->\r\n <ng-content select=\"[btnRight]\"></ng-content>\r\n\r\n</div>\r\n", styles: [".glb-max-height-350px{max-height:350px!important}\n"] }]
|
|
1577
1585
|
}], ctorParameters: () => [{ type: i2.FormBuilder }], propDecorators: { comboboxList: [{
|
|
1578
1586
|
type: Input,
|
|
1579
1587
|
args: [{ required: true }]
|
|
1580
1588
|
}], labelText: [{
|
|
1581
1589
|
type: Input,
|
|
1582
1590
|
args: [{ required: true }]
|
|
1583
|
-
}],
|
|
1591
|
+
}], initializedValueID: [{
|
|
1584
1592
|
type: Input
|
|
1585
1593
|
}], colorTheme: [{
|
|
1586
1594
|
type: Input
|
|
@@ -1621,7 +1629,7 @@ class InfraModule {
|
|
|
1621
1629
|
SearchTreePipe,
|
|
1622
1630
|
ClickOutsideDirective,
|
|
1623
1631
|
OrderingComponent,
|
|
1624
|
-
SearchComboboxComponent], imports: [CommonModule, i1.ModalModule, i2$
|
|
1632
|
+
SearchComboboxComponent], imports: [CommonModule, i1.ModalModule, i2$2.AccordionModule, i2$1.TooltipModule, FormsModule,
|
|
1625
1633
|
ReactiveFormsModule,
|
|
1626
1634
|
RouterModule], exports: [LoadingComponent,
|
|
1627
1635
|
FieldControlErrorComponent,
|