@progressio_resources/gravity-design-system 2.6.16 → 2.6.17

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.
@@ -102,10 +102,14 @@ export class GravityDropdownListComponent {
102
102
  this.dropdownOpened = !this.dropdownOpened;
103
103
  if (!this.dropdownOpened) {
104
104
  if (this.multiple) {
105
- this.selectedItemsResponse.emit(this.selectedItems);
105
+ if (this.selectedItems?.length > 0) {
106
+ this.selectedItemsResponse.emit(this.selectedItems);
107
+ }
106
108
  }
107
109
  else {
108
- this.selectedItemsResponse.emit(this.selectedItems[0]);
110
+ if (this.selectedItems[0]) {
111
+ this.selectedItemsResponse.emit(this.selectedItems[0]);
112
+ }
109
113
  }
110
114
  this.searchText = '';
111
115
  this.availableOptions = this.items;
@@ -124,7 +128,8 @@ export class GravityDropdownListComponent {
124
128
  }
125
129
  else {
126
130
  this.selectedItems = [itemToAdd];
127
- this.selectedItemsResponse.emit(itemToAdd);
131
+ // this.selectedItemsResponse.emit(itemToAdd);
132
+ this.toggleDropdown();
128
133
  }
129
134
  }
130
135
  checkIfSelected(itemToFind) {
@@ -202,4 +207,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
202
207
  type: HostListener,
203
208
  args: ['document:click', ['$event']]
204
209
  }] } });
205
- //# 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  SimpleChanges\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  @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 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  // Sizes\n  @Input() public size: 'sm' | 'md' = 'md';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\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\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['items']?.currentValue) {\n      this.availableOptions = this.items;\n    }\n\n    if (changes['customValues']?.currentValue) {\n      if (this.multiple) {\n        changes['customValues'].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 = changes['customValues'].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    }\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\n      if (!this.dropdownOpened) {\n        if (this.multiple) {\n          this.selectedItemsResponse.emit(this.selectedItems);\n        } else {\n          this.selectedItemsResponse.emit(this.selectedItems[0]);\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    }\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      if (this.multiple) {\n        this.selectedItemsResponse.emit(this.selectedItems);\n      } else {\n        this.selectedItemsResponse.emit(this.selectedItems[0]);\n      }\n\n      this.searchText = '';\n      this.availableOptions = this.items;\n    }\n  }\n}\n","<label class=\"hr-label sm-bold {{getStatus()}}\" *ngIf=\"label\">\n  {{label}} <span *ngIf=\"required || hasError\">*</span>\n</label>\n<div [attr.data-cy]=\"cypressTag\" class=\"gravity-input-field {{size}} {{width}}-width {{getStatus()}}\"\n     (click)=\"toggleDropdown()\">\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'\" [iconSize]=\"'md-16'\"\n                *ngIf=\"!isReadonly\"></gravity-icon>\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'\" autofocus\n             [(ngModel)]=\"searchText\" placeholder=\"{{currentLang == 'es' ? 'Limpiar' : '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    <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 [checked]=\"checkIfSelected(item)\" *ngIf=\"multiple\">\n          {{config ? item[config.label] : item}}\n        </gravity-checkbox>\n        <ng-container *ngIf=\"!multiple\">{{config ? item[config.label] : item}}</ng-container>\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 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<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"]}
210
+ //# 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  SimpleChanges\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  @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 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  // Sizes\n  @Input() public size: 'sm' | 'md' = 'md';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\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\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['items']?.currentValue) {\n      this.availableOptions = this.items;\n    }\n\n    if (changes['customValues']?.currentValue) {\n      if (this.multiple) {\n        changes['customValues'].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 = changes['customValues'].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    }\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\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      if (this.multiple) {\n        this.selectedItemsResponse.emit(this.selectedItems);\n      } else {\n        this.selectedItemsResponse.emit(this.selectedItems[0]);\n      }\n\n      this.searchText = '';\n      this.availableOptions = this.items;\n    }\n  }\n}\n","<label class=\"hr-label sm-bold {{getStatus()}}\" *ngIf=\"label\">\n  {{label}} <span *ngIf=\"required || hasError\">*</span>\n</label>\n<div [attr.data-cy]=\"cypressTag\" class=\"gravity-input-field {{size}} {{width}}-width {{getStatus()}}\"\n     (click)=\"toggleDropdown()\">\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'\" [iconSize]=\"'md-16'\"\n                *ngIf=\"!isReadonly\"></gravity-icon>\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'\" autofocus\n             [(ngModel)]=\"searchText\" placeholder=\"{{currentLang == 'es' ? 'Limpiar' : '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    <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 [checked]=\"checkIfSelected(item)\" *ngIf=\"multiple\">\n          {{config ? item[config.label] : item}}\n        </gravity-checkbox>\n        <ng-container *ngIf=\"!multiple\">{{config ? item[config.label] : item}}</ng-container>\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 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<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"]}
@@ -303,10 +303,14 @@ class GravityDropdownListComponent {
303
303
  this.dropdownOpened = !this.dropdownOpened;
304
304
  if (!this.dropdownOpened) {
305
305
  if (this.multiple) {
306
- this.selectedItemsResponse.emit(this.selectedItems);
306
+ if (this.selectedItems?.length > 0) {
307
+ this.selectedItemsResponse.emit(this.selectedItems);
308
+ }
307
309
  }
308
310
  else {
309
- this.selectedItemsResponse.emit(this.selectedItems[0]);
311
+ if (this.selectedItems[0]) {
312
+ this.selectedItemsResponse.emit(this.selectedItems[0]);
313
+ }
310
314
  }
311
315
  this.searchText = '';
312
316
  this.availableOptions = this.items;
@@ -325,7 +329,8 @@ class GravityDropdownListComponent {
325
329
  }
326
330
  else {
327
331
  this.selectedItems = [itemToAdd];
328
- this.selectedItemsResponse.emit(itemToAdd);
332
+ // this.selectedItemsResponse.emit(itemToAdd);
333
+ this.toggleDropdown();
329
334
  }
330
335
  }
331
336
  checkIfSelected(itemToFind) {