@progressio_resources/gravity-design-system 3.0.40 → 3.0.41

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.
@@ -45,47 +45,30 @@ export class GravityDropdownListComponent {
45
45
  this.availableOptions = this.items;
46
46
  }
47
47
  if (changes['customValues']) {
48
- let changeItem = changes['customValues'];
49
- if (changeItem?.currentValue) {
50
- if (this.multiple) {
51
- changeItem.currentValue.forEach((item) => {
52
- if (item) {
53
- let option;
54
- if (this.config) {
55
- option = this.availableOptions.find((availableOption) => availableOption[this.config.value] == item);
56
- }
57
- else {
58
- option = this.availableOptions.find((availableOption) => availableOption == item);
59
- }
60
- if (option) {
61
- let indexOfItem = this.selectedItems.findIndex((availableOption) => availableOption == option);
62
- if (indexOfItem == -1) {
63
- this.selectedItems.push(option);
64
- }
65
- }
66
- }
67
- });
68
- }
69
- else {
70
- let item = changeItem.currentValue;
48
+ const changeItem = changes['customValues'];
49
+ const currentValue = changeItem?.currentValue;
50
+ if (Array.isArray(currentValue)) {
51
+ this.selectedItems = [];
52
+ currentValue.forEach((item) => {
71
53
  if (item) {
72
- let option;
73
- if (this.config) {
74
- option = this.availableOptions.find((availableOption) => availableOption[this.config.value] == item);
75
- }
76
- else {
77
- option = this.availableOptions.find((availableOption) => availableOption == item);
78
- }
79
- if (option) {
80
- let indexOfItem = this.selectedItems.findIndex((availableOption) => availableOption == option);
81
- if (indexOfItem == -1) {
82
- this.selectedItems.push(option);
83
- }
54
+ const option = this.config
55
+ ? this.availableOptions.find((availableOption) => availableOption[this.config.value] == item)
56
+ : this.availableOptions.find((availableOption) => availableOption == item);
57
+ if (option && !this.selectedItems.includes(option)) {
58
+ this.selectedItems.push(option);
84
59
  }
85
60
  }
61
+ });
62
+ }
63
+ else if (currentValue != null && currentValue !== '') {
64
+ const option = this.config
65
+ ? this.availableOptions.find((availableOption) => availableOption[this.config.value] == currentValue)
66
+ : this.availableOptions.find((availableOption) => availableOption == currentValue);
67
+ if (option) {
68
+ this.selectedItems = [option];
86
69
  }
87
70
  }
88
- else if (!changeItem?.currentValue && !changeItem.firstChange) {
71
+ else if (!currentValue && !changeItem.firstChange) {
89
72
  this.clearSelection();
90
73
  }
91
74
  }
@@ -274,4 +257,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
274
257
  type: HostListener,
275
258
  args: ['document:click', ['$event']]
276
259
  }] } });
