@litigiovirtual/ius-design-components 1.0.113 → 1.0.115

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.
@@ -21,16 +21,28 @@ export class InputSelectComponent {
21
21
  this.onChangesValueEvent = new EventEmitter();
22
22
  this.onEnterKey = new EventEmitter();
23
23
  }
24
- //Esta funcion permite que el se cierre el listado si el usuario da click en otro lado fuera del componente
24
+ //Esta funcion permite que se cierre el listado si el usuario da click en otro lado fuera del componente
25
25
  onClickOutside(event) {
26
26
  if (!this.hasClickedInside) {
27
27
  return;
28
28
  }
29
29
  const target = event.target;
30
30
  const container = document.getElementById(this.componentId);
31
+ const containerTextfield = container?.querySelector('.container-textfield');
32
+ const containerList = container?.querySelector('.container-list');
33
+ // 1. Cierra la lista si el click está completamente fuera del componente
31
34
  if (container && !container.contains(target)) {
32
35
  this.closeList();
33
36
  }
37
+ // 2. Si el click está dentro del componente pero
38
+ // NO está ni en el textfield ni en la lista, también cierra
39
+ else if (containerTextfield && containerList) {
40
+ const clickEnTextfield = containerTextfield.contains(target);
41
+ const clickEnLista = containerList.contains(target);
42
+ if (!clickEnTextfield && !clickEnLista) {
43
+ this.closeList();
44
+ }
45
+ }
34
46
  }
35
47
  closeList(event) {
36
48
  if (event) {
@@ -128,4 +140,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
128
140
  type: HostListener,
129
141
  args: ['document:click', ['$event']]
130
142
  }] } });
