valtech-components 2.0.387 → 2.0.389

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.
@@ -34,14 +34,18 @@ export class SelectSearchComponent {
34
34
  console.log('[SelectSearch] filteredOptions computed:', {
35
35
  optionsCount: options.length,
36
36
  searchTerm: search,
37
- options: options.slice(0, 3),
37
+ options: options,
38
38
  labelProperty: this.labelProperty,
39
39
  valueProperty: this.valueProperty,
40
+ propsExists: !!this.props,
41
+ propsOptionsExists: !!this.props?.options,
42
+ propsOptionsLength: this.props?.options?.length || 0,
40
43
  firstOptionStructure: options[0] ? {
41
44
  [this.labelProperty]: options[0][this.labelProperty],
42
45
  [this.valueProperty]: options[0][this.valueProperty],
43
- typeOfId: typeof options[0][this.valueProperty]
44
- } : null
46
+ typeOfId: typeof options[0][this.valueProperty],
47
+ fullOption: options[0]
48
+ } : 'NO_OPTIONS'
45
49
  });
46
50
  if (!search) {
47
51
  return options;
@@ -62,6 +66,11 @@ export class SelectSearchComponent {
62
66
  document.addEventListener('click', this.handleClickOutside.bind(this));
63
67
  }
64
68
  ngOnInit() {
69
+ console.log('[SelectSearch] ngOnInit:', {
70
+ props: !!this.props,
71
+ options: this.props?.options?.length || 0,
72
+ control: !!this.props?.control
73
+ });
65
74
  this.applyDefaultValue();
66
75
  this.syncSelectedValue();
67
76
  }
@@ -69,6 +78,12 @@ export class SelectSearchComponent {
69
78
  document.removeEventListener('click', this.handleClickOutside.bind(this));
70
79
  }
71
80
  ngOnChanges(changes) {
81
+ console.log('[SelectSearch] ngOnChanges:', {
82
+ hasPropsChange: !!changes['props'],
83
+ props: !!this.props,
84
+ options: this.props?.options?.length || 0,
85
+ propsOptions: this.props?.options
86
+ });
72
87
  if (changes['props'] && this.props) {
73
88
  this.syncSelectedValue();
74
89
  }
@@ -124,6 +139,15 @@ export class SelectSearchComponent {
124
139
  applyDefaultValueToControl(this.props);
125
140
  }
126
141
  }
142
+ debugOptions() {
143
+ console.log('[SelectSearch] DEBUG CLICK:', {
144
+ props: this.props,
145
+ filteredOptions: this.filteredOptions(),
146
+ searchTerm: this.searchTerm(),
147
+ propsOptions: this.props?.options,
148
+ computed: this.filteredOptions()
149
+ });
150
+ }
127
151
  syncSelectedValue() {
128
152
  if (this.props?.control?.value) {
129
153
  this.selectedValue.set(String(this.props.control.value));
@@ -164,6 +188,11 @@ export class SelectSearchComponent {
164
188
  [class.visible]="isOpen()"
165
189
  #dropdown
166
190
  >
191
+ <!-- Debug button -->
192
+ <div class="search-container" style="background: red; color: white; padding: 4px;">
193
+ <button (click)="debugOptions()">DEBUG: {{ filteredOptions().length }} opciones</button>
194
+ </div>
195
+
167
196
  <!-- Search bar -->
168
197
  <div class="search-container" *ngIf="props?.options && props.options.length > 5">
169
198
  <ion-searchbar
@@ -198,6 +227,8 @@ export class SelectSearchComponent {
198
227
  <ion-item *ngIf="filteredOptions().length === 0" class="no-results">
199
228
  <ion-label color="medium">
200
229
  {{ searchTerm() ? 'No se encontraron resultados' : 'No hay opciones disponibles' }}
230
+ <!-- Debug info -->
231
+ <br><small>Debug: {{ filteredOptions().length }} opciones | Props: {{ !!props }} | Search: "{{ searchTerm() }}"</small>
201
232
  </ion-label>
202
233
  </ion-item>
203
234
  </ion-list>
@@ -241,6 +272,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
241
272
  [class.visible]="isOpen()"
242
273
  #dropdown
243
274
  >
275
+ <!-- Debug button -->
276
+ <div class="search-container" style="background: red; color: white; padding: 4px;">
277
+ <button (click)="debugOptions()">DEBUG: {{ filteredOptions().length }} opciones</button>
278
+ </div>
279
+
244
280
  <!-- Search bar -->
245
281
  <div class="search-container" *ngIf="props?.options && props.options.length > 5">
246
282
  <ion-searchbar
@@ -275,6 +311,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
275
311
  <ion-item *ngIf="filteredOptions().length === 0" class="no-results">
276
312
  <ion-label color="medium">
277
313
  {{ searchTerm() ? 'No se encontraron resultados' : 'No hay opciones disponibles' }}
314
+ <!-- Debug info -->
315
+ <br><small>Debug: {{ filteredOptions().length }} opciones | Props: {{ !!props }} | Search: "{{ searchTerm() }}"</small>
278
316
  </ion-label>
279
317
  </ion-item>
280
318
  </ion-list>
@@ -296,4 +334,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
296
334
  }], placeholder: [{
297
335
  type: Input
298
336
  }] } });
