@progressio_resources/gravity-design-system 2.6.15 → 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":"AAAA,OAAO,EACL,SAAS,EAET,YAAY,EACZ,YAAY,EACZ,KAAK,EAEL,MAAM,EAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,oBAAoB,EAAC,MAAM,wCAAwC,CAAC;AAC5E,OAAO,EAAC,YAAY,EAAC,MAAM,kBAAkB,CAAC;;;;;;;AAQ9C,MAAM,OAAO,4BAA4B;IA4BvC,YAA6B,YAA0B,EAAU,KAAiB;QAArD,iBAAY,GAAZ,YAAY,CAAc;QAAU,UAAK,GAAL,KAAK,CAAY;QA3BvD,0BAAqB,GAA8B,IAAI,YAAY,EAAE,CAAC;QAEjF,cAAS,GAAY,IAAI,CAAC;QAE1B,gBAAW,GAAW,IAAI,CAAC;QAG3B,aAAQ,GAAY,KAAK,CAAC;QAE1B,eAAU,GAAY,KAAK,CAAC;QAC5B,eAAU,GAAY,KAAK,CAAC;QAG5B,aAAQ,GAAY,KAAK,CAAC;QAE1B,aAAQ,GAAY,KAAK,CAAC;QAG1C,QAAQ;QACQ,SAAI,GAAgB,IAAI,CAAC;QACzB,UAAK,GAAwC,OAAO,CAAC;QAE9D,qBAAgB,GAAU,EAAE,CAAC;QAC7B,mBAAc,GAAY,KAAK,CAAC;QAChC,eAAU,GAAW,EAAE,CAAC;QACxB,kBAAa,GAAU,EAAE,CAAC;IAGjC,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,YAAY,EAAE;YAClC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC;SACpC;QAED,IAAI,OAAO,CAAC,cAAc,CAAC,EAAE,YAAY,EAAE;YACzC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,OAAO,CAAC,cAAc,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;oBACzD,IAAI,IAAI,EAAE;wBACR,IAAI,MAAW,CAAC;wBAEhB,IAAI,IAAI,CAAC,MAAM,EAAE;4BACf,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC;yBAC3G;6BAAM;4BACL,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,IAAI,IAAI,CAAC,CAAC;yBACxF;wBAED,IAAI,MAAM,EAAE;4BACV,IAAI,WAAW,GAAW,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,IAAI,MAAM,CAAC,CAAC;4BAE5G,IAAI,WAAW,IAAI,CAAC,CAAC,EAAE;gCACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;6BACjC;yBACF;qBACF;gBACH,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,IAAI,IAAI,GAAQ,OAAO,CAAC,cAAc,CAAC,CAAC,YAAY,CAAC;gBAErD,IAAI,IAAI,EAAE;oBACR,IAAI,MAAW,CAAC;oBAEhB,IAAI,IAAI,CAAC,MAAM,EAAE;wBACf,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC;qBAC3G;yBAAM;wBACL,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,IAAI,IAAI,CAAC,CAAC;qBACxF;oBAED,IAAI,MAAM,EAAE;wBACV,IAAI,WAAW,GAAW,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,IAAI,MAAM,CAAC,CAAC;wBAE5G,IAAI,WAAW,IAAI,CAAC,CAAC,EAAE;4BACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;yBACjC;qBACF;iBACF;aACF;SACF;IACH,CAAC;IAEM,SAAS;QACd,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,UAAU,CAAC;SACnB;aAAM,IAAI,IAAI,CAAC,UAAU,EAAE;YAC1B,OAAO,UAAU,CAAC;SACnB;aAAM,IAAI,IAAI,CAAC,QAAQ,EAAE;YACxB,OAAO,OAAO,CAAC;SAChB;aAAM,IAAI,IAAI,CAAC,cAAc,EAAE;YAC9B,OAAO,MAAM,CAAC;SACf;aAAM,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YACxC,OAAO,UAAU,CAAC;SACnB;aAAM;YACL,OAAO,QAAQ,CAAC;SACjB;IACH,CAAC;IAEM,aAAa;QAClB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO,oBAAoB,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACtD;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACxC,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC;YAE3C,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;gBACxB,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;iBACrD;qBAAM;oBACL,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;iBACxD;gBAED,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;gBACrB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC;aACpC;SACF;IACH,CAAC;IAEM,UAAU,CAAC,SAAc;QAC9B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,WAAW,GAAW,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,CAAC;YAEzF,IAAI,WAAW,IAAI,CAAC,CAAC,EAAE;gBACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aACpC;iBAAM;gBACL,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;aAC3C;SACF;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,CAAC,SAAS,CAAC,CAAC;YACjC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;SAC5C;IACH,CAAC;IAEM,eAAe,CAAC,UAAe;QACpC,OAAO,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,UAAU,IAAI,IAAI,CAAC,CAAC;IACtE,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACrD;aAAM;YACL,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACvC;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACnF,CAAC;IAE2C,eAAe,CAAC,MAAoB;QAC9E,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,cAAc,EAAE;YAC5E,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAE5B,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACrD;iBAAM;gBACL,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;aACxD;YAED,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC;SACpC;IACH,CAAC;+GAxKU,4BAA4B;mGAA5B,4BAA4B,kjBAF5B,CAAC,YAAY,CAAC,+CCjB3B,shHA6DA;;4FD1Ca,4BAA4B;kBANxC,SAAS;+BACE,uBAAuB,aAGtB,CAAC,YAAY,CAAC;4HAGE,qBAAqB;sBAA/C,MAAM;uBAAC,UAAU;gBAEF,SAAS;sBAAxB,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBAGU,IAAI;sBAAnB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBAsIsC,eAAe;sBAA1D,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","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":"AAAA,OAAO,EACL,SAAS,EAET,YAAY,EACZ,YAAY,EACZ,KAAK,EAEL,MAAM,EAEP,MAAM,eAAe,CAAC;AACvB,OAAO,EAAC,oBAAoB,EAAC,MAAM,wCAAwC,CAAC;AAC5E,OAAO,EAAC,YAAY,EAAC,MAAM,kBAAkB,CAAC;;;;;;;AAQ9C,MAAM,OAAO,4BAA4B;IA4BvC,YAA6B,YAA0B,EAAU,KAAiB;QAArD,iBAAY,GAAZ,YAAY,CAAc;QAAU,UAAK,GAAL,KAAK,CAAY;QA3BvD,0BAAqB,GAA8B,IAAI,YAAY,EAAE,CAAC;QAEjF,cAAS,GAAY,IAAI,CAAC;QAE1B,gBAAW,GAAW,IAAI,CAAC;QAG3B,aAAQ,GAAY,KAAK,CAAC;QAE1B,eAAU,GAAY,KAAK,CAAC;QAC5B,eAAU,GAAY,KAAK,CAAC;QAG5B,aAAQ,GAAY,KAAK,CAAC;QAE1B,aAAQ,GAAY,KAAK,CAAC;QAG1C,QAAQ;QACQ,SAAI,GAAgB,IAAI,CAAC;QACzB,UAAK,GAAwC,OAAO,CAAC;QAE9D,qBAAgB,GAAU,EAAE,CAAC;QAC7B,mBAAc,GAAY,KAAK,CAAC;QAChC,eAAU,GAAW,EAAE,CAAC;QACxB,kBAAa,GAAU,EAAE,CAAC;IAGjC,CAAC;IAED,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,CAAC,EAAE,YAAY,EAAE;YAClC,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC;SACpC;QAED,IAAI,OAAO,CAAC,cAAc,CAAC,EAAE,YAAY,EAAE;YACzC,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,OAAO,CAAC,cAAc,CAAC,CAAC,YAAY,CAAC,OAAO,CAAC,CAAC,IAAS,EAAE,EAAE;oBACzD,IAAI,IAAI,EAAE;wBACR,IAAI,MAAW,CAAC;wBAEhB,IAAI,IAAI,CAAC,MAAM,EAAE;4BACf,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC;yBAC3G;6BAAM;4BACL,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,IAAI,IAAI,CAAC,CAAC;yBACxF;wBAED,IAAI,MAAM,EAAE;4BACV,IAAI,WAAW,GAAW,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,IAAI,MAAM,CAAC,CAAC;4BAE5G,IAAI,WAAW,IAAI,CAAC,CAAC,EAAE;gCACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;6BACjC;yBACF;qBACF;gBACH,CAAC,CAAC,CAAC;aACJ;iBAAM;gBACL,IAAI,IAAI,GAAQ,OAAO,CAAC,cAAc,CAAC,CAAC,YAAY,CAAC;gBAErD,IAAI,IAAI,EAAE;oBACR,IAAI,MAAW,CAAC;oBAEhB,IAAI,IAAI,CAAC,MAAM,EAAE;wBACf,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,CAAC,IAAI,CAAC,MAAM,CAAC,KAAK,CAAC,IAAI,IAAI,CAAC,CAAC;qBAC3G;yBAAM;wBACL,MAAM,GAAG,IAAI,CAAC,gBAAgB,CAAC,IAAI,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,IAAI,IAAI,CAAC,CAAC;qBACxF;oBAED,IAAI,MAAM,EAAE;wBACV,IAAI,WAAW,GAAW,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,eAAoB,EAAE,EAAE,CAAC,eAAe,IAAI,MAAM,CAAC,CAAC;wBAE5G,IAAI,WAAW,IAAI,CAAC,CAAC,EAAE;4BACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;yBACjC;qBACF;iBACF;aACF;SACF;IACH,CAAC;IAEM,SAAS;QACd,IAAI,IAAI,CAAC,UAAU,EAAE;YACnB,OAAO,UAAU,CAAC;SACnB;aAAM,IAAI,IAAI,CAAC,UAAU,EAAE;YAC1B,OAAO,UAAU,CAAC;SACnB;aAAM,IAAI,IAAI,CAAC,QAAQ,EAAE;YACxB,OAAO,OAAO,CAAC;SAChB;aAAM,IAAI,IAAI,CAAC,cAAc,EAAE;YAC9B,OAAO,MAAM,CAAC;SACf;aAAM,IAAI,IAAI,CAAC,aAAa,CAAC,MAAM,GAAG,CAAC,EAAE;YACxC,OAAO,UAAU,CAAC;SACnB;aAAM;YACL,OAAO,QAAQ,CAAC;SACjB;IACH,CAAC;IAEM,aAAa;QAClB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,OAAO,oBAAoB,CAAC,SAAS,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;SACtD;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,IAAI,CAAC,UAAU,IAAI,CAAC,IAAI,CAAC,UAAU,EAAE;YACxC,IAAI,CAAC,cAAc,GAAG,CAAC,IAAI,CAAC,cAAc,CAAC;YAE3C,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE;gBACxB,IAAI,IAAI,CAAC,QAAQ,EAAE;oBACjB,IAAI,IAAI,CAAC,aAAa,EAAE,MAAM,GAAG,CAAC,EAAE;wBAClC,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;qBACrD;iBACF;qBAAM;oBACL,IAAI,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,EAAE;wBACzB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;qBACxD;iBACF;gBAED,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;gBACrB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC;aACpC;SACF;IACH,CAAC;IAEM,UAAU,CAAC,SAAc;QAC9B,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,WAAW,GAAW,IAAI,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,IAAI,IAAI,SAAS,CAAC,CAAC;YAEzF,IAAI,WAAW,IAAI,CAAC,CAAC,EAAE;gBACrB,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;aACpC;iBAAM;gBACL,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,WAAW,EAAE,CAAC,CAAC,CAAC;aAC3C;SACF;aAAM;YACL,IAAI,CAAC,aAAa,GAAG,CAAC,SAAS,CAAC,CAAC;YACjC,8CAA8C;YAC9C,IAAI,CAAC,cAAc,EAAE,CAAC;SACvB;IACH,CAAC;IAEM,eAAe,CAAC,UAAe;QACpC,OAAO,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,CAAC,IAAS,EAAE,EAAE,CAAC,UAAU,IAAI,IAAI,CAAC,CAAC;IACtE,CAAC;IAEM,cAAc;QACnB,IAAI,CAAC,aAAa,GAAG,EAAE,CAAC;QAExB,IAAI,IAAI,CAAC,QAAQ,EAAE;YACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;SACrD;aAAM;YACL,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC;SACvC;IACH,CAAC;IAEM,WAAW;QAChB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,CAAC,IAAI,CAAC,KAAK,EAAE,IAAI,CAAC,UAAU,CAAC,CAAC;IACnF,CAAC;IAE2C,eAAe,CAAC,MAAoB;QAC9E,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,QAAQ,CAAC,MAAM,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,cAAc,EAAE;YAC5E,IAAI,CAAC,cAAc,GAAG,KAAK,CAAC;YAE5B,IAAI,IAAI,CAAC,QAAQ,EAAE;gBACjB,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACrD;iBAAM;gBACL,IAAI,CAAC,qBAAqB,CAAC,IAAI,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC,CAAC,CAAC,CAAC;aACxD;YAED,IAAI,CAAC,UAAU,GAAG,EAAE,CAAC;YACrB,IAAI,CAAC,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC;SACpC;IACH,CAAC;+GA7KU,4BAA4B;mGAA5B,4BAA4B,kjBAF5B,CAAC,YAAY,CAAC,+CCjB3B,shHA6DA;;4FD1Ca,4BAA4B;kBANxC,SAAS;+BACE,uBAAuB,aAGtB,CAAC,YAAY,CAAC;4HAGE,qBAAqB;sBAA/C,MAAM;uBAAC,UAAU;gBAEF,SAAS;sBAAxB,KAAK;gBACU,MAAM;sBAArB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,YAAY;sBAA3B,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,UAAU;sBAAzB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBACU,QAAQ;sBAAvB,KAAK;gBACU,WAAW;sBAA1B,KAAK;gBAGU,IAAI;sBAAnB,KAAK;gBACU,KAAK;sBAApB,KAAK;gBA2IsC,eAAe;sBAA1D,YAAY;uBAAC,gBAAgB,EAAE,CAAC,QAAQ,CAAC","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"]}
@@ -107,7 +107,8 @@ export class GravityTextFieldComponent {
107
107
  ($event.key === 'a' && $event.metaKey === true) || // Allow: Cmd+A (Mac)
108
108
  ($event.key === 'c' && $event.metaKey === true) || // Allow: Cmd+C (Mac)
109
109
  ($event.key === 'v' && $event.metaKey === true) || // Allow: Cmd+V (Mac)
110
- ($event.key === 'x' && $event.metaKey === true) // Allow: Cmd+X (Mac)
110
+ ($event.key === 'x' && $event.metaKey === true) || // Allow: Cmd+X (Mac)
111
+ ($event.key === '.') || ($event.key === ',') // Allow: dot and comma for decimal
111
112
  ) {
112
113
  // let it happen, don't do anything
113
114
  return;
@@ -179,4 +180,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
179
180
  }], width: [{
180
181
  type: Input
181
182
  }] } });
