@progressio_resources/gravity-design-system 3.2.0 → 3.2.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -51,25 +51,33 @@ export class GravityDropdownListComponent {
51
51
  if (changes['customValues']) {
52
52
  const changeItem = changes['customValues'];
53
53
  const currentValue = changeItem?.currentValue;
54
+ const findOptionRecursively = (items, value) => {
55
+ for (const item of items) {
56
+ const itemValue = this.config ? item[this.config.value] : item;
57
+ if (itemValue == value) {
58
+ return item;
59
+ }
60
+ if (item.children) {
61
+ const foundChild = findOptionRecursively(item.children, value);
62
+ if (foundChild)
63
+ return foundChild;
64
+ }
65
+ }
66
+ return null;
67
+ };
68
+ this.selectedItems = [];
54
69
  if (Array.isArray(currentValue)) {
55
- this.selectedItems = [];
56
- currentValue.forEach((item) => {
57
- if (item) {
58
- const option = this.config
59
- ? this.availableOptions.find((availableOption) => availableOption[this.config.value] == item)
60
- : this.availableOptions.find((availableOption) => availableOption == item);
61
- if (option && !this.selectedItems.includes(option)) {
62
- this.selectedItems.push(option);
63
- }
70
+ currentValue.forEach((val) => {
71
+ const found = findOptionRecursively(this.items, val);
72
+ if (found && !this.selectedItems.includes(found)) {
73
+ this.selectedItems.push(found);
64
74
  }
65
75
  });
66
76
  }
67
77
  else if (currentValue != null && currentValue !== '') {
68
- const option = this.config
69
- ? this.availableOptions.find((availableOption) => availableOption[this.config.value] == currentValue)
70
- : this.availableOptions.find((availableOption) => availableOption == currentValue);
71
- if (option) {
72
- this.selectedItems = [option];
78
+ const found = findOptionRecursively(this.items, currentValue);
79
+ if (found) {
80
+ this.selectedItems = [found];
73
81
  }
74
82
  }
75
83
  else if (!currentValue && !changeItem.firstChange) {
@@ -128,7 +136,8 @@ export class GravityDropdownListComponent {
128
136
  if (this.multiple) {
129
137
  const isSelected = this.checkIfSelected(itemToAdd);
130
138
  if (isSelected) {
131
- this.selectedItems = this.selectedItems.filter(i => i !== itemToAdd);
139
+ this.selectedItems = this.selectedItems.filter(i => (this.config ? i[this.config.value] : i) !==
140
+ (this.config ? itemToAdd[this.config.value] : itemToAdd));
132
141
  if (isParent) {
133
142
  itemToAdd.children.forEach(child => {
134
143
  this.selectedItems = this.selectedItems.filter(i => i !== child);
@@ -182,7 +191,8 @@ export class GravityDropdownListComponent {
182
191
  return selectedChildren.length > 0 && selectedChildren.length < item.children.length;
183
192
  }
184
193
  checkIfSelected(itemToFind) {
185
- return !!this.selectedItems.find((item) => itemToFind == item);
194
+ return this.selectedItems.some(item => (this.config ? item[this.config.value] : item) ===
195
+ (this.config ? itemToFind[this.config.value] : itemToFind));
186
196
  }
187
197
  clearSelection() {
188
198
  this.selectedItems = [];
@@ -341,4 +351,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
341
351
  type: HostListener,
342
352
  args: ['document:click', ['$event']]
343
353
  }] } });
344
- //# 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 {Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, Output, SimpleChange, SimpleChanges, ViewChild} 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 { return this.dropdownOpened; }\n  set dropdownState(value: boolean) { this.dropdownOpened = value; }\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();\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  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      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\n        this.searchText = '';\n        this.availableOptions = this.items;\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 => i !== itemToAdd);\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(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    const search = this.searchText?.toLowerCase();\n\n    const filterRecursive = (items: any[]): any[] => {\n      return items\n        .map(item => {\n          const label = this.config ? item[this.config.label] : item;\n          const matches = label?.toString().toLowerCase().includes(search);\n          const filteredChildren = item.children ? filterRecursive(item.children) : [];\n\n          if (matches || filteredChildren.length > 0) {\n            return {\n              ...item,\n              children: filteredChildren\n            };\n          }\n\n          return null;\n        })\n        .filter(item => item !== null);\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': 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 getMultilevelSpacingClass(size: string) {\n    switch (size) {\n      case 'sm': return 'gravity-margin-right-md';\n      case 'md': return 'gravity-margin-right-lg';\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  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","<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\n    <ng-container *ngIf=\"isCurrency && selectedItems.length > 0\">\n      <gravity-currency\n          [ngClass]=\"getSpacingClass(size)\"\n          [size]=\"getCurrencyIconSize(size)\"\n          [currency]=\"{currency_id: selectedItems[0]?.currency_id}\">\n      </gravity-currency>\n    </ng-container>\n\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\n    <ng-container *ngIf=\"isCurrency && selectedItems.length > 0\">\n      <gravity-network-pill\n          [network]=\"{ iso: selectedItems[0]?.network?.code, id: selectedItems[0]?.network?.id }\">\n      </gravity-network-pill>\n    </ng-container>\n\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=\"items && 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=\"item-container\" *ngFor=\"let item of availableOptions\" [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)\">{{ config ? item[config.label] : item }}</div>\n            <gravity-network-pill *ngIf=\"isCurrency\"\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)\">{{ config ? child[config.label] : child }}</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=\"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\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    <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>"]}
354
+ //# 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 {Component, ElementRef, EventEmitter, HostListener, Input, OnChanges, Output, SimpleChange, SimpleChanges, ViewChild} 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 { return this.dropdownOpened; }\n  set dropdownState(value: boolean) { this.dropdownOpened = value; }\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();\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  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) {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      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\n        this.searchText = '';\n        this.availableOptions = this.items;\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(itemToFind: any): boolean {\n    return this.selectedItems.some(item =>\n      (this.config ? item[this.config.value] : item) ===\n      (this.config ? itemToFind[this.config.value] : itemToFind)\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  public filterItems(): void {\n    const search = this.searchText?.toLowerCase();\n\n    const filterRecursive = (items: any[]): any[] => {\n      return items\n        .map(item => {\n          const label = this.config ? item[this.config.label] : item;\n          const matches = label?.toString().toLowerCase().includes(search);\n          const filteredChildren = item.children ? filterRecursive(item.children) : [];\n\n          if (matches || filteredChildren.length > 0) {\n            return {\n              ...item,\n              children: filteredChildren\n            };\n          }\n\n          return null;\n        })\n        .filter(item => item !== null);\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': 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 getMultilevelSpacingClass(size: string) {\n    switch (size) {\n      case 'sm': return 'gravity-margin-right-md';\n      case 'md': return 'gravity-margin-right-lg';\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  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","<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\n    <ng-container *ngIf=\"isCurrency && selectedItems.length > 0\">\n      <gravity-currency\n          [ngClass]=\"getSpacingClass(size)\"\n          [size]=\"getCurrencyIconSize(size)\"\n          [currency]=\"{currency_id: selectedItems[0]?.currency_id}\">\n      </gravity-currency>\n    </ng-container>\n\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\n    <ng-container *ngIf=\"isCurrency && selectedItems.length > 0\">\n      <gravity-network-pill\n          [network]=\"{ iso: selectedItems[0]?.network?.code, id: selectedItems[0]?.network?.id }\">\n      </gravity-network-pill>\n    </ng-container>\n\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=\"items && 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=\"item-container\" *ngFor=\"let item of availableOptions\" [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)\">{{ config ? item[config.label] : item }}</div>\n            <gravity-network-pill *ngIf=\"isCurrency\"\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)\">{{ config ? child[config.label] : child }}</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=\"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\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    <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>"]}
@@ -1,6 +1,10 @@
1
1
  import { Component, Input } from '@angular/core';
2
2
  import * as i0 from "@angular/core";
3
+ import * as i1 from "@angular/common";
3
4
  export class GravityGenericAvatarComponent {
5
+ constructor() {
6
+ this.size = 'sm';
7
+ }
4
8
  getStatus() {
5
9
  if (this.isDisabled) {
6
10
  return 'disabled';
@@ -10,16 +14,18 @@ export class GravityGenericAvatarComponent {
10
14
  }
11
15
  }
12
16
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityGenericAvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
13
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityGenericAvatarComponent, selector: "gravity-generic-avatar", inputs: { label: "label", initials: "initials", isDisabled: "isDisabled" }, ngImport: i0, template: "<div class=\"gravity-generic-avatar {{getStatus()}}\">\n <div class=\"gravity-margin-right-xxs\">\n <span class=\"hr-body sm-regular\">{{initials}}</span>\n </div>\n <label class=\"hr-body sm-regular\">{{label}}</label>\n</div>", styles: [":host{display:block}.gravity-generic-avatar{display:flex;align-items:center}.gravity-generic-avatar div{width:24px;height:24px;display:flex;border-radius:50px;align-items:center;justify-content:center;color:var(--avatar-initials-text-color);background-color:var(--avatar-initials-backgroud-color)}.gravity-generic-avatar div span{margin-top:2px}.gravity-generic-avatar label{margin-top:2px;color:var(--avatar-label-color)}.gravity-generic-avatar.active{--avatar-label-color: var(--cl-generic-avatar-label-primary);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-primary);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-primary)}.gravity-generic-avatar.disabled{--avatar-label-color: var(--cl-generic-avatar-label-disabled);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-disabled);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-disabled)}\n"] }); }
17
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityGenericAvatarComponent, selector: "gravity-generic-avatar", inputs: { label: "label", initials: "initials", isDisabled: "isDisabled", size: "size" }, ngImport: i0, template: "<div class=\"gravity-generic-avatar {{getStatus()}} {{size}}\">\n <div class=\"gravity-margin-right-xxs\">\n <span class=\"hr-body sm-bold\">{{initials}}</span>\n </div>\n <label class=\"hr-body\" [ngClass]=\"size === 'sm' ? 'sm-regular' : 'md-bold'\">{{label}}</label>\n</div>", styles: [":host{display:block}.gravity-generic-avatar{display:flex;align-items:center}.gravity-generic-avatar div{width:24px;height:24px;display:flex;border-radius:50px;align-items:center;justify-content:center;color:var(--avatar-initials-text-color);background-color:var(--avatar-initials-backgroud-color)}.gravity-generic-avatar div span{margin-top:2px}.gravity-generic-avatar label{margin-top:2px;color:var(--avatar-label-color)}.gravity-generic-avatar.md div{width:32px;height:32px}.gravity-generic-avatar.active{--avatar-label-color: var(--cl-generic-avatar-label-primary);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-primary);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-primary)}.gravity-generic-avatar.disabled{--avatar-label-color: var(--cl-generic-avatar-label-disabled);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-disabled);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-disabled)}\n"], dependencies: [{ kind: "directive", type: i1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
14
18
  }
15
19
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityGenericAvatarComponent, decorators: [{
16
20
  type: Component,
17
- args: [{ selector: 'gravity-generic-avatar', template: "<div class=\"gravity-generic-avatar {{getStatus()}}\">\n <div class=\"gravity-margin-right-xxs\">\n <span class=\"hr-body sm-regular\">{{initials}}</span>\n </div>\n <label class=\"hr-body sm-regular\">{{label}}</label>\n</div>", styles: [":host{display:block}.gravity-generic-avatar{display:flex;align-items:center}.gravity-generic-avatar div{width:24px;height:24px;display:flex;border-radius:50px;align-items:center;justify-content:center;color:var(--avatar-initials-text-color);background-color:var(--avatar-initials-backgroud-color)}.gravity-generic-avatar div span{margin-top:2px}.gravity-generic-avatar label{margin-top:2px;color:var(--avatar-label-color)}.gravity-generic-avatar.active{--avatar-label-color: var(--cl-generic-avatar-label-primary);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-primary);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-primary)}.gravity-generic-avatar.disabled{--avatar-label-color: var(--cl-generic-avatar-label-disabled);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-disabled);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-disabled)}\n"] }]
21
+ args: [{ selector: 'gravity-generic-avatar', template: "<div class=\"gravity-generic-avatar {{getStatus()}} {{size}}\">\n <div class=\"gravity-margin-right-xxs\">\n <span class=\"hr-body sm-bold\">{{initials}}</span>\n </div>\n <label class=\"hr-body\" [ngClass]=\"size === 'sm' ? 'sm-regular' : 'md-bold'\">{{label}}</label>\n</div>", styles: [":host{display:block}.gravity-generic-avatar{display:flex;align-items:center}.gravity-generic-avatar div{width:24px;height:24px;display:flex;border-radius:50px;align-items:center;justify-content:center;color:var(--avatar-initials-text-color);background-color:var(--avatar-initials-backgroud-color)}.gravity-generic-avatar div span{margin-top:2px}.gravity-generic-avatar label{margin-top:2px;color:var(--avatar-label-color)}.gravity-generic-avatar.md div{width:32px;height:32px}.gravity-generic-avatar.active{--avatar-label-color: var(--cl-generic-avatar-label-primary);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-primary);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-primary)}.gravity-generic-avatar.disabled{--avatar-label-color: var(--cl-generic-avatar-label-disabled);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-disabled);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-disabled)}\n"] }]
18
22
  }], propDecorators: { label: [{
19
23
  type: Input
20
24
  }], initials: [{
21
25
  type: Input
22
26
  }], isDisabled: [{
23
27
  type: Input
28
+ }], size: [{
29
+ type: Input
24
30
  }] } });
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3Jhdml0eS1nZW5lcmljLWF2YXRhci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ncmF2aXR5LWRlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2dyYXZpdHktZ2VuZXJpYy1hdmF0YXIvZ3Jhdml0eS1nZW5lcmljLWF2YXRhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ncmF2aXR5LWRlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2dyYXZpdHktZ2VuZXJpYy1hdmF0YXIvZ3Jhdml0eS1nZW5lcmljLWF2YXRhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQzs7QUFPL0MsTUFBTSxPQUFPLDZCQUE2QjtJQUtqQyxTQUFTO1FBQ2QsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ25CLE9BQU8sVUFBVSxDQUFDO1NBQ3BCO2FBQU07WUFDSixPQUFPLFFBQVEsQ0FBQztTQUNqQjtJQUNILENBQUM7K0dBWFUsNkJBQTZCO21HQUE3Qiw2QkFBNkIsMElDUDFDLHFQQUtNOzs0RkRFTyw2QkFBNkI7a0JBTHpDLFNBQVM7K0JBQ0Usd0JBQXdCOzhCQUtsQixLQUFLO3NCQUFwQixLQUFLO2dCQUNVLFFBQVE7c0JBQXZCLEtBQUs7Z0JBQ1UsVUFBVTtzQkFBekIsS0FBSyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCB7Q29tcG9uZW50LCBJbnB1dH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5cbkBDb21wb25lbnQoe1xuICBzZWxlY3RvcjogJ2dyYXZpdHktZ2VuZXJpYy1hdmF0YXInLFxuICB0ZW1wbGF0ZVVybDogJy4vZ3Jhdml0eS1nZW5lcmljLWF2YXRhci5jb21wb25lbnQuaHRtbCcsXG4gIHN0eWxlVXJsczogWycuL2dyYXZpdHktZ2VuZXJpYy1hdmF0YXIuY29tcG9uZW50LnNjc3MnXVxufSlcbmV4cG9ydCBjbGFzcyBHcmF2aXR5R2VuZXJpY0F2YXRhckNvbXBvbmVudCB7XG4gIEBJbnB1dCgpIHB1YmxpYyBsYWJlbDogc3RyaW5nO1xuICBASW5wdXQoKSBwdWJsaWMgaW5pdGlhbHM6IHN0cmluZztcbiAgQElucHV0KCkgcHVibGljIGlzRGlzYWJsZWQ6IGJvb2xlYW47XG5cbiAgcHVibGljIGdldFN0YXR1cygpOiBzdHJpbmcge1xuICAgIGlmICh0aGlzLmlzRGlzYWJsZWQpIHtcbiAgICAgIHJldHVybiAnZGlzYWJsZWQnO1xuICAgfSBlbHNlIHtcbiAgICAgIHJldHVybiAnYWN0aXZlJztcbiAgICB9XG4gIH1cbn1cbiIsIjxkaXYgY2xhc3M9XCJncmF2aXR5LWdlbmVyaWMtYXZhdGFyIHt7Z2V0U3RhdHVzKCl9fVwiPlxuICAgIDxkaXYgY2xhc3M9XCJncmF2aXR5LW1hcmdpbi1yaWdodC14eHNcIj5cbiAgICAgICAgPHNwYW4gY2xhc3M9XCJoci1ib2R5IHNtLXJlZ3VsYXJcIj57e2luaXRpYWxzfX08L3NwYW4+XG4gICAgPC9kaXY+XG4gICAgPGxhYmVsIGNsYXNzPVwiaHItYm9keSBzbS1yZWd1bGFyXCI+e3tsYWJlbH19PC9sYWJlbD5cbjwvZGl2PiJdfQ==
31
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZ3Jhdml0eS1nZW5lcmljLWF2YXRhci5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ncmF2aXR5LWRlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2dyYXZpdHktZ2VuZXJpYy1hdmF0YXIvZ3Jhdml0eS1nZW5lcmljLWF2YXRhci5jb21wb25lbnQudHMiLCIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9ncmF2aXR5LWRlc2lnbi1zeXN0ZW0vc3JjL2xpYi9jb21wb25lbnRzL2dyYXZpdHktZ2VuZXJpYy1hdmF0YXIvZ3Jhdml0eS1nZW5lcmljLWF2YXRhci5jb21wb25lbnQuaHRtbCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUMsU0FBUyxFQUFFLEtBQUssRUFBQyxNQUFNLGVBQWUsQ0FBQzs7O0FBTy9DLE1BQU0sT0FBTyw2QkFBNkI7SUFMMUM7UUFTa0IsU0FBSSxHQUFnQixJQUFJLENBQUM7S0FTMUM7SUFQUSxTQUFTO1FBQ2QsSUFBSSxJQUFJLENBQUMsVUFBVSxFQUFFO1lBQ25CLE9BQU8sVUFBVSxDQUFDO1NBQ3BCO2FBQU07WUFDSixPQUFPLFFBQVEsQ0FBQztTQUNqQjtJQUNILENBQUM7K0dBWlUsNkJBQTZCO21HQUE3Qiw2QkFBNkIsd0pDUDFDLHVTQUtNOzs0RkRFTyw2QkFBNkI7a0JBTHpDLFNBQVM7K0JBQ0Usd0JBQXdCOzhCQUtsQixLQUFLO3NCQUFwQixLQUFLO2dCQUNVLFFBQVE7c0JBQXZCLEtBQUs7Z0JBQ1UsVUFBVTtzQkFBekIsS0FBSztnQkFDVSxJQUFJO3NCQUFuQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtDb21wb25lbnQsIElucHV0fSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnZ3Jhdml0eS1nZW5lcmljLWF2YXRhcicsXG4gIHRlbXBsYXRlVXJsOiAnLi9ncmF2aXR5LWdlbmVyaWMtYXZhdGFyLmNvbXBvbmVudC5odG1sJyxcbiAgc3R5bGVVcmxzOiBbJy4vZ3Jhdml0eS1nZW5lcmljLWF2YXRhci5jb21wb25lbnQuc2NzcyddXG59KVxuZXhwb3J0IGNsYXNzIEdyYXZpdHlHZW5lcmljQXZhdGFyQ29tcG9uZW50IHtcbiAgQElucHV0KCkgcHVibGljIGxhYmVsOiBzdHJpbmc7XG4gIEBJbnB1dCgpIHB1YmxpYyBpbml0aWFsczogc3RyaW5nO1xuICBASW5wdXQoKSBwdWJsaWMgaXNEaXNhYmxlZDogYm9vbGVhbjtcbiAgQElucHV0KCkgcHVibGljIHNpemU6ICdzbScgfCAnbWQnID0gJ3NtJztcblxuICBwdWJsaWMgZ2V0U3RhdHVzKCk6IHN0cmluZyB7XG4gICAgaWYgKHRoaXMuaXNEaXNhYmxlZCkge1xuICAgICAgcmV0dXJuICdkaXNhYmxlZCc7XG4gICB9IGVsc2Uge1xuICAgICAgcmV0dXJuICdhY3RpdmUnO1xuICAgIH1cbiAgfVxufVxuIiwiPGRpdiBjbGFzcz1cImdyYXZpdHktZ2VuZXJpYy1hdmF0YXIge3tnZXRTdGF0dXMoKX19IHt7c2l6ZX19XCI+XG4gICAgPGRpdiBjbGFzcz1cImdyYXZpdHktbWFyZ2luLXJpZ2h0LXh4c1wiPlxuICAgICAgICA8c3BhbiBjbGFzcz1cImhyLWJvZHkgc20tYm9sZFwiPnt7aW5pdGlhbHN9fTwvc3Bhbj5cbiAgICA8L2Rpdj5cbiAgICA8bGFiZWwgY2xhc3M9XCJoci1ib2R5XCIgW25nQ2xhc3NdPVwic2l6ZSA9PT0gJ3NtJyA/ICdzbS1yZWd1bGFyJyA6ICdtZC1ib2xkJ1wiPnt7bGFiZWx9fTwvbGFiZWw+XG48L2Rpdj4iXX0=
@@ -407,25 +407,33 @@ class GravityDropdownListComponent {
407
407
  if (changes['customValues']) {
408
408
  const changeItem = changes['customValues'];
409
409
  const currentValue = changeItem?.currentValue;
410
+ const findOptionRecursively = (items, value) => {
411
+ for (const item of items) {
412
+ const itemValue = this.config ? item[this.config.value] : item;
413
+ if (itemValue == value) {
414
+ return item;
415
+ }
416
+ if (item.children) {
417
+ const foundChild = findOptionRecursively(item.children, value);
418
+ if (foundChild)
419
+ return foundChild;
420
+ }
421
+ }
422
+ return null;
423
+ };
424
+ this.selectedItems = [];
410
425
  if (Array.isArray(currentValue)) {
411
- this.selectedItems = [];
412
- currentValue.forEach((item) => {
413
- if (item) {
414
- const option = this.config
415
- ? this.availableOptions.find((availableOption) => availableOption[this.config.value] == item)
416
- : this.availableOptions.find((availableOption) => availableOption == item);
417
- if (option && !this.selectedItems.includes(option)) {
418
- this.selectedItems.push(option);
419
- }
426
+ currentValue.forEach((val) => {
427
+ const found = findOptionRecursively(this.items, val);
428
+ if (found && !this.selectedItems.includes(found)) {
429
+ this.selectedItems.push(found);
420
430
  }
421
431
  });
422
432
  }
423
433
  else if (currentValue != null && currentValue !== '') {
424
- const option = this.config
425
- ? this.availableOptions.find((availableOption) => availableOption[this.config.value] == currentValue)
426
- : this.availableOptions.find((availableOption) => availableOption == currentValue);
427
- if (option) {
428
- this.selectedItems = [option];
434
+ const found = findOptionRecursively(this.items, currentValue);
435
+ if (found) {
436
+ this.selectedItems = [found];
429
437
  }
430
438
  }
431
439
  else if (!currentValue && !changeItem.firstChange) {
@@ -484,7 +492,8 @@ class GravityDropdownListComponent {
484
492
  if (this.multiple) {
485
493
  const isSelected = this.checkIfSelected(itemToAdd);
486
494
  if (isSelected) {
487
- this.selectedItems = this.selectedItems.filter(i => i !== itemToAdd);
495
+ this.selectedItems = this.selectedItems.filter(i => (this.config ? i[this.config.value] : i) !==
496
+ (this.config ? itemToAdd[this.config.value] : itemToAdd));
488
497
  if (isParent) {
489
498
  itemToAdd.children.forEach(child => {
490
499
  this.selectedItems = this.selectedItems.filter(i => i !== child);
@@ -538,7 +547,8 @@ class GravityDropdownListComponent {
538
547
  return selectedChildren.length > 0 && selectedChildren.length < item.children.length;
539
548
  }
540
549
  checkIfSelected(itemToFind) {
541
- return !!this.selectedItems.find((item) => itemToFind == item);
550
+ return this.selectedItems.some(item => (this.config ? item[this.config.value] : item) ===
551
+ (this.config ? itemToFind[this.config.value] : itemToFind));
542
552
  }
543
553
  clearSelection() {
544
554
  this.selectedItems = [];
@@ -5601,6 +5611,9 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
5601
5611
  }] } });
5602
5612
 
5603
5613
  class GravityGenericAvatarComponent {
5614
+ constructor() {
5615
+ this.size = 'sm';
5616
+ }
5604
5617
  getStatus() {
5605
5618
  if (this.isDisabled) {
5606
5619
  return 'disabled';
@@ -5610,17 +5623,19 @@ class GravityGenericAvatarComponent {
5610
5623
  }
5611
5624
  }
5612
5625
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityGenericAvatarComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
5613
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityGenericAvatarComponent, selector: "gravity-generic-avatar", inputs: { label: "label", initials: "initials", isDisabled: "isDisabled" }, ngImport: i0, template: "<div class=\"gravity-generic-avatar {{getStatus()}}\">\n <div class=\"gravity-margin-right-xxs\">\n <span class=\"hr-body sm-regular\">{{initials}}</span>\n </div>\n <label class=\"hr-body sm-regular\">{{label}}</label>\n</div>", styles: [":host{display:block}.gravity-generic-avatar{display:flex;align-items:center}.gravity-generic-avatar div{width:24px;height:24px;display:flex;border-radius:50px;align-items:center;justify-content:center;color:var(--avatar-initials-text-color);background-color:var(--avatar-initials-backgroud-color)}.gravity-generic-avatar div span{margin-top:2px}.gravity-generic-avatar label{margin-top:2px;color:var(--avatar-label-color)}.gravity-generic-avatar.active{--avatar-label-color: var(--cl-generic-avatar-label-primary);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-primary);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-primary)}.gravity-generic-avatar.disabled{--avatar-label-color: var(--cl-generic-avatar-label-disabled);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-disabled);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-disabled)}\n"] }); }
5626
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "16.2.12", type: GravityGenericAvatarComponent, selector: "gravity-generic-avatar", inputs: { label: "label", initials: "initials", isDisabled: "isDisabled", size: "size" }, ngImport: i0, template: "<div class=\"gravity-generic-avatar {{getStatus()}} {{size}}\">\n <div class=\"gravity-margin-right-xxs\">\n <span class=\"hr-body sm-bold\">{{initials}}</span>\n </div>\n <label class=\"hr-body\" [ngClass]=\"size === 'sm' ? 'sm-regular' : 'md-bold'\">{{label}}</label>\n</div>", styles: [":host{display:block}.gravity-generic-avatar{display:flex;align-items:center}.gravity-generic-avatar div{width:24px;height:24px;display:flex;border-radius:50px;align-items:center;justify-content:center;color:var(--avatar-initials-text-color);background-color:var(--avatar-initials-backgroud-color)}.gravity-generic-avatar div span{margin-top:2px}.gravity-generic-avatar label{margin-top:2px;color:var(--avatar-label-color)}.gravity-generic-avatar.md div{width:32px;height:32px}.gravity-generic-avatar.active{--avatar-label-color: var(--cl-generic-avatar-label-primary);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-primary);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-primary)}.gravity-generic-avatar.disabled{--avatar-label-color: var(--cl-generic-avatar-label-disabled);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-disabled);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-disabled)}\n"], dependencies: [{ kind: "directive", type: i1$1.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }] }); }
5614
5627
  }
5615
5628
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityGenericAvatarComponent, decorators: [{
5616
5629
  type: Component,
5617
- args: [{ selector: 'gravity-generic-avatar', template: "<div class=\"gravity-generic-avatar {{getStatus()}}\">\n <div class=\"gravity-margin-right-xxs\">\n <span class=\"hr-body sm-regular\">{{initials}}</span>\n </div>\n <label class=\"hr-body sm-regular\">{{label}}</label>\n</div>", styles: [":host{display:block}.gravity-generic-avatar{display:flex;align-items:center}.gravity-generic-avatar div{width:24px;height:24px;display:flex;border-radius:50px;align-items:center;justify-content:center;color:var(--avatar-initials-text-color);background-color:var(--avatar-initials-backgroud-color)}.gravity-generic-avatar div span{margin-top:2px}.gravity-generic-avatar label{margin-top:2px;color:var(--avatar-label-color)}.gravity-generic-avatar.active{--avatar-label-color: var(--cl-generic-avatar-label-primary);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-primary);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-primary)}.gravity-generic-avatar.disabled{--avatar-label-color: var(--cl-generic-avatar-label-disabled);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-disabled);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-disabled)}\n"] }]
5630
+ args: [{ selector: 'gravity-generic-avatar', template: "<div class=\"gravity-generic-avatar {{getStatus()}} {{size}}\">\n <div class=\"gravity-margin-right-xxs\">\n <span class=\"hr-body sm-bold\">{{initials}}</span>\n </div>\n <label class=\"hr-body\" [ngClass]=\"size === 'sm' ? 'sm-regular' : 'md-bold'\">{{label}}</label>\n</div>", styles: [":host{display:block}.gravity-generic-avatar{display:flex;align-items:center}.gravity-generic-avatar div{width:24px;height:24px;display:flex;border-radius:50px;align-items:center;justify-content:center;color:var(--avatar-initials-text-color);background-color:var(--avatar-initials-backgroud-color)}.gravity-generic-avatar div span{margin-top:2px}.gravity-generic-avatar label{margin-top:2px;color:var(--avatar-label-color)}.gravity-generic-avatar.md div{width:32px;height:32px}.gravity-generic-avatar.active{--avatar-label-color: var(--cl-generic-avatar-label-primary);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-primary);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-primary)}.gravity-generic-avatar.disabled{--avatar-label-color: var(--cl-generic-avatar-label-disabled);--avatar-initials-text-color: var(--cl-generic-avatar-initial-text-disabled);--avatar-initials-backgroud-color: var(--on-bg-generic-avatar-initials-disabled)}\n"] }]
5618
5631
  }], propDecorators: { label: [{
5619
5632
  type: Input
5620
5633
  }], initials: [{
5621
5634
  type: Input
5622
5635
  }], isDisabled: [{
5623
5636
  type: Input
5637
+ }], size: [{
5638
+ type: Input
5624
5639
  }] } });
5625
5640
 
5626
5641
  class GravityMultiLanguageComponent {