@progressio_resources/gravity-design-system 3.3.17 → 3.3.18
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.
|
@@ -364,40 +364,38 @@ export class GravityDropdownListComponent {
|
|
|
364
364
|
return child ?? '';
|
|
365
365
|
}
|
|
366
366
|
inputDisplayValue() {
|
|
367
|
-
if (this.selectedItems
|
|
367
|
+
if (!this.selectedItems?.length)
|
|
368
368
|
return '';
|
|
369
|
-
const labels = [];
|
|
370
369
|
const getValue = (item) => this.config ? item[this.config.value] : item;
|
|
371
370
|
const getLabel = (item) => {
|
|
372
371
|
const baseLabel = this.config ? item[this.config.label] : item;
|
|
373
|
-
|
|
374
|
-
|
|
375
|
-
|
|
376
|
-
networkCode = ` (${item.network.code})`;
|
|
377
|
-
}
|
|
378
|
-
}
|
|
372
|
+
const networkCode = (item.network?.code && (item.network_id !== item.currency_id || item.children || item.is_ERC20))
|
|
373
|
+
? ` (${item.network.code})`
|
|
374
|
+
: '';
|
|
379
375
|
return baseLabel + networkCode;
|
|
380
376
|
};
|
|
381
|
-
this.items
|
|
377
|
+
if (!this.items?.length) {
|
|
378
|
+
return this.selectedItems.map(getLabel).join(', ');
|
|
379
|
+
}
|
|
380
|
+
const labels = [];
|
|
381
|
+
for (const parent of this.items) {
|
|
382
382
|
if (parent.children?.length) {
|
|
383
383
|
const allChildrenSelected = parent.children.every(child => this.selectedItems.some(sel => getValue(sel) === getValue(child)));
|
|
384
384
|
if (allChildrenSelected) {
|
|
385
385
|
labels.push(getLabel(parent));
|
|
386
386
|
}
|
|
387
387
|
else {
|
|
388
|
-
parent.children
|
|
388
|
+
for (const child of parent.children) {
|
|
389
389
|
if (this.selectedItems.some(sel => getValue(sel) === getValue(child))) {
|
|
390
390
|
labels.push(getLabel(child));
|
|
391
391
|
}
|
|
392
|
-
}
|
|
392
|
+
}
|
|
393
393
|
}
|
|
394
394
|
}
|
|
395
|
-
else {
|
|
396
|
-
|
|
397
|
-
labels.push(getLabel(parent));
|
|
398
|
-
}
|
|
395
|
+
else if (this.selectedItems.some(sel => getValue(sel) === getValue(parent))) {
|
|
396
|
+
labels.push(getLabel(parent));
|
|
399
397
|
}
|
|
400
|
-
}
|
|
398
|
+
}
|
|
401
399
|
return labels.join(', ');
|
|
402
400
|
}
|
|
403
401
|
clearSearch() {
|
|
@@ -464,4 +462,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
|
|
|
464
462
|
type: HostListener,
|
|
465
463
|
args: ['document:click', ['$event']]
|
|
466
464
|
}] } });
|
|
467
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-dropdown-list.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChange,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {GravityIconComponent} from \"../gravity-icon/gravity-icon.component\";\nimport {FilterByPipe} from \"./filter-by.pipe\";\n\n@Component({\n  selector: 'gravity-dropdown-list',\n  templateUrl: './gravity-dropdown-list.component.html',\n  styleUrls: ['./gravity-dropdown-list.component.scss'],\n  providers: [FilterByPipe]\n})\nexport class GravityDropdownListComponent implements OnChanges {\n  @Input()\n  get dropdownState(): boolean {\n    return this.dropdownOpened;\n  }\n\n  set dropdownState(value: boolean) {\n    this.dropdownOpened = value;\n  }\n\n  @Output() dropdownStateChange = new EventEmitter<boolean>();\n  @Output('response') public selectedItemsResponse: EventEmitter<any[] | any> = new EventEmitter();\n\n  // Component features\n  @Input() public clearable: boolean = true;\n  @Input() public config?: { label: string; value: string; };\n  @Input() public currentLang: string = 'en';\n  @Input() public customValues: Array<any> | any;\n  @Input() public cypressTag: string;\n  @Input() public hasError: boolean = false;\n  @Input() public iconLeft: string;\n  @Input() public isCurrency: boolean = false;\n  @Input() public isDisabled: boolean = false;\n  @Input() public isReadonly: boolean = false;\n  @Input() public items: Array<any>;\n  @Input() public label: string;\n  @Input() public multiple: boolean = false;\n  @Input() public placeholder: string;\n  @Input() public required: boolean = false;\n  @Input() public supportText: string;\n\n  // Appearance settings\n  @Input() public labelSize: 'sm' | 'md' | 'lg' = 'sm';\n  @Input() public size: 'sm' | 'md' | 'lg' | 'xl' = 'md';\n  @Input() public inputType: 'field' | 'label' = 'field';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\n\n\n  @ViewChild('searchInput')\n  set watch(searchInput: ElementRef<HTMLInputElement>) {\n    if (searchInput) {\n      searchInput.nativeElement.focus({preventScroll: true});\n    }\n  };\n\n  public availableOptions: any[] = [];\n  public dropdownOpened: boolean = false;\n  public searchText: string = '';\n  public selectedItems: any[] = [];\n  public openChildrenMap = new Map<any, boolean>();\n\n  constructor(private readonly filterByPipe: FilterByPipe, private _eref: ElementRef) {\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['items']?.currentValue) {\n      this.availableOptions = this.items;\n    }\n\n    if (changes['customValues']) {\n      const changeItem: SimpleChange = changes['customValues'];\n      const currentValue = changeItem?.currentValue;\n\n      const findOptionRecursively = (items: any[], value: any): any | null => {\n        for (const item of items) {\n          const itemValue = this.config ? item[this.config.value] : item;\n          if (itemValue == value) {\n            return item;\n          }\n\n          if (item.children) {\n            const foundChild = findOptionRecursively(item.children, value);\n            if (foundChild) return foundChild;\n          }\n        }\n        return null;\n      };\n\n      this.selectedItems = [];\n\n      if (Array.isArray(currentValue)) {\n        currentValue.forEach((val: any) => {\n          const found = findOptionRecursively(this.items, val);\n          if (found && !this.selectedItems.includes(found)) {\n            this.selectedItems.push(found);\n          }\n        });\n      } else if (currentValue != null && currentValue !== '') {\n        const found = findOptionRecursively(this.items, currentValue);\n        if (found) {\n          this.selectedItems = [found];\n        }\n      } else if (!currentValue && !changeItem.firstChange) {\n        this.clearSelection();\n      }\n    }\n  }\n\n  public getStatus(): string {\n    if (this.isDisabled) {\n      return 'disabled';\n    } else if (this.isReadonly) {\n      return 'readonly';\n    } else if (this.hasError) {\n      return 'error';\n    } else if (this.dropdownOpened) {\n      return 'open';\n    } else if (this.selectedItems.length > 0) {\n      return 'selected';\n    } else {\n      return 'active';\n    }\n  }\n\n  public isIconLeftNew(): boolean {\n    if (this.iconLeft) {\n      return GravityIconComponent.isNewIcon(this.iconLeft);\n    }\n\n    return false;\n  }\n\n  public toggleDropdown(): void {\n    if (!this.isDisabled && !this.isReadonly) {\n      this.dropdownOpened = !this.dropdownOpened;\n      this.dropdownStateChange.emit(this.dropdownOpened);\n\n      if (!this.dropdownOpened) {\n        if (this.multiple) {\n          if (this.selectedItems?.length > 0) {\n            this.selectedItemsResponse.emit(this.selectedItems);\n          }\n        } else {\n          if (this.selectedItems[0]) {\n            this.selectedItemsResponse.emit(this.selectedItems[0]);\n          }\n        }\n        this.searchText = '';\n        this.availableOptions = this.items;\n      } else {\n        this.selectedItems?.forEach(sel => {\n          this.items?.forEach(parent => {\n            if (parent.children?.includes(sel)) {\n              this.openChildrenMap.set(parent, true);\n            }\n          });\n        });\n      }\n    }\n  }\n\n  public selectItem(itemToAdd: any): void {\n    const isParent = !!itemToAdd.children;\n\n    if (this.multiple) {\n      const isSelected = this.checkIfSelected(itemToAdd);\n\n      if (isSelected) {\n        this.selectedItems = this.selectedItems.filter(i =>\n          (this.config ? i[this.config.value] : i) !==\n          (this.config ? itemToAdd[this.config.value] : itemToAdd)\n        );\n\n        if (isParent) {\n          itemToAdd.children.forEach(child => {\n            this.selectedItems = this.selectedItems.filter(i => i !== child);\n          });\n        } else {\n          this.items.forEach(parent => {\n            if (parent.children?.includes(itemToAdd)) {\n              const anySelected = parent.children.some(child => this.checkIfSelected(child));\n              const allSelected = parent.children.every(child => this.checkIfSelected(child));\n              if (!anySelected) {\n                this.selectedItems = this.selectedItems.filter(i => i !== parent);\n              } else if (allSelected && !this.checkIfSelected(parent)) {\n                this.selectedItems.push(parent);\n              }\n            }\n          });\n        }\n\n      } else {\n        this.selectedItems.push(itemToAdd);\n\n        if (isParent) {\n          itemToAdd.children.forEach(child => {\n            if (!this.checkIfSelected(child)) {\n              this.selectedItems.push(child);\n            }\n          });\n        } else {\n          this.items.forEach(parent => {\n            if (parent.children?.includes(itemToAdd)) {\n              const allSelected = parent.children.every(child => this.checkIfSelected(child));\n              if (allSelected && !this.checkIfSelected(parent)) {\n                this.selectedItems.push(parent);\n              }\n            }\n          });\n        }\n      }\n    } else {\n      this.selectedItems = [itemToAdd];\n      this.toggleDropdown();\n    }\n  }\n\n  public isPartiallySelected(item: any): boolean {\n    if (!item.children?.length) return false;\n\n    const selectedChildren = item.children.filter(child => this.checkIfSelected(child));\n    return selectedChildren.length > 0 && selectedChildren.length < item.children.length;\n  }\n\n  public checkIfSelected(item?: any): boolean {\n    const getValue = (el: any) => this.config ? el[this.config.value] : el;\n\n    if (item) {\n      return this.selectedItems.some(selected => getValue(selected) === getValue(item));\n    }\n\n    const flatten = this.flattenItems(this.availableOptions);\n    return flatten.length > 0 && flatten.every(option =>\n      this.selectedItems.some(selected => getValue(selected) === getValue(option))\n    );\n  }\n\n  public selectAllItems(event: MouseEvent): void {\n    event.stopPropagation();\n    const flatten = this.flattenItems(this.availableOptions);\n    const getValue = (el: any) => this.config ? el[this.config.value] : el;\n\n    const allSelected = flatten.every(option =>\n      this.selectedItems.some(selected => getValue(selected) === getValue(option))\n    );\n\n    if (allSelected) {\n      this.selectedItems = this.selectedItems.filter(selected =>\n        !flatten.some(option => getValue(selected) === getValue(option))\n      );\n    } else {\n      flatten.forEach(option => {\n        if (!this.selectedItems.some(selected => getValue(selected) === getValue(option))) {\n          this.selectedItems.push(option);\n        }\n      });\n    }\n  }\n\n  private flattenItems(items: any[]): any[] {\n    return items.reduce((acc, item) => {\n      acc.push(item);\n      if (item.children?.length) {\n        acc.push(...this.flattenItems(item.children));\n      }\n      return acc;\n    }, []);\n  }\n\n  public clearSelection(): void {\n    this.selectedItems = [];\n\n    if (this.multiple) {\n      this.selectedItemsResponse.emit(this.selectedItems);\n    } else {\n      this.selectedItemsResponse.emit(null);\n    }\n  }\n\n  private openParents(item: any, items: any[]): void {\n    for (const parent of items) {\n      if (parent.children?.includes(item)) {\n        this.openChildrenMap.set(parent, true);\n        this.openParents(parent, this.items);\n        break;\n      } else if (parent.children) {\n        this.openParents(item, parent.children);\n      }\n    }\n  }\n\n  public filterItems(): void {\n    const search = this.searchText?.toLowerCase();\n    this.openChildrenMap.clear();\n\n    const filterRecursive = (items: any[]): any[] => {\n      return items\n        .filter(item => {\n          const label = this.config ? item[this.config.label] : item;\n          const match = label?.toString().toLowerCase().includes(search);\n\n          if (item.children) {\n            const childMatches = filterRecursive(item.children);\n            if (childMatches.length > 0) {\n              this.openChildrenMap.set(item, true);\n            }\n            return match || childMatches.length > 0;\n          }\n\n          if (match) {\n            this.openParents(item, this.items);\n          }\n\n          return match;\n        });\n    };\n\n    this.availableOptions = filterRecursive(this.items);\n  }\n\n  @HostListener('document:click', ['$event']) onDocumentClick($event: PointerEvent): void {\n    if (!this._eref.nativeElement.contains($event.target) && this.dropdownOpened) {\n      if (this.multiple) {\n        if (this.selectedItems?.length > 0) {\n          this.selectedItemsResponse.emit(this.selectedItems);\n        }\n      } else {\n        if (this.selectedItems[0]) {\n          this.selectedItemsResponse.emit(this.selectedItems[0]);\n        }\n      }\n\n      this.searchText = '';\n      this.dropdownOpened = false;\n      this.availableOptions = this.items;\n      this.dropdownStateChange.emit(this.dropdownOpened);\n    }\n  }\n\n  public getCurrencyIconSize(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'sm-16';\n      case 'lg':\n        return 'lg-32';\n      case 'xl':\n        return 'xl-40';\n      default:\n        return 'md-24';\n    }\n  }\n\n  public getSpacingClass(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'gravity-margin-right-xxs';\n      case 'md':\n        return 'gravity-margin-right-xs';\n      case 'lg':\n        return 'gravity-margin-right-sm';\n      case 'xl':\n        return 'gravity-margin-right-md';\n      default:\n        return '';\n    }\n  }\n\n  public getMultilevelSpacingClass(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'gravity-margin-right-md';\n      case 'md':\n        return 'gravity-margin-right-lg';\n      default:\n        return '';\n    }\n  }\n\n  public getLabelText(): string {\n    let result: string = '';\n    if (this.selectedItems.length === 0) {\n      result = this.label;\n    } else {\n      this.selectedItems.forEach((item, i) => {\n        let displayValue = this.config ? item[this.config.label] : item;\n        let separator = i !== this.selectedItems.length - 1 ? ',' : '';\n        result = result + displayValue + separator;\n      });\n    }\n    return result;\n  }\n\n  public isChildrenOpen(item: any): boolean {\n    return this.openChildrenMap.get(item) === true;\n  }\n\n  public toggleChildren(item: any, event: MouseEvent): void {\n    event.stopPropagation();\n    const current = this.openChildrenMap.get(item) || false;\n    this.openChildrenMap.set(item, !current);\n  }\n\n  public getDisplayValue(child: any, config?: { label: string }): string {\n    if (config?.label && typeof child === 'object' && child !== null) {\n      return child[config.label] ?? '';\n    }\n    return child ?? '';\n  }\n\n  public inputDisplayValue(): string {\n    if (this.selectedItems.length === 0) return '';\n\n    const labels: string[] = [];\n    const getValue = (item: any) => this.config ? item[this.config.value] : item;\n\n    const getLabel = (item: any): string => {\n      const baseLabel = this.config ? item[this.config.label] : item;\n      let networkCode = '';\n      if (item.network && item.network.code) {\n        if (item.network_id !== item.currency_id || item.children || item.is_ERC20) {\n          networkCode = ` (${item.network.code})`;\n        }\n      }\n      return baseLabel + networkCode;\n    };\n\n    this.items.forEach(parent => {\n      if (parent.children?.length) {\n        const allChildrenSelected = parent.children.every(child =>\n            this.selectedItems.some(sel => getValue(sel) === getValue(child))\n        );\n\n        if (allChildrenSelected) {\n          labels.push(getLabel(parent));\n        } else {\n          parent.children.forEach(child => {\n            if (this.selectedItems.some(sel => getValue(sel) === getValue(child))) {\n              labels.push(getLabel(child));\n            }\n          });\n        }\n      } else {\n        if (this.selectedItems.some(sel => getValue(sel) === getValue(parent))) {\n          labels.push(getLabel(parent));\n        }\n      }\n    });\n\n    return labels.join(', ');\n  }\n\n  public clearSearch(): void {\n    this.searchText = '';\n    this.availableOptions = this.items;\n  }\n}\n","<ng-container *ngIf=\"inputType === 'field'\">\n  <label class=\"hr-label sm-bold {{getStatus()}}\" *ngIf=\"label\">\n    {{ label }} <span *ngIf=\"required || hasError\">*</span>\n  </label>\n</ng-container>\n\n<div class=\"gravity-input-field {{inputType}}-{{labelSize}} {{size}} {{width}}-width {{getStatus()}}\"\n     [attr.data-cy]=\"cypressTag\" (click)=\"toggleDropdown()\">\n\n  <ng-container *ngIf=\"inputType === 'field'\">\n    <gravity-icon class=\"left\" [iconName]=\"iconLeft\" [iconSize]=\"isIconLeftNew() ? 'md-16' : null\"\n                  *ngIf=\"(iconLeft && !dropdownOpened) || (iconLeft && !items)\"></gravity-icon>\n\n    <gravity-icon class=\"search-icon\" [iconName]=\"'search'\" [iconSize]=\"'sm-12'\"\n                  *ngIf=\"(dropdownOpened && items)\"></gravity-icon>\n\n    <input autocomplete=\"off\"\n           class=\"hr-label {{size}}-regular {{getStatus()}}\"\n           (focus)=\"searchText = ''\" [readonly]=\"!dropdownOpened || !items\"\n           (input)=\"filterItems(); dropdownOpened = true\"\n           [attr.data-cy]=\"cypressTag + '_search_input'\"\n           #searchInput\n           [ngModel]=\"(dropdownOpened && items) ? searchText : inputDisplayValue()\"\n           (ngModelChange)=\"searchText = $event\"\n           placeholder=\"{{(dropdownOpened && items) ? (currentLang == 'es' ? 'Buscar' : 'Search input') : (placeholder ? placeholder : label)}}\">\n\n    <gravity-icon class=\"right\" [iconName]=\"dropdownOpened ? 'arrow-up': 'arrow-down'\"\n                  [iconSize]=\"'md-16'\" *ngIf=\"!isReadonly && searchText.length == 0\"></gravity-icon>\n\n    <gravity-icon class=\"right\" [iconName]=\"'unsuccess'\" (click)=\"clearSearch()\"\n                  [iconSize]=\"'md-16'\" *ngIf=\"dropdownOpened && searchText.length > 0\"></gravity-icon>\n  </ng-container>\n\n  <ng-container *ngIf=\"inputType === 'label'\">\n    <gravity-dropdown-label (onClickLabel)=\"toggleDropdown()\" [label]=\"getLabelText()\"\n                            [size]=\"labelSize\" [isOpen]=\"dropdownOpened\">\n    </gravity-dropdown-label>\n  </ng-container>\n\n  <div class=\"dropdown-panel {{getStatus()}}\" (click)=\"$event.stopPropagation()\" *ngIf=\"items && dropdownOpened\"\n       [attr.data-cy]=\"cypressTag + '_panel'\">\n    <div class=\"search-input\" *ngIf=\"inputType === 'label'\">\n      <gravity-icon class=\"search-icon\" [iconName]=\"'search'\" [iconSize]=\"'sm-12'\"></gravity-icon>\n      <input autocomplete=\"off\" class=\"hr-label {{size}}-regular\" (input)=\"filterItems()\"\n             [attr.data-cy]=\"cypressTag + '_search_input'\" #searchInput\n             [(ngModel)]=\"searchText\" placeholder=\"{{currentLang == 'es' ? 'Buscar' : 'Search input'}}\">\n      <gravity-icon class=\"pointer reset-icon\" (click)=\"searchText = ''; filterItems()\" [iconName]=\"'unsuccess'\"\n                    [iconSize]=\"'sm-12'\" *ngIf=\"searchText?.length > 0\"></gravity-icon>\n    </div>\n\n    <div class=\"select-all\" *ngIf=\"multiple && availableOptions.length != 0\">\n      <gravity-checkbox [ngClass]=\"getSpacingClass(size)\"\n                        (click)=\"selectAllItems($event)\"\n                        [checked]=\"checkIfSelected()\"></gravity-checkbox>\n      <p class=\"hr-label {{size}}-regular\">{{ currentLang == 'es' ? 'Seleccionar todo' : 'Select all' }}</p>\n    </div>\n\n    <div class=\"items-container\">\n      <div class=\"items\">\n        <div class=\"item-container\" *ngFor=\"let item of availableOptions\"\n             [attr.data-cy]=\"isCurrency ? 'currency_option_' + item.currency_id : ''\">\n          <div class=\"hr-label item {{size}}-regular pointer\"\n               [class.selected]=\"checkIfSelected(item)\"\n               [class.partial]=\"isPartiallySelected(item)\"\n               (click)=\"item.children?.length ? multiple ?selectItem(item) : toggleChildren(item, $event) : selectItem(item)\">\n            <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getSpacingClass(size)\"\n                              [isPartial]=\"isPartiallySelected(item)\"\n                              [checked]=\"checkIfSelected(item)\"></gravity-checkbox>\n            <gravity-currency *ngIf=\"isCurrency\" [ngClass]=\"getSpacingClass(size)\" [size]=\"getCurrencyIconSize(size)\"\n                              [currency]=\"{currency_id: item.currency_id}\"></gravity-currency>\n            <div [ngClass]=\"getSpacingClass(size)\">{{ getDisplayValue(item, config) }}</div>\n            <gravity-network-pill *ngIf=\"isCurrency && !item.children?.length\"\n                                  [network]=\"{ iso: item.network?.code, id: item.network?.id }\"></gravity-network-pill>\n            <gravity-icon style=\"margin-left: auto\" (click)=\"toggleChildren(item, $event)\"\n                          [iconName]=\"isChildrenOpen(item) ? 'arrow-up' : 'arrow-down'\"\n                          [iconSize]=\"'md-16'\" *ngIf=\"item.children?.length\"></gravity-icon>\n          </div>\n\n          <div class=\"item-children\" *ngIf=\"item.children?.length && isChildrenOpen(item)\">\n            <ng-container *ngFor=\"let child of item.children\">\n              <div class=\"hr-label item {{size}}-regular pointer\" [ngClass]=\"{'multiple' : multiple}\"\n                   [class.selected]=\"checkIfSelected(child)\"\n                   (click)=\"selectItem(child)\">\n                <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getMultilevelSpacingClass(size)\"\n                                  [checked]=\"checkIfSelected(child)\"></gravity-checkbox>\n                <gravity-currency *ngIf=\"isCurrency\" [ngClass]=\"getSpacingClass(size)\"\n                                  [size]=\"getCurrencyIconSize(size)\"\n                                  [currency]=\"{currency_id: child.currency_id}\"></gravity-currency>\n                <div [ngClass]=\"getSpacingClass(size)\">{{ getDisplayValue(child, config) }}</div>\n                <gravity-network-pill *ngIf=\"isCurrency\"\n                                      [network]=\"{ iso: child.network?.code, id: child.network?.id }\"></gravity-network-pill>\n              </div>\n            </ng-container>\n          </div>\n        </div>\n        <div class=\"item-container\">\n          <div class=\"hr-label item {{size}}-bold no-results\" *ngIf=\"availableOptions.length === 0\">\n            {{ currentLang == 'es' ? 'Sin resultados encontrados' : 'No results found.' }}\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"dropdown-footer\" *ngIf=\"selectedItems.length > 0 && availableOptions.length !== 0\" [class.not-clearable]=\"!clearable\">\n        <gravity-link *ngIf=\"clearable\"\n          (click)=\"clearSelection()\"\n          [fontClass]=\"'hr-label sm-regular'\"\n          [attr.data-cy]=\"cypressTag + '_clear'\"\n          [linkText]=\"currentLang == 'es' ? 'Limpiar' : 'Clear selection'\">\n        </gravity-link>\n\n        <gravity-link *ngIf=\"availableOptions.length != 0\"\n                      [fontClass]=\"'hr-label sm-bold'\"\n                      [attr.data-cy]=\"cypressTag + '_apply'\"\n                      (click)=\"$event.stopPropagation(); toggleDropdown()\"\n                      [linkText]=\"currentLang == 'es' ? 'Aplicar' : 'Apply'\">\n        </gravity-link>\n    </div>\n    <div class=\"dropdown-footer no-results\" *ngIf=\"availableOptions.length === 0\" [class.not-clearable]=\"!clearable\">\n        <gravity-link *ngIf=\"clearable\"\n                      (click)=\"clearSearch()\"\n                      [fontClass]=\"'hr-label sm-regular'\"\n                      [attr.data-cy]=\"cypressTag + '_clear_search'\"\n                      [linkText]=\"currentLang == 'es' ? 'Limpiar búsqueda' : 'Clear search'\">\n        </gravity-link>\n    </div>\n  </div>\n\n  <section class=\"external-content\" *ngIf=\"!items && dropdownOpened\" (click)=\"$event.stopPropagation()\">\n    <ng-content></ng-content>\n  </section>\n</div>\n\n<ng-container *ngIf=\"inputType === 'field'\">\n  <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\" *ngIf=\"supportText\">\n    {{ supportText }}\n  </p>\n  <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\"\n     *ngIf=\"!supportText && getStatus() == 'active' && selectedItems.length == 0 && required\">\n    {{ currentLang == 'es' ? 'Requerido' : 'Required' }}\n  </p>\n</ng-container>"]}
|
|
465
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-dropdown-list.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-dropdown-list/gravity-dropdown-list.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n  Component,\n  ElementRef,\n  EventEmitter,\n  HostListener,\n  Input,\n  OnChanges,\n  Output,\n  SimpleChange,\n  SimpleChanges,\n  ViewChild\n} from '@angular/core';\nimport {GravityIconComponent} from \"../gravity-icon/gravity-icon.component\";\nimport {FilterByPipe} from \"./filter-by.pipe\";\n\n@Component({\n  selector: 'gravity-dropdown-list',\n  templateUrl: './gravity-dropdown-list.component.html',\n  styleUrls: ['./gravity-dropdown-list.component.scss'],\n  providers: [FilterByPipe]\n})\nexport class GravityDropdownListComponent implements OnChanges {\n  @Input()\n  get dropdownState(): boolean {\n    return this.dropdownOpened;\n  }\n\n  set dropdownState(value: boolean) {\n    this.dropdownOpened = value;\n  }\n\n  @Output() dropdownStateChange = new EventEmitter<boolean>();\n  @Output('response') public selectedItemsResponse: EventEmitter<any[] | any> = new EventEmitter();\n\n  // Component features\n  @Input() public clearable: boolean = true;\n  @Input() public config?: { label: string; value: string; };\n  @Input() public currentLang: string = 'en';\n  @Input() public customValues: Array<any> | any;\n  @Input() public cypressTag: string;\n  @Input() public hasError: boolean = false;\n  @Input() public iconLeft: string;\n  @Input() public isCurrency: boolean = false;\n  @Input() public isDisabled: boolean = false;\n  @Input() public isReadonly: boolean = false;\n  @Input() public items: Array<any>;\n  @Input() public label: string;\n  @Input() public multiple: boolean = false;\n  @Input() public placeholder: string;\n  @Input() public required: boolean = false;\n  @Input() public supportText: string;\n\n  // Appearance settings\n  @Input() public labelSize: 'sm' | 'md' | 'lg' = 'sm';\n  @Input() public size: 'sm' | 'md' | 'lg' | 'xl' = 'md';\n  @Input() public inputType: 'field' | 'label' = 'field';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\n\n\n  @ViewChild('searchInput')\n  set watch(searchInput: ElementRef<HTMLInputElement>) {\n    if (searchInput) {\n      searchInput.nativeElement.focus({preventScroll: true});\n    }\n  };\n\n  public availableOptions: any[] = [];\n  public dropdownOpened: boolean = false;\n  public searchText: string = '';\n  public selectedItems: any[] = [];\n  public openChildrenMap = new Map<any, boolean>();\n\n  constructor(private readonly filterByPipe: FilterByPipe, private _eref: ElementRef) {\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['items']?.currentValue) {\n      this.availableOptions = this.items;\n    }\n\n    if (changes['customValues']) {\n      const changeItem: SimpleChange = changes['customValues'];\n      const currentValue = changeItem?.currentValue;\n\n      const findOptionRecursively = (items: any[], value: any): any | null => {\n        for (const item of items) {\n          const itemValue = this.config ? item[this.config.value] : item;\n          if (itemValue == value) {\n            return item;\n          }\n\n          if (item.children) {\n            const foundChild = findOptionRecursively(item.children, value);\n            if (foundChild) return foundChild;\n          }\n        }\n        return null;\n      };\n\n      this.selectedItems = [];\n\n      if (Array.isArray(currentValue)) {\n        currentValue.forEach((val: any) => {\n          const found = findOptionRecursively(this.items, val);\n          if (found && !this.selectedItems.includes(found)) {\n            this.selectedItems.push(found);\n          }\n        });\n      } else if (currentValue != null && currentValue !== '') {\n        const found = findOptionRecursively(this.items, currentValue);\n        if (found) {\n          this.selectedItems = [found];\n        }\n      } else if (!currentValue && !changeItem.firstChange) {\n        this.clearSelection();\n      }\n    }\n  }\n\n  public getStatus(): string {\n    if (this.isDisabled) {\n      return 'disabled';\n    } else if (this.isReadonly) {\n      return 'readonly';\n    } else if (this.hasError) {\n      return 'error';\n    } else if (this.dropdownOpened) {\n      return 'open';\n    } else if (this.selectedItems.length > 0) {\n      return 'selected';\n    } else {\n      return 'active';\n    }\n  }\n\n  public isIconLeftNew(): boolean {\n    if (this.iconLeft) {\n      return GravityIconComponent.isNewIcon(this.iconLeft);\n    }\n\n    return false;\n  }\n\n  public toggleDropdown(): void {\n    if (!this.isDisabled && !this.isReadonly) {\n      this.dropdownOpened = !this.dropdownOpened;\n      this.dropdownStateChange.emit(this.dropdownOpened);\n\n      if (!this.dropdownOpened) {\n        if (this.multiple) {\n          if (this.selectedItems?.length > 0) {\n            this.selectedItemsResponse.emit(this.selectedItems);\n          }\n        } else {\n          if (this.selectedItems[0]) {\n            this.selectedItemsResponse.emit(this.selectedItems[0]);\n          }\n        }\n        this.searchText = '';\n        this.availableOptions = this.items;\n      } else {\n        this.selectedItems?.forEach(sel => {\n          this.items?.forEach(parent => {\n            if (parent.children?.includes(sel)) {\n              this.openChildrenMap.set(parent, true);\n            }\n          });\n        });\n      }\n    }\n  }\n\n  public selectItem(itemToAdd: any): void {\n    const isParent = !!itemToAdd.children;\n\n    if (this.multiple) {\n      const isSelected = this.checkIfSelected(itemToAdd);\n\n      if (isSelected) {\n        this.selectedItems = this.selectedItems.filter(i =>\n          (this.config ? i[this.config.value] : i) !==\n          (this.config ? itemToAdd[this.config.value] : itemToAdd)\n        );\n\n        if (isParent) {\n          itemToAdd.children.forEach(child => {\n            this.selectedItems = this.selectedItems.filter(i => i !== child);\n          });\n        } else {\n          this.items.forEach(parent => {\n            if (parent.children?.includes(itemToAdd)) {\n              const anySelected = parent.children.some(child => this.checkIfSelected(child));\n              const allSelected = parent.children.every(child => this.checkIfSelected(child));\n              if (!anySelected) {\n                this.selectedItems = this.selectedItems.filter(i => i !== parent);\n              } else if (allSelected && !this.checkIfSelected(parent)) {\n                this.selectedItems.push(parent);\n              }\n            }\n          });\n        }\n\n      } else {\n        this.selectedItems.push(itemToAdd);\n\n        if (isParent) {\n          itemToAdd.children.forEach(child => {\n            if (!this.checkIfSelected(child)) {\n              this.selectedItems.push(child);\n            }\n          });\n        } else {\n          this.items.forEach(parent => {\n            if (parent.children?.includes(itemToAdd)) {\n              const allSelected = parent.children.every(child => this.checkIfSelected(child));\n              if (allSelected && !this.checkIfSelected(parent)) {\n                this.selectedItems.push(parent);\n              }\n            }\n          });\n        }\n      }\n    } else {\n      this.selectedItems = [itemToAdd];\n      this.toggleDropdown();\n    }\n  }\n\n  public isPartiallySelected(item: any): boolean {\n    if (!item.children?.length) return false;\n\n    const selectedChildren = item.children.filter(child => this.checkIfSelected(child));\n    return selectedChildren.length > 0 && selectedChildren.length < item.children.length;\n  }\n\n  public checkIfSelected(item?: any): boolean {\n    const getValue = (el: any) => this.config ? el[this.config.value] : el;\n\n    if (item) {\n      return this.selectedItems.some(selected => getValue(selected) === getValue(item));\n    }\n\n    const flatten = this.flattenItems(this.availableOptions);\n    return flatten.length > 0 && flatten.every(option =>\n      this.selectedItems.some(selected => getValue(selected) === getValue(option))\n    );\n  }\n\n  public selectAllItems(event: MouseEvent): void {\n    event.stopPropagation();\n    const flatten = this.flattenItems(this.availableOptions);\n    const getValue = (el: any) => this.config ? el[this.config.value] : el;\n\n    const allSelected = flatten.every(option =>\n      this.selectedItems.some(selected => getValue(selected) === getValue(option))\n    );\n\n    if (allSelected) {\n      this.selectedItems = this.selectedItems.filter(selected =>\n        !flatten.some(option => getValue(selected) === getValue(option))\n      );\n    } else {\n      flatten.forEach(option => {\n        if (!this.selectedItems.some(selected => getValue(selected) === getValue(option))) {\n          this.selectedItems.push(option);\n        }\n      });\n    }\n  }\n\n  private flattenItems(items: any[]): any[] {\n    return items.reduce((acc, item) => {\n      acc.push(item);\n      if (item.children?.length) {\n        acc.push(...this.flattenItems(item.children));\n      }\n      return acc;\n    }, []);\n  }\n\n  public clearSelection(): void {\n    this.selectedItems = [];\n\n    if (this.multiple) {\n      this.selectedItemsResponse.emit(this.selectedItems);\n    } else {\n      this.selectedItemsResponse.emit(null);\n    }\n  }\n\n  private openParents(item: any, items: any[]): void {\n    for (const parent of items) {\n      if (parent.children?.includes(item)) {\n        this.openChildrenMap.set(parent, true);\n        this.openParents(parent, this.items);\n        break;\n      } else if (parent.children) {\n        this.openParents(item, parent.children);\n      }\n    }\n  }\n\n  public filterItems(): void {\n    const search = this.searchText?.toLowerCase();\n    this.openChildrenMap.clear();\n\n    const filterRecursive = (items: any[]): any[] => {\n      return items\n        .filter(item => {\n          const label = this.config ? item[this.config.label] : item;\n          const match = label?.toString().toLowerCase().includes(search);\n\n          if (item.children) {\n            const childMatches = filterRecursive(item.children);\n            if (childMatches.length > 0) {\n              this.openChildrenMap.set(item, true);\n            }\n            return match || childMatches.length > 0;\n          }\n\n          if (match) {\n            this.openParents(item, this.items);\n          }\n\n          return match;\n        });\n    };\n\n    this.availableOptions = filterRecursive(this.items);\n  }\n\n  @HostListener('document:click', ['$event']) onDocumentClick($event: PointerEvent): void {\n    if (!this._eref.nativeElement.contains($event.target) && this.dropdownOpened) {\n      if (this.multiple) {\n        if (this.selectedItems?.length > 0) {\n          this.selectedItemsResponse.emit(this.selectedItems);\n        }\n      } else {\n        if (this.selectedItems[0]) {\n          this.selectedItemsResponse.emit(this.selectedItems[0]);\n        }\n      }\n\n      this.searchText = '';\n      this.dropdownOpened = false;\n      this.availableOptions = this.items;\n      this.dropdownStateChange.emit(this.dropdownOpened);\n    }\n  }\n\n  public getCurrencyIconSize(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'sm-16';\n      case 'lg':\n        return 'lg-32';\n      case 'xl':\n        return 'xl-40';\n      default:\n        return 'md-24';\n    }\n  }\n\n  public getSpacingClass(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'gravity-margin-right-xxs';\n      case 'md':\n        return 'gravity-margin-right-xs';\n      case 'lg':\n        return 'gravity-margin-right-sm';\n      case 'xl':\n        return 'gravity-margin-right-md';\n      default:\n        return '';\n    }\n  }\n\n  public getMultilevelSpacingClass(size: string) {\n    switch (size) {\n      case 'sm':\n        return 'gravity-margin-right-md';\n      case 'md':\n        return 'gravity-margin-right-lg';\n      default:\n        return '';\n    }\n  }\n\n  public getLabelText(): string {\n    let result: string = '';\n    if (this.selectedItems.length === 0) {\n      result = this.label;\n    } else {\n      this.selectedItems.forEach((item, i) => {\n        let displayValue = this.config ? item[this.config.label] : item;\n        let separator = i !== this.selectedItems.length - 1 ? ',' : '';\n        result = result + displayValue + separator;\n      });\n    }\n    return result;\n  }\n\n  public isChildrenOpen(item: any): boolean {\n    return this.openChildrenMap.get(item) === true;\n  }\n\n  public toggleChildren(item: any, event: MouseEvent): void {\n    event.stopPropagation();\n    const current = this.openChildrenMap.get(item) || false;\n    this.openChildrenMap.set(item, !current);\n  }\n\n  public getDisplayValue(child: any, config?: { label: string }): string {\n    if (config?.label && typeof child === 'object' && child !== null) {\n      return child[config.label] ?? '';\n    }\n    return child ?? '';\n  }\n\n  public inputDisplayValue(): string {\n    if (!this.selectedItems?.length) return '';\n\n    const getValue = (item: any) => this.config ? item[this.config.value] : item;\n\n    const getLabel = (item: any): string => {\n      const baseLabel = this.config ? item[this.config.label] : item;\n      const networkCode = (item.network?.code && (item.network_id !== item.currency_id || item.children || item.is_ERC20))\n          ? ` (${item.network.code})`\n          : '';\n      return baseLabel + networkCode;\n    };\n\n    if (!this.items?.length) {\n      return this.selectedItems.map(getLabel).join(', ');\n    }\n\n    const labels: string[] = [];\n\n    for (const parent of this.items) {\n      if (parent.children?.length) {\n        const allChildrenSelected = parent.children.every(child =>\n            this.selectedItems.some(sel => getValue(sel) === getValue(child))\n        );\n\n        if (allChildrenSelected) {\n          labels.push(getLabel(parent));\n        } else {\n          for (const child of parent.children) {\n            if (this.selectedItems.some(sel => getValue(sel) === getValue(child))) {\n              labels.push(getLabel(child));\n            }\n          }\n        }\n      } else if (this.selectedItems.some(sel => getValue(sel) === getValue(parent))) {\n        labels.push(getLabel(parent));\n      }\n    }\n\n    return labels.join(', ');\n  }\n\n  public clearSearch(): void {\n    this.searchText = '';\n    this.availableOptions = this.items;\n  }\n}\n","<ng-container *ngIf=\"inputType === 'field'\">\n  <label class=\"hr-label sm-bold {{getStatus()}}\" *ngIf=\"label\">\n    {{ label }} <span *ngIf=\"required || hasError\">*</span>\n  </label>\n</ng-container>\n\n<div class=\"gravity-input-field {{inputType}}-{{labelSize}} {{size}} {{width}}-width {{getStatus()}}\"\n     [attr.data-cy]=\"cypressTag\" (click)=\"toggleDropdown()\">\n\n  <ng-container *ngIf=\"inputType === 'field'\">\n    <gravity-icon class=\"left\" [iconName]=\"iconLeft\" [iconSize]=\"isIconLeftNew() ? 'md-16' : null\"\n                  *ngIf=\"(iconLeft && !dropdownOpened) || (iconLeft && !items)\"></gravity-icon>\n\n    <gravity-icon class=\"search-icon\" [iconName]=\"'search'\" [iconSize]=\"'sm-12'\"\n                  *ngIf=\"(dropdownOpened && items)\"></gravity-icon>\n\n    <input autocomplete=\"off\"\n           class=\"hr-label {{size}}-regular {{getStatus()}}\"\n           (focus)=\"searchText = ''\" [readonly]=\"!dropdownOpened || !items\"\n           (input)=\"filterItems(); dropdownOpened = true\"\n           [attr.data-cy]=\"cypressTag + '_search_input'\"\n           #searchInput\n           [ngModel]=\"(dropdownOpened && items) ? searchText : inputDisplayValue()\"\n           (ngModelChange)=\"searchText = $event\"\n           placeholder=\"{{(dropdownOpened && items) ? (currentLang == 'es' ? 'Buscar' : 'Search input') : (placeholder ? placeholder : label)}}\">\n\n    <gravity-icon class=\"right\" [iconName]=\"dropdownOpened ? 'arrow-up': 'arrow-down'\"\n                  [iconSize]=\"'md-16'\" *ngIf=\"!isReadonly && searchText.length == 0\"></gravity-icon>\n\n    <gravity-icon class=\"right\" [iconName]=\"'unsuccess'\" (click)=\"clearSearch()\"\n                  [iconSize]=\"'md-16'\" *ngIf=\"dropdownOpened && searchText.length > 0\"></gravity-icon>\n  </ng-container>\n\n  <ng-container *ngIf=\"inputType === 'label'\">\n    <gravity-dropdown-label (onClickLabel)=\"toggleDropdown()\" [label]=\"getLabelText()\"\n                            [size]=\"labelSize\" [isOpen]=\"dropdownOpened\">\n    </gravity-dropdown-label>\n  </ng-container>\n\n  <div class=\"dropdown-panel {{getStatus()}}\" (click)=\"$event.stopPropagation()\" *ngIf=\"items && dropdownOpened\"\n       [attr.data-cy]=\"cypressTag + '_panel'\">\n    <div class=\"search-input\" *ngIf=\"inputType === 'label'\">\n      <gravity-icon class=\"search-icon\" [iconName]=\"'search'\" [iconSize]=\"'sm-12'\"></gravity-icon>\n      <input autocomplete=\"off\" class=\"hr-label {{size}}-regular\" (input)=\"filterItems()\"\n             [attr.data-cy]=\"cypressTag + '_search_input'\" #searchInput\n             [(ngModel)]=\"searchText\" placeholder=\"{{currentLang == 'es' ? 'Buscar' : 'Search input'}}\">\n      <gravity-icon class=\"pointer reset-icon\" (click)=\"searchText = ''; filterItems()\" [iconName]=\"'unsuccess'\"\n                    [iconSize]=\"'sm-12'\" *ngIf=\"searchText?.length > 0\"></gravity-icon>\n    </div>\n\n    <div class=\"select-all\" *ngIf=\"multiple && availableOptions.length != 0\">\n      <gravity-checkbox [ngClass]=\"getSpacingClass(size)\"\n                        (click)=\"selectAllItems($event)\"\n                        [checked]=\"checkIfSelected()\"></gravity-checkbox>\n      <p class=\"hr-label {{size}}-regular\">{{ currentLang == 'es' ? 'Seleccionar todo' : 'Select all' }}</p>\n    </div>\n\n    <div class=\"items-container\">\n      <div class=\"items\">\n        <div class=\"item-container\" *ngFor=\"let item of availableOptions\"\n             [attr.data-cy]=\"isCurrency ? 'currency_option_' + item.currency_id : ''\">\n          <div class=\"hr-label item {{size}}-regular pointer\"\n               [class.selected]=\"checkIfSelected(item)\"\n               [class.partial]=\"isPartiallySelected(item)\"\n               (click)=\"item.children?.length ? multiple ?selectItem(item) : toggleChildren(item, $event) : selectItem(item)\">\n            <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getSpacingClass(size)\"\n                              [isPartial]=\"isPartiallySelected(item)\"\n                              [checked]=\"checkIfSelected(item)\"></gravity-checkbox>\n            <gravity-currency *ngIf=\"isCurrency\" [ngClass]=\"getSpacingClass(size)\" [size]=\"getCurrencyIconSize(size)\"\n                              [currency]=\"{currency_id: item.currency_id}\"></gravity-currency>\n            <div [ngClass]=\"getSpacingClass(size)\">{{ getDisplayValue(item, config) }}</div>\n            <gravity-network-pill *ngIf=\"isCurrency && !item.children?.length\"\n                                  [network]=\"{ iso: item.network?.code, id: item.network?.id }\"></gravity-network-pill>\n            <gravity-icon style=\"margin-left: auto\" (click)=\"toggleChildren(item, $event)\"\n                          [iconName]=\"isChildrenOpen(item) ? 'arrow-up' : 'arrow-down'\"\n                          [iconSize]=\"'md-16'\" *ngIf=\"item.children?.length\"></gravity-icon>\n          </div>\n\n          <div class=\"item-children\" *ngIf=\"item.children?.length && isChildrenOpen(item)\">\n            <ng-container *ngFor=\"let child of item.children\">\n              <div class=\"hr-label item {{size}}-regular pointer\" [ngClass]=\"{'multiple' : multiple}\"\n                   [class.selected]=\"checkIfSelected(child)\"\n                   (click)=\"selectItem(child)\">\n                <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getMultilevelSpacingClass(size)\"\n                                  [checked]=\"checkIfSelected(child)\"></gravity-checkbox>\n                <gravity-currency *ngIf=\"isCurrency\" [ngClass]=\"getSpacingClass(size)\"\n                                  [size]=\"getCurrencyIconSize(size)\"\n                                  [currency]=\"{currency_id: child.currency_id}\"></gravity-currency>\n                <div [ngClass]=\"getSpacingClass(size)\">{{ getDisplayValue(child, config) }}</div>\n                <gravity-network-pill *ngIf=\"isCurrency\"\n                                      [network]=\"{ iso: child.network?.code, id: child.network?.id }\"></gravity-network-pill>\n              </div>\n            </ng-container>\n          </div>\n        </div>\n        <div class=\"item-container\">\n          <div class=\"hr-label item {{size}}-bold no-results\" *ngIf=\"availableOptions.length === 0\">\n            {{ currentLang == 'es' ? 'Sin resultados encontrados' : 'No results found.' }}\n          </div>\n        </div>\n      </div>\n    </div>\n\n    <div class=\"dropdown-footer\" *ngIf=\"selectedItems.length > 0 && availableOptions.length !== 0\" [class.not-clearable]=\"!clearable\">\n        <gravity-link *ngIf=\"clearable\"\n          (click)=\"clearSelection()\"\n          [fontClass]=\"'hr-label sm-regular'\"\n          [attr.data-cy]=\"cypressTag + '_clear'\"\n          [linkText]=\"currentLang == 'es' ? 'Limpiar' : 'Clear selection'\">\n        </gravity-link>\n\n        <gravity-link *ngIf=\"availableOptions.length != 0\"\n                      [fontClass]=\"'hr-label sm-bold'\"\n                      [attr.data-cy]=\"cypressTag + '_apply'\"\n                      (click)=\"$event.stopPropagation(); toggleDropdown()\"\n                      [linkText]=\"currentLang == 'es' ? 'Aplicar' : 'Apply'\">\n        </gravity-link>\n    </div>\n    <div class=\"dropdown-footer no-results\" *ngIf=\"availableOptions.length === 0\" [class.not-clearable]=\"!clearable\">\n        <gravity-link *ngIf=\"clearable\"\n                      (click)=\"clearSearch()\"\n                      [fontClass]=\"'hr-label sm-regular'\"\n                      [attr.data-cy]=\"cypressTag + '_clear_search'\"\n                      [linkText]=\"currentLang == 'es' ? 'Limpiar búsqueda' : 'Clear search'\">\n        </gravity-link>\n    </div>\n  </div>\n\n  <section class=\"external-content\" *ngIf=\"!items && dropdownOpened\" (click)=\"$event.stopPropagation()\">\n    <ng-content></ng-content>\n  </section>\n</div>\n\n<ng-container *ngIf=\"inputType === 'field'\">\n  <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\" *ngIf=\"supportText\">\n    {{ supportText }}\n  </p>\n  <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\"\n     *ngIf=\"!supportText && getStatus() == 'active' && selectedItems.length == 0 && required\">\n    {{ currentLang == 'es' ? 'Requerido' : 'Required' }}\n  </p>\n</ng-container>"]}
|
|
@@ -749,40 +749,38 @@ class GravityDropdownListComponent {
|
|
|
749
749
|
return child ?? '';
|
|
750
750
|
}
|
|
751
751
|
inputDisplayValue() {
|
|
752
|
-
if (this.selectedItems
|
|
752
|
+
if (!this.selectedItems?.length)
|
|
753
753
|
return '';
|
|
754
|
-
const labels = [];
|
|
755
754
|
const getValue = (item) => this.config ? item[this.config.value] : item;
|
|
756
755
|
const getLabel = (item) => {
|
|
757
756
|
const baseLabel = this.config ? item[this.config.label] : item;
|
|
758
|
-
|
|
759
|
-
|
|
760
|
-
|
|
761
|
-
networkCode = ` (${item.network.code})`;
|
|
762
|
-
}
|
|
763
|
-
}
|
|
757
|
+
const networkCode = (item.network?.code && (item.network_id !== item.currency_id || item.children || item.is_ERC20))
|
|
758
|
+
? ` (${item.network.code})`
|
|
759
|
+
: '';
|
|
764
760
|
return baseLabel + networkCode;
|
|
765
761
|
};
|
|
766
|
-
this.items
|
|
762
|
+
if (!this.items?.length) {
|
|
763
|
+
return this.selectedItems.map(getLabel).join(', ');
|
|
764
|
+
}
|
|
765
|
+
const labels = [];
|
|
766
|
+
for (const parent of this.items) {
|
|
767
767
|
if (parent.children?.length) {
|
|
768
768
|
const allChildrenSelected = parent.children.every(child => this.selectedItems.some(sel => getValue(sel) === getValue(child)));
|
|
769
769
|
if (allChildrenSelected) {
|
|
770
770
|
labels.push(getLabel(parent));
|
|
771
771
|
}
|
|
772
772
|
else {
|
|
773
|
-
parent.children
|
|
773
|
+
for (const child of parent.children) {
|
|
774
774
|
if (this.selectedItems.some(sel => getValue(sel) === getValue(child))) {
|
|
775
775
|
labels.push(getLabel(child));
|
|
776
776
|
}
|
|
777
|
-
}
|
|
777
|
+
}
|
|
778
778
|
}
|
|
779
779
|
}
|
|
780
|
-
else {
|
|
781
|
-
|
|
782
|
-
labels.push(getLabel(parent));
|
|
783
|
-
}
|
|
780
|
+
else if (this.selectedItems.some(sel => getValue(sel) === getValue(parent))) {
|
|
781
|
+
labels.push(getLabel(parent));
|
|
784
782
|
}
|
|
785
|
-
}
|
|
783
|
+
}
|
|
786
784
|
return labels.join(', ');
|
|
787
785
|
}
|
|
788
786
|
clearSearch() {
|