299
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-search.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/select-search/select-search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  inject,\n  Input,\n  OnInit,\n  OnDestroy,\n  OnChanges,\n  SimpleChanges,\n  ViewChild,\n  signal,\n  computed\n} from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { IonicModule } from '@ionic/angular';\nimport { LangService } from '../../../services/lang-provider/lang-provider.service';\nimport { applyDefaultValueToControl } from '../../../shared/utils/form-defaults';\nimport { replaceSpecialChars } from '../../../shared/utils/text';\nimport { InputMetadata, InputOption } from '../../types';\n\n@Component({\n  selector: 'val-select-search',\n  standalone: true,\n  imports: [CommonModule, IonicModule, FormsModule, ReactiveFormsModule],\n  template: `\n    <div class=\"select-container\" (click)=\"toggleDropdown($event)\">\n      <!-- Main input display -->\n      <ion-input\n        #mainInput\n        type=\"text\"\n        [value]=\"displayValue()\"\n        [placeholder]=\"props?.placeholder || placeholder\"\n        readonly\n        class=\"main-input\"\n        [class.is-open]=\"isOpen()\"\n      />\n      \n      <!-- Dropdown icon -->\n      <ion-icon \n        name=\"chevron-down-outline\" \n        class=\"dropdown-icon\" \n        [class.rotated]=\"isOpen()\"\n      ></ion-icon>\n      \n      <!-- Hidden input for form control -->\n      <ion-input \n        style=\"position: absolute; opacity: 0; pointer-events: none;\" \n        [formControl]=\"props?.control\" \n        type=\"hidden\"\n      />\n    </div>\n\n    <!-- Dropdown overlay -->\n    <div \n      class=\"dropdown-overlay\" \n      [class.visible]=\"isOpen()\"\n      #dropdown\n    >\n      <!-- Search bar -->\n      <div class=\"search-container\" *ngIf=\"props?.options && props.options.length > 5\">\n        <ion-searchbar\n          #searchbar\n          [placeholder]=\"'Buscar'\"\n          (ionInput)=\"onSearch($event)\"\n          [value]=\"searchTerm()\"\n          show-clear-button=\"focus\"\n          [debounce]=\"200\"\n        ></ion-searchbar>\n      </div>\n      \n      <!-- Options list -->\n      <div class=\"options-container\">\n        <ion-list class=\"options-list\">\n          <ion-item \n            *ngFor=\"let option of filteredOptions(); trackBy: trackByFn\" \n            button \n            (click)=\"selectOption(option)\"\n            class=\"option-item\"\n          >\n            <ion-label>{{ option[labelProperty] }}</ion-label>\n            <ion-icon \n              *ngIf=\"isSelected(option)\" \n              name=\"checkmark-outline\" \n              slot=\"end\" \n              color=\"primary\"\n            ></ion-icon>\n          </ion-item>\n          \n          <!-- No results message -->\n          <ion-item *ngIf=\"filteredOptions().length === 0\" class=\"no-results\">\n            <ion-label color=\"medium\">\n              {{ searchTerm() ? 'No se encontraron resultados' : 'No hay opciones disponibles' }}\n            </ion-label>\n          </ion-item>\n        </ion-list>\n      </div>\n    </div>\n  `,\n  styleUrls: ['./select-search.component.scss']\n})\nexport class SelectSearchComponent implements OnInit, OnDestroy, OnChanges {\n  @ViewChild('dropdown') dropdownRef!: ElementRef;\n  @ViewChild('mainInput') mainInputRef!: ElementRef;\n\n  @Input() props!: InputMetadata;\n  @Input() labelProperty: string = 'name';\n  @Input() valueProperty: string = 'id';\n  @Input() placeholder: string = '';\n\n  private langService = inject(LangService);\n  \n  // Signals for reactive state management\n  isOpen = signal(false);\n  searchTerm = signal('');\n  selectedValue = signal<string | null>(null);\n  \n  // Computed signals\n  displayValue = computed(() => {\n    const value = this.selectedValue();\n    if (!value) return '';\n    \n    const option = this.getOptionByValue(value);\n    return option ? option[this.labelProperty] : '';\n  });\n\n  filteredOptions = computed(() => {\n    const options = this.props?.options || [];\n    const search = this.searchTerm().toLowerCase();\n    \n    // Debug mejorado\n    console.log('[SelectSearch] filteredOptions computed:', {\n      optionsCount: options.length,\n      searchTerm: search,\n      options: options.slice(0, 3),\n      labelProperty: this.labelProperty,\n      valueProperty: this.valueProperty,\n      firstOptionStructure: options[0] ? {\n        [this.labelProperty]: options[0][this.labelProperty],\n        [this.valueProperty]: options[0][this.valueProperty],\n        typeOfId: typeof options[0][this.valueProperty]\n      } : null\n    });\n    \n    if (!search) {\n      return options;\n    }\n    \n    return options.filter(option => {\n      const label = option[this.labelProperty]\n        ? replaceSpecialChars(String(option[this.labelProperty]).toLowerCase())\n        : '';\n      const value = option[this.valueProperty]\n        ? replaceSpecialChars(String(option[this.valueProperty]).toLowerCase())\n        : '';\n      const searchTerm = replaceSpecialChars(search);\n      return label.includes(searchTerm) || value.includes(searchTerm);\n    });\n  });\n\n  constructor() {\n    this.placeholder = this.langService.getText('_global', 'selectOption', 'Seleccione una opción');\n    \n    // Close dropdown when clicking outside\n    document.addEventListener('click', this.handleClickOutside.bind(this));\n  }\n\n  ngOnInit() {\n    this.applyDefaultValue();\n    this.syncSelectedValue();\n  }\n\n  ngOnDestroy() {\n    document.removeEventListener('click', this.handleClickOutside.bind(this));\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['props'] && this.props) {\n      this.syncSelectedValue();\n    }\n  }\n\n  // Component methods\n  toggleDropdown(event: Event): void {\n    event.stopPropagation();\n    this.isOpen.update(value => !value);\n    \n    if (this.isOpen()) {\n      // Focus search bar when opening if available\n      setTimeout(() => {\n        const searchbar = this.dropdownRef?.nativeElement?.querySelector('ion-searchbar');\n        if (searchbar) {\n          searchbar.setFocus();\n        }\n      }, 100);\n    }\n  }\n\n  onSearch(event: any): void {\n    this.searchTerm.set(event.detail.value || '');\n  }\n\n  selectOption(option: InputOption): void {\n    const value = String(option[this.valueProperty]); // Convertir a string\n    this.selectedValue.set(value);\n    this.isOpen.set(false);\n    this.searchTerm.set('');\n    \n    // Update form control\n    if (this.props?.control) {\n      this.props.control.setValue(value);\n      this.props.control.markAsDirty();\n      this.props.control.markAsTouched();\n    }\n  }\n\n  isSelected(option: InputOption): boolean {\n    return String(this.selectedValue()) === String(option[this.valueProperty]);\n  }\n\n  trackByFn(_index: number, option: InputOption): any {\n    return option[this.valueProperty];\n  }\n\n  private handleClickOutside(event: Event): void {\n    if (this.isOpen() && \n        !this.mainInputRef?.nativeElement?.contains(event.target) &&\n        !this.dropdownRef?.nativeElement?.contains(event.target)) {\n      this.isOpen.set(false);\n      this.searchTerm.set('');\n    }\n  }\n\n  private getOptionByValue(value: string): InputOption | undefined {\n    return this.props?.options?.find(option => \n      String(option[this.valueProperty]) === String(value)\n    );\n  }\n\n  private applyDefaultValue(): void {\n    if (this.props) {\n      applyDefaultValueToControl(this.props);\n    }\n  }\n\n  private syncSelectedValue(): void {\n    if (this.props?.control?.value) {\n      this.selectedValue.set(String(this.props.control.value));\n    }\n  }\n}\n"]}
337
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select-search.component.js","sourceRoot":"","sources":["../../../../../../../projects/valtech-components/src/lib/components/molecules/select-search/select-search.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\nimport {\n  Component,\n  ElementRef,\n  inject,\n  Input,\n  OnInit,\n  OnDestroy,\n  OnChanges,\n  SimpleChanges,\n  ViewChild,\n  signal,\n  computed\n} from '@angular/core';\nimport { FormsModule, ReactiveFormsModule } from '@angular/forms';\nimport { IonicModule } from '@ionic/angular';\nimport { LangService } from '../../../services/lang-provider/lang-provider.service';\nimport { applyDefaultValueToControl } from '../../../shared/utils/form-defaults';\nimport { replaceSpecialChars } from '../../../shared/utils/text';\nimport { InputMetadata, InputOption } from '../../types';\n\n@Component({\n  selector: 'val-select-search',\n  standalone: true,\n  imports: [CommonModule, IonicModule, FormsModule, ReactiveFormsModule],\n  template: `\n    <div class=\"select-container\" (click)=\"toggleDropdown($event)\">\n      <!-- Main input display -->\n      <ion-input\n        #mainInput\n        type=\"text\"\n        [value]=\"displayValue()\"\n        [placeholder]=\"props?.placeholder || placeholder\"\n        readonly\n        class=\"main-input\"\n        [class.is-open]=\"isOpen()\"\n      />\n      \n      <!-- Dropdown icon -->\n      <ion-icon \n        name=\"chevron-down-outline\" \n        class=\"dropdown-icon\" \n        [class.rotated]=\"isOpen()\"\n      ></ion-icon>\n      \n      <!-- Hidden input for form control -->\n      <ion-input \n        style=\"position: absolute; opacity: 0; pointer-events: none;\" \n        [formControl]=\"props?.control\" \n        type=\"hidden\"\n      />\n    </div>\n\n    <!-- Dropdown overlay -->\n    <div \n      class=\"dropdown-overlay\" \n      [class.visible]=\"isOpen()\"\n      #dropdown\n    >\n      <!-- Debug button -->\n      <div class=\"search-container\" style=\"background: red; color: white; padding: 4px;\">\n        <button (click)=\"debugOptions()\">DEBUG: {{ filteredOptions().length }} opciones</button>\n      </div>\n      \n      <!-- Search bar -->\n      <div class=\"search-container\" *ngIf=\"props?.options && props.options.length > 5\">\n        <ion-searchbar\n          #searchbar\n          [placeholder]=\"'Buscar'\"\n          (ionInput)=\"onSearch($event)\"\n          [value]=\"searchTerm()\"\n          show-clear-button=\"focus\"\n          [debounce]=\"200\"\n        ></ion-searchbar>\n      </div>\n      \n      <!-- Options list -->\n      <div class=\"options-container\">\n        <ion-list class=\"options-list\">\n          <ion-item \n            *ngFor=\"let option of filteredOptions(); trackBy: trackByFn\" \n            button \n            (click)=\"selectOption(option)\"\n            class=\"option-item\"\n          >\n            <ion-label>{{ option[labelProperty] }}</ion-label>\n            <ion-icon \n              *ngIf=\"isSelected(option)\" \n              name=\"checkmark-outline\" \n              slot=\"end\" \n              color=\"primary\"\n            ></ion-icon>\n          </ion-item>\n          \n          <!-- No results message -->\n          <ion-item *ngIf=\"filteredOptions().length === 0\" class=\"no-results\">\n            <ion-label color=\"medium\">\n              {{ searchTerm() ? 'No se encontraron resultados' : 'No hay opciones disponibles' }}\n              <!-- Debug info -->\n              <br><small>Debug: {{ filteredOptions().length }} opciones | Props: {{ !!props }} | Search: \"{{ searchTerm() }}\"</small>\n            </ion-label>\n          </ion-item>\n        </ion-list>\n      </div>\n    </div>\n  `,\n  styleUrls: ['./select-search.component.scss']\n})\nexport class SelectSearchComponent implements OnInit, OnDestroy, OnChanges {\n  @ViewChild('dropdown') dropdownRef!: ElementRef;\n  @ViewChild('mainInput') mainInputRef!: ElementRef;\n\n  @Input() props!: InputMetadata;\n  @Input() labelProperty: string = 'name';\n  @Input() valueProperty: string = 'id';\n  @Input() placeholder: string = '';\n\n  private langService = inject(LangService);\n  \n  // Signals for reactive state management\n  isOpen = signal(false);\n  searchTerm = signal('');\n  selectedValue = signal<string | null>(null);\n  \n  // Computed signals\n  displayValue = computed(() => {\n    const value = this.selectedValue();\n    if (!value) return '';\n    \n    const option = this.getOptionByValue(value);\n    return option ? option[this.labelProperty] : '';\n  });\n\n  filteredOptions = computed(() => {\n    const options = this.props?.options || [];\n    const search = this.searchTerm().toLowerCase();\n    \n    // Debug mejorado\n    console.log('[SelectSearch] filteredOptions computed:', {\n      optionsCount: options.length,\n      searchTerm: search,\n      options: options,\n      labelProperty: this.labelProperty,\n      valueProperty: this.valueProperty,\n      propsExists: !!this.props,\n      propsOptionsExists: !!this.props?.options,\n      propsOptionsLength: this.props?.options?.length || 0,\n      firstOptionStructure: options[0] ? {\n        [this.labelProperty]: options[0][this.labelProperty],\n        [this.valueProperty]: options[0][this.valueProperty],\n        typeOfId: typeof options[0][this.valueProperty],\n        fullOption: options[0]\n      } : 'NO_OPTIONS'\n    });\n    \n    if (!search) {\n      return options;\n    }\n    \n    return options.filter(option => {\n      const label = option[this.labelProperty]\n        ? replaceSpecialChars(String(option[this.labelProperty]).toLowerCase())\n        : '';\n      const value = option[this.valueProperty]\n        ? replaceSpecialChars(String(option[this.valueProperty]).toLowerCase())\n        : '';\n      const searchTerm = replaceSpecialChars(search);\n      return label.includes(searchTerm) || value.includes(searchTerm);\n    });\n  });\n\n  constructor() {\n    this.placeholder = this.langService.getText('_global', 'selectOption', 'Seleccione una opción');\n    \n    // Close dropdown when clicking outside\n    document.addEventListener('click', this.handleClickOutside.bind(this));\n  }\n\n  ngOnInit() {\n    console.log('[SelectSearch] ngOnInit:', {\n      props: !!this.props,\n      options: this.props?.options?.length || 0,\n      control: !!this.props?.control\n    });\n    this.applyDefaultValue();\n    this.syncSelectedValue();\n  }\n\n  ngOnDestroy() {\n    document.removeEventListener('click', this.handleClickOutside.bind(this));\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    console.log('[SelectSearch] ngOnChanges:', {\n      hasPropsChange: !!changes['props'],\n      props: !!this.props,\n      options: this.props?.options?.length || 0,\n      propsOptions: this.props?.options\n    });\n    if (changes['props'] && this.props) {\n      this.syncSelectedValue();\n    }\n  }\n\n  // Component methods\n  toggleDropdown(event: Event): void {\n    event.stopPropagation();\n    this.isOpen.update(value => !value);\n    \n    if (this.isOpen()) {\n      // Focus search bar when opening if available\n      setTimeout(() => {\n        const searchbar = this.dropdownRef?.nativeElement?.querySelector('ion-searchbar');\n        if (searchbar) {\n          searchbar.setFocus();\n        }\n      }, 100);\n    }\n  }\n\n  onSearch(event: any): void {\n    this.searchTerm.set(event.detail.value || '');\n  }\n\n  selectOption(option: InputOption): void {\n    const value = String(option[this.valueProperty]); // Convertir a string\n    this.selectedValue.set(value);\n    this.isOpen.set(false);\n    this.searchTerm.set('');\n    \n    // Update form control\n    if (this.props?.control) {\n      this.props.control.setValue(value);\n      this.props.control.markAsDirty();\n      this.props.control.markAsTouched();\n    }\n  }\n\n  isSelected(option: InputOption): boolean {\n    return String(this.selectedValue()) === String(option[this.valueProperty]);\n  }\n\n  trackByFn(_index: number, option: InputOption): any {\n    return option[this.valueProperty];\n  }\n\n  private handleClickOutside(event: Event): void {\n    if (this.isOpen() && \n        !this.mainInputRef?.nativeElement?.contains(event.target) &&\n        !this.dropdownRef?.nativeElement?.contains(event.target)) {\n      this.isOpen.set(false);\n      this.searchTerm.set('');\n    }\n  }\n\n  private getOptionByValue(value: string): InputOption | undefined {\n    return this.props?.options?.find(option => \n      String(option[this.valueProperty]) === String(value)\n    );\n  }\n\n  private applyDefaultValue(): void {\n    if (this.props) {\n      applyDefaultValueToControl(this.props);\n    }\n  }\n\n  debugOptions(): void {\n    console.log('[SelectSearch] DEBUG CLICK:', {\n      props: this.props,\n      filteredOptions: this.filteredOptions(),\n      searchTerm: this.searchTerm(),\n      propsOptions: this.props?.options,\n      computed: this.filteredOptions()\n    });\n  }\n\n  private syncSelectedValue(): void {\n    if (this.props?.control?.value) {\n      this.selectedValue.set(String(this.props.control.value));\n    }\n  }\n}\n"]}
@@ -6784,14 +6784,18 @@ class SelectSearchComponent {
6784
6784
  console.log('[SelectSearch] filteredOptions computed:', {
6785
6785
  optionsCount: options.length,
6786
6786
  searchTerm: search,
6787
- options: options.slice(0, 3),
6787
+ options: options,
6788
6788
  labelProperty: this.labelProperty,
6789
6789
  valueProperty: this.valueProperty,
6790
+ propsExists: !!this.props,
6791
+ propsOptionsExists: !!this.props?.options,
6792
+ propsOptionsLength: this.props?.options?.length || 0,
6790
6793
  firstOptionStructure: options[0] ? {
6791
6794
  [this.labelProperty]: options[0][this.labelProperty],
6792
6795
  [this.valueProperty]: options[0][this.valueProperty],
6793
- typeOfId: typeof options[0][this.valueProperty]
6794
- } : null
6796
+ typeOfId: typeof options[0][this.valueProperty],
6797
+ fullOption: options[0]
6798
+ } : 'NO_OPTIONS'
6795
6799
  });
6796
6800
  if (!search) {
6797
6801
  return options;
@@ -6812,6 +6816,11 @@ class SelectSearchComponent {
6812
6816
  document.addEventListener('click', this.handleClickOutside.bind(this));
6813
6817
  }
6814
6818
  ngOnInit() {
6819
+ console.log('[SelectSearch] ngOnInit:', {
6820
+ props: !!this.props,
6821
+ options: this.props?.options?.length || 0,
6822
+ control: !!this.props?.control
6823
+ });
6815
6824
  this.applyDefaultValue();
6816
6825
  this.syncSelectedValue();
6817
6826
  }
@@ -6819,6 +6828,12 @@ class SelectSearchComponent {
6819
6828
  document.removeEventListener('click', this.handleClickOutside.bind(this));
6820
6829
  }
6821
6830
  ngOnChanges(changes) {
6831
+ console.log('[SelectSearch] ngOnChanges:', {
6832
+ hasPropsChange: !!changes['props'],
6833
+ props: !!this.props,
6834
+ options: this.props?.options?.length || 0,
6835
+ propsOptions: this.props?.options
6836
+ });
6822
6837
  if (changes['props'] && this.props) {
6823
6838
  this.syncSelectedValue();
6824
6839
  }
@@ -6874,6 +6889,15 @@ class SelectSearchComponent {
6874
6889
  applyDefaultValueToControl(this.props);
6875
6890
  }
6876
6891
  }
6892
+ debugOptions() {
6893
+ console.log('[SelectSearch] DEBUG CLICK:', {
6894
+ props: this.props,
6895
+ filteredOptions: this.filteredOptions(),
6896
+ searchTerm: this.searchTerm(),
6897
+ propsOptions: this.props?.options,
6898
+ computed: this.filteredOptions()
6899
+ });
6900
+ }
6877
6901
  syncSelectedValue() {
6878
6902
  if (this.props?.control?.value) {
6879
6903
  this.selectedValue.set(String(this.props.control.value));
@@ -6914,6 +6938,11 @@ class SelectSearchComponent {
6914
6938
  [class.visible]="isOpen()"
6915
6939
  #dropdown
6916
6940
  >
6941
+ <!-- Debug button -->
6942
+ <div class="search-container" style="background: red; color: white; padding: 4px;">
6943
+ <button (click)="debugOptions()">DEBUG: {{ filteredOptions().length }} opciones</button>
6944
+ </div>
6945
+
6917
6946
  <!-- Search bar -->
6918
6947
  <div class="search-container" *ngIf="props?.options && props.options.length > 5">
6919
6948
  <ion-searchbar
@@ -6948,6 +6977,8 @@ class SelectSearchComponent {
6948
6977
  <ion-item *ngIf="filteredOptions().length === 0" class="no-results">
6949
6978
  <ion-label color="medium">
6950
6979
  {{ searchTerm() ? 'No se encontraron resultados' : 'No hay opciones disponibles' }}
6980
+ <!-- Debug info -->
6981
+ <br><small>Debug: {{ filteredOptions().length }} opciones | Props: {{ !!props }} | Search: "{{ searchTerm() }}"</small>
6951
6982
  </ion-label>
6952
6983
  </ion-item>
6953
6984
  </ion-list>
@@ -6991,6 +7022,11 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
6991
7022
  [class.visible]="isOpen()"
6992
7023
  #dropdown
6993
7024
  >
7025
+ <!-- Debug button -->
7026
+ <div class="search-container" style="background: red; color: white; padding: 4px;">
7027
+ <button (click)="debugOptions()">DEBUG: {{ filteredOptions().length }} opciones</button>
7028
+ </div>
7029
+
6994
7030
  <!-- Search bar -->
6995
7031
  <div class="search-container" *ngIf="props?.options && props.options.length > 5">
6996
7032
  <ion-searchbar
@@ -7025,6 +7061,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
7025
7061
  <ion-item *ngIf="filteredOptions().length === 0" class="no-results">
7026
7062
  <ion-label color="medium">
7027
7063
  {{ searchTerm() ? 'No se encontraron resultados' : 'No hay opciones disponibles' }}
7064
+ <!-- Debug info -->
7065
+ <br><small>Debug: {{ filteredOptions().length }} opciones | Props: {{ !!props }} | Search: "{{ searchTerm() }}"</small>
7028
7066
  </ion-label>
7029
7067
  </ion-item>
7030
7068
  </ion-list>