131
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-select.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/input-select/input-select.component.ts","../../../../../projects/ius-design-components/src/lib/input-select/input-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\nimport { IconMdComponent } from '../icon-md/icon-md.component';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\n\n@Component({\n  selector: 'ius-input-select',\n  standalone: true,\n  imports: [IconMdComponent, FormsModule, CommonModule],\n  templateUrl: './input-select.component.html',\n  styleUrl: './input-select.component.scss',\n})\nexport class InputSelectComponent {\n\n  isFocused: boolean = false;\n  isAlertText: boolean = false;\n  showList: boolean = false;\n  hasClickedInside: boolean = false; //Bandera para detectar que ya dieron el primer click en el componente\n  selected: boolean = false;\n\n  @Input({ required: true }) componentId: string = ''; //Debe mandar un componenteID para llamar el input varias veces\n  @Input() required = false;\n  @Input() disabled = false;\n  @Input() showHelpText = false;\n\n  @Input() labelSuperior?: string;\n  @Input() labelInferior?: string;\n  @Input() labelInput?: string;\n  @Input() iconInput?: string;\n\n  @Input() textInput?: string = '';\n  @Input() maxlenght?: number;\n  @Input() inputType: string = 'text';\n\n  @Output() onChangesValueEvent = new EventEmitter<any>();\n  @Output() onEnterKey = new EventEmitter<string>();\n\n  //Esta funcion permite que el se cierre el listado si el usuario da click en otro lado fuera del componente\n  @HostListener('document:click', ['$event'])\n  onClickOutside(event: Event) {\n    if (!this.hasClickedInside) {\n      return;\n    }\n    const target = event.target as HTMLElement;\n    const container = document.getElementById(this.componentId);\n    if (container && !container.contains(target)) {\n      this.closeList();\n    }\n  }\n\n  closeList(event?: Event): void {\n    if (event) {\n      event.stopImmediatePropagation();\n    }\n    this.isFocused = false;\n    this.showList = false;\n    if (!this.selected && !this.showList && this.required) {\n      this.isAlertText = true;\n    } else {\n      this.isAlertText = false;\n    }\n  }\n\n  onInput(): void {\n    if (this.selected) {\n      this.selected = false;\n    }\n    this.onChangesValueEvent.emit(this.textInput);\n  }\n\n  onFocus(): void {\n    if (this.disabled) {\n      return;\n    }\n    this.isFocused = true;\n    this.showList = true;\n    this.hasClickedInside = true;\n  }\n\n  onBlur(): void {\n    this.isFocused = false;\n    if (this.required && !this.selected) {\n      if (this.textInput === '') {\n        this.isAlertText = true;\n      } else {\n        this.isAlertText = false;\n      }\n    }\n  }\n\n  onKeyPress(event: KeyboardEvent): void {\n    if (event.key === 'Enter') {\n      if (this.textInput!.trim() !== '') {\n        this.onEnterKey.emit(this.textInput);\n      }\n    }\n  }\n\n  onSelectOption() {\n    this.selected = true;\n    this.isFocused = false;\n    this.showList = false;\n    this.isAlertText = false;\n  }\n\n  onDropBlock(event: DragEvent) {\n    // Evita que se dropee contenido en el input\n    event.preventDefault();\n  }\n\n  onDragOverBlock(event: DragEvent) {\n    // Evita que se permita arrastrar texto sobre el input\n    event.preventDefault();\n  }\n}\n","<div class=\"container-general\" [id]=\"componentId\">\n  @if (labelSuperior) {\n  <div class=\"container-label-sup\" [ngClass]=\"{\n        'disabled': disabled\n    }\">\n    @if(!disabled && required){\n    <div class=\"icon-dot\"></div>\n    }\n    <span class=\"\">{{labelSuperior}}</span>\n    @if(!disabled && showHelpText){\n    <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\n    }\n    <span>:</span>\n  </div>\n  }\n  <div class=\"container-textfield\" [ngClass]=\"{\n        'disabled': disabled,\n        'focused': isFocused,\n        'alert': !isFocused && isAlertText && !disabled\n    }\" (click)=\"onFocus()\">\n    @if (iconInput) {\n    <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\n    }\n    <input [type]=\"inputType\" [(ngModel)]=\"textInput\" [placeholder]=\"labelInput\" [disabled]=\"disabled\" (input)=\"onInput()\"\n      [maxlength]=\"maxlenght ?? null\" (focus)=\"onFocus()\" (blur)=\"onBlur()\"\n      (keypress)=\"onKeyPress($event)\" (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($event)\">\n    <div class=\"cnt-icon-right\">\n      @if(!showList){\n      <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\n      }@else{\n      <div (click)=\"closeList($event)\" style=\"height: 20px;\">\n        <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n      </div>\n      }\n    </div>\n  </div>\n  @if (labelInferior && isFocused) {\n  <span class=\"label-inf\">{{labelInferior}}</span>\n  }\n  @if (labelInferior && !isFocused && isAlertText) {\n  <span class=\"label-inf\" [ngClass]=\"{\n        'alert': !isFocused && isAlertText && !disabled\n    }\">{{labelInferior}}</span>\n  }\n  @if (showList) {\n  <div class=\"container-list scrollable-small\">\n    <div (click)=\"onSelectOption()\">\n      <ng-content selector=\"ius-option\"></ng-content>\n    </div>\n  </div>\n  }\n</div>"]}
143
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-select.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/input-select/input-select.component.ts","../../../../../projects/ius-design-components/src/lib/input-select/input-select.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\nimport { IconMdComponent } from '../icon-md/icon-md.component';\nimport { CommonModule } from '@angular/common';\nimport { FormsModule } from '@angular/forms';\n\n@Component({\n  selector: 'ius-input-select',\n  standalone: true,\n  imports: [IconMdComponent, FormsModule, CommonModule],\n  templateUrl: './input-select.component.html',\n  styleUrl: './input-select.component.scss',\n})\nexport class InputSelectComponent {\n\n  isFocused: boolean = false;\n  isAlertText: boolean = false;\n  showList: boolean = false;\n  hasClickedInside: boolean = false; //Bandera para detectar que ya dieron el primer click en el componente\n  selected: boolean = false;\n\n  @Input({ required: true }) componentId: string = ''; //Debe mandar un componenteID para llamar el input varias veces\n  @Input() required = false;\n  @Input() disabled = false;\n  @Input() showHelpText = false;\n\n  @Input() labelSuperior?: string;\n  @Input() labelInferior?: string;\n  @Input() labelInput?: string;\n  @Input() iconInput?: string;\n\n  @Input() textInput?: string = '';\n  @Input() maxlenght?: number;\n  @Input() inputType: string = 'text';\n\n  @Output() onChangesValueEvent = new EventEmitter<any>();\n  @Output() onEnterKey = new EventEmitter<string>();\n\n  //Esta funcion permite que se cierre el listado si el usuario da click en otro lado fuera del componente\n  @HostListener('document:click', ['$event'])\n  onClickOutside(event: Event) {\n    if (!this.hasClickedInside) {\n      return;\n    }\n    const target = event.target as HTMLElement;\n    const container = document.getElementById(this.componentId);\n    const containerTextfield = container?.querySelector('.container-textfield');\n    const containerList = container?.querySelector('.container-list');\n\n    // 1. Cierra la lista si el click está completamente fuera del componente\n    if (container && !container.contains(target)) {\n      this.closeList();\n    }\n    // 2. Si el click está dentro del componente pero\n    //    NO está ni en el textfield ni en la lista, también cierra\n    else if (containerTextfield && containerList) {\n      const clickEnTextfield = containerTextfield.contains(target);\n      const clickEnLista = containerList.contains(target);\n      if (!clickEnTextfield && !clickEnLista) {\n        this.closeList();\n      }\n    }\n  }\n\n\n  closeList(event?: Event): void {\n    if (event) {\n      event.stopImmediatePropagation();\n    }\n    this.isFocused = false;\n    this.showList = false;\n    if (!this.selected && !this.showList && this.required) {\n      this.isAlertText = true;\n    } else {\n      this.isAlertText = false;\n    }\n  }\n\n  onInput(): void {\n    if (this.selected) {\n      this.selected = false;\n    }\n    this.onChangesValueEvent.emit(this.textInput);\n  }\n\n  onFocus(): void {\n    if (this.disabled) {\n      return;\n    }\n    this.isFocused = true;\n    this.showList = true;\n    this.hasClickedInside = true;\n  }\n\n  onBlur(): void {\n    this.isFocused = false;\n    if (this.required && !this.selected) {\n      if (this.textInput === '') {\n        this.isAlertText = true;\n      } else {\n        this.isAlertText = false;\n      }\n    }\n  }\n\n  onKeyPress(event: KeyboardEvent): void {\n    if (event.key === 'Enter') {\n      if (this.textInput!.trim() !== '') {\n        this.onEnterKey.emit(this.textInput);\n      }\n    }\n  }\n\n  onSelectOption() {\n    this.selected = true;\n    this.isFocused = false;\n    this.showList = false;\n    this.isAlertText = false;\n  }\n\n  onDropBlock(event: DragEvent) {\n    // Evita que se dropee contenido en el input\n    event.preventDefault();\n  }\n\n  onDragOverBlock(event: DragEvent) {\n    // Evita que se permita arrastrar texto sobre el input\n    event.preventDefault();\n  }\n}\n","<div class=\"container-general\" [id]=\"componentId\">\n  @if (labelSuperior) {\n  <div class=\"container-label-sup\" [ngClass]=\"{\n        'disabled': disabled\n    }\">\n    @if(!disabled && required){\n    <div class=\"icon-dot\"></div>\n    }\n    <span class=\"\">{{labelSuperior}}</span>\n    @if(!disabled && showHelpText){\n    <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\n    }\n    <span>:</span>\n  </div>\n  }\n  <div class=\"container-textfield\" [ngClass]=\"{\n        'disabled': disabled,\n        'focused': isFocused,\n        'alert': !isFocused && isAlertText && !disabled\n    }\" (click)=\"onFocus()\">\n    @if (iconInput) {\n    <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\n    }\n    <input [type]=\"inputType\" [(ngModel)]=\"textInput\" [placeholder]=\"labelInput\" [disabled]=\"disabled\" (input)=\"onInput()\"\n      [maxlength]=\"maxlenght ?? null\" (focus)=\"onFocus()\" (blur)=\"onBlur()\"\n      (keypress)=\"onKeyPress($event)\" (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($event)\">\n    <div class=\"cnt-icon-right\">\n      @if(!showList){\n      <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\n      }@else{\n      <div (click)=\"closeList($event)\" style=\"height: 20px;\">\n        <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\n      </div>\n      }\n    </div>\n  </div>\n  @if (labelInferior && isFocused) {\n  <span class=\"label-inf\">{{labelInferior}}</span>\n  }\n  @if (labelInferior && !isFocused && isAlertText) {\n  <span class=\"label-inf\" [ngClass]=\"{\n        'alert': !isFocused && isAlertText && !disabled\n    }\">{{labelInferior}}</span>\n  }\n  @if (showList) {\n  <div class=\"container-list scrollable-small\">\n    <div (click)=\"onSelectOption()\">\n      <ng-content selector=\"ius-option\"></ng-content>\n    </div>\n  </div>\n  }\n</div>"]}
@@ -22,14 +22,18 @@ export class InputSelectFilterComponent {
22
22
  this.inputType = 'text';
23
23
  this.onChangesValueEvent = new EventEmitter();
24
24
  this.onEnterKey = new EventEmitter();
25
+ /** Firma de los ítems seleccionados para detectar cambios externos (reset, etc.) */
26
+ this.lastSelectedSignature = '';
25
27
  }
26
- set filterData(value) {
27
- this._filterData = value;
28
- // cada vez que cambie desde afuera recalculo el texto
29
- this.updateTextInputFromSelected();
30
- }
31
- get filterData() {
32
- return this._filterData;
28
+ // 🔍 Se ejecuta en cada ciclo de detección de cambios
29
+ ngDoCheck() {
30
+ const selectedItems = this.getSelectedItems();
31
+ const newSignature = selectedItems.map(i => (i.id ?? i.text)).join('|');
32
+ if (newSignature !== this.lastSelectedSignature) {
33
+ this.lastSelectedSignature = newSignature;
34
+ // Actualiza el texto en el input cada vez que cambia la selección desde afuera o desde adentro
35
+ this.textInput = selectedItems.map(i => i.text).join(', ');
36
+ }
33
37
  }
34
38
  //Esta funcion permite que el se cierre el listado si el usuario da click en otro lado fuera del componente
35
39
  onClickOutside(event) {
@@ -97,28 +101,11 @@ export class InputSelectFilterComponent {
97
101
  selectedItem(data) {
98
102
  data.checked = !data.checked;
99
103
  this.itemSelected = data;
100
- const selected = this.updateTextInputFromSelected();
104
+ const selected = this.getSelectedItems();
105
+ this.textInput = selected.map(i => i.text).join(', ');
106
+ this.lastSelectedSignature = selected.map(i => (i.id ?? i.text)).join('|');
101
107
  this.onChangesValueEvent.emit({ text: this.textInput ?? '', items: selected });
102
108
  }
103
- updateTextInputFromSelected() {
104
- const selectedItems = [];
105
- if (!this.filterData) {
106
- this.textInput = '';
107
- return selectedItems;
108
- }
109
- for (const group of this.filterData) {
110
- if (!group.values) {
111
- continue;
112
- }
113
- for (const v of group.values) {
114
- if (v && v.checked) {
115
- selectedItems.push(v);
116
- }
117
- }
118
- }
119
- this.textInput = selectedItems.map(i => i.text).join(', ');
120
- return selectedItems;
121
- }
122
109
  getSelectedItems() {
123
110
  const selectedItems = [];
124
111
  if (!this.filterData) {
@@ -171,4 +158,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.12", ngImpo
171
158
  type: HostListener,
172
159
  args: ['document:click', ['$event']]
173
160
  }] } });
174
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-select-filter.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/input-select-filter/input-select-filter.component.ts","../../../../../projects/ius-design-components/src/lib/input-select-filter/input-select-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter, HostListener, Input, Output } from '@angular/core';\r\nimport { IconMdComponent } from '../icon-md/icon-md.component';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { CommonModule } from '@angular/common';\r\nimport { IconSmComponent } from \"../icon-sm\";\r\nimport { CheckboxComponent } from \"../checkbox\";\r\n\r\nexport type FilterData = { title: string; values: FilterItemInputList[]; };\r\n\r\nexport type FilterItemInputList = {\r\n  id?: number;\r\n  text: string;\r\n  checked: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'ius-input-select-filter',\r\n  standalone: true,\r\n  imports: [IconMdComponent, FormsModule, CommonModule, IconSmComponent, CheckboxComponent],\r\n  templateUrl: './input-select-filter.component.html',\r\n  styleUrl: './input-select-filter.component.scss'\r\n})\r\nexport class InputSelectFilterComponent {\r\n\r\n  private _filterData?: FilterData[];\r\n  @Input()\r\n  set filterData(value: FilterData[] | undefined) {\r\n    this._filterData = value;\r\n    // cada vez que cambie desde afuera recalculo el texto\r\n    this.updateTextInputFromSelected();\r\n  }\r\n  get filterData(): FilterData[] | undefined {\r\n    return this._filterData;\r\n  }\r\n\r\n  filterDataSelected?: FilterData;\r\n  itemSelected?: FilterItemInputList;\r\n\r\n  isFocused: boolean = false;\r\n  isAlertText: boolean = false;\r\n  showList: boolean = false;\r\n  hasClickedInside: boolean = false; //Bandera para detectar que ya dieron el primer click en el componente\r\n  selected: boolean = false;\r\n\r\n  @Input({ required: true }) componentId: string = ''; //Debe mandar un componenteID para llamar el input varias veces\r\n  @Input() disabled = false;\r\n  @Input() showHelpText = false;\r\n\r\n  @Input() labelSuperior?: string;\r\n  @Input() labelInput?: string;\r\n  @Input() iconInput?: string = 'icon-search';\r\n\r\n  @Input() textInput?: string = '';\r\n  @Input() maxlenght?: number;\r\n  @Input() inputType: string = 'text';\r\n\r\n  @Output() onChangesValueEvent = new EventEmitter<{ text: string; items: FilterItemInputList[] }>();\r\n  @Output() onEnterKey = new EventEmitter<string>();\r\n\r\n  //Esta funcion permite que el se cierre el listado si el usuario da click en otro lado fuera del componente\r\n  @HostListener('document:click', ['$event'])\r\n  onClickOutside(event: Event) {\r\n    if (!this.hasClickedInside) {\r\n      return;\r\n    }\r\n    const target = event.target as HTMLElement;\r\n    const container = document.getElementById(this.componentId);\r\n    const containerTextfield = container?.querySelector('.container-textfield');\r\n    const containerList = container?.querySelector('.container-list');\r\n\r\n    // Cierra la lista solo si el click está fuera del componente completo\r\n    if (container && !container.contains(target)) {\r\n      this.closeList();\r\n    }\r\n    // Si el click está dentro del componente pero fuera de textfield y lista, cierra\r\n    else if (containerTextfield && containerList) {\r\n      if (!containerTextfield.contains(target) && !containerList.contains(target)) {\r\n        this.closeList();\r\n      }\r\n    }\r\n  }\r\n\r\n  closeList(event?: Event): void {\r\n    if (event) {\r\n      event.stopImmediatePropagation();\r\n    }\r\n    this.isFocused = false;\r\n    this.showList = false;\r\n  }\r\n\r\n  onInput(): void {\r\n    if (this.selected) {\r\n      this.selected = false;\r\n    }\r\n    const items = this.getSelectedItems();\r\n    this.onChangesValueEvent.emit({ text: this.textInput ?? '', items });\r\n  }\r\n\r\n  onFocus(): void {\r\n    if (this.disabled) {\r\n      return;\r\n    }\r\n    this.isFocused = true;\r\n    this.showList = true;\r\n    this.hasClickedInside = true;\r\n  }\r\n\r\n  onBlur(): void {\r\n    this.isFocused = false;\r\n  }\r\n\r\n  onKeyPress(event: KeyboardEvent): void {\r\n    if (event.key === 'Enter') {\r\n      if (this.textInput!.trim() !== '') {\r\n        this.onEnterKey.emit(this.textInput);\r\n      }\r\n    }\r\n  }\r\n\r\n  onDropBlock(event: DragEvent) {\r\n    // Evita que se dropee contenido en el input\r\n    event.preventDefault();\r\n  }\r\n\r\n  onDragOverBlock(event: DragEvent) {\r\n    // Evita que se permita arrastrar texto sobre el input\r\n    event.preventDefault();\r\n  }\r\n\r\n  selectedData(data: FilterData) {\r\n    this.filterDataSelected = data;\r\n  }\r\n\r\n  selectedItem(data: FilterItemInputList) {\r\n    data.checked = !data.checked;\r\n    this.itemSelected = data;\r\n\r\n    const selected = this.updateTextInputFromSelected();\r\n\r\n    this.onChangesValueEvent.emit({ text: this.textInput ?? '', items: selected });\r\n  }\r\n\r\n  updateTextInputFromSelected(): FilterItemInputList[] {\r\n    const selectedItems: FilterItemInputList[] = [];\r\n    if (!this.filterData) {\r\n      this.textInput = '';\r\n      return selectedItems;\r\n    }\r\n\r\n    for (const group of this.filterData) {\r\n      if (!group.values) { continue; }\r\n      for (const v of group.values) {\r\n        if (v && v.checked) {\r\n          selectedItems.push(v);\r\n        }\r\n      }\r\n    }\r\n\r\n    this.textInput = selectedItems.map(i => i.text).join(', ');\r\n    return selectedItems;\r\n  }\r\n\r\n  getSelectedItems(): FilterItemInputList[] {\r\n    const selectedItems: FilterItemInputList[] = [];\r\n    if (!this.filterData) { return selectedItems; }\r\n    for (const group of this.filterData) {\r\n      if (!group.values) { continue; }\r\n      for (const v of group.values) {\r\n        if (v && v.checked) {\r\n          selectedItems.push(v);\r\n        }\r\n      }\r\n    }\r\n    return selectedItems;\r\n  }\r\n}\r\n","<div class=\"container-general\" [id]=\"componentId\">\r\n    @if (labelSuperior) {\r\n    <div class=\"container-label-sup\" [ngClass]=\"{\r\n        'disabled': disabled\r\n    }\">\r\n        <span class=\"\">{{labelSuperior}}</span>\r\n        @if(!disabled && showHelpText){\r\n        <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\r\n        }\r\n        <span>:</span>\r\n    </div>\r\n    }\r\n    <div class=\"container-textfield\" [ngClass]=\"{\r\n        'disabled': disabled,\r\n        'focused': isFocused\r\n    }\" (click)=\"onFocus()\">\r\n        @if (iconInput) {\r\n        <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\r\n        }\r\n        <input [type]=\"inputType\" [(ngModel)]=\"textInput\" readonly [placeholder]=\"labelInput\" [disabled]=\"disabled\"\r\n            [maxlength]=\"maxlenght ?? null\" (focus)=\"onFocus()\" (blur)=\"onBlur()\"\r\n            (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($event)\">\r\n        <div class=\"cnt-icon-right\">\r\n            @if(!showList){\r\n            <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\r\n            }@else{\r\n            <div (click)=\"closeList($event)\" style=\"height: 20px;\">\r\n                <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\r\n            </div>\r\n            }\r\n        </div>\r\n    </div>\r\n    @if (showList) {\r\n    <div class=\"container-list \">\r\n        <div class=\"ctn-items scrollable-small\">\r\n            @for (data of filterData; track $index) {\r\n            <button class=\"item-list\" (click)=\"selectedData(data)\">\r\n                <span class=\"tx-item body-b color-pry\">{{data.title}}</span>\r\n                <ius-icon-sm iconName=\"icon-arrow-forward-ios\" class=\"color-pry\"></ius-icon-sm>\r\n            </button>\r\n            }\r\n        </div>\r\n        @if(filterDataSelected){\r\n        <div class=\"separator\"></div>\r\n        <div class=\"ctn-items scrollable-small\">\r\n            @for (item of filterDataSelected.values; track $index) {\r\n            <div class=\"item-check\" (click)=\"selectedItem(item)\">\r\n                <ius-checkbox [checked]=\"item.checked\" (click)=\"$event.stopPropagation(); selectedItem(item)\"></ius-checkbox>\r\n                <span class=\"tx-item body-b color-pry\">{{item.text}}</span>\r\n            </div>\r\n            }\r\n        </div>\r\n        }\r\n    </div>\r\n    }\r\n</div>"]}
161
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"input-select-filter.component.js","sourceRoot":"","sources":["../../../../../projects/ius-design-components/src/lib/input-select-filter/input-select-filter.component.ts","../../../../../projects/ius-design-components/src/lib/input-select-filter/input-select-filter.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, DoCheck, EventEmitter, HostListener, Input, Output } from '@angular/core';\r\nimport { IconMdComponent } from '../icon-md/icon-md.component';\r\nimport { FormsModule } from '@angular/forms';\r\nimport { CommonModule } from '@angular/common';\r\nimport { IconSmComponent } from \"../icon-sm\";\r\nimport { CheckboxComponent } from \"../checkbox\";\r\n\r\nexport type FilterData = { title: string; values: FilterItemInputList[]; };\r\n\r\nexport type FilterItemInputList = {\r\n  id?: number;\r\n  text: string;\r\n  checked: boolean;\r\n}\r\n\r\n@Component({\r\n  selector: 'ius-input-select-filter',\r\n  standalone: true,\r\n  imports: [IconMdComponent, FormsModule, CommonModule, IconSmComponent, CheckboxComponent],\r\n  templateUrl: './input-select-filter.component.html',\r\n  styleUrl: './input-select-filter.component.scss'\r\n})\r\nexport class InputSelectFilterComponent implements DoCheck {\r\n\r\n  @Input() filterData?: FilterData[];\r\n  filterDataSelected?: FilterData;\r\n  itemSelected?: FilterItemInputList;\r\n\r\n  isFocused: boolean = false;\r\n  isAlertText: boolean = false;\r\n  showList: boolean = false;\r\n  hasClickedInside: boolean = false; //Bandera para detectar que ya dieron el primer click en el componente\r\n  selected: boolean = false;\r\n\r\n  @Input({ required: true }) componentId: string = ''; //Debe mandar un componenteID para llamar el input varias veces\r\n  @Input() disabled = false;\r\n  @Input() showHelpText = false;\r\n\r\n  @Input() labelSuperior?: string;\r\n  @Input() labelInput?: string;\r\n  @Input() iconInput?: string = 'icon-search';\r\n\r\n  @Input() textInput?: string = '';\r\n  @Input() maxlenght?: number;\r\n  @Input() inputType: string = 'text';\r\n\r\n  @Output() onChangesValueEvent = new EventEmitter<{ text: string; items: FilterItemInputList[] }>();\r\n  @Output() onEnterKey = new EventEmitter<string>();\r\n\r\n  /** Firma de los ítems seleccionados para detectar cambios externos (reset, etc.) */\r\n  private lastSelectedSignature: string = '';\r\n\r\n  // 🔍 Se ejecuta en cada ciclo de detección de cambios\r\n  ngDoCheck(): void {\r\n    const selectedItems = this.getSelectedItems();\r\n    const newSignature = selectedItems.map(i => (i.id ?? i.text)).join('|');\r\n\r\n    if (newSignature !== this.lastSelectedSignature) {\r\n      this.lastSelectedSignature = newSignature;\r\n      // Actualiza el texto en el input cada vez que cambia la selección desde afuera o desde adentro\r\n      this.textInput = selectedItems.map(i => i.text).join(', ');\r\n    }\r\n  }\r\n\r\n  //Esta funcion permite que el se cierre el listado si el usuario da click en otro lado fuera del componente\r\n  @HostListener('document:click', ['$event'])\r\n  onClickOutside(event: Event) {\r\n    if (!this.hasClickedInside) {\r\n      return;\r\n    }\r\n    const target = event.target as HTMLElement;\r\n    const container = document.getElementById(this.componentId);\r\n    const containerTextfield = container?.querySelector('.container-textfield');\r\n    const containerList = container?.querySelector('.container-list');\r\n    \r\n    // Cierra la lista solo si el click está fuera del componente completo\r\n    if (container && !container.contains(target)) {\r\n      this.closeList();\r\n    }\r\n    // Si el click está dentro del componente pero fuera de textfield y lista, cierra\r\n    else if (containerTextfield && containerList) {\r\n      if (!containerTextfield.contains(target) && !containerList.contains(target)) {\r\n        this.closeList();\r\n      }\r\n    }\r\n  }\r\n\r\n  closeList(event?: Event): void {\r\n    if (event) {\r\n      event.stopImmediatePropagation();\r\n    }\r\n    this.isFocused = false;\r\n    this.showList = false;\r\n  }\r\n\r\n  onInput(): void {\r\n    if (this.selected) {\r\n      this.selected = false;\r\n    }\r\n    const items = this.getSelectedItems();\r\n    this.onChangesValueEvent.emit({ text: this.textInput ?? '', items });\r\n  }\r\n\r\n  onFocus(): void {\r\n    if (this.disabled) {\r\n      return;\r\n    }\r\n    this.isFocused = true;\r\n    this.showList = true;\r\n    this.hasClickedInside = true;\r\n  }\r\n\r\n  onBlur(): void {\r\n    this.isFocused = false;\r\n  }\r\n\r\n  onKeyPress(event: KeyboardEvent): void {\r\n    if (event.key === 'Enter') {\r\n      if (this.textInput!.trim() !== '') {\r\n        this.onEnterKey.emit(this.textInput);\r\n      }\r\n    }\r\n  }\r\n\r\n  onDropBlock(event: DragEvent) {\r\n    // Evita que se dropee contenido en el input\r\n    event.preventDefault();\r\n  }\r\n\r\n  onDragOverBlock(event: DragEvent) {\r\n    // Evita que se permita arrastrar texto sobre el input\r\n    event.preventDefault();\r\n  }\r\n\r\n  selectedData(data: FilterData) {\r\n    this.filterDataSelected = data;\r\n  }\r\n\r\n  selectedItem(data: FilterItemInputList) {\r\n    data.checked = !data.checked;\r\n    this.itemSelected = data;\r\n\r\n    const selected = this.getSelectedItems();\r\n    this.textInput = selected.map(i => i.text).join(', ');\r\n    this.lastSelectedSignature = selected.map(i => (i.id ?? i.text)).join('|');\r\n\r\n    this.onChangesValueEvent.emit({ text: this.textInput ?? '', items: selected });\r\n  }\r\n\r\n  getSelectedItems(): FilterItemInputList[] {\r\n    const selectedItems: FilterItemInputList[] = [];\r\n    if (!this.filterData) { return selectedItems; }\r\n    for (const group of this.filterData) {\r\n      if (!group.values) { continue; }\r\n      for (const v of group.values) {\r\n        if (v && v.checked) {\r\n          selectedItems.push(v);\r\n        }\r\n      }\r\n    }\r\n    return selectedItems;\r\n  }\r\n}\r\n","<div class=\"container-general\" [id]=\"componentId\">\r\n    @if (labelSuperior) {\r\n    <div class=\"container-label-sup\" [ngClass]=\"{\r\n        'disabled': disabled\r\n    }\">\r\n        <span class=\"\">{{labelSuperior}}</span>\r\n        @if(!disabled && showHelpText){\r\n        <ius-icon-md iconName=\"icon-help\" class=\"icon-color-help\"></ius-icon-md>\r\n        }\r\n        <span>:</span>\r\n    </div>\r\n    }\r\n    <div class=\"container-textfield\" [ngClass]=\"{\r\n        'disabled': disabled,\r\n        'focused': isFocused\r\n    }\" (click)=\"onFocus()\">\r\n        @if (iconInput) {\r\n        <ius-icon-md [iconName]=\"iconInput\" class=\"icon-color\"></ius-icon-md>\r\n        }\r\n        <input [type]=\"inputType\" [(ngModel)]=\"textInput\" readonly [placeholder]=\"labelInput\" [disabled]=\"disabled\"\r\n            [maxlength]=\"maxlenght ?? null\" (focus)=\"onFocus()\" (blur)=\"onBlur()\"\r\n            (drop)=\"onDropBlock($event)\" (dragover)=\"onDragOverBlock($event)\">\r\n        <div class=\"cnt-icon-right\">\r\n            @if(!showList){\r\n            <ius-icon-md iconName=\"icon-keyboard-arrow-down\" class=\"icon-arrows\"></ius-icon-md>\r\n            }@else{\r\n            <div (click)=\"closeList($event)\" style=\"height: 20px;\">\r\n                <ius-icon-md iconName=\"icon-keyboard-arrow-up\" class=\"icon-arrows\"></ius-icon-md>\r\n            </div>\r\n            }\r\n        </div>\r\n    </div>\r\n    @if (showList) {\r\n    <div class=\"container-list \">\r\n        <div class=\"ctn-items scrollable-small\">\r\n            @for (data of filterData; track $index) {\r\n            <button class=\"item-list\" (click)=\"selectedData(data)\">\r\n                <span class=\"tx-item body-b color-pry\">{{data.title}}</span>\r\n                <ius-icon-sm iconName=\"icon-arrow-forward-ios\" class=\"color-pry\"></ius-icon-sm>\r\n            </button>\r\n            }\r\n        </div>\r\n        @if(filterDataSelected){\r\n        <div class=\"separator\"></div>\r\n        <div class=\"ctn-items scrollable-small\">\r\n            @for (item of filterDataSelected.values; track $index) {\r\n            <div class=\"item-check\" (click)=\"selectedItem(item)\">\r\n                <ius-checkbox [checked]=\"item.checked\" (click)=\"$event.stopPropagation(); selectedItem(item)\"></ius-checkbox>\r\n                <span class=\"tx-item body-b color-pry\">{{item.text}}</span>\r\n            </div>\r\n            }\r\n        </div>\r\n        }\r\n    </div>\r\n    }\r\n</div>"]}
@@ -2520,16 +2520,28 @@ class InputSelectComponent {
2520
2520
  this.onChangesValueEvent = new EventEmitter();
2521
2521
  this.onEnterKey = new EventEmitter();
2522
2522
  }