277
- //# 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  @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  @ViewChild('searchInput')\n  set watch(searchInput: ElementRef<HTMLInputElement>) {\n    if (searchInput) {\n      searchInput.nativeElement.focus();\n    }\n  };\n\n  public availableOptions: any[] = [];\n  public dropdownOpened: boolean = false;\n  public searchText: string = '';\n  public selectedItems: any[] = [];\n\n  constructor(private readonly filterByPipe: FilterByPipe, private _eref: ElementRef) { }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['items']?.currentValue) {\n      this.availableOptions = this.items;\n    }\n\n    if (changes['customValues']) {\n      let changeItem: SimpleChange = changes['customValues'];\n\n      if (changeItem?.currentValue) {\n        if (this.multiple) {\n          changeItem.currentValue.forEach((item: any) => {\n            if (item) {\n              let option: any;\n\n              if (this.config) {\n                option = this.availableOptions.find((availableOption: any) => availableOption[this.config.value] == item);\n              } else {\n                option = this.availableOptions.find((availableOption: any) => availableOption == item);\n              }\n\n              if (option) {\n                let indexOfItem: number = this.selectedItems.findIndex((availableOption: any) => availableOption == option);\n\n                if (indexOfItem == -1) {\n                  this.selectedItems.push(option);\n                }\n              }\n            }\n          });\n        } else {\n          let item: any = changeItem.currentValue;\n\n          if (item) {\n            let option: any;\n\n            if (this.config) {\n              option = this.availableOptions.find((availableOption: any) => availableOption[this.config.value] == item);\n            } else {\n              option = this.availableOptions.find((availableOption: any) => availableOption == item);\n            }\n\n            if (option) {\n              let indexOfItem: number = this.selectedItems.findIndex((availableOption: any) => availableOption == option);\n\n              if (indexOfItem == -1) {\n                this.selectedItems.push(option);\n              }\n            }\n          }\n        }\n      } else if (!changeItem?.currentValue && !changeItem.firstChange) {\n        this.clearSelection();\n      }\n    }\n  }\n\n  public getStatus(): string {\n    if (this.isDisabled) {return 'disabled';}\n    else if (this.isReadonly) {return 'readonly';}\n    else if (this.hasError) {return 'error';}\n    else if (this.dropdownOpened) {return 'open';}\n    else if (this.selectedItems.length > 0) {return 'selected';}\n    else {return 'active';}\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\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\n        this.searchText = '';\n        this.availableOptions = this.items;\n      }\n    }\n  }\n\n  public selectItem(itemToAdd: any): void {\n    if (this.multiple) {\n      let indexOfItem: number = this.selectedItems.findIndex((item: any) => item == itemToAdd);\n\n      if (indexOfItem == -1) {\n        this.selectedItems.push(itemToAdd);\n      } else {\n        this.selectedItems.splice(indexOfItem, 1);\n      }\n    } else {\n      this.selectedItems = [itemToAdd];\n      // this.selectedItemsResponse.emit(itemToAdd);\n      this.toggleDropdown();\n    }\n  }\n\n  public checkIfSelected(itemToFind: any): boolean {\n    return !!this.selectedItems.find((item: any) => itemToFind == item);\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  public filterItems(): void {\n    this.availableOptions = this.filterByPipe.transform(this.items, this.searchText);\n  }\n\n  @HostListener('document:click', ['$event']) onDocumentClick($event: PointerEvent): void {\n    if (!this._eref.nativeElement.contains($event.target) && this.dropdownOpened) {\n      this.dropdownOpened = false;\n\n\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.availableOptions = this.items;\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': return 'gravity-margin-right-xxs';\n      case 'md': return 'gravity-margin-right-xs';\n      case 'lg': return 'gravity-margin-right-sm';\n      case 'xl': return 'gravity-margin-right-md';\n      default: 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","<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\"></gravity-icon>\n      <p class=\"hr-label {{size}}-regular value\">\n        <ng-container *ngIf=\"selectedItems.length == 0\">\n          {{ placeholder ? placeholder : label }}\n        </ng-container>\n        <ng-container *ngIf=\"selectedItems.length > 0\">\n          <ng-container *ngFor=\"let item of selectedItems; let i = index\">\n            {{ config ? item[config.label] : item }}{{ i != selectedItems.length - 1 ? ',' : '' }}\n          </ng-container>\n        </ng-container>\n      </p>\n      <gravity-icon class=\"right\" [iconName]=\"dropdownOpened ? 'arrow-up': 'arrow-down'\"\n                    [iconSize]=\"'md-16'\" *ngIf=\"!isReadonly\"></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\" (click)=\"$event.stopPropagation()\" *ngIf=\"dropdownOpened\"\n       [attr.data-cy]=\"cypressTag + '_panel'\">\n    <div class=\"search-input\">\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=\"items-container\">\n      <div class=\"items\">\n        <div class=\"hr-label item {{size}}-regular pointer\" [class.selected]=\"checkIfSelected(item)\"\n             (click)=\"selectItem(item)\" *ngFor=\"let item of availableOptions\">\n          <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getSpacingClass(size)\"\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)\">{{ config ? item[config.label] : item }}</div>\n          <gravity-network-pill *ngIf=\"isCurrency\" [network]=\"{ iso: item.network.code, id: item.network.id }\" ></gravity-network-pill>\n        </div>\n        <div class=\"hr-label item {{size}}-bold no-results\" *ngIf=\"availableOptions.length === 0\">\n          {{ currentLang == 'es' ? 'Sin resultados' : 'No results' }}\n        </div>\n      </div>\n    </div>\n\n    <div class=\"dropdown-footer\" *ngIf=\"selectedItems.length > 0\" [class.not-clearable]=\"!clearable\">\n      <p class=\"hr-label pointer sm-regular\" (click)=\"clearSelection()\" *ngIf=\"clearable\"\n         [attr.data-cy]=\"cypressTag + '_clear'\">\n        {{ currentLang == 'es' ? 'Limpiar' : 'Clear selection' }}\n      </p>\n      <p class=\"hr-label pointer sm-bold\" (click)=\"$event.stopPropagation(); toggleDropdown()\"\n         *ngIf=\"availableOptions.length != 0\" [attr.data-cy]=\"cypressTag + '_apply'\">\n        {{ currentLang == 'es' ? 'Aplicar' : 'Apply' }}\n      </p>\n    </div>\n  </div>\n</div>\n\n<ng-container *ngIf=\"inputType === 'field'\">\n    <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\" *ngIf=\"supportText\">\n      <gravity-icon [iconName]=\"'question-circle'\" *ngIf=\"hasError\" [iconSize]=\"'md-16'\"></gravity-icon>\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>\n"]}
260
+ //# 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  @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  @ViewChild('searchInput')\n  set watch(searchInput: ElementRef<HTMLInputElement>) {\n    if (searchInput) {\n      searchInput.nativeElement.focus();\n    }\n  };\n\n  public availableOptions: any[] = [];\n  public dropdownOpened: boolean = false;\n  public searchText: string = '';\n  public selectedItems: any[] = [];\n\n  constructor(private readonly filterByPipe: FilterByPipe, private _eref: ElementRef) { }\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      if (Array.isArray(currentValue)) {\n        this.selectedItems = [];\n\n        currentValue.forEach((item: any) => {\n          if (item) {\n            const option = this.config\n              ? this.availableOptions.find((availableOption: any) => availableOption[this.config.value] == item)\n              : this.availableOptions.find((availableOption: any) => availableOption == item);\n\n            if (option && !this.selectedItems.includes(option)) {\n              this.selectedItems.push(option);\n            }\n          }\n        });\n      } else if (currentValue != null && currentValue !== '') {\n        const option = this.config\n          ? this.availableOptions.find((availableOption: any) => availableOption[this.config.value] == currentValue)\n          : this.availableOptions.find((availableOption: any) => availableOption == currentValue);\n\n        if (option) {\n          this.selectedItems = [option];\n        }\n      } else if (!currentValue && !changeItem.firstChange) {\n        this.clearSelection();\n      }\n    }\n  }\n\n  public getStatus(): string {\n    if (this.isDisabled) {return 'disabled';}\n    else if (this.isReadonly) {return 'readonly';}\n    else if (this.hasError) {return 'error';}\n    else if (this.dropdownOpened) {return 'open';}\n    else if (this.selectedItems.length > 0) {return 'selected';}\n    else {return 'active';}\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\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\n        this.searchText = '';\n        this.availableOptions = this.items;\n      }\n    }\n  }\n\n  public selectItem(itemToAdd: any): void {\n    if (this.multiple) {\n      let indexOfItem: number = this.selectedItems.findIndex((item: any) => item == itemToAdd);\n\n      if (indexOfItem == -1) {\n        this.selectedItems.push(itemToAdd);\n      } else {\n        this.selectedItems.splice(indexOfItem, 1);\n      }\n    } else {\n      this.selectedItems = [itemToAdd];\n      // this.selectedItemsResponse.emit(itemToAdd);\n      this.toggleDropdown();\n    }\n  }\n\n  public checkIfSelected(itemToFind: any): boolean {\n    return !!this.selectedItems.find((item: any) => itemToFind == item);\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  public filterItems(): void {\n    this.availableOptions = this.filterByPipe.transform(this.items, this.searchText);\n  }\n\n  @HostListener('document:click', ['$event']) onDocumentClick($event: PointerEvent): void {\n    if (!this._eref.nativeElement.contains($event.target) && this.dropdownOpened) {\n      this.dropdownOpened = false;\n\n\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.availableOptions = this.items;\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': return 'gravity-margin-right-xxs';\n      case 'md': return 'gravity-margin-right-xs';\n      case 'lg': return 'gravity-margin-right-sm';\n      case 'xl': return 'gravity-margin-right-md';\n      default: 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","<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\"></gravity-icon>\n      <p class=\"hr-label {{size}}-regular value\">\n        <ng-container *ngIf=\"selectedItems.length == 0\">\n          {{ placeholder ? placeholder : label }}\n        </ng-container>\n        <ng-container *ngIf=\"selectedItems.length > 0\">\n          <ng-container *ngFor=\"let item of selectedItems; let i = index\">\n            {{ config ? item[config.label] : item }}{{ i != selectedItems.length - 1 ? ',' : '' }}\n          </ng-container>\n        </ng-container>\n      </p>\n      <gravity-icon class=\"right\" [iconName]=\"dropdownOpened ? 'arrow-up': 'arrow-down'\"\n                    [iconSize]=\"'md-16'\" *ngIf=\"!isReadonly\"></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\" (click)=\"$event.stopPropagation()\" *ngIf=\"dropdownOpened\"\n       [attr.data-cy]=\"cypressTag + '_panel'\">\n    <div class=\"search-input\">\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=\"items-container\">\n      <div class=\"items\">\n        <div class=\"hr-label item {{size}}-regular pointer\" [class.selected]=\"checkIfSelected(item)\"\n             (click)=\"selectItem(item)\" *ngFor=\"let item of availableOptions\">\n          <gravity-checkbox *ngIf=\"multiple\" [ngClass]=\"getSpacingClass(size)\"\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)\">{{ config ? item[config.label] : item }}</div>\n          <gravity-network-pill *ngIf=\"isCurrency\" [network]=\"{ iso: item.network.code, id: item.network.id }\" ></gravity-network-pill>\n        </div>\n        <div class=\"hr-label item {{size}}-bold no-results\" *ngIf=\"availableOptions.length === 0\">\n          {{ currentLang == 'es' ? 'Sin resultados' : 'No results' }}\n        </div>\n      </div>\n    </div>\n\n    <div class=\"dropdown-footer\" *ngIf=\"selectedItems.length > 0\" [class.not-clearable]=\"!clearable\">\n      <p class=\"hr-label pointer sm-regular\" (click)=\"clearSelection()\" *ngIf=\"clearable\"\n         [attr.data-cy]=\"cypressTag + '_clear'\">\n        {{ currentLang == 'es' ? 'Limpiar' : 'Clear selection' }}\n      </p>\n      <p class=\"hr-label pointer sm-bold\" (click)=\"$event.stopPropagation(); toggleDropdown()\"\n         *ngIf=\"availableOptions.length != 0\" [attr.data-cy]=\"cypressTag + '_apply'\">\n        {{ currentLang == 'es' ? 'Aplicar' : 'Apply' }}\n      </p>\n    </div>\n  </div>\n</div>\n\n<ng-container *ngIf=\"inputType === 'field'\">\n    <p class=\"hr-label sm-regular supporting-text {{getStatus()}} {{size}}\" *ngIf=\"supportText\">\n      <gravity-icon [iconName]=\"'question-circle'\" *ngIf=\"hasError\" [iconSize]=\"'md-16'\"></gravity-icon>\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>\n"]}
@@ -389,47 +389,30 @@ class GravityDropdownListComponent {
389
389
  this.availableOptions = this.items;
390
390
  }
