ngx-sp-infra 3.20.0 → 3.20.2
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.
|
@@ -148,6 +148,8 @@ export class LibComboboxComponent {
|
|
|
148
148
|
this.updateSelectedValue();
|
|
149
149
|
if (changes["libRequired"]?.currentValue != undefined)
|
|
150
150
|
this.setValidator();
|
|
151
|
+
if (changes["separator"].currentValue != undefined)
|
|
152
|
+
this.updateSelectedValue(this.control.value, false);
|
|
151
153
|
if (changes["control"]?.currentValue) {
|
|
152
154
|
this.setValidator();
|
|
153
155
|
this.updateSelectedValue(changes["control"].currentValue.value);
|
|
@@ -180,14 +182,14 @@ export class LibComboboxComponent {
|
|
|
180
182
|
this.setControlStatus(this.innerControl.status);
|
|
181
183
|
this.changeValue.emit(null);
|
|
182
184
|
}
|
|
183
|
-
updateSelectedValue(value) {
|
|
185
|
+
updateSelectedValue(value, noChange = true) {
|
|
184
186
|
this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa
|
|
185
187
|
const selectedValue = value ?? this._outerControl.value;
|
|
186
188
|
if (!this.list || (selectedValue === null && selectedValue === ''))
|
|
187
189
|
return;
|
|
188
190
|
const initializedValue = this.list.find(item => item.ID === selectedValue);
|
|
189
191
|
if (initializedValue)
|
|
190
|
-
this.innerControl.setValue(`${initializedValue.AdditionalStringProperty1 && initializedValue.AdditionalStringProperty1 != '' ? initializedValue.AdditionalStringProperty1 : ""}${this.separator === undefined ? "" : " " + this.separator + " "}${initializedValue.LABEL}
|
|
192
|
+
this.innerControl.setValue(`${initializedValue.AdditionalStringProperty1 && initializedValue.AdditionalStringProperty1 != '' ? initializedValue.AdditionalStringProperty1 : ""}${this.separator === undefined ? "" : " " + this.separator + " "}${initializedValue.LABEL}`, { emitEvent: noChange });
|
|
191
193
|
}
|
|
192
194
|
adjustDropdownWidth() {
|
|
193
195
|
if (this._mainInput && this._dropdownMenu) {
|
|
@@ -287,4 +289,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
287
289
|
type: HostListener,
|
|
288
290
|
args: ['window:resize', ['$event']]
|
|
289
291
|
}] } });
|
|
290
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-combobox.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { AbstractControl, FormControl, FormControlStatus, Validators } from '@angular/forms';\n\nimport { Subscription } from 'rxjs';\n\nimport { RecordCombobox } from '../../models/combobox/record-combobox';\n\n/**\n * @component LibComboboxComponent\n * @selector lib-combobox\n * \n * @description\n * O componente LibComboboxComponent é projetado para fornecer aos usuários uma interface para pesquisar e selecionar itens de uma lista.\n * Ele suporta a filtragem de itens com base na entrada do usuário, permitindo uma seleção mais fácil em listas extensas.\n * \n * ## Funcionalidades:\n * - Pesquisa e filtragem de itens na lista do combobox.\n * - Seleção de itens com feedback visual.\n * - Emissão de eventos personalizados para interações do usuário, como recarregar a lista ou selecionar um item.\n * - Ajuste dinâmico da largura do dropdown para corresponder ao input principal.\n * - Inicialização de um valor selecionado, se fornecido.\n * \n * ## Inputs:\n * - `control` (FormControl | AbstractControl): Control para seleção dos valores, atualizará automaticamente o control do componente pai também\n * - `comboboxList` (RecordCombobox[]): Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\n * - `labelText` (string): Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\n * - `disabled` (boolean): Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\n * - `libRequired` (boolean): Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\n * - `mainInputPlaceholder` (string): Placeholder do campo principal do combo\n * - `searchInputPlaceholder` (string): Placeholder do campo de pesquisa dentro do combo\n * - `colorTheme` (\"primary\" | \"secondary\" | \"success\" | \"danger\" | \"warning\" | \"info\" | \"light\" | \"dark\"): Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\n * - `returnRecord` (boolean): Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID\n * \n * ## Outputs:\n * - `onReloadList` (EventEmitter<string>): Evento emitido quando a lista precisa ser recarregada.\n */\n@Component({\n  selector: 'lib-combobox',\n  templateUrl: './lib-combobox.component.html',\n  styles: `\n    .glb-max-height-350px { max-height: 350px !important; }\n    .form-label { font-size: 16px !important; }\n    .z-index-1020 { z-index: 1020 !important; }\n    .cursor-pointer { cursor: pointer !important; }\n  `\n})\nexport class LibComboboxComponent implements OnInit, AfterViewInit, OnDestroy, OnChanges {\n\n  // #region ==========> PROPERTIES <==========\n\n  // #region PROTECTED\n  protected textoPesquisa: string = \"\";\n\n  protected get ariaExpanded(): boolean { return this._ariaExpanded; }\n  protected set ariaExpanded(value: boolean) {\n    this._ariaExpanded = value;\n    this.adjustDropdownWidth();\n    \n    if (value === false) {\n      this.textoPesquisa = \"\";\n      this._searchInput.nativeElement.value = \"\";\n    }\n  }\n\n  protected innerControl: FormControl = new FormControl<string | number | null>(null);\n  protected invalidControl: boolean = false;\n  protected isRequired: boolean = false;\n\n  protected invalid: boolean = false;\n  protected dirty: boolean = false;\n  protected touched: boolean = false;\n\n  protected comboboxID!: string;\n  protected labelID!: string;\n  // #endregion PROTECTED\n\n  // #region PRIVATE\n  private _disabled?: boolean = false;\n  private _ariaExpanded: boolean = false;\n  private _subscription: Subscription = new Subscription();\n\n  private _outerControl: FormControl = new FormControl<string | number | null>(null);\n  // #endregion PRIVATE\n\n  // #region PUBLIC\n\n  /** (obrigatório) Control para seleção dos valores, atualizará automaticamente o control do componente pai também\n   * @alias 'control'\n   * @type {FormControl<any> | AbstractControl<any>} */\n  @Input({ required: true })\n  public get control(): FormControl<unknown> { return this._outerControl }\n  public set control(value: FormControl<unknown> | AbstractControl<unknown>) {\n    this._outerControl = value as FormControl;\n\n    // Cancela a subscrição anterior (se houver) para evitar múltiplas subscrições\n    if (this._subscription) this._subscription.unsubscribe();\n\n    // Subscrição ao observável valueChanges para reagir a mudanças no valor\n    this._subscription = this._outerControl.valueChanges.subscribe(value => { this.updateSelectedValue(value) });\n    this._subscription = this._outerControl.statusChanges.subscribe(status => { this.setControlStatus(status) });\n  }\n\n  /** (obrigatório) Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\n   * @alias 'list'\n   * @type {RecordCombobox[]} */\n  @Input({ required: true }) public list?: RecordCombobox[];\n\n  /** (opcional) Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\n   * @type {string} */\n  @Input() public labelText?: string;\n\n  /** (opcional) Texto ou caractere separador entre a informação de ID e LABEL\n   * @example \" - \"\n   * @type {string} */\n  @Input() public separator?: string = \" \";\n\n  /** (opcional) Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\n   * @type {boolean} */\n  @Input()\n  public libRequired?: boolean;\n\n  /** (opcional) Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\n   * @type {boolean}\n   * @default false */\n  @Input()\n  public get disabled(): boolean { return this._disabled ?? false; }\n  public set disabled(value: boolean | undefined) {\n    if (value && value === true) this.innerControl.disable();\n    else this.innerControl.enable();\n\n    //this.setControlStatus();\n  }\n\n  /** (opcional) Placeholder do campo principal do combo\n   * @alias 'mainPlaceholder'\n   * @type {string}\n   * @default \"Selecione uma opção...\" */\n  @Input() public mainPlaceholder?: string = \"Selecione uma opção...\";\n\n  /** (opcional) Placeholder do campo de pesquisa dentro do combo\n   * @alias 'searchPlaceholder'\n   * @type {string}\n   * @default \"Pesquisa...\" */\n  @Input() public searchPlaceholder?: string = \"Pesquisa...\";\n\n  /** (opcional) Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\n   * @alias 'theme'\n   * @type {string}\n   * @default \"primary\"\n  */\n  @Input() public theme?: string = \"primary\";\n\n  /** (opcional) Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID.\n   * @type {boolean}\n   * @default false\n  */\n  @Input() public returnRecord?: boolean = false;\n\n  /** (opcional) Define se o código extra chamado 'AdditionalStringProperty1' será exibido em negrito ou não.\n   * @type { boolean }\n   * @default true\n  */\n  @Input() public additionalStringBold?: boolean = true;\n\n  /** Evento emitido ao recarregar a lista de registros\n   * @example Ao ser emitido, o componente pai pode refazer o GET da lista, por exemplo.\n   * @emits EventEmitter<string> que leva o valor string da pesquisa feita para ser enviada para o GET\n   * @type {EventEmitter<string>} */\n  @Output() public reloadListChange: EventEmitter<string> = new EventEmitter<string>();\n\n\n  /** Evento emitido ao selecionar um registro da lista do combobox\n   * @example Ao ser emitido, o componente pai pode realizar uma validação com o valor selecionado.\n   * @emits EventEmitter<string|number|null> que leva o valor string da pesquisa feita para ser enviada para o GET\n   * @type {EventEmitter<string | number | null>} */\n  @Output() public changeValue: EventEmitter<RecordCombobox | string | number | null> = new EventEmitter<RecordCombobox | string | number | null>();\n  \n\n  @ViewChild('mainInput') private _mainInput!: ElementRef<HTMLInputElement>;\n  @ViewChild('searchInput') private _searchInput!: ElementRef<HTMLInputElement>;\n  @ViewChild('dropdownMenu') private _dropdownMenu!: ElementRef<HTMLDivElement>;\n  // #endregion PUBLIC\n\n  // #endregion ==========> PROPERTIES <==========\n\n\n  // #region ==========> INITIALIZATION <==========\n  constructor() { }\n\n  ngOnInit(): void {\n    this.comboboxID = `lib-combobox-${Math.random() * 100}`;\n    this.labelID = `${Math.random() * 100}`;\n\n    this.adjustDropdownWidth();\n\n    this.setValidator();\n    this.updateSelectedValue();\n  }\n\n  ngAfterViewInit(): void {\n    this.adjustDropdownWidth();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes[\"list\"]?.currentValue) this.updateSelectedValue();\n    if (changes[\"libRequired\"]?.currentValue != undefined) this.setValidator();\n    if (changes[\"control\"]?.currentValue) {\n      this.setValidator();\n      this.updateSelectedValue((changes[\"control\"].currentValue as FormControl).value);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._subscription.unsubscribe();\n  }\n\n  // O que fazer quando o evento de redimensionamento ocorrer\n  @HostListener('window:resize', ['$event'])\n  onResize(): void { this.adjustDropdownWidth() }\n  // #endregion ==========> INITIALIZATION <==========\n\n\n  // #region ==========> UTILS <==========\n  public setValue(item: RecordCombobox): void {\n    this.textoPesquisa = \"\";\n    this.innerControl.markAsDirty();\n    this._outerControl.markAsDirty();\n    \n    this._outerControl.setValue(item.ID);\n    this.innerControl.setValue(\n      `${item.AdditionalStringProperty1 && item.AdditionalStringProperty1 != '' ? item.AdditionalStringProperty1 : \"\"}${this.separator === undefined ? \" \" : \" \"+this.separator+\" \"}${item.LABEL}`\n    );\n\n    this.ariaExpanded = false;\n    this.setControlStatus(this.innerControl.status);\n    \n    this.changeValue.emit(this.returnRecord ? item as RecordCombobox : item.ID);\n  }\n\n  public clearValue(): void {\n    this.textoPesquisa = \"\";\n    this.innerControl.markAsDirty();\n    this._outerControl.markAsDirty();\n\n    this._outerControl.setValue(null);\n    this.innerControl.setValue(null);\n\n    this.ariaExpanded = false;\n    this.setControlStatus(this.innerControl.status);\n\n    this.changeValue.emit(null);\n  }\n\n  private updateSelectedValue(value?: string | number | null): void {\n    this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa\n    \n    const selectedValue: string | number | null = value ?? this._outerControl.value;\n    if (!this.list || (selectedValue === null && selectedValue === '')) return;\n    \n    const initializedValue = this.list.find(item => item.ID === selectedValue)\n    if (initializedValue) this.innerControl.setValue(\n      `${initializedValue.AdditionalStringProperty1 && initializedValue.AdditionalStringProperty1 != '' ? initializedValue.AdditionalStringProperty1 : \"\"}${this.separator === undefined ? \"\" : \" \"+this.separator+\" \"}${initializedValue.LABEL}`\n    );\n  }\n\n  private adjustDropdownWidth(): void {\n    if (this._mainInput && this._dropdownMenu) {\n      const inputWidth = this._mainInput.nativeElement.offsetWidth;\n      this._dropdownMenu.nativeElement.style.width = `${inputWidth}px`;\n    }\n  }\n\n  /** Serve para aplicar ou remover o Validator.required do controle.\n   * Por padrão ele priorizará a propriedade libRequired para esta validação. */\n  private setValidator(): void {\n    if (this.libRequired !== undefined) {\n      if (this.libRequired) {\n        this.innerControl.addValidators(Validators.required);\n        this.isRequired = true;\n      }\n      else {\n        this.innerControl.removeValidators(Validators.required);\n        this.isRequired = false;\n      }\n    }\n    else {\n      if (this._outerControl.hasValidator(Validators.required)) {\n        this.innerControl.addValidators(Validators.required);\n        this.isRequired = true;\n      }\n      else {\n        this.innerControl.removeValidators(Validators.required);\n        this.isRequired = false;\n      }\n    }\n  }\n\n  private setControlStatus(formStatus: FormControlStatus): void {\n    switch(formStatus) {\n      case 'VALID':\n        this.invalidControl = false;\n        this.innerControl.enable();\n        break;\n\n      case 'INVALID':\n        this.invalidControl = true;\n        this.innerControl.enable();\n        break;\n\n      case 'PENDING':\n        this.invalidControl = false;\n        this.innerControl.enable();\n        break;\n\n      case 'DISABLED':\n        this.invalidControl = false;\n        this.innerControl.disable();\n        break;\n    }\n  }\n\n  public reloadList(): void { this.reloadListChange.emit(this.textoPesquisa) }\n  // #endregion ==========> UTILS <==========\n\n}","<!-- eslint-disable @angular-eslint/template/interactive-supports-focus -->\n<!-- eslint-disable @angular-eslint/template/click-events-have-key-events -->\n\n<label *ngIf=\"labelText && labelText !== ''\" class=\"form-label fw-bold\" [id]=\"labelID\" [for]=\"comboboxID\" [libRequired]=\"isRequired\">{{ labelText }}</label>\n\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\n\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.\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. -->\n   <ng-content select=\"[btnLeft]\"></ng-content>\n\n   <input  #mainInput class=\"form-select text-start rounded-end cursor-pointer\" type=\"text\"\n            data-bs-toggle=\"dropdown\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly\n            [placeholder]=\"mainPlaceholder\" [formControl]=\"innerControl\" [class.is-invalid]=\"invalidControl\" [id]=\"comboboxID\"\n            (click)=\"ariaExpanded = !ariaExpanded; searchInput.focus()\" (focus)=\"searchInput.focus()\">\n\n   <ul  #dropdownMenu  class=\"dropdown-menu p-2 glb-max-height-350px overflow-y-scroll z-index-1020\" [class.show]=\"ariaExpanded\">\n      <div class=\"input-group mb-2\">\n         <input #searchInput (input)=\"textoPesquisa = searchInput.value\" type=\"text\" id=\"searchInput-{{comboboxID}}\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchPlaceholder\" (keyup.enter)=\"reloadList()\">\n         <button class=\"btn btn-{{theme}}\" (click)=\"reloadList()\"> <lib-icon iconName=\"lupa\" iconSize=\"medium-small\" /> </button>\n      </div>\n\n      @if (list) {\n         <li *ngIf=\"innerControl.value !== '' && innerControl.value !== null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar opção selecionada</span> </li>\n         @for (item of list | textFilter:textoPesquisa; track $index) {\n            <li class=\"dropdown-item\" (click)=\"setValue(item)\">\n               <span *ngIf=\"item.AdditionalStringProperty1 && item.AdditionalStringProperty1 !== ''\" class=\"glb-fs-12 d-inline-block w-125\" [class.fw-bold]=\"additionalStringBold\">\n                  {{ item.AdditionalStringProperty1 + (separator === undefined ? \"\" : \" \"+separator) }}\n               </span> {{ item.LABEL }}\n            </li>\n         }\n         @empty { <li class=\"dropdown-item fst-italic\">Nenhum registro encontrado com esta pesquisa...</li> }\n      }\n      @else { <li class=\"dropdown-item text-center\"> <div class=\"spinner-border\" role=\"status\"><span class=\"visually-hidden\">Carregando dados...</span></div> </li> }\n   </ul>\n\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.\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. -->\n   <ng-content select=\"[btnRight]\"></ng-content>\n\n</div>\n\n<!-- #region MENSAGEM DE ERRO DE VALIDAÇÃO -->\n<lib-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo é obrigatório.\" />\n<!-- #endregion MENSAGEM DE ERRO DE VALIDAÇÃO -->"]}
|
|
292
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lib-combobox.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.ts","../../../../../../projects/ngx-sp-infra/src/lib/widgets/lib-combobox/lib-combobox.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, OnDestroy, OnInit, Output, SimpleChanges, ViewChild } from '@angular/core';\nimport { AbstractControl, FormControl, FormControlStatus, Validators } from '@angular/forms';\n\nimport { Subscription } from 'rxjs';\n\nimport { RecordCombobox } from '../../models/combobox/record-combobox';\n\n/**\n * @component LibComboboxComponent\n * @selector lib-combobox\n * \n * @description\n * O componente LibComboboxComponent é projetado para fornecer aos usuários uma interface para pesquisar e selecionar itens de uma lista.\n * Ele suporta a filtragem de itens com base na entrada do usuário, permitindo uma seleção mais fácil em listas extensas.\n * \n * ## Funcionalidades:\n * - Pesquisa e filtragem de itens na lista do combobox.\n * - Seleção de itens com feedback visual.\n * - Emissão de eventos personalizados para interações do usuário, como recarregar a lista ou selecionar um item.\n * - Ajuste dinâmico da largura do dropdown para corresponder ao input principal.\n * - Inicialização de um valor selecionado, se fornecido.\n * \n * ## Inputs:\n * - `control` (FormControl | AbstractControl): Control para seleção dos valores, atualizará automaticamente o control do componente pai também\n * - `comboboxList` (RecordCombobox[]): Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\n * - `labelText` (string): Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\n * - `disabled` (boolean): Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\n * - `libRequired` (boolean): Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\n * - `mainInputPlaceholder` (string): Placeholder do campo principal do combo\n * - `searchInputPlaceholder` (string): Placeholder do campo de pesquisa dentro do combo\n * - `colorTheme` (\"primary\" | \"secondary\" | \"success\" | \"danger\" | \"warning\" | \"info\" | \"light\" | \"dark\"): Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\n * - `returnRecord` (boolean): Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID\n * \n * ## Outputs:\n * - `onReloadList` (EventEmitter<string>): Evento emitido quando a lista precisa ser recarregada.\n */\n@Component({\n  selector: 'lib-combobox',\n  templateUrl: './lib-combobox.component.html',\n  styles: `\n    .glb-max-height-350px { max-height: 350px !important; }\n    .form-label { font-size: 16px !important; }\n    .z-index-1020 { z-index: 1020 !important; }\n    .cursor-pointer { cursor: pointer !important; }\n  `\n})\nexport class LibComboboxComponent implements OnInit, AfterViewInit, OnDestroy, OnChanges {\n\n  // #region ==========> PROPERTIES <==========\n\n  // #region PROTECTED\n  protected textoPesquisa: string = \"\";\n\n  protected get ariaExpanded(): boolean { return this._ariaExpanded; }\n  protected set ariaExpanded(value: boolean) {\n    this._ariaExpanded = value;\n    this.adjustDropdownWidth();\n    \n    if (value === false) {\n      this.textoPesquisa = \"\";\n      this._searchInput.nativeElement.value = \"\";\n    }\n  }\n\n  protected innerControl: FormControl = new FormControl<string | number | null>(null);\n  protected invalidControl: boolean = false;\n  protected isRequired: boolean = false;\n\n  protected invalid: boolean = false;\n  protected dirty: boolean = false;\n  protected touched: boolean = false;\n\n  protected comboboxID!: string;\n  protected labelID!: string;\n  // #endregion PROTECTED\n\n  // #region PRIVATE\n  private _disabled?: boolean = false;\n  private _ariaExpanded: boolean = false;\n  private _subscription: Subscription = new Subscription();\n\n  private _outerControl: FormControl = new FormControl<string | number | null>(null);\n  // #endregion PRIVATE\n\n  // #region PUBLIC\n\n  /** (obrigatório) Control para seleção dos valores, atualizará automaticamente o control do componente pai também\n   * @alias 'control'\n   * @type {FormControl<any> | AbstractControl<any>} */\n  @Input({ required: true })\n  public get control(): FormControl<unknown> { return this._outerControl }\n  public set control(value: FormControl<unknown> | AbstractControl<unknown>) {\n    this._outerControl = value as FormControl;\n\n    // Cancela a subscrição anterior (se houver) para evitar múltiplas subscrições\n    if (this._subscription) this._subscription.unsubscribe();\n\n    // Subscrição ao observável valueChanges para reagir a mudanças no valor\n    this._subscription = this._outerControl.valueChanges.subscribe(value => { this.updateSelectedValue(value) });\n    this._subscription = this._outerControl.statusChanges.subscribe(status => { this.setControlStatus(status) });\n  }\n\n  /** (obrigatório) Lista de registros que serão exibidos no combo, enquanto eles estiverem carregando será exibido um spinner\n   * @alias 'list'\n   * @type {RecordCombobox[]} */\n  @Input({ required: true }) public list?: RecordCombobox[];\n\n  /** (opcional) Texto do rótulo que será exibido acima do combo. Caso não informado nada será exibido\n   * @type {string} */\n  @Input() public labelText?: string;\n\n  /** (opcional) Texto ou caractere separador entre a informação de ID e LABEL\n   * @example \" - \"\n   * @type {string} */\n  @Input() public separator?: string = \" \";\n\n  /** (opcional) Define se o campo é obrigatório, vai exibir o '*' vermelho ao lado do label (se ele estiver presente)\n   * @type {boolean} */\n  @Input()\n  public libRequired?: boolean;\n\n  /** (opcional) Define se o campo está desabilitado. Deve ser usado para validações de habilitação dinâmica do campo\n   * @type {boolean}\n   * @default false */\n  @Input()\n  public get disabled(): boolean { return this._disabled ?? false; }\n  public set disabled(value: boolean | undefined) {\n    if (value && value === true) this.innerControl.disable();\n    else this.innerControl.enable();\n\n    //this.setControlStatus();\n  }\n\n  /** (opcional) Placeholder do campo principal do combo\n   * @alias 'mainPlaceholder'\n   * @type {string}\n   * @default \"Selecione uma opção...\" */\n  @Input() public mainPlaceholder?: string = \"Selecione uma opção...\";\n\n  /** (opcional) Placeholder do campo de pesquisa dentro do combo\n   * @alias 'searchPlaceholder'\n   * @type {string}\n   * @default \"Pesquisa...\" */\n  @Input() public searchPlaceholder?: string = \"Pesquisa...\";\n\n  /** (opcional) Define o tema de cor do componente, como \"primary\", \"success\", ou \"danger\"\n   * @alias 'theme'\n   * @type {string}\n   * @default \"primary\"\n  */\n  @Input() public theme?: string = \"primary\";\n\n  /** (opcional) Define se o tipo de retorno ao selecionar uma opção será o Record inteiro ou apenas o ID.\n   * @type {boolean}\n   * @default false\n  */\n  @Input() public returnRecord?: boolean = false;\n\n  /** (opcional) Define se o código extra chamado 'AdditionalStringProperty1' será exibido em negrito ou não.\n   * @type { boolean }\n   * @default true\n  */\n  @Input() public additionalStringBold?: boolean = true;\n\n  /** Evento emitido ao recarregar a lista de registros\n   * @example Ao ser emitido, o componente pai pode refazer o GET da lista, por exemplo.\n   * @emits EventEmitter<string> que leva o valor string da pesquisa feita para ser enviada para o GET\n   * @type {EventEmitter<string>} */\n  @Output() public reloadListChange: EventEmitter<string> = new EventEmitter<string>();\n\n\n  /** Evento emitido ao selecionar um registro da lista do combobox\n   * @example Ao ser emitido, o componente pai pode realizar uma validação com o valor selecionado.\n   * @emits EventEmitter<string|number|null> que leva o valor string da pesquisa feita para ser enviada para o GET\n   * @type {EventEmitter<string | number | null>} */\n  @Output() public changeValue: EventEmitter<RecordCombobox | string | number | null> = new EventEmitter<RecordCombobox | string | number | null>();\n  \n\n  @ViewChild('mainInput') private _mainInput!: ElementRef<HTMLInputElement>;\n  @ViewChild('searchInput') private _searchInput!: ElementRef<HTMLInputElement>;\n  @ViewChild('dropdownMenu') private _dropdownMenu!: ElementRef<HTMLDivElement>;\n  // #endregion PUBLIC\n\n  // #endregion ==========> PROPERTIES <==========\n\n\n  // #region ==========> INITIALIZATION <==========\n  constructor() { }\n\n  ngOnInit(): void {\n    this.comboboxID = `lib-combobox-${Math.random() * 100}`;\n    this.labelID = `${Math.random() * 100}`;\n\n    this.adjustDropdownWidth();\n\n    this.setValidator();\n    this.updateSelectedValue();\n  }\n\n  ngAfterViewInit(): void {\n    this.adjustDropdownWidth();\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes[\"list\"]?.currentValue) this.updateSelectedValue();\n    if (changes[\"libRequired\"]?.currentValue != undefined) this.setValidator();\n\n    if (changes[\"separator\"].currentValue != undefined) this.updateSelectedValue(this.control.value as string | number, false);\n\n    if (changes[\"control\"]?.currentValue) {\n      this.setValidator();\n      this.updateSelectedValue((changes[\"control\"].currentValue as FormControl).value);\n    }\n  }\n\n  ngOnDestroy(): void {\n    this._subscription.unsubscribe();\n  }\n\n  // O que fazer quando o evento de redimensionamento ocorrer\n  @HostListener('window:resize', ['$event'])\n  onResize(): void { this.adjustDropdownWidth() }\n  // #endregion ==========> INITIALIZATION <==========\n\n\n  // #region ==========> UTILS <==========\n  public setValue(item: RecordCombobox): void {\n    this.textoPesquisa = \"\";\n    this.innerControl.markAsDirty();\n    this._outerControl.markAsDirty();\n    \n    this._outerControl.setValue(item.ID);\n    this.innerControl.setValue(\n      `${item.AdditionalStringProperty1 && item.AdditionalStringProperty1 != '' ? item.AdditionalStringProperty1 : \"\"}${this.separator === undefined ? \" \" : \" \"+this.separator+\" \"}${item.LABEL}`\n    );\n\n    this.ariaExpanded = false;\n    this.setControlStatus(this.innerControl.status);\n    \n    this.changeValue.emit(this.returnRecord ? item as RecordCombobox : item.ID);\n  }\n\n  public clearValue(): void {\n    this.textoPesquisa = \"\";\n    this.innerControl.markAsDirty();\n    this._outerControl.markAsDirty();\n\n    this._outerControl.setValue(null);\n    this.innerControl.setValue(null);\n\n    this.ariaExpanded = false;\n    this.setControlStatus(this.innerControl.status);\n\n    this.changeValue.emit(null);\n  }\n\n  private updateSelectedValue(value?: string | number | null, noChange: boolean = true): void {\n    this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa\n    \n    const selectedValue: string | number | null = value ?? this._outerControl.value;\n    if (!this.list || (selectedValue === null && selectedValue === '')) return;\n    \n    const initializedValue = this.list.find(item => item.ID === selectedValue)\n    if (initializedValue) this.innerControl.setValue(\n      `${initializedValue.AdditionalStringProperty1 && initializedValue.AdditionalStringProperty1 != '' ? initializedValue.AdditionalStringProperty1 : \"\"}${this.separator === undefined ? \"\" : \" \"+this.separator+\" \"}${initializedValue.LABEL}`,\n      { emitEvent: noChange }\n    );\n  }\n\n  private adjustDropdownWidth(): void {\n    if (this._mainInput && this._dropdownMenu) {\n      const inputWidth = this._mainInput.nativeElement.offsetWidth;\n      this._dropdownMenu.nativeElement.style.width = `${inputWidth}px`;\n    }\n  }\n\n  /** Serve para aplicar ou remover o Validator.required do controle.\n   * Por padrão ele priorizará a propriedade libRequired para esta validação. */\n  private setValidator(): void {\n    if (this.libRequired !== undefined) {\n      if (this.libRequired) {\n        this.innerControl.addValidators(Validators.required);\n        this.isRequired = true;\n      }\n      else {\n        this.innerControl.removeValidators(Validators.required);\n        this.isRequired = false;\n      }\n    }\n    else {\n      if (this._outerControl.hasValidator(Validators.required)) {\n        this.innerControl.addValidators(Validators.required);\n        this.isRequired = true;\n      }\n      else {\n        this.innerControl.removeValidators(Validators.required);\n        this.isRequired = false;\n      }\n    }\n  }\n\n  private setControlStatus(formStatus: FormControlStatus): void {\n    switch(formStatus) {\n      case 'VALID':\n        this.invalidControl = false;\n        this.innerControl.enable();\n        break;\n\n      case 'INVALID':\n        this.invalidControl = true;\n        this.innerControl.enable();\n        break;\n\n      case 'PENDING':\n        this.invalidControl = false;\n        this.innerControl.enable();\n        break;\n\n      case 'DISABLED':\n        this.invalidControl = false;\n        this.innerControl.disable();\n        break;\n    }\n  }\n\n  public reloadList(): void { this.reloadListChange.emit(this.textoPesquisa) }\n  // #endregion ==========> UTILS <==========\n\n}","<!-- eslint-disable @angular-eslint/template/interactive-supports-focus -->\n<!-- eslint-disable @angular-eslint/template/click-events-have-key-events -->\n\n<label *ngIf=\"labelText && labelText !== ''\" class=\"form-label fw-bold\" [id]=\"labelID\" [for]=\"comboboxID\" [libRequired]=\"isRequired\">{{ labelText }}</label>\n\n<div class=\"input-group dropdown flex-fill glb-max-height-350px\">\n\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.\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. -->\n   <ng-content select=\"[btnLeft]\"></ng-content>\n\n   <input  #mainInput class=\"form-select text-start rounded-end cursor-pointer\" type=\"text\"\n            data-bs-toggle=\"dropdown\" data-bs-auto-close=\"outside\" aria-expanded=\"false\" readonly\n            [placeholder]=\"mainPlaceholder\" [formControl]=\"innerControl\" [class.is-invalid]=\"invalidControl\" [id]=\"comboboxID\"\n            (click)=\"ariaExpanded = !ariaExpanded; searchInput.focus()\" (focus)=\"searchInput.focus()\">\n\n   <ul  #dropdownMenu  class=\"dropdown-menu p-2 glb-max-height-350px overflow-y-scroll z-index-1020\" [class.show]=\"ariaExpanded\">\n      <div class=\"input-group mb-2\">\n         <input #searchInput (input)=\"textoPesquisa = searchInput.value\" type=\"text\" id=\"searchInput-{{comboboxID}}\" class=\"form-control glb-input-no-glow\" [placeholder]=\"searchPlaceholder\" (keyup.enter)=\"reloadList()\">\n         <button class=\"btn btn-{{theme}}\" (click)=\"reloadList()\"> <lib-icon iconName=\"lupa\" iconSize=\"medium-small\" /> </button>\n      </div>\n\n      @if (list) {\n         <li *ngIf=\"innerControl.value !== '' && innerControl.value !== null\" class=\"dropdown-item\" (click)=\"clearValue()\"> <span class=\"fw-bold\">Limpar opção selecionada</span> </li>\n         @for (item of list | textFilter:textoPesquisa; track $index) {\n            <li class=\"dropdown-item\" (click)=\"setValue(item)\">\n               <span *ngIf=\"item.AdditionalStringProperty1 && item.AdditionalStringProperty1 !== ''\" class=\"glb-fs-12 d-inline-block w-125\" [class.fw-bold]=\"additionalStringBold\">\n                  {{ item.AdditionalStringProperty1 + (separator === undefined ? \"\" : \" \"+separator) }}\n               </span> {{ item.LABEL }}\n            </li>\n         }\n         @empty { <li class=\"dropdown-item fst-italic\">Nenhum registro encontrado com esta pesquisa...</li> }\n      }\n      @else { <li class=\"dropdown-item text-center\"> <div class=\"spinner-border\" role=\"status\"><span class=\"visually-hidden\">Carregando dados...</span></div> </li> }\n   </ul>\n\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.\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. -->\n   <ng-content select=\"[btnRight]\"></ng-content>\n\n</div>\n\n<!-- #region MENSAGEM DE ERRO DE VALIDAÇÃO -->\n<lib-error-message *ngIf=\"invalidControl\" customMessage=\"Este campo é obrigatório.\" />\n<!-- #endregion MENSAGEM DE ERRO DE VALIDAÇÃO -->"]}
|
|
@@ -22,7 +22,6 @@ export class SearchInputComponent {
|
|
|
22
22
|
}
|
|
23
23
|
loadRoutes() {
|
|
24
24
|
this.http.get('assets/jsons/routes.json').subscribe(data => {
|
|
25
|
-
console.log(data);
|
|
26
25
|
this.items = data;
|
|
27
26
|
}, error => {
|
|
28
27
|
console.error('Error loading routes:', error);
|
|
@@ -84,4 +83,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
|
|
|
84
83
|
type: HostListener,
|
|
85
84
|
args: ['document:keydown', ['$event']]
|
|
86
85
|
}] } });
|
|
87
|
-
//# sourceMappingURL=data:application/json;base64,
|
|
86
|
+
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoic2VhcmNoLWlucHV0LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1zcC1pbmZyYS9zcmMvbGliL3dpZGdldHMvc2VhcmNoLWlucHV0L3NlYXJjaC1pbnB1dC5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtc3AtaW5mcmEvc3JjL2xpYi93aWRnZXRzL3NlYXJjaC1pbnB1dC9zZWFyY2gtaW5wdXQuY29tcG9uZW50Lmh0bWwiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBQ0EsT0FBTyxFQUFFLFNBQVMsRUFBYyxZQUFZLEVBQUUsU0FBUyxFQUF5QixNQUFNLGVBQWUsQ0FBQzs7Ozs7QUFRdEcsTUFBTSxPQUFPLG9CQUFvQjtJQVUvQixZQUFvQixJQUFnQixFQUFVLE1BQWM7UUFBeEMsU0FBSSxHQUFKLElBQUksQ0FBWTtRQUFVLFdBQU0sR0FBTixNQUFNLENBQVE7UUFUNUQsY0FBUyxHQUFHLEtBQUssQ0FBQztRQUNsQixnQkFBVyxHQUFHLEVBQUUsQ0FBQztRQUVqQixVQUFLLEdBQXVDLEVBQUUsQ0FBQztRQUUvQyxrQkFBYSxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7SUFJK0IsQ0FBQztJQUVoRSxRQUFRO1FBQ04sSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO0lBQ3BCLENBQUM7SUFFRCxlQUFlO1FBQ2IsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7WUFDbkIsSUFBSSxDQUFDLFVBQVUsRUFBRSxDQUFDO1FBQ3BCLENBQUM7SUFDSCxDQUFDO0lBRUQsVUFBVTtRQUNSLElBQUksQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFxQywwQkFBMEIsQ0FBQyxDQUFDLFNBQVMsQ0FDckYsSUFBSSxDQUFDLEVBQUU7WUFDTCxJQUFJLENBQUMsS0FBSyxHQUFHLElBQUksQ0FBQztRQUNwQixDQUFDLEVBQUUsS0FBSyxDQUFDLEVBQUU7WUFDVCxPQUFPLENBQUMsS0FBSyxDQUFDLHVCQUF1QixFQUFFLEtBQUssQ0FBQyxDQUFDO1FBQ2hELENBQUMsQ0FBQyxDQUFDO0lBQ1AsQ0FBQztJQUdELFNBQVMsQ0FBQyxLQUFvQjtRQUM1QixJQUFJLEtBQUssQ0FBQyxPQUFPLElBQUksS0FBSyxDQUFDLEdBQUcsS0FBSyxHQUFHLEVBQUUsQ0FBQztZQUN2QyxLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDdkIsSUFBSSxDQUFDLFNBQVMsR0FBRyxDQUFDLElBQUksQ0FBQyxTQUFTLENBQUM7WUFDakMsSUFBSSxJQUFJLENBQUMsU0FBUyxFQUFFLENBQUM7Z0JBQ25CLFVBQVUsQ0FBQyxHQUFHLEVBQUUsQ0FBQyxJQUFJLENBQUMsVUFBVSxFQUFFLEVBQUUsQ0FBQyxDQUFDLENBQUM7WUFDekMsQ0FBQztpQkFBTSxDQUFDO2dCQUNOLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztZQUNyQixDQUFDO1FBQ0gsQ0FBQzthQUFNLElBQUksSUFBSSxDQUFDLFNBQVMsSUFBSSxLQUFLLENBQUMsR0FBRyxLQUFLLE9BQU8sRUFBRSxDQUFDO1lBQ25ELEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUN2QixJQUFJLElBQUksQ0FBQyxhQUFhLENBQUMsTUFBTSxHQUFHLENBQUMsRUFBRSxDQUFDO2dCQUNsQyxJQUFJLENBQUMsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsQ0FBQyxDQUFDLENBQUMsS0FBSyxDQUFDLENBQUM7WUFDL0MsQ0FBQztRQUNILENBQUM7SUFDSCxDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxTQUFTLEdBQUcsS0FBSyxDQUFDO1FBQ3ZCLElBQUksQ0FBQyxXQUFXLEVBQUUsQ0FBQztJQUNyQixDQUFDO0lBRUQsV0FBVztRQUNULElBQUksQ0FBQyxXQUFXLEdBQUcsRUFBRSxDQUFDO1FBQ3RCLElBQUksQ0FBQyxhQUFhLEdBQUcsQ0FBQyxHQUFHLElBQUksQ0FBQyxLQUFLLENBQUMsQ0FBQztJQUN2QyxDQUFDO0lBRUQsUUFBUTtRQUNOLElBQUksSUFBSSxDQUFDLFdBQVcsQ0FBQyxJQUFJLEVBQUUsRUFBRSxDQUFDO1lBQzVCLElBQUksQ0FBQyxhQUFhLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLEVBQUUsQ0FDNUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxXQUFXLEVBQUUsQ0FBQyxRQUFRLENBQUMsSUFBSSxDQUFDLFdBQVcsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxDQUNsRSxDQUFDO1FBQ0osQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLENBQUMsYUFBYSxHQUFHLENBQUMsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUM7UUFDdkMsQ0FBQztJQUNILENBQUM7SUFFRCxVQUFVLENBQUMsS0FBYTtRQUN0QixJQUFJLENBQUMsTUFBTSxDQUFDLFFBQVEsQ0FBQyxDQUFDLEtBQUssQ0FBQyxDQUFDLENBQUM7UUFDOUIsSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO0lBQ3JCLENBQUM7SUFFTyxVQUFVO1FBQ2hCLElBQUksSUFBSSxDQUFDLFdBQVcsRUFBRSxDQUFDO1lBQ3JCLElBQUksQ0FBQyxXQUFXLENBQUMsYUFBYSxDQUFDLEtBQUssRUFBRSxDQUFDO1FBQ3pDLENBQUM7SUFDSCxDQUFDOytHQTlFVSxvQkFBb0I7bUdBQXBCLG9CQUFvQixzT0NUakMsMjlCQTBCQzs7NEZEakJZLG9CQUFvQjtrQkFMaEMsU0FBUzsrQkFDRSxrQkFBa0I7b0dBWUYsV0FBVztzQkFBcEMsU0FBUzt1QkFBQyxhQUFhO2dCQXdCeEIsU0FBUztzQkFEUixZQUFZO3VCQUFDLGtCQUFrQixFQUFFLENBQUMsUUFBUSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSHR0cENsaWVudCB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcbmltcG9ydCB7IENvbXBvbmVudCwgRWxlbWVudFJlZiwgSG9zdExpc3RlbmVyLCBWaWV3Q2hpbGQsIEFmdGVyVmlld0luaXQsIE9uSW5pdCB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgUm91dGVyIH0gZnJvbSAnQGFuZ3VsYXIvcm91dGVyJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnbGliLXNlYXJjaC1pbnB1dCcsXG4gIHRlbXBsYXRlVXJsOiAnLi9zZWFyY2gtaW5wdXQuY29tcG9uZW50Lmh0bWwnLFxuICBzdHlsZVVybDogJy4vc2VhcmNoLWlucHV0LmNvbXBvbmVudC5zY3NzJ1xufSlcbmV4cG9ydCBjbGFzcyBTZWFyY2hJbnB1dENvbXBvbmVudCBpbXBsZW1lbnRzIE9uSW5pdCwgQWZ0ZXJWaWV3SW5pdCB7XG4gIGlzVmlzaWJsZSA9IGZhbHNlO1xuICBzZWFyY2hRdWVyeSA9ICcnO1xuICBcbiAgaXRlbXM6IHsgbGFiZWw6IHN0cmluZywgcm91dGU6IHN0cmluZyB9W10gPSBbXTtcbiAgXG4gIGZpbHRlcmVkSXRlbXMgPSBbLi4udGhpcy5pdGVtc107XG5cbiAgQFZpZXdDaGlsZCgnc2VhcmNoSW5wdXQnKSBzZWFyY2hJbnB1dCE6IEVsZW1lbnRSZWY8SFRNTElucHV0RWxlbWVudD47XG5cbiAgY29uc3RydWN0b3IocHJpdmF0ZSBodHRwOiBIdHRwQ2xpZW50LCBwcml2YXRlIHJvdXRlcjogUm91dGVyKSB7fVxuXG4gIG5nT25Jbml0KCk6IHZvaWQge1xuICAgIHRoaXMubG9hZFJvdXRlcygpO1xuICB9XG5cbiAgbmdBZnRlclZpZXdJbml0KCk6IHZvaWQge1xuICAgIGlmICh0aGlzLmlzVmlzaWJsZSkge1xuICAgICAgdGhpcy5mb2N1c0lucHV0KCk7XG4gICAgfVxuICB9XG5cbiAgbG9hZFJvdXRlcygpOiB2b2lkIHtcbiAgICB0aGlzLmh0dHAuZ2V0PHsgbGFiZWw6IHN0cmluZywgcm91dGU6IHN0cmluZyB9W10+KCdhc3NldHMvanNvbnMvcm91dGVzLmpzb24nKS5zdWJzY3JpYmUoXG4gICAgICBkYXRhID0+IHtcbiAgICAgICAgdGhpcy5pdGVtcyA9IGRhdGE7XG4gICAgICB9LCBlcnJvciA9PiB7XG4gICAgICAgIGNvbnNvbGUuZXJyb3IoJ0Vycm9yIGxvYWRpbmcgcm91dGVzOicsIGVycm9yKTtcbiAgICAgIH0pO1xuICB9XG5cbiAgQEhvc3RMaXN0ZW5lcignZG9jdW1lbnQ6a2V5ZG93bicsIFsnJGV2ZW50J10pXG4gIG9uS2V5ZG93bihldmVudDogS2V5Ym9hcmRFdmVudCk6IHZvaWQge1xuICAgIGlmIChldmVudC5jdHJsS2V5ICYmIGV2ZW50LmtleSA9PT0gJ3AnKSB7XG4gICAgICBldmVudC5wcmV2ZW50RGVmYXVsdCgpO1xuICAgICAgdGhpcy5pc1Zpc2libGUgPSAhdGhpcy5pc1Zpc2libGU7XG4gICAgICBpZiAodGhpcy5pc1Zpc2libGUpIHtcbiAgICAgICAgc2V0VGltZW91dCgoKSA9PiB0aGlzLmZvY3VzSW5wdXQoKSwgMCk7XG4gICAgICB9IGVsc2Uge1xuICAgICAgICB0aGlzLnJlc2V0U2VhcmNoKCk7XG4gICAgICB9XG4gICAgfSBlbHNlIGlmICh0aGlzLmlzVmlzaWJsZSAmJiBldmVudC5rZXkgPT09ICdFbnRlcicpIHtcbiAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICBpZiAodGhpcy5maWx0ZXJlZEl0ZW1zLmxlbmd0aCA+IDApIHtcbiAgICAgICAgdGhpcy5uYXZpZ2F0ZVRvKHRoaXMuZmlsdGVyZWRJdGVtc1swXS5yb3V0ZSk7XG4gICAgICB9XG4gICAgfVxuICB9XG4gIFxuICBjbG9zZVNlYXJjaCgpOiB2b2lkIHtcbiAgICB0aGlzLmlzVmlzaWJsZSA9IGZhbHNlO1xuICAgIHRoaXMucmVzZXRTZWFyY2goKTtcbiAgfVxuXG4gIHJlc2V0U2VhcmNoKCk6IHZvaWQge1xuICAgIHRoaXMuc2VhcmNoUXVlcnkgPSAnJztcbiAgICB0aGlzLmZpbHRlcmVkSXRlbXMgPSBbLi4udGhpcy5pdGVtc107XG4gIH1cblxuICBvblNlYXJjaCgpOiB2b2lkIHtcbiAgICBpZiAodGhpcy5zZWFyY2hRdWVyeS50cmltKCkpIHtcbiAgICAgIHRoaXMuZmlsdGVyZWRJdGVtcyA9IHRoaXMuaXRlbXMuZmlsdGVyKGl0ZW0gPT5cbiAgICAgICAgaXRlbS5sYWJlbC50b0xvd2VyQ2FzZSgpLmluY2x1ZGVzKHRoaXMuc2VhcmNoUXVlcnkudG9Mb3dlckNhc2UoKSlcbiAgICAgICk7XG4gICAgfSBlbHNlIHtcbiAgICAgIHRoaXMuZmlsdGVyZWRJdGVtcyA9IFsuLi50aGlzLml0ZW1zXTtcbiAgICB9XG4gIH1cblxuICBuYXZpZ2F0ZVRvKHJvdXRlOiBzdHJpbmcpOiB2b2lkIHtcbiAgICB0aGlzLnJvdXRlci5uYXZpZ2F0ZShbcm91dGVdKTtcbiAgICB0aGlzLmNsb3NlU2VhcmNoKCk7XG4gIH1cblxuICBwcml2YXRlIGZvY3VzSW5wdXQoKTogdm9pZCB7XG4gICAgaWYgKHRoaXMuc2VhcmNoSW5wdXQpIHtcbiAgICAgIHRoaXMuc2VhcmNoSW5wdXQubmF0aXZlRWxlbWVudC5mb2N1cygpO1xuICAgIH1cbiAgfVxufVxuIiwiQGlmIChpc1Zpc2libGUpIHtcbjxkaXYgY2xhc3M9XCJzZWFyY2gtb3ZlcmxheVwiPlxuICA8ZGl2IGNsYXNzPVwic2VhcmNoLXdyYXBwZXJcIj5cbiAgICA8ZGl2IGNsYXNzPVwic2VhcmNoLWNvbnRhaW5lclwiPlxuICAgICAgPGlucHV0IHR5cGU9XCJ0ZXh0XCIgI3NlYXJjaElucHV0IFsobmdNb2RlbCldPVwic2VhcmNoUXVlcnlcIiAoaW5wdXQpPVwib25TZWFyY2goKVwiXG4gICAgICAgIHBsYWNlaG9sZGVyPVwiUGVzcXVpc2UgcG9yIHRlbGFzIGRhIGFwbGljYcOnw6NvLi4uXCIgY2xhc3M9XCJmb3JtLWNvbnRyb2xcIiAvPlxuICAgICAgPGJ1dHRvbiAoY2xpY2spPVwiY2xvc2VTZWFyY2goKVwiIGNsYXNzPVwiYnRuIGJ0bi1vdXRsaW5lLXByaW1hcnkgbXMtMlwiPkZlY2hhcjwvYnV0dG9uPlxuICAgIDwvZGl2PlxuXG4gICAgQGlmIChzZWFyY2hRdWVyeSAhPT0gJycpIHtcbiAgICAgIDxkaXYgY2xhc3M9XCJzZWFyY2gtcmVzdWx0c1wiPlxuICAgICAgICA8ZGl2IGNsYXNzPVwic2Nyb2xsYWJsZS1jb250ZW50XCI+XG4gICAgICAgICAgPHVsIGNsYXNzPVwibGlzdC1ncm91cCBsaXN0LWdyb3VwLWZsdXNoXCI+XG4gICAgICAgICAgICBAZm9yIChpdGVtIG9mIGZpbHRlcmVkSXRlbXM7IHRyYWNrICRpbmRleCkge1xuICAgICAgICAgICAgICA8bGkgKGNsaWNrKT1cIm5hdmlnYXRlVG8oaXRlbS5yb3V0ZSlcIiBzdHlsZT1cImN1cnNvcjogcG9pbnRlcjtcIiBjbGFzcz1cImxpc3QtZ3JvdXAtaXRlbVwiPnt7aXRlbS5sYWJlbH19PC9saT5cbiAgICAgICAgICAgIH0gXG4gICAgICAgICAgICBAZW1wdHkge1xuICAgICAgICAgICAgICA8bGkgY2xhc3M9XCJsaXN0LWdyb3VwLWl0ZW1cIj5OZW5odW0gcmVnaXN0cm8gZW5jb250cmFkbzwvbGk+XG4gICAgICAgICAgICB9XG4gICAgICAgICAgPC91bD5cbiAgICAgICAgPC9kaXY+XG4gICAgICA8L2Rpdj5cbiAgICAgIFxuICAgIH1cbiAgPC9kaXY+XG48L2Rpdj5cbn0iXX0=
|
|
@@ -5316,6 +5316,8 @@ class LibComboboxComponent {
|
|
|
5316
5316
|
this.updateSelectedValue();
|
|
5317
5317
|
if (changes["libRequired"]?.currentValue != undefined)
|
|
5318
5318
|
this.setValidator();
|
|
5319
|
+
if (changes["separator"].currentValue != undefined)
|
|
5320
|
+
this.updateSelectedValue(this.control.value, false);
|
|
5319
5321
|
if (changes["control"]?.currentValue) {
|
|
5320
5322
|
this.setValidator();
|
|
5321
5323
|
this.updateSelectedValue(changes["control"].currentValue.value);
|
|
@@ -5348,14 +5350,14 @@ class LibComboboxComponent {
|
|
|
5348
5350
|
this.setControlStatus(this.innerControl.status);
|
|
5349
5351
|
this.changeValue.emit(null);
|
|
5350
5352
|
}
|
|
5351
|
-
updateSelectedValue(value) {
|
|
5353
|
+
updateSelectedValue(value, noChange = true) {
|
|
5352
5354
|
this.innerControl.setValue(null); // Limpa o campo antes de qualquer coisa
|
|
5353
5355
|
const selectedValue = value ?? this._outerControl.value;
|
|
5354
5356
|
if (!this.list || (selectedValue === null && selectedValue === ''))
|
|
5355
5357
|
return;
|
|
5356
5358
|
const initializedValue = this.list.find(item => item.ID === selectedValue);
|
|
5357
5359
|
if (initializedValue)
|
|
5358
|
-
this.innerControl.setValue(`${initializedValue.AdditionalStringProperty1 && initializedValue.AdditionalStringProperty1 != '' ? initializedValue.AdditionalStringProperty1 : ""}${this.separator === undefined ? "" : " " + this.separator + " "}${initializedValue.LABEL}
|
|
5360
|
+
this.innerControl.setValue(`${initializedValue.AdditionalStringProperty1 && initializedValue.AdditionalStringProperty1 != '' ? initializedValue.AdditionalStringProperty1 : ""}${this.separator === undefined ? "" : " " + this.separator + " "}${initializedValue.LABEL}`, { emitEvent: noChange });
|
|
5359
5361
|
}
|
|
5360
5362
|
adjustDropdownWidth() {
|
|
5361
5363
|
if (this._mainInput && this._dropdownMenu) {
|
|
@@ -7387,7 +7389,6 @@ class SearchInputComponent {
|
|
|
7387
7389
|
}
|
|
7388
7390
|
loadRoutes() {
|
|
7389
7391
|
this.http.get('assets/jsons/routes.json').subscribe(data => {
|
|
7390
|
-
console.log(data);
|
|
7391
7392
|
this.items = data;
|
|
7392
7393
|
}, error => {
|
|
7393
7394
|
console.error('Error loading routes:', error);
|