182
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-text-field.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild} from '@angular/core';\nimport {GravityIconComponent} from \"../gravity-icon/gravity-icon.component\";\n\n@Component({\n  selector: 'gravity-text-field',\n  templateUrl: './gravity-text-field.component.html',\n  styleUrls: ['./gravity-text-field.component.scss']\n})\nexport class GravityTextFieldComponent implements OnInit, OnChanges {\n  @Output('clickIconLeft') public leftIconResponse: EventEmitter<void> = new EventEmitter();\n  @Output('clickIconRight') public rightIconResponse: EventEmitter<void> = new EventEmitter();\n  @Output('response') public textFieldValueResponse: EventEmitter<string> = new EventEmitter();\n\n  @ViewChild('inputElement', {static: false}) private inputElement: any;\n  @ViewChild('textAreaElement', {static: false}) private textAreaElement: any;\n\n  // Component\n  @Input() public currentLang: string = 'en';\n  @Input() public customInputValue: string;\n  @Input() public customState: 'default' | 'active' | 'hover' | 'typing' | 'typed' | 'typed-error' | 'typed-positive' | 'disabled' | 'readonly' | 'autofill' = 'default';\n  @Input() public cypressTag: string;\n  @Input() public label: string;\n  @Input() public prefix: string = \"\";\n  @Input() public required: boolean;\n  @Input() public supportText: string;\n  @Input() public textFieldType: 'input' | 'textarea' = \"input\";\n\n  // Icons\n  @Input() public clickOnLeftIcon: boolean = false;\n  @Input() public clickOnRightIcon: boolean = false;\n  @Input() public iconLeft: string;\n  @Input() public iconRight: string;\n\n  // Input | Textarea\n  @Input() public autocomplete: string = 'off';\n  @Input() public inputContentType: 'email' | 'number' | 'password' | 'tel' | 'text' = \"text\";\n  @Input() public placeholder: string;\n  @Input() public validations: { maxLength?: number; minLength?: number };\n\n  // Sizes\n  @Input() public size: 'sm' | 'md' = 'md';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\n\n  public focusInput: boolean = false;\n  public inputValue: string = '';\n\n  ngOnInit(): void {\n    this.inputValue = this.customInputValue ? this.customInputValue : '';\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['customInputValue']) {\n      this.inputValue = changes['customInputValue'].currentValue ? changes['customInputValue'].currentValue : '';\n    }\n  }\n\n  public getPlaceholder(): string {\n    if (this.placeholder && this.placeholder != '') {\n      return this.placeholder;\n    } else {\n      return this.label;\n    }\n  }\n\n  public clearInput(): void {\n    this.changeInputValue(true);\n  }\n\n  public changeInputValue(clearInput: boolean = false): void {\n    if (clearInput) {\n      this.inputValue = '';\n    } else if (this.textFieldType == 'input') {\n      this.inputValue = this.inputElement.nativeElement.value;\n    } else {\n      this.inputValue = this.textAreaElement.nativeElement.value;\n    }\n\n    if (this.inputValue == '') {\n      this.textFieldValueResponse.emit('');\n    } else {\n      this.textFieldValueResponse.emit(this.prefix + this.inputValue);\n    }\n  }\n\n  public handleIconClick(iconPosition: 'left' | 'right'): void {\n    if (iconPosition == 'left' && this.clickOnLeftIcon) {\n      this.leftIconResponse.emit();\n    }\n\n    if (iconPosition == 'right' && this.clickOnRightIcon) {\n      this.rightIconResponse.emit();\n    }\n  }\n\n  public getTextFieldStatus(): string {\n    if (this.customState == 'default') {\n      if (!this.focusInput && !this.inputValue) {\n        return 'active';\n      } else if (!this.focusInput && this.inputValue) {\n        return 'typed';\n      } else {\n        return 'typing';\n      }\n    } else {\n      return this.customState;\n    }\n  }\n\n  public getTextFieldInputFontSize(): string {\n    return 'hr-label ' + this.size + '-regular';\n  }\n\n  public isNewIcon(iconPosition: 'left' | 'right'): boolean {\n    if (iconPosition == 'left') {\n      return GravityIconComponent.isNewIcon(this.iconLeft);\n    } else {\n      return GravityIconComponent.isNewIcon(this.iconRight);\n    }\n  }\n\n  public onKeyDownEvent($event: KeyboardEvent): void {\n    if (this.inputContentType == 'number') {\n      let navigationKeys = ['Backspace', 'Delete', 'Tab', 'Escape', 'Enter', 'Home', 'End', 'ArrowLeft', 'ArrowRight', 'Clear', 'Copy', 'Paste'];\n\n      if (\n        navigationKeys.indexOf($event.key) > -1 || // Allow: navigation keys: backspace, delete, arrows etc.\n        ($event.key === 'a' && $event.ctrlKey === true) || // Allow: Ctrl+A\n        ($event.key === 'c' && $event.ctrlKey === true) || // Allow: Ctrl+C\n        ($event.key === 'v' && $event.ctrlKey === true) || // Allow: Ctrl+V\n        ($event.key === 'x' && $event.ctrlKey === true) || // Allow: Ctrl+X\n        ($event.key === 'a' && $event.metaKey === true) || // Allow: Cmd+A (Mac)\n        ($event.key === 'c' && $event.metaKey === true) || // Allow: Cmd+C (Mac)\n        ($event.key === 'v' && $event.metaKey === true) || // Allow: Cmd+V (Mac)\n        ($event.key === 'x' && $event.metaKey === true) // Allow: Cmd+X (Mac)\n      ) {\n        // let it happen, don't do anything\n        return;\n      }\n\n      // Ensure that it is a number and stop the keypress\n      if (\n        ($event.shiftKey || ($event.keyCode < 48 || $event.keyCode > 57)) &&\n        ($event.keyCode < 96 || $event.keyCode > 105)\n      ) {\n        $event.preventDefault();\n      }\n    }\n  }\n}\n","<label class=\"hr-label sm-bold {{getTextFieldStatus()}}\" [class.custom-label-size]=\"size == 'sm'\" *ngIf=\"label\">\n  {{label}} <span *ngIf=\"required || getTextFieldStatus() == 'typed-error'\">*</span>\n</label>\n<div class=\"gravity-input-field {{size}} {{width}}-width {{getTextFieldStatus()}}\">\n  <ng-container *ngIf=\"iconLeft\">\n    <ng-container [ngTemplateOutlet]=\"icons\" [ngTemplateOutletContext]=\"{iconPosition: 'left'}\"></ng-container>\n  </ng-container>\n  <span class=\"{{getTextFieldInputFontSize()}} prefix\">{{prefix}}</span>\n  <input [attr.data-cy]=\"cypressTag\"\n         [attr.disabled]=\"customState == 'disabled' ? true : null\"\n         [attr.readonly]=\"customState == 'readonly' ? true : null\"\n         [autocomplete]=\"autocomplete\"\n         [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n         [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n         [placeholder]=\"getPlaceholder()\"\n         [type]=\"inputContentType != 'number' ? inputContentType : 'text'\"\n         [value]=\"inputValue\"\n\n         (blur)=\"focusInput = false\"\n         (change)=\"changeInputValue()\"\n         (focus)=\"focusInput = true\"\n         (keydown)=\"onKeyDownEvent($event)\"\n         (keyup)=\"changeInputValue()\"\n\n         class=\"{{getTextFieldInputFontSize()}}\"\n\n         #inputElement\n\n         *ngIf=\"textFieldType == 'input'\">\n  <textarea [attr.data-cy]=\"cypressTag\"\n            [attr.disabled]=\"customState == 'disabled' ? true : null\"\n            [attr.readonly]=\"customState == 'readonly' ? true : null\"\n            [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n            [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n            [placeholder]=\"getPlaceholder()\"\n            [value]=\"inputValue\"\n\n            (blur)=\"focusInput = false\"\n            (change)=\"changeInputValue()\"\n            (focus)=\"focusInput = true\"\n            (keydown)=\"onKeyDownEvent($event)\"\n            (keyup)=\"changeInputValue()\"\n\n            class=\"{{getTextFieldInputFontSize()}}\"\n            rows=\"1\"\n\n            #textAreaElement\n\n            *ngIf=\"textFieldType == 'textarea'\"></textarea>\n  <ng-container *ngIf=\"iconRight\">\n    <ng-container [ngTemplateOutlet]=\"icons\" [ngTemplateOutletContext]=\"{iconPosition: 'right'}\"></ng-container>\n  </ng-container>\n</div>\n<p class=\"hr-label sm-regular supporting-text {{getTextFieldStatus()}} {{size}}\"\n   [class.custom-label-size]=\"size == 'sm'\" *ngIf=\"supportText\">\n  <gravity-icon [iconName]=\"'question-circle'\" *ngIf=\"getTextFieldStatus() == 'typed-error'\"\n                [iconSize]=\"'md-16'\"></gravity-icon>\n  {{supportText}}\n</p>\n<p class=\"hr-label sm-regular supporting-text {{getTextFieldStatus()}} {{size}}\"\n   [class.custom-label-size]=\"size == 'sm'\"\n   *ngIf=\"!supportText && getTextFieldStatus() == 'active' && inputValue == '' && required\">\n  {{currentLang == 'es' ? 'Requerido' : 'Required'}}\n</p>\n\n<ng-template #icons let-iconPosition=\"iconPosition\">\n  <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(iconPosition)\" class=\"{{iconPosition}}\"\n                [class.pointer]=\"(iconPosition == 'left' && clickOnLeftIcon) || (iconPosition == 'right' && clickOnRightIcon)\"\n                [iconName]=\"iconPosition == 'left' ? iconLeft : iconRight\"\n                [iconSize]=\"isNewIcon(iconPosition) ? 'md-16' : null\"></gravity-icon>\n</ng-template>\n"]}
183
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"gravity-text-field.component.js","sourceRoot":"","sources":["../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.ts","../../../../../../projects/gravity-design-system/src/lib/components/gravity-text-field/gravity-text-field.component.html"],"names":[],"mappings":"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","sourcesContent":["import {Component, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, ViewChild} from '@angular/core';\nimport {GravityIconComponent} from \"../gravity-icon/gravity-icon.component\";\n\n@Component({\n  selector: 'gravity-text-field',\n  templateUrl: './gravity-text-field.component.html',\n  styleUrls: ['./gravity-text-field.component.scss']\n})\nexport class GravityTextFieldComponent implements OnInit, OnChanges {\n  @Output('clickIconLeft') public leftIconResponse: EventEmitter<void> = new EventEmitter();\n  @Output('clickIconRight') public rightIconResponse: EventEmitter<void> = new EventEmitter();\n  @Output('response') public textFieldValueResponse: EventEmitter<string> = new EventEmitter();\n\n  @ViewChild('inputElement', {static: false}) private inputElement: any;\n  @ViewChild('textAreaElement', {static: false}) private textAreaElement: any;\n\n  // Component\n  @Input() public currentLang: string = 'en';\n  @Input() public customInputValue: string;\n  @Input() public customState: 'default' | 'active' | 'hover' | 'typing' | 'typed' | 'typed-error' | 'typed-positive' | 'disabled' | 'readonly' | 'autofill' = 'default';\n  @Input() public cypressTag: string;\n  @Input() public label: string;\n  @Input() public prefix: string = \"\";\n  @Input() public required: boolean;\n  @Input() public supportText: string;\n  @Input() public textFieldType: 'input' | 'textarea' = \"input\";\n\n  // Icons\n  @Input() public clickOnLeftIcon: boolean = false;\n  @Input() public clickOnRightIcon: boolean = false;\n  @Input() public iconLeft: string;\n  @Input() public iconRight: string;\n\n  // Input | Textarea\n  @Input() public autocomplete: string = 'off';\n  @Input() public inputContentType: 'email' | 'number' | 'password' | 'tel' | 'text' = \"text\";\n  @Input() public placeholder: string;\n  @Input() public validations: { maxLength?: number; minLength?: number };\n\n  // Sizes\n  @Input() public size: 'sm' | 'md' = 'md';\n  @Input() public width: 'short' | 'medium' | 'full' | 'fit' = 'short';\n\n  public focusInput: boolean = false;\n  public inputValue: string = '';\n\n  ngOnInit(): void {\n    this.inputValue = this.customInputValue ? this.customInputValue : '';\n  }\n\n  ngOnChanges(changes: SimpleChanges) {\n    if (changes['customInputValue']) {\n      this.inputValue = changes['customInputValue'].currentValue ? changes['customInputValue'].currentValue : '';\n    }\n  }\n\n  public getPlaceholder(): string {\n    if (this.placeholder && this.placeholder != '') {\n      return this.placeholder;\n    } else {\n      return this.label;\n    }\n  }\n\n  public clearInput(): void {\n    this.changeInputValue(true);\n  }\n\n  public changeInputValue(clearInput: boolean = false): void {\n    if (clearInput) {\n      this.inputValue = '';\n    } else if (this.textFieldType == 'input') {\n      this.inputValue = this.inputElement.nativeElement.value;\n    } else {\n      this.inputValue = this.textAreaElement.nativeElement.value;\n    }\n\n    if (this.inputValue == '') {\n      this.textFieldValueResponse.emit('');\n    } else {\n      this.textFieldValueResponse.emit(this.prefix + this.inputValue);\n    }\n  }\n\n  public handleIconClick(iconPosition: 'left' | 'right'): void {\n    if (iconPosition == 'left' && this.clickOnLeftIcon) {\n      this.leftIconResponse.emit();\n    }\n\n    if (iconPosition == 'right' && this.clickOnRightIcon) {\n      this.rightIconResponse.emit();\n    }\n  }\n\n  public getTextFieldStatus(): string {\n    if (this.customState == 'default') {\n      if (!this.focusInput && !this.inputValue) {\n        return 'active';\n      } else if (!this.focusInput && this.inputValue) {\n        return 'typed';\n      } else {\n        return 'typing';\n      }\n    } else {\n      return this.customState;\n    }\n  }\n\n  public getTextFieldInputFontSize(): string {\n    return 'hr-label ' + this.size + '-regular';\n  }\n\n  public isNewIcon(iconPosition: 'left' | 'right'): boolean {\n    if (iconPosition == 'left') {\n      return GravityIconComponent.isNewIcon(this.iconLeft);\n    } else {\n      return GravityIconComponent.isNewIcon(this.iconRight);\n    }\n  }\n\n  public onKeyDownEvent($event: KeyboardEvent): void {\n    if (this.inputContentType == 'number') {\n      let navigationKeys = ['Backspace', 'Delete', 'Tab', 'Escape', 'Enter', 'Home', 'End', 'ArrowLeft', 'ArrowRight', 'Clear', 'Copy', 'Paste'];\n\n      if (\n        navigationKeys.indexOf($event.key) > -1 || // Allow: navigation keys: backspace, delete, arrows etc.\n        ($event.key === 'a' && $event.ctrlKey === true) || // Allow: Ctrl+A\n        ($event.key === 'c' && $event.ctrlKey === true) || // Allow: Ctrl+C\n        ($event.key === 'v' && $event.ctrlKey === true) || // Allow: Ctrl+V\n        ($event.key === 'x' && $event.ctrlKey === true) || // Allow: Ctrl+X\n        ($event.key === 'a' && $event.metaKey === true) || // Allow: Cmd+A (Mac)\n        ($event.key === 'c' && $event.metaKey === true) || // Allow: Cmd+C (Mac)\n        ($event.key === 'v' && $event.metaKey === true) || // Allow: Cmd+V (Mac)\n        ($event.key === 'x' && $event.metaKey === true) ||// Allow: Cmd+X (Mac)\n        ($event.key === '.') || ($event.key === ',') // Allow: dot and comma for decimal\n      ) {\n        // let it happen, don't do anything\n        return;\n      }\n\n      // Ensure that it is a number and stop the keypress\n      if (\n        ($event.shiftKey || ($event.keyCode < 48 || $event.keyCode > 57)) &&\n        ($event.keyCode < 96 || $event.keyCode > 105)\n      ) {\n        $event.preventDefault();\n      }\n    }\n  }\n}\n","<label class=\"hr-label sm-bold {{getTextFieldStatus()}}\" [class.custom-label-size]=\"size == 'sm'\" *ngIf=\"label\">\n  {{label}} <span *ngIf=\"required || getTextFieldStatus() == 'typed-error'\">*</span>\n</label>\n<div class=\"gravity-input-field {{size}} {{width}}-width {{getTextFieldStatus()}}\">\n  <ng-container *ngIf=\"iconLeft\">\n    <ng-container [ngTemplateOutlet]=\"icons\" [ngTemplateOutletContext]=\"{iconPosition: 'left'}\"></ng-container>\n  </ng-container>\n  <span class=\"{{getTextFieldInputFontSize()}} prefix\">{{prefix}}</span>\n  <input [attr.data-cy]=\"cypressTag\"\n         [attr.disabled]=\"customState == 'disabled' ? true : null\"\n         [attr.readonly]=\"customState == 'readonly' ? true : null\"\n         [autocomplete]=\"autocomplete\"\n         [maxLength]=\"validations?.maxLength ? validations?.maxLength : 100\"\n         [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n         [placeholder]=\"getPlaceholder()\"\n         [type]=\"inputContentType != 'number' ? inputContentType : 'text'\"\n         [value]=\"inputValue\"\n\n         (blur)=\"focusInput = false\"\n         (change)=\"changeInputValue()\"\n         (focus)=\"focusInput = true\"\n         (keydown)=\"onKeyDownEvent($event)\"\n         (keyup)=\"changeInputValue()\"\n\n         class=\"{{getTextFieldInputFontSize()}}\"\n\n         #inputElement\n\n         *ngIf=\"textFieldType == 'input'\">\n  <textarea [attr.data-cy]=\"cypressTag\"\n            [attr.disabled]=\"customState == 'disabled' ? true : null\"\n            [attr.readonly]=\"customState == 'readonly' ? true : null\"\n            [maxLength]=\"validations?.maxLength ? validations?.maxLength : 200\"\n            [minLength]=\"validations?.minLength ? validations?.minLength : 0\"\n            [placeholder]=\"getPlaceholder()\"\n            [value]=\"inputValue\"\n\n            (blur)=\"focusInput = false\"\n            (change)=\"changeInputValue()\"\n            (focus)=\"focusInput = true\"\n            (keydown)=\"onKeyDownEvent($event)\"\n            (keyup)=\"changeInputValue()\"\n\n            class=\"{{getTextFieldInputFontSize()}}\"\n            rows=\"1\"\n\n            #textAreaElement\n\n            *ngIf=\"textFieldType == 'textarea'\"></textarea>\n  <ng-container *ngIf=\"iconRight\">\n    <ng-container [ngTemplateOutlet]=\"icons\" [ngTemplateOutletContext]=\"{iconPosition: 'right'}\"></ng-container>\n  </ng-container>\n</div>\n<p class=\"hr-label sm-regular supporting-text {{getTextFieldStatus()}} {{size}}\"\n   [class.custom-label-size]=\"size == 'sm'\" *ngIf=\"supportText\">\n  <gravity-icon [iconName]=\"'question-circle'\" *ngIf=\"getTextFieldStatus() == 'typed-error'\"\n                [iconSize]=\"'md-16'\"></gravity-icon>\n  {{supportText}}\n</p>\n<p class=\"hr-label sm-regular supporting-text {{getTextFieldStatus()}} {{size}}\"\n   [class.custom-label-size]=\"size == 'sm'\"\n   *ngIf=\"!supportText && getTextFieldStatus() == 'active' && inputValue == '' && required\">\n  {{currentLang == 'es' ? 'Requerido' : 'Required'}}\n</p>\n\n<ng-template #icons let-iconPosition=\"iconPosition\">\n  <gravity-icon (click)=\"$event.stopPropagation(); handleIconClick(iconPosition)\" class=\"{{iconPosition}}\"\n                [class.pointer]=\"(iconPosition == 'left' && clickOnLeftIcon) || (iconPosition == 'right' && clickOnRightIcon)\"\n                [iconName]=\"iconPosition == 'left' ? iconLeft : iconRight\"\n                [iconSize]=\"isNewIcon(iconPosition) ? 'md-16' : null\"></gravity-icon>\n</ng-template>\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) {
@@ -508,7 +513,8 @@ class GravityTextFieldComponent {
508
513
  ($event.key === 'a' && $event.metaKey === true) || // Allow: Cmd+A (Mac)
509
514
  ($event.key === 'c' && $event.metaKey === true) || // Allow: Cmd+C (Mac)
510
515
  ($event.key === 'v' && $event.metaKey === true) || // Allow: Cmd+V (Mac)
511
- ($event.key === 'x' && $event.metaKey === true) // Allow: Cmd+X (Mac)
516
+ ($event.key === 'x' && $event.metaKey === true) || // Allow: Cmd+X (Mac)
517
+ ($event.key === '.') || ($event.key === ',') // Allow: dot and comma for decimal
512
518
  ) {
513
519
  // let it happen, don't do anything
514
520
  return;