2523
- //Esta funcion permite que el se cierre el listado si el usuario da click en otro lado fuera del componente
2523
+ //Esta funcion permite que se cierre el listado si el usuario da click en otro lado fuera del componente
2524
2524
  onClickOutside(event) {
2525
2525
  if (!this.hasClickedInside) {
2526
2526
  return;
2527
2527
  }
2528
2528
  const target = event.target;
2529
2529
  const container = document.getElementById(this.componentId);
2530
+ const containerTextfield = container?.querySelector('.container-textfield');
2531
+ const containerList = container?.querySelector('.container-list');
2532
+ // 1. Cierra la lista si el click está completamente fuera del componente
2530
2533
  if (container && !container.contains(target)) {
2531
2534
  this.closeList();
2532
2535
  }
2536
+ // 2. Si el click está dentro del componente pero
2537
+ // NO está ni en el textfield ni en la lista, también cierra
2538
+ else if (containerTextfield && containerList) {
2539
+ const clickEnTextfield = containerTextfield.contains(target);
2540
+ const clickEnLista = containerList.contains(target);
2541
+ if (!clickEnTextfield && !clickEnLista) {
2542
+ this.closeList();
2543
+ }
2544
+ }
2533
2545
  }
2534
2546
  closeList(event) {
2535
2547
  if (event) {
@@ -4930,14 +4942,18 @@ class InputSelectFilterComponent {
4930
4942
  this.inputType = 'text';
4931
4943
  this.onChangesValueEvent = new EventEmitter();
4932
4944
  this.onEnterKey = new EventEmitter();
4945
+ /** Firma de los ítems seleccionados para detectar cambios externos (reset, etc.) */
4946
+ this.lastSelectedSignature = '';
4933
4947
  }
4934
- set filterData(value) {
4935
- this._filterData = value;
4936
- // cada vez que cambie desde afuera recalculo el texto
4937
- this.updateTextInputFromSelected();
4938
- }
4939
- get filterData() {
4940
- return this._filterData;
4948
+ // 🔍 Se ejecuta en cada ciclo de detección de cambios
4949
+ ngDoCheck() {
4950
+ const selectedItems = this.getSelectedItems();
4951
+ const newSignature = selectedItems.map(i => (i.id ?? i.text)).join('|');
4952
+ if (newSignature !== this.lastSelectedSignature) {
4953
+ this.lastSelectedSignature = newSignature;
4954
+ // Actualiza el texto en el input cada vez que cambia la selección desde afuera o desde adentro
4955
+ this.textInput = selectedItems.map(i => i.text).join(', ');
4956
+ }
4941
4957
  }
4942
4958
  //Esta funcion permite que el se cierre el listado si el usuario da click en otro lado fuera del componente
4943
4959
  onClickOutside(event) {
@@ -5005,28 +5021,11 @@ class InputSelectFilterComponent {
5005
5021
  selectedItem(data) {
5006
5022
  data.checked = !data.checked;
5007
5023
  this.itemSelected = data;
5008
- const selected = this.updateTextInputFromSelected();
5024
+ const selected = this.getSelectedItems();
5025
+ this.textInput = selected.map(i => i.text).join(', ');
5026
+ this.lastSelectedSignature = selected.map(i => (i.id ?? i.text)).join('|');
5009
5027
  this.onChangesValueEvent.emit({ text: this.textInput ?? '', items: selected });
5010
5028
  }
5011
- updateTextInputFromSelected() {
5012
- const selectedItems = [];
5013
- if (!this.filterData) {
5014
- this.textInput = '';
5015
- return selectedItems;
5016
- }
5017
- for (const group of this.filterData) {
5018
- if (!group.values) {
5019
- continue;
5020
- }
5021
- for (const v of group.values) {
5022
- if (v && v.checked) {
5023
- selectedItems.push(v);
5024
- }
5025
- }
5026
- }
5027
- this.textInput = selectedItems.map(i => i.text).join(', ');
5028
- return selectedItems;
5029
- }
5030
5029
  getSelectedItems() {
5031
5030
  const selectedItems = [];
5032
5031
  if (!this.filterData) {