@klippa/ngx-enhancy-forms 14.11.2 → 14.11.3

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.
@@ -165,11 +165,11 @@ export class SelectComponent extends ValueAccessorBase {
165
165
  else {
166
166
  this.dropdownPanelOffsetX = -extraNeededSpace;
167
167
  }
168
- this.setPanelOffsets();
169
168
  }
170
169
  else if (extraNeededSpace > spaceRightOfElRef) {
171
170
  this.dropdownPanelOffsetX = -extraNeededSpace + spaceRightOfElRef - 20;
172
171
  }
172
+ this.setPanelOffsets();
173
173
  }
174
174
  }
175
175
  }
@@ -298,4 +298,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
298
298
  type: ContentChild,
299
299
  args: [KlpSelectOptionTemplateDirective, { read: TemplateRef }]
300
300
  }] } });
301
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/select/select.component.ts","../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/select/select.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterViewInit,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tElementRef,\n\tEventEmitter,\n\tHost,\n\tInject,\n\tInjectionToken,\n\tInput,\n\tOnChanges, OnDestroy,\n\tOptional,\n\tOutput,\n\tSimpleChanges,\n\tTemplateRef,\n\tViewChild\n} from '@angular/core';\nimport {ControlContainer, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {ValueAccessorBase} from '../value-accessor-base/value-accessor-base.component';\nimport {FormElementComponent} from '../../form/form-element/form-element.component';\nimport {isValueSet, stringIsSetAndFilled} from '../../util/values';\nimport {awaitableForNextCycle} from \"../../util/angular\";\n\nexport type AppSelectOptions = Array<AppSelectOption>;\nexport type AppSelectOption = {\n\tid: any;\n\tname: string;\n\tdescription?: string;\n\tactive?: boolean;\n\tdisabled?: boolean;\n};\n\nexport const SELECT_TRANSLATIONS = new InjectionToken<any>('klp.form.select.translations');\n\n@Directive({ selector: '[klpSelectOptionTpl]' })\nexport class KlpSelectOptionTemplateDirective {}\n\n@Component({\n\tselector: 'klp-form-select',\n\ttemplateUrl: './select.component.html',\n\tstyleUrls: ['./select.component.scss'],\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: SelectComponent, multi: true}],\n})\nexport class SelectComponent extends ValueAccessorBase<string | string[]> implements OnChanges, AfterViewInit, OnDestroy{\n\t@Input() placeholder: string;\n\t@Input() prefix: string;\n\t@Input() orientation: 'vertical' | 'horizontal' = 'horizontal';\n\t@Input() options: AppSelectOptions;\n\t@Input() multiple = false;\n\t@Input() multipleDisplayedAsAmount = false;\n\t@Input() clearable = true;\n\t@Input() truncateOptions = true;\n\t@Input() withSeparatingLine = false;\n\t@Input() searchable = true;\n\t@Input() public dropdownPosition: 'auto' | 'bottom' | 'top' | 'left' | 'right' = null;\n\t@Input() public dropdownAlignment: 'left' | 'right' = 'left';\n\t@Input() public customSearchFn: (term: string, item: { id: string; name: string; description: string }) => boolean;\n\t@Input() public footerElement: TemplateRef<any>;\n\t@Output() public onSearch = new EventEmitter<string>();\n\t@Output() public onEndReached = new EventEmitter<void>();\n\t@Output() public onOpened = new EventEmitter<void>();\n\t@Output() public onClosed = new EventEmitter<void>();\n\t@Output() public onBlur = new EventEmitter<void>();\n\t@Output() public onClear = new EventEmitter<void>();\n\t@Output() public onEnterKey = new EventEmitter<string>();\n\t@ViewChild('ngSelect') ngSelect;\n\t@ContentChild(KlpSelectOptionTemplateDirective, { read: TemplateRef }) customOptionTpl: TemplateRef<any>;\n\n\tprivate lastItemIndexReached = -1;\n\tpublic dropdownPositionToUse: 'auto' | 'bottom' | 'top' | 'left' | 'right' = 'bottom';\n\tprivate isOpen: boolean = false;\n\tprivate dropdownPanelOffsetX = 0;\n\tprivate dropdownPanelOffsetY = 0;\n\tprivate anchorAbsolute: HTMLDivElement;\n\tprivate anchorFixed: HTMLDivElement;\n\n\tconstructor(\n\t\t@Optional() @Host() protected parent: FormElementComponent,\n\t\t@Optional() @Host() protected controlContainer: ControlContainer,\n\t\t@Inject(SELECT_TRANSLATIONS) @Optional() private translations: any,\n\t\tprivate elRef: ElementRef,\n\t) {\n\t\tsuper(parent, controlContainer);\n\t}\n\n\tngAfterViewInit(): void {\n\t\tthis.addPrefix();\n\t\tthis.elRef.nativeElement.querySelector('input').addEventListener('keydown', this.keyListener);\n\t}\n\n\tprivate keyListener = (e) => {\n\t\tif (e.key === 'Enter') {\n\t\t\tthis.onEnterKey.emit(e.target.value);\n\t\t}\n\t}\n\n\tprivate addPrefix(): void {\n\t\tif (stringIsSetAndFilled(this.prefix)) {\n\t\t\tconst container = this.elRef.nativeElement.querySelector('.ng-select-container');\n\t\t\tconst newNode = document.createElement('div');\n\t\t\tnewNode.className = 'prefix';\n\t\t\tnewNode.innerText = this.prefix;\n\t\t\tcontainer.insertBefore(newNode, container.children[0]);\n\t\t}\n\t}\n\n\tngOnChanges(changes: SimpleChanges): void {\n\t\tif (isValueSet(changes.options)) {\n\t\t\tthis.lastItemIndexReached = -1;\n\t\t\tthis.setWidthBasedOnOptionsWidths();\n\t\t}\n\t\tthis.dropdownPositionToUse = this.dropdownPosition;\n\t}\n\n\tgetDefaultTranslation(key: string): (x: any) => string {\n\t\tswitch (key) {\n\t\t\tcase 'placeholder':\n\t\t\t\treturn () => 'Pick an option';\n\t\t\tcase 'amountSelected':\n\t\t\t\treturn (amount) => `${amount} selected`;\n\t\t}\n\t}\n\n\tgetTranslation(key: string, params: any = null): string {\n\t\tif (key === 'placeholder' && stringIsSetAndFilled(this.placeholder)) {\n\t\t\treturn this.placeholder;\n\t\t}\n\t\treturn this.translations?.[key]?.(params) ?? this.getDefaultTranslation(key)(params);\n\t}\n\n\tonScroll(lastItemIndex: number): void {\n\t\tconst visibleItems = this.ngSelect?.itemsList?.filteredItems?.length ?? 0;\n\t\tif (this.lastItemIndexReached < lastItemIndex && lastItemIndex === visibleItems) {\n\t\t\tthis.onEndReached.emit();\n\t\t}\n\t\tthis.lastItemIndexReached = Math.max(lastItemIndex, this.lastItemIndexReached);\n\t\tthis.setWidthBasedOnOptionsWidths();\n\t}\n\n\tsearchQueryChanged(searchQuery: string): void {\n\t\tthis.onSearch.emit(searchQuery);\n\t}\n\n\tasync onOpen(): Promise<void> {\n\t\tthis.isOpen = true;\n\n\t\tif (this.orientation === 'horizontal' && !isValueSet(this.dropdownPosition)) {\n\t\t\tthis.determineDropdownPosition();\n\t\t}\n\n\t\tif (!this.truncateOptions) {\n\t\t\tthis.createAnchors();\n\t\t}\n\t\t// waiting for the thing to render until we fire the event\n\t\tawait awaitableForNextCycle();\n\t\tthis.onOpened.emit();\n\n\t\tawait this.setWidthBasedOnOptionsWidths();\n\t\tif (!this.truncateOptions) {\n\t\t\tthis.setFixedDropdownPanelPosition();\n\t\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.addEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t}\n\t}\n\n\tprivate createAnchors(): void {\n\t\tthis.anchorAbsolute = document.createElement('div');\n\t\tif (this.dropdownPositionToUse === 'top') {\n\t\t\tthis.elRef.nativeElement.prepend(this.anchorAbsolute);\n\t\t} else {\n\t\t\tthis.elRef.nativeElement.appendChild(this.anchorAbsolute);\n\t\t}\n\n\t\tthis.anchorFixed = document.createElement('div');\n\t\tthis.anchorFixed.style.position = 'fixed';\n\t\tthis.elRef.nativeElement.appendChild(this.anchorFixed);\n\t}\n\tprivate removeAnchors(): void {\n\t\tthis.elRef.nativeElement.removeChild(this.anchorAbsolute);\n\t\tthis.elRef.nativeElement.removeChild(this.anchorFixed);\n\t}\n\n\tprivate setFixedDropdownPanelPosition = () => {\n\t\tconst difference = this.anchorAbsolute.getBoundingClientRect().top - this.anchorFixed.getBoundingClientRect().top;\n\t\tthis.dropdownPanelOffsetY = difference;\n\n\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tdropdownPanel.style.position = 'fixed';\n\t\tdropdownPanel.style.visibility = 'initial';\n\t\tthis.setPanelOffsets();\n\t};\n\n\tprivate async setWidthBasedOnOptionsWidths(): Promise<void> {\n\t\tif (this.truncateOptions === false) {\n\t\t\tawait awaitableForNextCycle();\n\t\t\tconst widths: Array<number> = Array.from(this.elRef.nativeElement.querySelectorAll('.ng-option div')).map(\n\t\t\t\t(e: any) => e.scrollWidth,\n\t\t\t);\n\t\t\tconst maxWidth = Math.max(...widths);\n\t\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\t\tif (dropdownPanel) {\n\t\t\t\tdropdownPanel.style.minWidth = `${this.elRef.nativeElement.clientWidth}px`;\n\t\t\t\tdropdownPanel.style.width = `${Math.max(this.elRef.nativeElement.clientWidth, maxWidth + 40, dropdownPanel.getBoundingClientRect().width)}px`;\n\t\t\t\tawait awaitableForNextCycle();\n\t\t\t\tconst pickerWidth = this.elRef.nativeElement.getBoundingClientRect().width;\n\t\t\t\tconst dropdownPanelWidth = dropdownPanel.getBoundingClientRect().width;\n\n\t\t\t\tconst spaceLeftOfElRef = this.elRef.nativeElement.getBoundingClientRect().left;\n\t\t\t\tconst spaceRightOfElRef = window.innerWidth - (this.elRef.nativeElement.getBoundingClientRect().width + spaceLeftOfElRef);\n\t\t\t\tconst extraNeededSpace = dropdownPanelWidth - pickerWidth;\n\t\t\t\tif (this.dropdownAlignment === 'right') {\n\t\t\t\t\tif (extraNeededSpace > spaceLeftOfElRef) {\n\t\t\t\t\t\tthis.dropdownPanelOffsetX = -spaceLeftOfElRef + 10;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.dropdownPanelOffsetX = -extraNeededSpace;\n\t\t\t\t\t}\n\t\t\t\t\tthis.setPanelOffsets();\n\t\t\t\t} else if (extraNeededSpace > spaceRightOfElRef) {\n\t\t\t\t\tthis.dropdownPanelOffsetX = -extraNeededSpace + spaceRightOfElRef - 20;\n\t\t\t\t}\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate getAllLimitingContainers(): Array<HTMLElement> {\n\t\tconst result = [];\n\t\tlet current = this.elRef.nativeElement;\n\t\twhile (current.parentElement) {\n\t\t\tif (this.isLimitingContainer(current.parentElement)) {\n\t\t\t\tresult.push(current.parentElement);\n\t\t\t}\n\t\t\tcurrent = current.parentElement;\n\t\t}\n\t\treturn result;\n\t}\n\n\tprivate setPanelOffsets(): void {\n\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tconst scrollPositionOffset = `translate(${this.dropdownPanelOffsetX}px, ${this.dropdownPanelOffsetY}px)`;\n\t\tconst dropdownPositionOffset = this.dropdownPositionToUse === 'top' ? `translateY(-100%) translateY(1px)` : '';\n\t\tdropdownPanel.style.transform = [scrollPositionOffset, dropdownPositionOffset].join(' ');\n\t}\n\n\tprivate determineDropdownPosition(): void {\n\t\tconst bottomSpace = window.innerHeight - this.elRef.nativeElement.getBoundingClientRect().top;\n\t\tif (bottomSpace >= 300) {\n\t\t\tthis.dropdownPositionToUse = 'bottom';\n\t\t} else {\n\t\t\tthis.dropdownPositionToUse = 'top';\n\t\t}\n\t}\n\n\tprivate isLimitingContainer(element: Element): boolean {\n\t\tconst style = getComputedStyle(element);\n\t\tif (style.overflowY === 'auto') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflow === 'auto') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflowY === 'scroll') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflow === 'scroll') {\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tpublic focus = (): void => {\n\t\tthis.ngSelect.focus();\n\t}\n\tpublic close = (): void => {\n\t\tthis.ngSelect.close();\n\t}\n\n\tpublic onClose(): void {\n\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.removeEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t// Give angular a second to render the closed situation before emitting the close event\n\t\tsetTimeout(() => {\n\t\t\tthis.isOpen = false;\n\t\t\tif (!this.truncateOptions) {\n\t\t\t\tthis.removeAnchors();\n\t\t\t}\n\t\t\tthis.onClosed.emit();\n\t\t});\n\t}\n\n\tngOnDestroy(): void {\n\t\tsuper.ngOnDestroy();\n\t\tthis.elRef.nativeElement?.querySelector('input')?.removeEventListener('keydown', this.keyListener);\n\t}\n}\n","<ng-select\n\t#ngSelect\n\t[placeholder]=\"getTranslation('placeholder')\"\n\tbindLabel=\"name\"\n\tbindValue=\"id\"\n\t[items]=\"options\"\n\t[clearable]=\"clearable\"\n\t[(ngModel)]=\"innerValue\"\n\t[ngClass]=\"{showErrors: isInErrorState(), verticalOrientation: orientation === 'vertical', truncateOptions: truncateOptions, nonTruncatedOptions: !truncateOptions, withSeparatingLine: withSeparatingLine}\"\n\t(change)=\"setInnerValueAndNotify(innerValue)\"\n\t[multiple]=\"multiple\"\n\t[disabled]=\"disabled\"\n\t(blur)=\"touch(); onBlur.emit()\"\n\t(clear)=\"onClear.emit()\"\n\t(search)=\"searchQueryChanged($event.term)\"\n\t[searchable]=\"searchable\"\n\t[dropdownPosition]=\"dropdownPositionToUse\"\n\t[searchFn]=\"customSearchFn\"\n\t[selectOnTab]=\"true\"\n\t[virtualScroll]=\"true\"\n\t(scroll)=\"onScroll($event.end)\"\n\t(open)=\"onOpen()\"\n\t(close)=\"onClose()\"\n>\n\t<ng-template let-item=\"item\" ng-option-tmp>\n\t\t<ng-container *ngIf=\"customOptionTpl\" [ngTemplateOutlet]=\"customOptionTpl\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n\t\t<div [attr.data-cy]=\"item.id\" *ngIf=\"!customOptionTpl\">\n\t\t\t{{ item.name }}\n\t\t\t<div *ngIf=\"item.description\" class=\"dropdown-item-description\">\n\t\t\t\t{{ item.description }}\n\t\t\t</div>\n\t\t</div>\n\t</ng-template>\n\t<ng-container *ngIf=\"multiple && multipleDisplayedAsAmount && innerValue?.length > 1\">\n\t\t<ng-template ng-multi-label-tmp>\n\t\t\t<div class=\"ng-value\">\n\t\t\t\t<span class=\"ng-value-label\">{{getTranslation('amountSelected', innerValue?.length)}}</span>\n\t\t\t</div>\n\t\t</ng-template>\n\t</ng-container>\n\t<ng-template ng-footer-tmp *ngIf=\"footerElement\">\n\t\t<ng-container [ngTemplateOutlet]=\"footerElement\"></ng-container>\n\t</ng-template>\n</ng-select>\n"]}
301
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"select.component.js","sourceRoot":"","sources":["../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/select/select.component.ts","../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/elements/select/select.component.html"],"names":[],"mappings":"AAAA,OAAO,EAEN,SAAS,EACT,YAAY,EACZ,SAAS,EAET,YAAY,EACZ,IAAI,EACJ,MAAM,EACN,cAAc,EACd,KAAK,EAEL,QAAQ,EACR,MAAM,EAEN,WAAW,EACX,SAAS,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAmB,iBAAiB,EAAC,MAAM,gBAAgB,CAAC;AACnE,OAAO,EAAC,iBAAiB,EAAC,MAAM,sDAAsD,CAAC;AAEvF,OAAO,EAAC,UAAU,EAAE,oBAAoB,EAAC,MAAM,mBAAmB,CAAC;AACnE,OAAO,EAAC,qBAAqB,EAAC,MAAM,oBAAoB,CAAC;;;;;;AAWzD,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,cAAc,CAAM,8BAA8B,CAAC,CAAC;AAG3F,MAAM,OAAO,gCAAgC;;6HAAhC,gCAAgC;iHAAhC,gCAAgC;2FAAhC,gCAAgC;kBAD5C,SAAS;mBAAC,EAAE,QAAQ,EAAE,sBAAsB,EAAE;;AAS/C,MAAM,OAAO,eAAgB,SAAQ,iBAAoC;IAiCxE,YAC+B,MAA4B,EAC5B,gBAAkC,EACf,YAAiB,EAC1D,KAAiB;QAEzB,KAAK,CAAC,MAAM,EAAE,gBAAgB,CAAC,CAAC;QALF,WAAM,GAAN,MAAM,CAAsB;QAC5B,qBAAgB,GAAhB,gBAAgB,CAAkB;QACf,iBAAY,GAAZ,YAAY,CAAK;QAC1D,UAAK,GAAL,KAAK,CAAY;QAlCjB,gBAAW,GAA8B,YAAY,CAAC;QAEtD,aAAQ,GAAG,KAAK,CAAC;QACjB,8BAAyB,GAAG,KAAK,CAAC;QAClC,cAAS,GAAG,IAAI,CAAC;QACjB,oBAAe,GAAG,IAAI,CAAC;QACvB,uBAAkB,GAAG,KAAK,CAAC;QAC3B,eAAU,GAAG,IAAI,CAAC;QACX,qBAAgB,GAAiD,IAAI,CAAC;QACtE,sBAAiB,GAAqB,MAAM,CAAC;QAG5C,aAAQ,GAAG,IAAI,YAAY,EAAU,CAAC;QACtC,iBAAY,GAAG,IAAI,YAAY,EAAQ,CAAC;QACxC,aAAQ,GAAG,IAAI,YAAY,EAAQ,CAAC;QACpC,aAAQ,GAAG,IAAI,YAAY,EAAQ,CAAC;QACpC,WAAM,GAAG,IAAI,YAAY,EAAQ,CAAC;QAClC,YAAO,GAAG,IAAI,YAAY,EAAQ,CAAC;QACnC,eAAU,GAAG,IAAI,YAAY,EAAU,CAAC;QAIjD,yBAAoB,GAAG,CAAC,CAAC,CAAC;QAC3B,0BAAqB,GAAiD,QAAQ,CAAC;QAC9E,WAAM,GAAY,KAAK,CAAC;QACxB,yBAAoB,GAAG,CAAC,CAAC;QACzB,yBAAoB,GAAG,CAAC,CAAC;QAkBzB,gBAAW,GAAG,CAAC,CAAC,EAAE,EAAE;YAC3B,IAAI,CAAC,CAAC,GAAG,KAAK,OAAO,EAAE;gBACtB,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC;aACrC;QACF,CAAC,CAAA;QAuFO,kCAA6B,GAAG,GAAG,EAAE;YAC5C,MAAM,UAAU,GAAG,IAAI,CAAC,cAAc,CAAC,qBAAqB,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,WAAW,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC;YAClH,IAAI,CAAC,oBAAoB,GAAG,UAAU,CAAC;YAEvC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;YAClF,aAAa,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;YACvC,aAAa,CAAC,KAAK,CAAC,UAAU,GAAG,SAAS,CAAC;YAC3C,IAAI,CAAC,eAAe,EAAE,CAAC;QACxB,CAAC,CAAC;QA+EK,UAAK,GAAG,GAAS,EAAE;YACzB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QACvB,CAAC,CAAA;QACM,UAAK,GAAG,GAAS,EAAE;YACzB,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,CAAC;QACvB,CAAC,CAAA;IA9LD,CAAC;IAED,eAAe;QACd,IAAI,CAAC,SAAS,EAAE,CAAC;QACjB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,OAAO,CAAC,CAAC,gBAAgB,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IAC/F,CAAC;IAQO,SAAS;QAChB,IAAI,oBAAoB,CAAC,IAAI,CAAC,MAAM,CAAC,EAAE;YACtC,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,sBAAsB,CAAC,CAAC;YACjF,MAAM,OAAO,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9C,OAAO,CAAC,SAAS,GAAG,QAAQ,CAAC;YAC7B,OAAO,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,CAAC;YAChC,SAAS,CAAC,YAAY,CAAC,OAAO,EAAE,SAAS,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC;SACvD;IACF,CAAC;IAED,WAAW,CAAC,OAAsB;QACjC,IAAI,UAAU,CAAC,OAAO,CAAC,OAAO,CAAC,EAAE;YAChC,IAAI,CAAC,oBAAoB,GAAG,CAAC,CAAC,CAAC;YAC/B,IAAI,CAAC,4BAA4B,EAAE,CAAC;SACpC;QACD,IAAI,CAAC,qBAAqB,GAAG,IAAI,CAAC,gBAAgB,CAAC;IACpD,CAAC;IAED,qBAAqB,CAAC,GAAW;QAChC,QAAQ,GAAG,EAAE;YACZ,KAAK,aAAa;gBACjB,OAAO,GAAG,EAAE,CAAC,gBAAgB,CAAC;YAC/B,KAAK,gBAAgB;gBACpB,OAAO,CAAC,MAAM,EAAE,EAAE,CAAC,GAAG,MAAM,WAAW,CAAC;SACzC;IACF,CAAC;IAED,cAAc,CAAC,GAAW,EAAE,SAAc,IAAI;QAC7C,IAAI,GAAG,KAAK,aAAa,IAAI,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;YACpE,OAAO,IAAI,CAAC,WAAW,CAAC;SACxB;QACD,OAAO,IAAI,CAAC,YAAY,EAAE,CAAC,GAAG,CAAC,EAAE,CAAC,MAAM,CAAC,IAAI,IAAI,CAAC,qBAAqB,CAAC,GAAG,CAAC,CAAC,MAAM,CAAC,CAAC;IACtF,CAAC;IAED,QAAQ,CAAC,aAAqB;QAC7B,MAAM,YAAY,GAAG,IAAI,CAAC,QAAQ,EAAE,SAAS,EAAE,aAAa,EAAE,MAAM,IAAI,CAAC,CAAC;QAC1E,IAAI,IAAI,CAAC,oBAAoB,GAAG,aAAa,IAAI,aAAa,KAAK,YAAY,EAAE;YAChF,IAAI,CAAC,YAAY,CAAC,IAAI,EAAE,CAAC;SACzB;QACD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,IAAI,CAAC,oBAAoB,CAAC,CAAC;QAC/E,IAAI,CAAC,4BAA4B,EAAE,CAAC;IACrC,CAAC;IAED,kBAAkB,CAAC,WAAmB;QACrC,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACjC,CAAC;IAED,KAAK,CAAC,MAAM;QACX,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC;QAEnB,IAAI,IAAI,CAAC,WAAW,KAAK,YAAY,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,gBAAgB,CAAC,EAAE;YAC5E,IAAI,CAAC,yBAAyB,EAAE,CAAC;SACjC;QAED,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YAC1B,IAAI,CAAC,aAAa,EAAE,CAAC;SACrB;QACD,0DAA0D;QAC1D,MAAM,qBAAqB,EAAE,CAAC;QAC9B,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QAErB,MAAM,IAAI,CAAC,4BAA4B,EAAE,CAAC;QAC1C,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;YAC1B,IAAI,CAAC,6BAA6B,EAAE,CAAC;YACrC,CAAC,GAAG,IAAI,CAAC,wBAAwB,EAAE,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,CAAC,CAAC;SAC5H;IACF,CAAC;IAEO,aAAa;QACpB,IAAI,CAAC,cAAc,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACpD,IAAI,IAAI,CAAC,qBAAqB,KAAK,KAAK,EAAE;YACzC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SACtD;aAAM;YACN,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;SAC1D;QAED,IAAI,CAAC,WAAW,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;QACjD,IAAI,CAAC,WAAW,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;QAC1C,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACxD,CAAC;IACO,aAAa;QACpB,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC;QAC1D,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,WAAW,CAAC,CAAC;IACxD,CAAC;IAYO,KAAK,CAAC,4BAA4B;QACzC,IAAI,IAAI,CAAC,eAAe,KAAK,KAAK,EAAE;YACnC,MAAM,qBAAqB,EAAE,CAAC;YAC9B,MAAM,MAAM,GAAkB,KAAK,CAAC,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,gBAAgB,CAAC,gBAAgB,CAAC,CAAC,CAAC,GAAG,CACxG,CAAC,CAAM,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,CACzB,CAAC;YACF,MAAM,QAAQ,GAAG,IAAI,CAAC,GAAG,CAAC,GAAG,MAAM,CAAC,CAAC;YACrC,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;YAClF,IAAI,aAAa,EAAE;gBAClB,aAAa,CAAC,KAAK,CAAC,QAAQ,GAAG,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,IAAI,CAAC;gBAC3E,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,IAAI,CAAC,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,WAAW,EAAE,QAAQ,GAAG,EAAE,EAAE,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC,IAAI,CAAC;gBAC9I,MAAM,qBAAqB,EAAE,CAAC;gBAC9B,MAAM,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;gBAC3E,MAAM,kBAAkB,GAAG,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,CAAC;gBAEvE,MAAM,gBAAgB,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,IAAI,CAAC;gBAC/E,MAAM,iBAAiB,GAAG,MAAM,CAAC,UAAU,GAAG,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,GAAG,gBAAgB,CAAC,CAAC;gBAC1H,MAAM,gBAAgB,GAAG,kBAAkB,GAAG,WAAW,CAAC;gBAC1D,IAAI,IAAI,CAAC,iBAAiB,KAAK,OAAO,EAAE;oBACvC,IAAI,gBAAgB,GAAG,gBAAgB,EAAE;wBACxC,IAAI,CAAC,oBAAoB,GAAG,CAAC,gBAAgB,GAAG,EAAE,CAAC;qBACnD;yBAAM;wBACN,IAAI,CAAC,oBAAoB,GAAG,CAAC,gBAAgB,CAAC;qBAC9C;iBACD;qBAAM,IAAI,gBAAgB,GAAG,iBAAiB,EAAE;oBAChD,IAAI,CAAC,oBAAoB,GAAG,CAAC,gBAAgB,GAAG,iBAAiB,GAAG,EAAE,CAAC;iBACvE;gBACD,IAAI,CAAC,eAAe,EAAE,CAAC;aACvB;SACD;IACF,CAAC;IAEO,wBAAwB;QAC/B,MAAM,MAAM,GAAG,EAAE,CAAC;QAClB,IAAI,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC;QACvC,OAAO,OAAO,CAAC,aAAa,EAAE;YAC7B,IAAI,IAAI,CAAC,mBAAmB,CAAC,OAAO,CAAC,aAAa,CAAC,EAAE;gBACpD,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;aACnC;YACD,OAAO,GAAG,OAAO,CAAC,aAAa,CAAC;SAChC;QACD,OAAO,MAAM,CAAC;IACf,CAAC;IAEO,eAAe;QACtB,MAAM,aAAa,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,aAAa,CAAC,mBAAmB,CAAC,CAAC;QAClF,MAAM,oBAAoB,GAAG,aAAa,IAAI,CAAC,oBAAoB,OAAO,IAAI,CAAC,oBAAoB,KAAK,CAAC;QACzG,MAAM,sBAAsB,GAAG,IAAI,CAAC,qBAAqB,KAAK,KAAK,CAAC,CAAC,CAAC,mCAAmC,CAAC,CAAC,CAAC,EAAE,CAAC;QAC/G,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,CAAC,oBAAoB,EAAE,sBAAsB,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IAC1F,CAAC;IAEO,yBAAyB;QAChC,MAAM,WAAW,GAAG,MAAM,CAAC,WAAW,GAAG,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC;QAC9F,IAAI,WAAW,IAAI,GAAG,EAAE;YACvB,IAAI,CAAC,qBAAqB,GAAG,QAAQ,CAAC;SACtC;aAAM;YACN,IAAI,CAAC,qBAAqB,GAAG,KAAK,CAAC;SACnC;IACF,CAAC;IAEO,mBAAmB,CAAC,OAAgB;QAC3C,MAAM,KAAK,GAAG,gBAAgB,CAAC,OAAO,CAAC,CAAC;QACxC,IAAI,KAAK,CAAC,SAAS,KAAK,MAAM,EAAE;YAC/B,OAAO,IAAI,CAAC;SACZ;QACD,IAAI,KAAK,CAAC,QAAQ,KAAK,MAAM,EAAE;YAC9B,OAAO,IAAI,CAAC;SACZ;QACD,IAAI,KAAK,CAAC,SAAS,KAAK,QAAQ,EAAE;YACjC,OAAO,IAAI,CAAC;SACZ;QACD,IAAI,KAAK,CAAC,QAAQ,KAAK,QAAQ,EAAE;YAChC,OAAO,IAAI,CAAC;SACZ;QACD,OAAO,KAAK,CAAC;IACd,CAAC;IASM,OAAO;QACb,CAAC,GAAG,IAAI,CAAC,wBAAwB,EAAE,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,6BAA6B,CAAC,CAAC,CAAC;QAC/H,uFAAuF;QACvF,UAAU,CAAC,GAAG,EAAE;YACf,IAAI,CAAC,MAAM,GAAG,KAAK,CAAC;YACpB,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;gBAC1B,IAAI,CAAC,aAAa,EAAE,CAAC;aACrB;YACD,IAAI,CAAC,QAAQ,CAAC,IAAI,EAAE,CAAC;QACtB,CAAC,CAAC,CAAC;IACJ,CAAC;IAED,WAAW;QACV,KAAK,CAAC,WAAW,EAAE,CAAC;QACpB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,aAAa,CAAC,OAAO,CAAC,EAAE,mBAAmB,CAAC,SAAS,EAAE,IAAI,CAAC,WAAW,CAAC,CAAC;IACpG,CAAC;;4GAvPW,eAAe,8IAoClB,mBAAmB;gGApChB,eAAe,+pBAFhB,CAAC,EAAC,OAAO,EAAE,iBAAiB,EAAE,WAAW,EAAE,eAAe,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC,uEAyBtE,gCAAgC,2BAAU,WAAW,+KCnEpE,owDA4CA;2FDAa,eAAe;kBAN3B,SAAS;+BACC,iBAAiB,aAGhB,CAAC,EAAC,OAAO,EAAE,iBAAiB,EAAE,WAAW,iBAAiB,EAAE,KAAK,EAAE,IAAI,EAAC,CAAC;;0BAoClF,QAAQ;;0BAAI,IAAI;;0BAChB,QAAQ;;0BAAI,IAAI;;0BAChB,MAAM;2BAAC,mBAAmB;;0BAAG,QAAQ;qEAnC9B,WAAW;sBAAnB,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,OAAO;sBAAf,KAAK;gBACG,QAAQ;sBAAhB,KAAK;gBACG,yBAAyB;sBAAjC,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,kBAAkB;sBAA1B,KAAK;gBACG,UAAU;sBAAlB,KAAK;gBACU,gBAAgB;sBAA/B,KAAK;gBACU,iBAAiB;sBAAhC,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,aAAa;sBAA5B,KAAK;gBACW,QAAQ;sBAAxB,MAAM;gBACU,YAAY;sBAA5B,MAAM;gBACU,QAAQ;sBAAxB,MAAM;gBACU,QAAQ;sBAAxB,MAAM;gBACU,MAAM;sBAAtB,MAAM;gBACU,OAAO;sBAAvB,MAAM;gBACU,UAAU;sBAA1B,MAAM;gBACgB,QAAQ;sBAA9B,SAAS;uBAAC,UAAU;gBACkD,eAAe;sBAArF,YAAY;uBAAC,gCAAgC,EAAE,EAAE,IAAI,EAAE,WAAW,EAAE","sourcesContent":["import {\n\tAfterViewInit,\n\tComponent,\n\tContentChild,\n\tDirective,\n\tElementRef,\n\tEventEmitter,\n\tHost,\n\tInject,\n\tInjectionToken,\n\tInput,\n\tOnChanges, OnDestroy,\n\tOptional,\n\tOutput,\n\tSimpleChanges,\n\tTemplateRef,\n\tViewChild\n} from '@angular/core';\nimport {ControlContainer, NG_VALUE_ACCESSOR} from '@angular/forms';\nimport {ValueAccessorBase} from '../value-accessor-base/value-accessor-base.component';\nimport {FormElementComponent} from '../../form/form-element/form-element.component';\nimport {isValueSet, stringIsSetAndFilled} from '../../util/values';\nimport {awaitableForNextCycle} from \"../../util/angular\";\n\nexport type AppSelectOptions = Array<AppSelectOption>;\nexport type AppSelectOption = {\n\tid: any;\n\tname: string;\n\tdescription?: string;\n\tactive?: boolean;\n\tdisabled?: boolean;\n};\n\nexport const SELECT_TRANSLATIONS = new InjectionToken<any>('klp.form.select.translations');\n\n@Directive({ selector: '[klpSelectOptionTpl]' })\nexport class KlpSelectOptionTemplateDirective {}\n\n@Component({\n\tselector: 'klp-form-select',\n\ttemplateUrl: './select.component.html',\n\tstyleUrls: ['./select.component.scss'],\n\tproviders: [{provide: NG_VALUE_ACCESSOR, useExisting: SelectComponent, multi: true}],\n})\nexport class SelectComponent extends ValueAccessorBase<string | string[]> implements OnChanges, AfterViewInit, OnDestroy{\n\t@Input() placeholder: string;\n\t@Input() prefix: string;\n\t@Input() orientation: 'vertical' | 'horizontal' = 'horizontal';\n\t@Input() options: AppSelectOptions;\n\t@Input() multiple = false;\n\t@Input() multipleDisplayedAsAmount = false;\n\t@Input() clearable = true;\n\t@Input() truncateOptions = true;\n\t@Input() withSeparatingLine = false;\n\t@Input() searchable = true;\n\t@Input() public dropdownPosition: 'auto' | 'bottom' | 'top' | 'left' | 'right' = null;\n\t@Input() public dropdownAlignment: 'left' | 'right' = 'left';\n\t@Input() public customSearchFn: (term: string, item: { id: string; name: string; description: string }) => boolean;\n\t@Input() public footerElement: TemplateRef<any>;\n\t@Output() public onSearch = new EventEmitter<string>();\n\t@Output() public onEndReached = new EventEmitter<void>();\n\t@Output() public onOpened = new EventEmitter<void>();\n\t@Output() public onClosed = new EventEmitter<void>();\n\t@Output() public onBlur = new EventEmitter<void>();\n\t@Output() public onClear = new EventEmitter<void>();\n\t@Output() public onEnterKey = new EventEmitter<string>();\n\t@ViewChild('ngSelect') ngSelect;\n\t@ContentChild(KlpSelectOptionTemplateDirective, { read: TemplateRef }) customOptionTpl: TemplateRef<any>;\n\n\tprivate lastItemIndexReached = -1;\n\tpublic dropdownPositionToUse: 'auto' | 'bottom' | 'top' | 'left' | 'right' = 'bottom';\n\tprivate isOpen: boolean = false;\n\tprivate dropdownPanelOffsetX = 0;\n\tprivate dropdownPanelOffsetY = 0;\n\tprivate anchorAbsolute: HTMLDivElement;\n\tprivate anchorFixed: HTMLDivElement;\n\n\tconstructor(\n\t\t@Optional() @Host() protected parent: FormElementComponent,\n\t\t@Optional() @Host() protected controlContainer: ControlContainer,\n\t\t@Inject(SELECT_TRANSLATIONS) @Optional() private translations: any,\n\t\tprivate elRef: ElementRef,\n\t) {\n\t\tsuper(parent, controlContainer);\n\t}\n\n\tngAfterViewInit(): void {\n\t\tthis.addPrefix();\n\t\tthis.elRef.nativeElement.querySelector('input').addEventListener('keydown', this.keyListener);\n\t}\n\n\tprivate keyListener = (e) => {\n\t\tif (e.key === 'Enter') {\n\t\t\tthis.onEnterKey.emit(e.target.value);\n\t\t}\n\t}\n\n\tprivate addPrefix(): void {\n\t\tif (stringIsSetAndFilled(this.prefix)) {\n\t\t\tconst container = this.elRef.nativeElement.querySelector('.ng-select-container');\n\t\t\tconst newNode = document.createElement('div');\n\t\t\tnewNode.className = 'prefix';\n\t\t\tnewNode.innerText = this.prefix;\n\t\t\tcontainer.insertBefore(newNode, container.children[0]);\n\t\t}\n\t}\n\n\tngOnChanges(changes: SimpleChanges): void {\n\t\tif (isValueSet(changes.options)) {\n\t\t\tthis.lastItemIndexReached = -1;\n\t\t\tthis.setWidthBasedOnOptionsWidths();\n\t\t}\n\t\tthis.dropdownPositionToUse = this.dropdownPosition;\n\t}\n\n\tgetDefaultTranslation(key: string): (x: any) => string {\n\t\tswitch (key) {\n\t\t\tcase 'placeholder':\n\t\t\t\treturn () => 'Pick an option';\n\t\t\tcase 'amountSelected':\n\t\t\t\treturn (amount) => `${amount} selected`;\n\t\t}\n\t}\n\n\tgetTranslation(key: string, params: any = null): string {\n\t\tif (key === 'placeholder' && stringIsSetAndFilled(this.placeholder)) {\n\t\t\treturn this.placeholder;\n\t\t}\n\t\treturn this.translations?.[key]?.(params) ?? this.getDefaultTranslation(key)(params);\n\t}\n\n\tonScroll(lastItemIndex: number): void {\n\t\tconst visibleItems = this.ngSelect?.itemsList?.filteredItems?.length ?? 0;\n\t\tif (this.lastItemIndexReached < lastItemIndex && lastItemIndex === visibleItems) {\n\t\t\tthis.onEndReached.emit();\n\t\t}\n\t\tthis.lastItemIndexReached = Math.max(lastItemIndex, this.lastItemIndexReached);\n\t\tthis.setWidthBasedOnOptionsWidths();\n\t}\n\n\tsearchQueryChanged(searchQuery: string): void {\n\t\tthis.onSearch.emit(searchQuery);\n\t}\n\n\tasync onOpen(): Promise<void> {\n\t\tthis.isOpen = true;\n\n\t\tif (this.orientation === 'horizontal' && !isValueSet(this.dropdownPosition)) {\n\t\t\tthis.determineDropdownPosition();\n\t\t}\n\n\t\tif (!this.truncateOptions) {\n\t\t\tthis.createAnchors();\n\t\t}\n\t\t// waiting for the thing to render until we fire the event\n\t\tawait awaitableForNextCycle();\n\t\tthis.onOpened.emit();\n\n\t\tawait this.setWidthBasedOnOptionsWidths();\n\t\tif (!this.truncateOptions) {\n\t\t\tthis.setFixedDropdownPanelPosition();\n\t\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.addEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t}\n\t}\n\n\tprivate createAnchors(): void {\n\t\tthis.anchorAbsolute = document.createElement('div');\n\t\tif (this.dropdownPositionToUse === 'top') {\n\t\t\tthis.elRef.nativeElement.prepend(this.anchorAbsolute);\n\t\t} else {\n\t\t\tthis.elRef.nativeElement.appendChild(this.anchorAbsolute);\n\t\t}\n\n\t\tthis.anchorFixed = document.createElement('div');\n\t\tthis.anchorFixed.style.position = 'fixed';\n\t\tthis.elRef.nativeElement.appendChild(this.anchorFixed);\n\t}\n\tprivate removeAnchors(): void {\n\t\tthis.elRef.nativeElement.removeChild(this.anchorAbsolute);\n\t\tthis.elRef.nativeElement.removeChild(this.anchorFixed);\n\t}\n\n\tprivate setFixedDropdownPanelPosition = () => {\n\t\tconst difference = this.anchorAbsolute.getBoundingClientRect().top - this.anchorFixed.getBoundingClientRect().top;\n\t\tthis.dropdownPanelOffsetY = difference;\n\n\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tdropdownPanel.style.position = 'fixed';\n\t\tdropdownPanel.style.visibility = 'initial';\n\t\tthis.setPanelOffsets();\n\t};\n\n\tprivate async setWidthBasedOnOptionsWidths(): Promise<void> {\n\t\tif (this.truncateOptions === false) {\n\t\t\tawait awaitableForNextCycle();\n\t\t\tconst widths: Array<number> = Array.from(this.elRef.nativeElement.querySelectorAll('.ng-option div')).map(\n\t\t\t\t(e: any) => e.scrollWidth,\n\t\t\t);\n\t\t\tconst maxWidth = Math.max(...widths);\n\t\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\t\tif (dropdownPanel) {\n\t\t\t\tdropdownPanel.style.minWidth = `${this.elRef.nativeElement.clientWidth}px`;\n\t\t\t\tdropdownPanel.style.width = `${Math.max(this.elRef.nativeElement.clientWidth, maxWidth + 40, dropdownPanel.getBoundingClientRect().width)}px`;\n\t\t\t\tawait awaitableForNextCycle();\n\t\t\t\tconst pickerWidth = this.elRef.nativeElement.getBoundingClientRect().width;\n\t\t\t\tconst dropdownPanelWidth = dropdownPanel.getBoundingClientRect().width;\n\n\t\t\t\tconst spaceLeftOfElRef = this.elRef.nativeElement.getBoundingClientRect().left;\n\t\t\t\tconst spaceRightOfElRef = window.innerWidth - (this.elRef.nativeElement.getBoundingClientRect().width + spaceLeftOfElRef);\n\t\t\t\tconst extraNeededSpace = dropdownPanelWidth - pickerWidth;\n\t\t\t\tif (this.dropdownAlignment === 'right') {\n\t\t\t\t\tif (extraNeededSpace > spaceLeftOfElRef) {\n\t\t\t\t\t\tthis.dropdownPanelOffsetX = -spaceLeftOfElRef + 10;\n\t\t\t\t\t} else {\n\t\t\t\t\t\tthis.dropdownPanelOffsetX = -extraNeededSpace;\n\t\t\t\t\t}\n\t\t\t\t} else if (extraNeededSpace > spaceRightOfElRef) {\n\t\t\t\t\tthis.dropdownPanelOffsetX = -extraNeededSpace + spaceRightOfElRef - 20;\n\t\t\t\t}\n\t\t\t\tthis.setPanelOffsets();\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate getAllLimitingContainers(): Array<HTMLElement> {\n\t\tconst result = [];\n\t\tlet current = this.elRef.nativeElement;\n\t\twhile (current.parentElement) {\n\t\t\tif (this.isLimitingContainer(current.parentElement)) {\n\t\t\t\tresult.push(current.parentElement);\n\t\t\t}\n\t\t\tcurrent = current.parentElement;\n\t\t}\n\t\treturn result;\n\t}\n\n\tprivate setPanelOffsets(): void {\n\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tconst scrollPositionOffset = `translate(${this.dropdownPanelOffsetX}px, ${this.dropdownPanelOffsetY}px)`;\n\t\tconst dropdownPositionOffset = this.dropdownPositionToUse === 'top' ? `translateY(-100%) translateY(1px)` : '';\n\t\tdropdownPanel.style.transform = [scrollPositionOffset, dropdownPositionOffset].join(' ');\n\t}\n\n\tprivate determineDropdownPosition(): void {\n\t\tconst bottomSpace = window.innerHeight - this.elRef.nativeElement.getBoundingClientRect().top;\n\t\tif (bottomSpace >= 300) {\n\t\t\tthis.dropdownPositionToUse = 'bottom';\n\t\t} else {\n\t\t\tthis.dropdownPositionToUse = 'top';\n\t\t}\n\t}\n\n\tprivate isLimitingContainer(element: Element): boolean {\n\t\tconst style = getComputedStyle(element);\n\t\tif (style.overflowY === 'auto') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflow === 'auto') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflowY === 'scroll') {\n\t\t\treturn true;\n\t\t}\n\t\tif (style.overflow === 'scroll') {\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tpublic focus = (): void => {\n\t\tthis.ngSelect.focus();\n\t}\n\tpublic close = (): void => {\n\t\tthis.ngSelect.close();\n\t}\n\n\tpublic onClose(): void {\n\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.removeEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t// Give angular a second to render the closed situation before emitting the close event\n\t\tsetTimeout(() => {\n\t\t\tthis.isOpen = false;\n\t\t\tif (!this.truncateOptions) {\n\t\t\t\tthis.removeAnchors();\n\t\t\t}\n\t\t\tthis.onClosed.emit();\n\t\t});\n\t}\n\n\tngOnDestroy(): void {\n\t\tsuper.ngOnDestroy();\n\t\tthis.elRef.nativeElement?.querySelector('input')?.removeEventListener('keydown', this.keyListener);\n\t}\n}\n","<ng-select\n\t#ngSelect\n\t[placeholder]=\"getTranslation('placeholder')\"\n\tbindLabel=\"name\"\n\tbindValue=\"id\"\n\t[items]=\"options\"\n\t[clearable]=\"clearable\"\n\t[(ngModel)]=\"innerValue\"\n\t[ngClass]=\"{showErrors: isInErrorState(), verticalOrientation: orientation === 'vertical', truncateOptions: truncateOptions, nonTruncatedOptions: !truncateOptions, withSeparatingLine: withSeparatingLine}\"\n\t(change)=\"setInnerValueAndNotify(innerValue)\"\n\t[multiple]=\"multiple\"\n\t[disabled]=\"disabled\"\n\t(blur)=\"touch(); onBlur.emit()\"\n\t(clear)=\"onClear.emit()\"\n\t(search)=\"searchQueryChanged($event.term)\"\n\t[searchable]=\"searchable\"\n\t[dropdownPosition]=\"dropdownPositionToUse\"\n\t[searchFn]=\"customSearchFn\"\n\t[selectOnTab]=\"true\"\n\t[virtualScroll]=\"true\"\n\t(scroll)=\"onScroll($event.end)\"\n\t(open)=\"onOpen()\"\n\t(close)=\"onClose()\"\n>\n\t<ng-template let-item=\"item\" ng-option-tmp>\n\t\t<ng-container *ngIf=\"customOptionTpl\" [ngTemplateOutlet]=\"customOptionTpl\" [ngTemplateOutletContext]=\"{item: item}\"></ng-container>\n\t\t<div [attr.data-cy]=\"item.id\" *ngIf=\"!customOptionTpl\">\n\t\t\t{{ item.name }}\n\t\t\t<div *ngIf=\"item.description\" class=\"dropdown-item-description\">\n\t\t\t\t{{ item.description }}\n\t\t\t</div>\n\t\t</div>\n\t</ng-template>\n\t<ng-container *ngIf=\"multiple && multipleDisplayedAsAmount && innerValue?.length > 1\">\n\t\t<ng-template ng-multi-label-tmp>\n\t\t\t<div class=\"ng-value\">\n\t\t\t\t<span class=\"ng-value-label\">{{getTranslation('amountSelected', innerValue?.length)}}</span>\n\t\t\t</div>\n\t\t</ng-template>\n\t</ng-container>\n\t<ng-template ng-footer-tmp *ngIf=\"footerElement\">\n\t\t<ng-container [ngTemplateOutlet]=\"footerElement\"></ng-container>\n\t</ng-template>\n</ng-select>\n"]}
@@ -1073,11 +1073,11 @@ class SelectComponent extends ValueAccessorBase {
1073
1073
  else {
1074
1074
  this.dropdownPanelOffsetX = -extraNeededSpace;
1075
1075
  }
1076
- this.setPanelOffsets();
1077
1076
  }
1078
1077
  else if (extraNeededSpace > spaceRightOfElRef) {
1079
1078
  this.dropdownPanelOffsetX = -extraNeededSpace + spaceRightOfElRef - 20;
1080
1079
  }
1080
+ this.setPanelOffsets();
1081
1081
  }
1082
1082
  }
1083
1083
  });