@progressio_resources/gravity-design-system 2.6.4 → 2.6.6

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.
@@ -107,7 +107,8 @@ export class GravityDropdownListComponent {
107
107
  else {
108
108
  this.selectedItemsResponse.emit(this.selectedItems[0]);
109
109
  }
110
- this.searchText = null;
110
+ this.searchText = '';
111
+ this.availableOptions = this.items;
111
112
  }
112
113
  }
113
114
  }
@@ -123,6 +124,7 @@ export class GravityDropdownListComponent {
123
124
  }
124
125
  else {
125
126
  this.selectedItems = [itemToAdd];
127
+ this.selectedItemsResponse.emit(itemToAdd);
126
128
  }
127
129
  }
128
130
  checkIfSelected(itemToFind) {
@@ -130,12 +132,18 @@ export class GravityDropdownListComponent {
130
132
  }
131
133
  clearSelection() {
132
134
  this.selectedItems = [];
135
+ if (this.multiple) {
136
+ this.selectedItemsResponse.emit(this.selectedItems);
137
+ }
138
+ else {
139
+ this.selectedItemsResponse.emit(null);
140
+ }
133
141
  }
134
142
  filterItems() {
135
143
  this.availableOptions = this.filterByPipe.transform(this.items, this.searchText);
136
144
  }
137
145
  onDocumentClick($event) {
138
- if (!this._eref.nativeElement.contains($event.target)) {
146
+ if (!this._eref.nativeElement.contains($event.target) && this.dropdownOpened) {
139
147
  this.dropdownOpened = false;
140
148
  if (this.multiple) {
141
149
  this.selectedItemsResponse.emit(this.selectedItems);
@@ -143,7 +151,8 @@ export class GravityDropdownListComponent {
143
151
  else {
144
152
  this.selectedItemsResponse.emit(this.selectedItems[0]);
145
153
  }
146
- this.searchText = null;
154
+ this.searchText = '';
155
+ this.availableOptions = this.items;
147
156
  }
148
157
  }
149
158
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityDropdownListComponent, deps: [{ token: i1.FilterByPipe }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }
@@ -193,4 +202,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImpo
193
202
  type: HostListener,
194
203
  args: ['document:click', ['$event']]
195
204
  }] } });
196
- //# 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 = null;\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    }\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\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)) {\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 = null;\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'\"\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"]}
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'\"\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"]}
@@ -307,7 +307,8 @@ class GravityDropdownListComponent {
307
307
  else {
308
308
  this.selectedItemsResponse.emit(this.selectedItems[0]);
309
309
  }
310
- this.searchText = null;
310
+ this.searchText = '';
311
+ this.availableOptions = this.items;
311
312
  }
312
313
  }
313
314
  }
@@ -323,6 +324,7 @@ class GravityDropdownListComponent {
323
324
  }
324
325
  else {
325
326
  this.selectedItems = [itemToAdd];
327
+ this.selectedItemsResponse.emit(itemToAdd);
326
328
  }
327
329
  }
328
330
  checkIfSelected(itemToFind) {
@@ -330,12 +332,18 @@ class GravityDropdownListComponent {
330
332
  }
331
333
  clearSelection() {
332
334
  this.selectedItems = [];
335
+ if (this.multiple) {
336
+ this.selectedItemsResponse.emit(this.selectedItems);
337
+ }
338
+ else {
339
+ this.selectedItemsResponse.emit(null);
340
+ }
333
341
  }
334
342
  filterItems() {
335
343
  this.availableOptions = this.filterByPipe.transform(this.items, this.searchText);
336
344
  }
337
345
  onDocumentClick($event) {
338
- if (!this._eref.nativeElement.contains($event.target)) {
346
+ if (!this._eref.nativeElement.contains($event.target) && this.dropdownOpened) {
339
347
  this.dropdownOpened = false;
340
348
  if (this.multiple) {
341
349
  this.selectedItemsResponse.emit(this.selectedItems);
@@ -343,7 +351,8 @@ class GravityDropdownListComponent {
343
351
  else {
344
352
  this.selectedItemsResponse.emit(this.selectedItems[0]);
345
353
  }
346
- this.searchText = null;
354
+ this.searchText = '';
355
+ this.availableOptions = this.items;
347
356
  }
348
357
  }
349
358
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: GravityDropdownListComponent, deps: [{ token: FilterByPipe }, { token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); }