@leanix/components 0.4.166 → 0.4.167

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.
@@ -40,8 +40,10 @@ export class BasicDropdownComponent extends KeyboardSelectDirective {
40
40
  this.isTopDropdown = false;
41
41
  }
42
42
  selectOption(option) {
43
- const isDisabledOption = Object.entries(this.disabledOptions || {}).length > 0 &&
44
- ((this.itemKey && this.disabledOptions[option[this.itemKey]]) || this.disabledOptions[option]);
43
+ const isDisabledOption = option
44
+ ? Object.entries(this.disabledOptions || {}).length > 0 &&
45
+ ((this.itemKey && this.disabledOptions[option[this.itemKey]]) || this.disabledOptions[option])
46
+ : false;
45
47
  if (!option || !isDisabledOption) {
46
48
  this.onItemSelected.emit(option);
47
49
  }
@@ -134,4 +136,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.1.0", ngImpor
134
136
  type: ViewChild,
135
137
  args: ['selectOrigin', { static: false }]
136
138
  }] } });
137
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,mBAAmB,EAAE,gBAAgB,EAAkC,MAAM,sBAAsB,CAAC;AAC7G,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,KAAK,EAAE,IAAI,EAAE,gBAAgB,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AACnG,OAAO,EAEL,uBAAuB,EACvB,SAAS,EACT,YAAY,EACZ,YAAY,EACZ,KAAK,EACL,MAAM,EAEN,SAAS,EACT,UAAU,EACX,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACtD,OAAO,EAAE,OAAO,EAAE,IAAI,EAAE,OAAO,EAAE,MAAM,WAAW,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,qBAAqB,CAAC;AAC3D,OAAO,EAAE,gBAAgB,EAAE,MAAM,uDAAuD,CAAC;AACzF,OAAO,EAAE,gBAAgB,EAAE,MAAM,uDAAuD,CAAC;AACzF,OAAO,EAAE,uBAAuB,EAAE,MAAM,4CAA4C,CAAC;AAErF,OAAO,EAAE,uBAAuB,EAAE,MAAM,8BAA8B,CAAC;;;;AAyBvE,MAAM,OAAO,sBAAuB,SAAQ,uBAAuB;IAC1D,MAAM,CAAC,SAAS,CAAC,KAAY,EAAE,IAAY,EAAE,GAAY;QAC9D,IAAI,CAAC,IAAI,EAAE;YACT,OAAO,KAAK,CAAC;SACd;QACD,MAAM,mBAAmB,GAAG,CAAC,IAAS,EAAE,EAAE;YACxC,MAAM,KAAK,GAAG,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC;YACrC,OAAO,OAAO,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE,OAAO,CAAC,IAAI,CAAC,CAAC,CAAC;QAChD,CAAC,CAAC;QACF,OAAO,CAAC,IAAI,CAAC,mBAAmB,EAAE,KAAK,CAAC,CAAC;IAC3C,CAAC;IA8BD;QACE,KAAK,EAAE,CAAC;QA7BD,SAAI,GAAG,wBAAwB,CAAC;QAEhC,YAAO,GAAU,EAAE,CAAC;QACpB,2BAAsB,GAAG,CAAC,CAAC,CAAC;QAI5B,YAAO,GAAY,KAAK,CAAC;QAEzB,YAAO,GAAyB,SAAS,CAAC;QAC1C,wBAAmB,GAAG,KAAK,CAAC;QAE5B,oBAAe,GAA+B,EAAE,CAAC;QACxC,uBAAkB,GAAG,KAAK,CAAC;QACpC,oBAAe,GAAG,KAAK,CAAC;QAGvB,mBAAc,GAAG,IAAI,YAAY,EAAO,CAAC;QACzC,iCAA4B,GAAG,IAAI,YAAY,EAAQ,CAAC;QACxD,2BAAsB,GAAG,IAAI,YAAY,EAAU,CAAC;QACpD,4BAAuB,GAAG,IAAI,YAAY,EAAQ,CAAC;QAM7D,kBAAa,GAAG,KAAK,CAAC;IAItB,CAAC;IAED,YAAY,CAAC,MAAW;QACtB,MAAM,gBAAgB,GACpB,MAAM,CAAC,OAAO,CAAC,IAAI,CAAC,eAAe,IAAI,EAAE,CAAC,CAAC,MAAM,GAAG,CAAC;YACrD,CAAC,CAAC,IAAI,CAAC,OAAO,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,IAAI,CAAC,eAAe,CAAC,MAAM,CAAC,CAAC,CAAC;QAEjG,IAAI,CAAC,MAAM,IAAI,CAAC,gBAAgB,EAAE;YAChC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,MAAM,CAAC,CAAC;SAClC;IACH,CAAC;IAED,gBAAgB,CAAC,KAAqC;QACpD,IAAI,CAAC,aAAa,GAAG,KAAK,CAAC,cAAc,CAAC,OAAO,KAAK,KAAK,CAAC;IAC9D,CAAC;IAED,IAAW,SAAS;QAClB,OAAO,sBAAsB,CAAC,SAAS,CAAC,IAAI,CAAC,OAAO,EAAE,IAAI,CAAC,cAAc,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC;IAC5F,CAAC;IAEM,WAAW,CAAC,IAAa;QAC9B,OAAO,CAAC,KAAa,EAAE,IAAS,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC;IACnE,CAAC;IAEM,QAAQ;QACb,IAAI,CAAC,4BAA4B,CAAC,IAAI,EAAE,CAAC;IAC3C,CAAC;IAEM,iBAAiB;QACtB,IAAI,CAAC,IAAI,CAAC,OAAO,EAAE;YACjB,IAAI,CAAC,YAAY,CAAC,IAAI,CAAC,CAAC;YACxB,IAAI,CAAC,sBAAsB,CAAC,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACvD;IACH,CAAC;IAEM,yBAAyB;QAC9B,IAAI,CAAC,uBAAuB,CAAC,IAAI,EAAE,CAAC;IACtC,CAAC;8GA/EU,sBAAsB;kGAAtB,sBAAsB,mrBAnBtB,CAAC,EAAE,OAAO,EAAE,uBAAuB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,CAAC,sBAAsB,CAAC,EAAE,CAAC,2fC3B1G,g3JAiIA,+0CDlGI,IAAI,6FACJ,gBAAgB,oJAChB,gBAAgB,uIAChB,mBAAmB,4+BACnB,OAAO,mFACP,oBAAoB,maACpB,uBAAuB,uIACvB,gBAAgB,6FAChB,KAAK,mHACL,gBAAgB,8EAChB,SAAS,yCACT,aAAa,iDACb,eAAe;;2FAGN,sBAAsB;kBAvBlC,SAAS;+BACE,mBAAmB,aAGlB,CAAC,EAAE,OAAO,EAAE,uBAAuB,EAAE,WAAW,EAAE,UAAU,CAAC,GAAG,EAAE,uBAAuB,CAAC,EAAE,CAAC,mBACvF,uBAAuB,CAAC,MAAM,cACnC,IAAI,WACP;wBACP,IAAI;wBACJ,gBAAgB;wBAChB,gBAAgB;wBAChB,mBAAmB;wBACnB,OAAO;wBACP,oBAAoB;wBACpB,uBAAuB;wBACvB,gBAAgB;wBAChB,KAAK;wBACL,gBAAgB;wBAChB,SAAS;wBACT,aAAa;wBACb,eAAe;qBAChB;wDAgBQ,OAAO;sBAAf,KAAK;gBACG,sBAAsB;sBAA9B,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,cAAc;sBAAtB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,mBAAmB;sBAA3B,KAAK;gBAEG,eAAe;sBAAvB,KAAK;gBACY,kBAAkB;sBAAnC,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBAEI,cAAc;sBAAvB,MAAM;gBACG,4BAA4B;sBAArC,MAAM;gBACG,sBAAsB;sBAA/B,MAAM;gBACG,uBAAuB;sBAAhC,MAAM;gBAEyB,iBAAiB;sBAAhD,YAAY;uBAAC,gBAAgB;gBACW,0BAA0B;sBAAlE,YAAY;uBAAC,yBAAyB;gBACC,sBAAsB;sBAA7D,YAAY;uBAAC,wBAAwB;gBACQ,YAAY;sBAAzD,SAAS;uBAAC,cAAc,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, UpperCasePipe } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { isEqual, some, toLower } from 'lodash/fp';\nimport { InfiniteScrollModule } from 'ngx-infinite-scroll';\nimport { CounterComponent } from '../../../core-ui/components/counter/counter.component';\nimport { SpinnerComponent } from '../../../core-ui/components/spinner/spinner.component';\nimport { SelectableItemDirective } from '../../directives/selectable-item.directive';\nimport { SingleSelectPadding } from '../../models/single-select-padding.interface';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\n@Component({\n  selector: 'lx-basic-dropdown',\n  templateUrl: 'basic-dropdown.component.html',\n  styleUrls: ['basic-dropdown.component.scss'],\n  providers: [{ provide: KeyboardSelectDirective, useExisting: forwardRef(() => BasicDropdownComponent) }],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    NgTemplateOutlet,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    NgClass,\n    InfiniteScrollModule,\n    SelectableItemDirective,\n    CounterComponent,\n    NgFor,\n    SpinnerComponent,\n    AsyncPipe,\n    UpperCasePipe,\n    TranslateModule\n  ]\n})\nexport class BasicDropdownComponent extends KeyboardSelectDirective implements AfterViewInit {\n  public static isNewItem(items: any[], term: string, key?: string): boolean {\n    if (!term) {\n      return false;\n    }\n    const isEqualIgnoringCase = (item: any) => {\n      const value = key ? item[key] : item;\n      return isEqual(toLower(value), toLower(term));\n    };\n    return !some(isEqualIgnoringCase, items);\n  }\n\n  readonly NAME = 'BasicDropdownComponent';\n\n  @Input() options: any[] = [];\n  @Input() initiallySelectedIndex = -1;\n  @Input() labelKey?: string;\n  @Input() itemKey?: string;\n  @Input() placeholder?: string;\n  @Input() loading: boolean = false;\n  @Input() newOptionLabel!: string;\n  @Input() padding?: SingleSelectPadding = 'default';\n  @Input() showCreateNewOption = false;\n\n  @Input() disabledOptions: { [itemKey: string]: any } = {};\n  @Input() override overlayPositioning = false;\n  @Input() truncateOptions = false;\n  @Input() noResultsText?: string;\n\n  @Output() onItemSelected = new EventEmitter<any>();\n  @Output() triggerRequestForMoreEntries = new EventEmitter<void>();\n  @Output() newOptionLabelSelected = new EventEmitter<string>();\n  @Output() createNewOptionSelected = new EventEmitter<void>();\n\n  @ContentChild('optionTemplate') optionTemplateRef!: TemplateRef<any>;\n  @ContentChild('createNewOptionTemplate') createNewOptionTemplateRef!: TemplateRef<any>;\n  @ContentChild('descriptionTemplateRef') descriptionTemplateRef!: TemplateRef<any>;\n  @ViewChild('selectOrigin', { static: false }) selectOrigin!: CdkOverlayOrigin;\n  isTopDropdown = false;\n\n  constructor() {\n    super();\n  }\n\n  selectOption(option: any) {\n    const isDisabledOption =\n      Object.entries(this.disabledOptions || {}).length > 0 &&\n      ((this.itemKey && this.disabledOptions[option[this.itemKey]]) || this.disabledOptions[option]);\n\n    if (!option || !isDisabledOption) {\n      this.onItemSelected.emit(option);\n    }\n  }\n\n  onPositionChange(event: ConnectedOverlayPositionChange) {\n    this.isTopDropdown = event.connectionPair.originY === 'top';\n  }\n\n  public get isNewItem() {\n    return BasicDropdownComponent.isNewItem(this.options, this.newOptionLabel, this.labelKey);\n  }\n\n  public trackByProp(prop?: string) {\n    return (index: number, pill: any) => (prop ? pill[prop] : index);\n  }\n\n  public onScroll() {\n    this.triggerRequestForMoreEntries.emit();\n  }\n\n  public onNewItemSelected() {\n    if (!this.loading) {\n      this.selectOption(null);\n      this.newOptionLabelSelected.emit(this.newOptionLabel);\n    }\n  }\n\n  public onCreateNewOptionSelected() {\n    this.createNewOptionSelected.emit();\n  }\n}\n","<ng-container [ngTemplateOutlet]=\"dropdown\" *ngIf=\"!overlayPositioning\"></ng-container>\n<ng-container *ngIf=\"overlayPositioning\">\n  <div class=\"overlayOrigin\" cdkOverlayOrigin #selectOrigin=\"cdkOverlayOrigin\"></div>\n  <ng-template\n    cdkConnectedOverlay\n    [cdkConnectedOverlayOrigin]=\"selectOrigin\"\n    [cdkConnectedOverlayOpen]=\"!!(cdkOverlayOpen$ | async)\"\n    [cdkConnectedOverlayWidth]=\"selectOrigin.elementRef.nativeElement.offsetWidth\"\n    (positionChange)=\"onPositionChange($event)\"\n  >\n    <div class=\"overlayDropdown\" [ngClass]=\"{ top: isTopDropdown }\">\n      <ng-container [ngTemplateOutlet]=\"dropdown\"></ng-container>\n    </div>\n  </ng-template>\n</ng-container>\n\n<ng-template #dropdown>\n  <ul\n    class=\"options {{ padding }}Padding lxThinScrollbar\"\n    #keyboardSelectContainer\n    infinite-scroll\n    [scrollWindow]=\"false\"\n    [fromRoot]=\"true\"\n    [ngClass]=\"{ truncateOptions: truncateOptions }\"\n    (scrolled)=\"onScroll()\"\n  >\n    <li\n      *ngIf=\"newOptionLabel && isNewItem\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      (click)=\"onNewItemSelected()\"\n      (select)=\"onNewItemSelected()\"\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      class=\"option keyboardSelectable onTheFlyOption\"\n      [attr.aria-label]=\"newOptionLabel\"\n    >\n      <span class=\"newEntryContent\">\n        {{ newOptionLabel }}\n      </span>\n      <lx-counter class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\"></lx-counter>\n    </li>\n    <li\n      *ngIf=\"showCreateNewOption\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      (click)=\"onCreateNewOptionSelected()\"\n      (select)=\"onCreateNewOptionSelected()\"\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      class=\"option keyboardSelectable newEntryOption\"\n    >\n      <span class=\"newEntryContent\">\n        <ng-container *ngIf=\"createNewOptionTemplateRef; else defaultNewOption\">\n          <ng-container *ngTemplateOutlet=\"createNewOptionTemplateRef\"></ng-container>\n        </ng-container>\n        <ng-template #defaultNewOption>\n          <span>\n            {{ NAME + '.new' | translate }}\n          </span>\n        </ng-template>\n      </span>\n    </li>\n    <li\n      *ngIf=\"descriptionTemplateRef\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      class=\"option description disabledItem\"\n    >\n      <span class=\"descriptionContent\">\n        <ng-container *ngTemplateOutlet=\"descriptionTemplateRef\"></ng-container>\n      </span>\n    </li>\n    <li\n      *ngIf=\"options?.length === 0 && !newOptionLabel && !loading\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      class=\"option keyboardSelectable noOptionsAvailable\"\n      [attr.aria-label]=\"noResultsText ?? (NAME + '.noResults' | translate)\"\n    >\n      {{ noResultsText ?? (NAME + '.noResults' | translate) }}\n    </li>\n    <li\n      *ngIf=\"placeholder\"\n      tabindex=\"-1\"\n      class=\"option keyboardSelectable clearSelection\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      (click)=\"selectOption(null)\"\n      (select)=\"selectOption(null)\"\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      [attr.aria-label]=\"placeholder\"\n    >\n      {{ placeholder }}\n    </li>\n    <li\n      *ngFor=\"let option of options; let index = index; trackBy: trackByProp(itemKey)\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      class=\"option keyboardSelectable\"\n      (click)=\"selectOption(option)\"\n      (select)=\"selectOption(option)\"\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      [class.initiallySelected]=\"index === initiallySelectedIndex\"\n      [class.disabledItem]=\"(itemKey && !!disabledOptions[option[itemKey]]) || this.disabledOptions[option]\"\n      [attr.aria-label]=\"labelKey ? option[labelKey] : option\"\n    >\n      <ng-container *ngIf=\"optionTemplateRef; else simpleStringDisplay\">\n        <ng-container *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index }\"></ng-container>\n      </ng-container>\n      <ng-template #simpleStringDisplay>\n        <span>\n          {{ labelKey ? option[labelKey] : option }}\n        </span>\n      </ng-template>\n    </li>\n    <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\"></lx-spinner>\n  </ul>\n</ng-template>\n"]}
139
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"basic-dropdown.component.js","sourceRoot":"","sources":["../../../../../../../../libs/components/src/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.ts","../../../../../../../../libs/components/src/lib/forms-ui/components/basic-dropdown/basic-dropdown.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CdkConnectedOverlay, CdkOverlayOrigin, ConnectedOverlayPositionChange } from '@angular/cdk/overlay';\nimport { AsyncPipe, NgClass, NgFor, NgIf, NgTemplateOutlet, UpperCasePipe } from '@angular/common';\nimport {\n  AfterViewInit,\n  ChangeDetectionStrategy,\n  Component,\n  ContentChild,\n  EventEmitter,\n  Input,\n  Output,\n  TemplateRef,\n  ViewChild,\n  forwardRef\n} from '@angular/core';\nimport { TranslateModule } from '@ngx-translate/core';\nimport { isEqual, some, toLower } from 'lodash/fp';\nimport { InfiniteScrollModule } from 'ngx-infinite-scroll';\nimport { CounterComponent } from '../../../core-ui/components/counter/counter.component';\nimport { SpinnerComponent } from '../../../core-ui/components/spinner/spinner.component';\nimport { SelectableItemDirective } from '../../directives/selectable-item.directive';\nimport { SingleSelectPadding } from '../../models/single-select-padding.interface';\nimport { KeyboardSelectDirective } from '../keyboard-select.directive';\n\n@Component({\n  selector: 'lx-basic-dropdown',\n  templateUrl: 'basic-dropdown.component.html',\n  styleUrls: ['basic-dropdown.component.scss'],\n  providers: [{ provide: KeyboardSelectDirective, useExisting: forwardRef(() => BasicDropdownComponent) }],\n  changeDetection: ChangeDetectionStrategy.OnPush,\n  standalone: true,\n  imports: [\n    NgIf,\n    NgTemplateOutlet,\n    CdkOverlayOrigin,\n    CdkConnectedOverlay,\n    NgClass,\n    InfiniteScrollModule,\n    SelectableItemDirective,\n    CounterComponent,\n    NgFor,\n    SpinnerComponent,\n    AsyncPipe,\n    UpperCasePipe,\n    TranslateModule\n  ]\n})\nexport class BasicDropdownComponent extends KeyboardSelectDirective implements AfterViewInit {\n  public static isNewItem(items: any[], term: string, key?: string): boolean {\n    if (!term) {\n      return false;\n    }\n    const isEqualIgnoringCase = (item: any) => {\n      const value = key ? item[key] : item;\n      return isEqual(toLower(value), toLower(term));\n    };\n    return !some(isEqualIgnoringCase, items);\n  }\n\n  readonly NAME = 'BasicDropdownComponent';\n\n  @Input() options: any[] = [];\n  @Input() initiallySelectedIndex = -1;\n  @Input() labelKey?: string;\n  @Input() itemKey?: string;\n  @Input() placeholder?: string;\n  @Input() loading: boolean = false;\n  @Input() newOptionLabel!: string;\n  @Input() padding?: SingleSelectPadding = 'default';\n  @Input() showCreateNewOption = false;\n\n  @Input() disabledOptions: { [itemKey: string]: any } = {};\n  @Input() override overlayPositioning = false;\n  @Input() truncateOptions = false;\n  @Input() noResultsText?: string;\n\n  @Output() onItemSelected = new EventEmitter<any>();\n  @Output() triggerRequestForMoreEntries = new EventEmitter<void>();\n  @Output() newOptionLabelSelected = new EventEmitter<string>();\n  @Output() createNewOptionSelected = new EventEmitter<void>();\n\n  @ContentChild('optionTemplate') optionTemplateRef!: TemplateRef<any>;\n  @ContentChild('createNewOptionTemplate') createNewOptionTemplateRef!: TemplateRef<any>;\n  @ContentChild('descriptionTemplateRef') descriptionTemplateRef!: TemplateRef<any>;\n  @ViewChild('selectOrigin', { static: false }) selectOrigin!: CdkOverlayOrigin;\n  isTopDropdown = false;\n\n  constructor() {\n    super();\n  }\n\n  selectOption(option: any) {\n    const isDisabledOption = option\n      ? Object.entries(this.disabledOptions || {}).length > 0 &&\n        ((this.itemKey && this.disabledOptions[option[this.itemKey]]) || this.disabledOptions[option])\n      : false;\n\n    if (!option || !isDisabledOption) {\n      this.onItemSelected.emit(option);\n    }\n  }\n\n  onPositionChange(event: ConnectedOverlayPositionChange) {\n    this.isTopDropdown = event.connectionPair.originY === 'top';\n  }\n\n  public get isNewItem() {\n    return BasicDropdownComponent.isNewItem(this.options, this.newOptionLabel, this.labelKey);\n  }\n\n  public trackByProp(prop?: string) {\n    return (index: number, pill: any) => (prop ? pill[prop] : index);\n  }\n\n  public onScroll() {\n    this.triggerRequestForMoreEntries.emit();\n  }\n\n  public onNewItemSelected() {\n    if (!this.loading) {\n      this.selectOption(null);\n      this.newOptionLabelSelected.emit(this.newOptionLabel);\n    }\n  }\n\n  public onCreateNewOptionSelected() {\n    this.createNewOptionSelected.emit();\n  }\n}\n","<ng-container [ngTemplateOutlet]=\"dropdown\" *ngIf=\"!overlayPositioning\"></ng-container>\n<ng-container *ngIf=\"overlayPositioning\">\n  <div class=\"overlayOrigin\" cdkOverlayOrigin #selectOrigin=\"cdkOverlayOrigin\"></div>\n  <ng-template\n    cdkConnectedOverlay\n    [cdkConnectedOverlayOrigin]=\"selectOrigin\"\n    [cdkConnectedOverlayOpen]=\"!!(cdkOverlayOpen$ | async)\"\n    [cdkConnectedOverlayWidth]=\"selectOrigin.elementRef.nativeElement.offsetWidth\"\n    (positionChange)=\"onPositionChange($event)\"\n  >\n    <div class=\"overlayDropdown\" [ngClass]=\"{ top: isTopDropdown }\">\n      <ng-container [ngTemplateOutlet]=\"dropdown\"></ng-container>\n    </div>\n  </ng-template>\n</ng-container>\n\n<ng-template #dropdown>\n  <ul\n    class=\"options {{ padding }}Padding lxThinScrollbar\"\n    #keyboardSelectContainer\n    infinite-scroll\n    [scrollWindow]=\"false\"\n    [fromRoot]=\"true\"\n    [ngClass]=\"{ truncateOptions: truncateOptions }\"\n    (scrolled)=\"onScroll()\"\n  >\n    <li\n      *ngIf=\"newOptionLabel && isNewItem\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      (click)=\"onNewItemSelected()\"\n      (select)=\"onNewItemSelected()\"\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      class=\"option keyboardSelectable onTheFlyOption\"\n      [attr.aria-label]=\"newOptionLabel\"\n    >\n      <span class=\"newEntryContent\">\n        {{ newOptionLabel }}\n      </span>\n      <lx-counter class=\"lx-margin-left\" size=\"small\" [content]=\"'common.new' | translate | uppercase\"></lx-counter>\n    </li>\n    <li\n      *ngIf=\"showCreateNewOption\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      (click)=\"onCreateNewOptionSelected()\"\n      (select)=\"onCreateNewOptionSelected()\"\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      class=\"option keyboardSelectable newEntryOption\"\n    >\n      <span class=\"newEntryContent\">\n        <ng-container *ngIf=\"createNewOptionTemplateRef; else defaultNewOption\">\n          <ng-container *ngTemplateOutlet=\"createNewOptionTemplateRef\"></ng-container>\n        </ng-container>\n        <ng-template #defaultNewOption>\n          <span>\n            {{ NAME + '.new' | translate }}\n          </span>\n        </ng-template>\n      </span>\n    </li>\n    <li\n      *ngIf=\"descriptionTemplateRef\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      class=\"option description disabledItem\"\n    >\n      <span class=\"descriptionContent\">\n        <ng-container *ngTemplateOutlet=\"descriptionTemplateRef\"></ng-container>\n      </span>\n    </li>\n    <li\n      *ngIf=\"options?.length === 0 && !newOptionLabel && !loading\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      class=\"option keyboardSelectable noOptionsAvailable\"\n      [attr.aria-label]=\"noResultsText ?? (NAME + '.noResults' | translate)\"\n    >\n      {{ noResultsText ?? (NAME + '.noResults' | translate) }}\n    </li>\n    <li\n      *ngIf=\"placeholder\"\n      tabindex=\"-1\"\n      class=\"option keyboardSelectable clearSelection\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      (click)=\"selectOption(null)\"\n      (select)=\"selectOption(null)\"\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      [attr.aria-label]=\"placeholder\"\n    >\n      {{ placeholder }}\n    </li>\n    <li\n      *ngFor=\"let option of options; let index = index; trackBy: trackByProp(itemKey)\"\n      tabindex=\"-1\"\n      lxSelectableItem\n      [scrollInContainer]=\"keyboardSelectContainer\"\n      #item\n      class=\"option keyboardSelectable\"\n      (click)=\"selectOption(option)\"\n      (select)=\"selectOption(option)\"\n      [class.selected]=\"isItemSelected(item, (selectedItem$ | async)?.element)\"\n      [class.initiallySelected]=\"index === initiallySelectedIndex\"\n      [class.disabledItem]=\"(itemKey && !!disabledOptions[option[itemKey]]) || this.disabledOptions[option]\"\n      [attr.aria-label]=\"labelKey ? option[labelKey] : option\"\n    >\n      <ng-container *ngIf=\"optionTemplateRef; else simpleStringDisplay\">\n        <ng-container *ngTemplateOutlet=\"optionTemplateRef; context: { $implicit: option, index: index }\"></ng-container>\n      </ng-container>\n      <ng-template #simpleStringDisplay>\n        <span>\n          {{ labelKey ? option[labelKey] : option }}\n        </span>\n      </ng-template>\n    </li>\n    <lx-spinner *ngIf=\"loading\" [fadeBackground]=\"true\"></lx-spinner>\n  </ul>\n</ng-template>\n"]}
@@ -2477,8 +2477,10 @@ class BasicDropdownComponent extends KeyboardSelectDirective {
2477
2477
  this.isTopDropdown = false;
2478
2478
  }
2479
2479
  selectOption(option) {
2480
- const isDisabledOption = Object.entries(this.disabledOptions || {}).length > 0 &&
2481
- ((this.itemKey && this.disabledOptions[option[this.itemKey]]) || this.disabledOptions[option]);
2480
+ const isDisabledOption = option
2481
+ ? Object.entries(this.disabledOptions || {}).length > 0 &&
2482
+ ((this.itemKey && this.disabledOptions[option[this.itemKey]]) || this.disabledOptions[option])
2483
+ : false;
2482
2484
  if (!option || !isDisabledOption) {
2483
2485
  this.onItemSelected.emit(option);
2484
2486
  }