@klippa/ngx-enhancy-forms 18.33.22 → 18.33.23

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.
@@ -68,6 +68,8 @@ export class SelectComponent extends ValueAccessorBase {
68
68
  if (this.truncateOptions === false) {
69
69
  await awaitableForNextCycle();
70
70
  if (!isValueSet(this.elRef.nativeElement.querySelector('.scrollable-content'))) {
71
+ const panel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');
72
+ panel.style.width = `${this.elRef.nativeElement.clientWidth}px`;
71
73
  return;
72
74
  }
73
75
  this.elRef.nativeElement.querySelector('.scrollable-content').classList.add('calculatingWidths');
@@ -380,4 +382,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.0", ngImpor
380
382
  type: ContentChild,
381
383
  args: [KlpSelectOptionTemplateDirective, { read: TemplateRef }]
382
384
  }] } });
383
- //# 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, NgZone,\n\tOnChanges,\n\tOnDestroy,\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\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() hasBorderLeft = true;\n\t@Input() hasBorderRight = 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@ViewChild('tailRef') tailRef: ElementRef;\n\t@ViewChild('tailMockRef') tailMockRef: ElementRef;\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\tprivate ngZone: NgZone,\n\t) {\n\t\tsuper(parent, controlContainer);\n\t}\n\n\tngAfterViewInit(): void {\n\t\tthis.addPrefix();\n\t\tthis.addTail();\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\n\t\t}\n\t}\n\n\tprivate addTail(): void {\n\t\tif (this.tailMockRef) {\n\t\t\tconst container = this.elRef.nativeElement.querySelector('.ng-select-container');\n\t\t\tconst arrowWrapper = this.elRef.nativeElement.querySelector('.ng-arrow-wrapper');\n\t\t\tcontainer.insertBefore(this.tailMockRef.nativeElement, arrowWrapper);\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\tasync ngOnChanges(changes: SimpleChanges): Promise<void> {\n\t\tif (this.isOpen && isValueSet(changes.options)) {\n\t\t\tthis.lastItemIndexReached = -1;\n\t\t\t// waiting for the thing to render until we fire the event\n\t\t\tawait awaitableForNextCycle();\n\t\t\tawait this.setWidthBasedOnOptionsWidths();\n\t\t}\n\t\tif (changes.dropdownPosition) {\n\t\t\tthis.dropdownPositionToUse = this.dropdownPosition;\n\t\t}\n\t\tif (changes.prefix) {\n\t\t\tconst container = this.elRef?.nativeElement?.querySelector('.ng-select-container .prefix');\n\t\t\tif (isValueSet(container)) {\n\t\t\t\tcontainer.innerText = changes.prefix.currentValue;\n\t\t\t}\n\t\t}\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\tthis.ngZone.runOutsideAngular(() => {\n\t\t\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.addEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t\t});\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\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 dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tdropdownPanel.style.visibility = 'initial';\n\t\tif (this.orientation === 'vertical') {\n\t\t\treturn;\n\t\t}\n\t\tconst difference = this.anchorAbsolute.getBoundingClientRect().top - this.anchorFixed.getBoundingClientRect().top;\n\t\tthis.dropdownPanelOffsetY = difference;\n\n\t\tdropdownPanel.style.position = 'fixed';\n\t\tthis.setPanelOffsets();\n\t};\n\n\tprivate setWidthBasedOnOptionsWidths = async (): Promise<void> => {\n\t\tif (this.truncateOptions === false) {\n\t\t\tawait awaitableForNextCycle();\n\t\t\tif (!isValueSet(this.elRef.nativeElement.querySelector('.scrollable-content'))) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.elRef.nativeElement.querySelector('.scrollable-content').classList.add('calculatingWidths');\n\t\t\tconst paddingForScrollbar = this.getScrollbarWidth();\n\t\t\tconst maxWidth = this.elRef.nativeElement.querySelector('.scrollable-content').getBoundingClientRect().width + paddingForScrollbar;\n\t\t\tthis.elRef.nativeElement.querySelector('.scrollable-content').classList.remove('calculatingWidths');\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, 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\tif (!isValueSet(dropdownPanel)) {\n\t\t\treturn;\n\t\t}\n\t\tconst scrollPositionOffset = `translate(${this.dropdownPanelOffsetX}px, ${this.dropdownPanelOffsetY}px)`;\n\t\tconst dropdownPositionOffset = this.dropdownPositionToUse === 'top' ? `translateY(-100%) translateY(1px)` : '';\n\t\tif (this.orientation === 'vertical') {\n\t\t\tdropdownPanel.style.transformOrigin = 'top left';\n\t\t\tdropdownPanel.style.transform = `rotate(90deg) translateY(-${this.elRef.nativeElement.getBoundingClientRect().width}px)`;\n\t\t} else {\n\t\t\tdropdownPanel.style.transform = [scrollPositionOffset, dropdownPositionOffset].join(' ');\n\t\t}\n\t}\n\n\tprivate determineDropdownPosition(): void {\n\t\tconst bottomSpace = window.innerHeight - this.elRef.nativeElement.getBoundingClientRect().top;\n\t\tif (bottomSpace >= 330) {\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\n\tpublic open = (): void => {\n\t\tthis.ngSelect.open();\n\t}\n\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\tonFocus(): void {\n\t\tconst singleValueInputElement = this.elRef.nativeElement.querySelector('.ng-select-single .ng-input');\n\t\tconst prefixElement = this.elRef.nativeElement.querySelector('.ng-select-single .prefix');\n\t\tif (isValueSet(singleValueInputElement) && isValueSet(prefixElement)) {\n\t\t\tconst prefixWidth = prefixElement.getBoundingClientRect().width;\n\t\t\tconst spacing = '0.4rem';\n\t\t\tsingleValueInputElement.style.left = `calc(${prefixWidth}px + ${spacing})`;\n\t\t} else if (isValueSet(singleValueInputElement)) {\n\t\t\tsingleValueInputElement.style.left = `0px`;\n\t\t}\n\t}\n\n\tprivate getScrollbarWidth(): number {\n\t\t// Create a temporary div element\n\t\tconst div = document.createElement('div');\n\n\t\t// Set the style to measure the scrollbar\n\t\tdiv.style.overflow = 'scroll'; // Enable scrollbar\n\t\tdiv.style.width = '100px';      // Set a fixed width\n\t\tdiv.style.height = '100px';     // Set a fixed height\n\t\tdiv.style.position = 'absolute'; // Prevent the element from taking space in the layout\n\t\tdiv.style.top = '-9999px';      // Position it out of the viewport\n\n\t\t// Append the element to the body\n\t\tdocument.body.appendChild(div);\n\n\t\t// Get the width of the scrollbar\n\t\tconst scrollbarWidth = div.offsetWidth - div.clientWidth;\n\n\t\t// Remove the temporary element from the DOM\n\t\tdocument.body.removeChild(div);\n\n\t\treturn scrollbarWidth;\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, noBorderLeft: !hasBorderLeft, noBorderRight: !hasBorderRight}\"\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\t(focus)=\"onFocus()\"\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\n<div class=\"tail\" #tailRef>\n\t<ng-container [ngTemplateOutlet]=\"getTailTpl()\"></ng-container>\n</div>\n<!-- I need this mock to reserve the space. I cant use the normal tail because that opens the dropdown from ng-select -->\n<!-- I have no idea how to avoid that -->\n<div class=\"tailMock\" #tailMockRef>\n\t<ng-container [ngTemplateOutlet]=\"getTailTpl()\"></ng-container>\n</div>\n"]}
385
+ //# 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, NgZone,\n\tOnChanges,\n\tOnDestroy,\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\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() hasBorderLeft = true;\n\t@Input() hasBorderRight = 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@ViewChild('tailRef') tailRef: ElementRef;\n\t@ViewChild('tailMockRef') tailMockRef: ElementRef;\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\tprivate ngZone: NgZone,\n\t) {\n\t\tsuper(parent, controlContainer);\n\t}\n\n\tngAfterViewInit(): void {\n\t\tthis.addPrefix();\n\t\tthis.addTail();\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\n\t\t}\n\t}\n\n\tprivate addTail(): void {\n\t\tif (this.tailMockRef) {\n\t\t\tconst container = this.elRef.nativeElement.querySelector('.ng-select-container');\n\t\t\tconst arrowWrapper = this.elRef.nativeElement.querySelector('.ng-arrow-wrapper');\n\t\t\tcontainer.insertBefore(this.tailMockRef.nativeElement, arrowWrapper);\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\tasync ngOnChanges(changes: SimpleChanges): Promise<void> {\n\t\tif (this.isOpen && isValueSet(changes.options)) {\n\t\t\tthis.lastItemIndexReached = -1;\n\t\t\t// waiting for the thing to render until we fire the event\n\t\t\tawait awaitableForNextCycle();\n\t\t\tawait this.setWidthBasedOnOptionsWidths();\n\t\t}\n\t\tif (changes.dropdownPosition) {\n\t\t\tthis.dropdownPositionToUse = this.dropdownPosition;\n\t\t}\n\t\tif (changes.prefix) {\n\t\t\tconst container = this.elRef?.nativeElement?.querySelector('.ng-select-container .prefix');\n\t\t\tif (isValueSet(container)) {\n\t\t\t\tcontainer.innerText = changes.prefix.currentValue;\n\t\t\t}\n\t\t}\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\tthis.ngZone.runOutsideAngular(() => {\n\t\t\t\t[...this.getAllLimitingContainers(), window].forEach(e => e.addEventListener('scroll', this.setFixedDropdownPanelPosition));\n\t\t\t});\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\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 dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\tdropdownPanel.style.visibility = 'initial';\n\t\tif (this.orientation === 'vertical') {\n\t\t\treturn;\n\t\t}\n\t\tconst difference = this.anchorAbsolute.getBoundingClientRect().top - this.anchorFixed.getBoundingClientRect().top;\n\t\tthis.dropdownPanelOffsetY = difference;\n\n\t\tdropdownPanel.style.position = 'fixed';\n\t\tthis.setPanelOffsets();\n\t};\n\n\tprivate setWidthBasedOnOptionsWidths = async (): Promise<void> => {\n\t\tif (this.truncateOptions === false) {\n\t\t\tawait awaitableForNextCycle();\n\t\t\tif (!isValueSet(this.elRef.nativeElement.querySelector('.scrollable-content'))) {\n\t\t\t\tconst panel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\t\t\tpanel.style.width = `${this.elRef.nativeElement.clientWidth}px`;\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tthis.elRef.nativeElement.querySelector('.scrollable-content').classList.add('calculatingWidths');\n\t\t\tconst paddingForScrollbar = this.getScrollbarWidth();\n\t\t\tconst maxWidth = this.elRef.nativeElement.querySelector('.scrollable-content').getBoundingClientRect().width + paddingForScrollbar;\n\t\t\tthis.elRef.nativeElement.querySelector('.scrollable-content').classList.remove('calculatingWidths');\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, 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\tif (!isValueSet(dropdownPanel)) {\n\t\t\treturn;\n\t\t}\n\t\tconst scrollPositionOffset = `translate(${this.dropdownPanelOffsetX}px, ${this.dropdownPanelOffsetY}px)`;\n\t\tconst dropdownPositionOffset = this.dropdownPositionToUse === 'top' ? `translateY(-100%) translateY(1px)` : '';\n\t\tif (this.orientation === 'vertical') {\n\t\t\tdropdownPanel.style.transformOrigin = 'top left';\n\t\t\tdropdownPanel.style.transform = `rotate(90deg) translateY(-${this.elRef.nativeElement.getBoundingClientRect().width}px)`;\n\t\t} else {\n\t\t\tdropdownPanel.style.transform = [scrollPositionOffset, dropdownPositionOffset].join(' ');\n\t\t}\n\t}\n\n\tprivate determineDropdownPosition(): void {\n\t\tconst bottomSpace = window.innerHeight - this.elRef.nativeElement.getBoundingClientRect().top;\n\t\tif (bottomSpace >= 330) {\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\n\tpublic open = (): void => {\n\t\tthis.ngSelect.open();\n\t}\n\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\tonFocus(): void {\n\t\tconst singleValueInputElement = this.elRef.nativeElement.querySelector('.ng-select-single .ng-input');\n\t\tconst prefixElement = this.elRef.nativeElement.querySelector('.ng-select-single .prefix');\n\t\tif (isValueSet(singleValueInputElement) && isValueSet(prefixElement)) {\n\t\t\tconst prefixWidth = prefixElement.getBoundingClientRect().width;\n\t\t\tconst spacing = '0.4rem';\n\t\t\tsingleValueInputElement.style.left = `calc(${prefixWidth}px + ${spacing})`;\n\t\t} else if (isValueSet(singleValueInputElement)) {\n\t\t\tsingleValueInputElement.style.left = `0px`;\n\t\t}\n\t}\n\n\tprivate getScrollbarWidth(): number {\n\t\t// Create a temporary div element\n\t\tconst div = document.createElement('div');\n\n\t\t// Set the style to measure the scrollbar\n\t\tdiv.style.overflow = 'scroll'; // Enable scrollbar\n\t\tdiv.style.width = '100px';      // Set a fixed width\n\t\tdiv.style.height = '100px';     // Set a fixed height\n\t\tdiv.style.position = 'absolute'; // Prevent the element from taking space in the layout\n\t\tdiv.style.top = '-9999px';      // Position it out of the viewport\n\n\t\t// Append the element to the body\n\t\tdocument.body.appendChild(div);\n\n\t\t// Get the width of the scrollbar\n\t\tconst scrollbarWidth = div.offsetWidth - div.clientWidth;\n\n\t\t// Remove the temporary element from the DOM\n\t\tdocument.body.removeChild(div);\n\n\t\treturn scrollbarWidth;\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, noBorderLeft: !hasBorderLeft, noBorderRight: !hasBorderRight}\"\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\t(focus)=\"onFocus()\"\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\n<div class=\"tail\" #tailRef>\n\t<ng-container [ngTemplateOutlet]=\"getTailTpl()\"></ng-container>\n</div>\n<!-- I need this mock to reserve the space. I cant use the normal tail because that opens the dropdown from ng-select -->\n<!-- I have no idea how to avoid that -->\n<div class=\"tailMock\" #tailMockRef>\n\t<ng-container [ngTemplateOutlet]=\"getTailTpl()\"></ng-container>\n</div>\n"]}
@@ -1338,6 +1338,8 @@ class SelectComponent extends ValueAccessorBase {
1338
1338
  if (this.truncateOptions === false) {
1339
1339
  await awaitableForNextCycle();
1340
1340
  if (!isValueSet(this.elRef.nativeElement.querySelector('.scrollable-content'))) {
1341
+ const panel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');
1342
+ panel.style.width = `${this.elRef.nativeElement.clientWidth}px`;
1341
1343
  return;
1342
1344
  }
1343
1345
  this.elRef.nativeElement.querySelector('.scrollable-content').classList.add('calculatingWidths');