391
391
  if (changes['customValues']) {
392
- let changeItem = changes['customValues'];
393
- if (changeItem?.currentValue) {
394
- if (this.multiple) {
395
- changeItem.currentValue.forEach((item) => {
396
- if (item) {
397
- let option;
398
- if (this.config) {
399
- option = this.availableOptions.find((availableOption) => availableOption[this.config.value] == item);
400
- }
401
- else {
402
- option = this.availableOptions.find((availableOption) => availableOption == item);
403
- }
404
- if (option) {
405
- let indexOfItem = this.selectedItems.findIndex((availableOption) => availableOption == option);
406
- if (indexOfItem == -1) {
407
- this.selectedItems.push(option);
408
- }
409
- }
410
- }
411
- });
412
- }
413
- else {
414
- let item = changeItem.currentValue;
392
+ const changeItem = changes['customValues'];
393
+ const currentValue = changeItem?.currentValue;
394
+ if (Array.isArray(currentValue)) {
395
+ this.selectedItems = [];
396
+ currentValue.forEach((item) => {
415
397
  if (item) {
416
- let option;
417
- if (this.config) {
418
- option = this.availableOptions.find((availableOption) => availableOption[this.config.value] == item);
419
- }
420
- else {
421
- option = this.availableOptions.find((availableOption) => availableOption == item);
422
- }
423
- if (option) {
424
- let indexOfItem = this.selectedItems.findIndex((availableOption) => availableOption == option);
425
- if (indexOfItem == -1) {
426
- this.selectedItems.push(option);
427
- }
398
+ const option = this.config
399
+ ? this.availableOptions.find((availableOption) => availableOption[this.config.value] == item)
400
+ : this.availableOptions.find((availableOption) => availableOption == item);
401
+ if (option && !this.selectedItems.includes(option)) {
402
+ this.selectedItems.push(option);
428
403
  }
429
404
  }
405
+ });
406
+ }
407
+ else if (currentValue != null && currentValue !== '') {
408
+ const option = this.config
409
+ ? this.availableOptions.find((availableOption) => availableOption[this.config.value] == currentValue)
410
+ : this.availableOptions.find((availableOption) => availableOption == currentValue);
411
+ if (option) {
412
+ this.selectedItems = [option];
430
413
  }
431
414
  }
432
- else if (!changeItem?.currentValue && !changeItem.firstChange) {
415
+ else if (!currentValue && !changeItem.firstChange) {
433
416
  this.clearSelection();
434
417
  }
435
418
  }