@klippa/ngx-enhancy-forms 14.10.2 → 14.10.4

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.
@@ -114,6 +114,7 @@ export class SelectComponent extends ValueAccessorBase {
114
114
  const maxWidth = Math.max(...widths);
115
115
  const dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');
116
116
  if (dropdownPanel) {
117
+ dropdownPanel.style.minWidth = `${this.elRef.nativeElement.clientWidth}px`;
117
118
  dropdownPanel.style.width = `${Math.max(this.elRef.nativeElement.clientWidth, maxWidth + 40, dropdownPanel.getBoundingClientRect().width)}px`;
118
119
  }
119
120
  let limitingParentContainer = this.elRef.nativeElement;
@@ -124,9 +125,8 @@ export class SelectComponent extends ValueAccessorBase {
124
125
  const spaceInParent = limitingParentContainer.clientWidth;
125
126
  const spaceLeftOfElRef = this.elRef?.nativeElement.getBoundingClientRect().left - limitingParentContainer.getBoundingClientRect().left;
126
127
  const spaceRightOfElRef = spaceInParent - spaceLeftOfElRef;
127
- const shiftToLeft = dropdownPanel?.clientWidth - spaceRightOfElRef + 20;
128
- if (shiftToLeft > 0) {
129
- dropdownPanel.style.left = `-${shiftToLeft}px`;
128
+ if (spaceRightOfElRef < dropdownPanel?.clientWidth) {
129
+ dropdownPanel.style.right = `0px`;
130
130
  }
131
131
  }
132
132
  });
@@ -238,4 +238,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
238
238
  type: ContentChild,
239
239
  args: [KlpSelectOptionTemplateDirective, { read: TemplateRef }]
240
240
  }] } });
241
- //# 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';\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 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\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\tonOpen(): void {\n\t\tif (this.orientation === 'horizontal' && !isValueSet(this.dropdownPosition)) {\n\t\t\tthis.determineDropdownPosition();\n\t\t}\n\t\t// waiting for the thing to render until we fire the event\n\t\tsetTimeout(() => {\n\t\t\tthis.onOpened.emit();\n\t\t\tthis.setWidthBasedOnOptionsWidths();\n\t\t});\n\t}\n\n\tprivate setWidthBasedOnOptionsWidths(): void {\n\t\tif (this.truncateOptions === false) {\n\t\t\tsetTimeout(() => {\n\t\t\t\tconst widths: Array<number> = Array.from(this.elRef.nativeElement.querySelectorAll('.ng-option div')).map(\n\t\t\t\t\t(e: any) => e.scrollWidth,\n\t\t\t\t);\n\t\t\t\tconst maxWidth = Math.max(...widths);\n\t\t\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\t\t\tif (dropdownPanel) {\n\t\t\t\t\tdropdownPanel.style.width = `${Math.max(this.elRef.nativeElement.clientWidth, maxWidth + 40, dropdownPanel.getBoundingClientRect().width)}px`;\n\t\t\t\t}\n\n\t\t\t\tlet limitingParentContainer = this.elRef.nativeElement;\n\t\t\t\twhile (limitingParentContainer.parentElement && !this.isLimitingContainer(limitingParentContainer)) {\n\t\t\t\t\tlimitingParentContainer = limitingParentContainer.parentElement;\n\t\t\t\t}\n\n\t\t\t\tif (dropdownPanel) {\n\t\t\t\t\tconst spaceInParent = limitingParentContainer.clientWidth;\n\t\t\t\t\tconst spaceLeftOfElRef = this.elRef?.nativeElement.getBoundingClientRect().left - limitingParentContainer.getBoundingClientRect().left;\n\t\t\t\t\tconst spaceRightOfElRef = spaceInParent - spaceLeftOfElRef;\n\t\t\t\t\tconst shiftToLeft = dropdownPanel?.clientWidth - spaceRightOfElRef + 20;\n\t\t\t\t\tif (shiftToLeft > 0) {\n\t\t\t\t\t\tdropdownPanel.style.left = `-${shiftToLeft}px`;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate determineDropdownPosition(): void {\n\t\tlet current = this.elRef.nativeElement;\n\t\twhile (current.parentElement && !this.isLimitingContainer(current)) {\n\t\t\tcurrent = current.parentElement;\n\t\t}\n\t\tconst topSpace = this.elRef.nativeElement.getBoundingClientRect().top - current.getBoundingClientRect().top;\n\t\tconst bottomSpace = current.clientHeight - topSpace;\n\t\tif (bottomSpace >= 285) {\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// Give angular a second to render the closed situation before emitting the close event\n\t\tsetTimeout(() => {\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, 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"]}
241
+ //# 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';\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 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\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\tonOpen(): void {\n\t\tif (this.orientation === 'horizontal' && !isValueSet(this.dropdownPosition)) {\n\t\t\tthis.determineDropdownPosition();\n\t\t}\n\t\t// waiting for the thing to render until we fire the event\n\t\tsetTimeout(() => {\n\t\t\tthis.onOpened.emit();\n\t\t\tthis.setWidthBasedOnOptionsWidths();\n\t\t});\n\t}\n\n\tprivate setWidthBasedOnOptionsWidths(): void {\n\t\tif (this.truncateOptions === false) {\n\t\t\tsetTimeout(() => {\n\t\t\t\tconst widths: Array<number> = Array.from(this.elRef.nativeElement.querySelectorAll('.ng-option div')).map(\n\t\t\t\t\t(e: any) => e.scrollWidth,\n\t\t\t\t);\n\t\t\t\tconst maxWidth = Math.max(...widths);\n\t\t\t\tconst dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');\n\t\t\t\tif (dropdownPanel) {\n\t\t\t\t\tdropdownPanel.style.minWidth = `${this.elRef.nativeElement.clientWidth}px`;\n\t\t\t\t\tdropdownPanel.style.width = `${Math.max(this.elRef.nativeElement.clientWidth, maxWidth + 40, dropdownPanel.getBoundingClientRect().width)}px`;\n\t\t\t\t}\n\n\t\t\t\tlet limitingParentContainer = this.elRef.nativeElement;\n\t\t\t\twhile (limitingParentContainer.parentElement && !this.isLimitingContainer(limitingParentContainer)) {\n\t\t\t\t\tlimitingParentContainer = limitingParentContainer.parentElement;\n\t\t\t\t}\n\n\t\t\t\tif (dropdownPanel) {\n\t\t\t\t\tconst spaceInParent = limitingParentContainer.clientWidth;\n\t\t\t\t\tconst spaceLeftOfElRef = this.elRef?.nativeElement.getBoundingClientRect().left - limitingParentContainer.getBoundingClientRect().left;\n\t\t\t\t\tconst spaceRightOfElRef = spaceInParent - spaceLeftOfElRef;\n\t\t\t\t\tif (spaceRightOfElRef < dropdownPanel?.clientWidth) {\n\t\t\t\t\t\tdropdownPanel.style.right = `0px`;\n\t\t\t\t\t}\n\t\t\t\t}\n\t\t\t});\n\t\t}\n\t}\n\n\tprivate determineDropdownPosition(): void {\n\t\tlet current = this.elRef.nativeElement;\n\t\twhile (current.parentElement && !this.isLimitingContainer(current)) {\n\t\t\tcurrent = current.parentElement;\n\t\t}\n\t\tconst topSpace = this.elRef.nativeElement.getBoundingClientRect().top - current.getBoundingClientRect().top;\n\t\tconst bottomSpace = current.clientHeight - topSpace;\n\t\tif (bottomSpace >= 285) {\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// Give angular a second to render the closed situation before emitting the close event\n\t\tsetTimeout(() => {\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, 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"]}
@@ -50,7 +50,7 @@ export class FormComponent {
50
50
  this.formGroup.patchValue(valueBeforeInject);
51
51
  }
52
52
  injectInto.setControl(injectAt, this.formGroup);
53
- this.onInjected.emit();
53
+ this.onInjected.emit(valueBeforeInject);
54
54
  }
55
55
  else if (injectInto instanceof UntypedFormGroup) {
56
56
  if (typeof injectAt !== 'string') {
@@ -64,7 +64,7 @@ export class FormComponent {
64
64
  this.formGroup.patchValue(valueBeforeInject);
65
65
  }
66
66
  injectInto.setControl(injectAt, this.formGroup);
67
- this.onInjected.emit();
67
+ this.onInjected.emit(valueBeforeInject);
68
68
  }
69
69
  }
70
70
  }
@@ -269,4 +269,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
269
269
  }], onInjected: [{
270
270
  type: Output
271
271
  }] } });
272
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/form/form.component.ts","../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/form/form.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n\tComponent,\n\tDirective, EventEmitter,\n\tInput,\n\tOnChanges,\n\tOnDestroy,\n\tOnInit,\n\tOptional,\n\tOutput,\n\tSimpleChanges,\n\tSkipSelf\n} from '@angular/core';\nimport {AbstractControl, FormArray, FormControl, FormGroup, UntypedFormArray, UntypedFormControl, UntypedFormGroup} from '@angular/forms';\nimport {FormElementComponent} from './form-element/form-element.component';\nimport {isValueSet} from '../util/values';\nimport { deepMerge } from '../util/objects';\n\nexport const invalidFieldsSymbol = Symbol('Not all fields are valid');\n\n@Directive({\n\t// tslint:disable-next-line:directive-selector\n\tselector: 'klp-sub-form',\n})\nexport class SubFormDirective {\n\t@Input() injectInto: UntypedFormArray | UntypedFormGroup;\n\t@Input() at: number | string;\n}\n\n@Component({\n\tselector: 'klp-form',\n\ttemplateUrl: './form.component.html',\n\tstyleUrls: ['./form.component.scss'],\n})\nexport class FormComponent implements OnInit, OnDestroy, OnChanges {\n\t@Input() public readOnly = false;\n\t@Input() public showErrorMessages = true;\n\t@Input() public errorMessageLocation: 'belowCaption' | 'rightOfCaption' = 'belowCaption';\n\t@Input() public formGroup: UntypedFormGroup;\n\t@Input() public patchValueInterceptor: (values: any) => Promise<any>;\n\t@Output() public onInjected = new EventEmitter<void>();\n\n\t// we keep track of what form controls are actually rendered. Only those count when looking at form validation\n\tprivate activeControls: Array<{\n\t\tformControl: UntypedFormControl;\n\t\tformElement: FormElementComponent;\n\t}> = [];\n\n\tconstructor(@SkipSelf() @Optional() private parent: FormComponent, @Optional() private subFormPlaceholder: SubFormDirective) {\n\t}\n\n\tngOnInit(): void {\n\t\tif (isValueSet(this.patchValueInterceptor)) {\n\t\t\tthis.addSupportForPatchValueInterceptor();\n\t\t}\n\t\tif (isValueSet(this.parent) && isValueSet(this.subFormPlaceholder)) {\n\t\t\tconst injectInto = this.subFormPlaceholder.injectInto;\n\t\t\tconst injectAt = this.subFormPlaceholder.at;\n\t\t\tif (injectInto instanceof UntypedFormArray) {\n\t\t\t\tif (typeof injectAt !== 'number') {\n\t\t\t\t\tthrow new Error(`cannot index FormArray with ${typeof injectAt}`);\n\t\t\t\t}\n\t\t\t\tif (injectInto.at(injectAt)?.disabled) {\n\t\t\t\t\tthis.formGroup.disable();\n\t\t\t\t}\n\t\t\t\tconst valueBeforeInject = injectInto.at(injectAt)?.value;\n\t\t\t\tif (isValueSet(valueBeforeInject)) {\n\t\t\t\t\tthis.formGroup.patchValue(valueBeforeInject);\n\t\t\t\t}\n\t\t\t\tinjectInto.setControl(injectAt, this.formGroup);\n\t\t\t\tthis.onInjected.emit();\n\t\t\t} else if (injectInto instanceof UntypedFormGroup) {\n\t\t\t\tif (typeof injectAt !== 'string') {\n\t\t\t\t\tthrow new Error(`cannot index FormGroup with ${typeof injectAt}`);\n\t\t\t\t}\n\t\t\t\tif (injectInto.get(injectAt)?.disabled) {\n\t\t\t\t\tthis.formGroup.disable();\n\t\t\t\t}\n\t\t\t\tconst valueBeforeInject = injectInto.get(injectAt)?.value;\n\t\t\t\tif (isValueSet(valueBeforeInject)) {\n\t\t\t\t\tthis.formGroup.patchValue(valueBeforeInject);\n\t\t\t\t}\n\t\t\t\tinjectInto.setControl(injectAt, this.formGroup);\n\t\t\t\tthis.onInjected.emit();\n\t\t\t}\n\t\t}\n\t}\n\n\tngOnChanges(simpleChanges: SimpleChanges): void {\n\t\tif (simpleChanges.readOnly?.currentValue === true) {\n\t\t\tthis.activeControls.forEach(e => e.formControl.disable());\n\t\t}\n\t}\n\n\tngOnDestroy(): void {\n\t\tif (isValueSet(this.parent) && isValueSet(this.subFormPlaceholder)) {\n\t\t\tconst injectInto = this.subFormPlaceholder.injectInto;\n\t\t\tconst injectAt = this.subFormPlaceholder.at;\n\t\t\tif (injectInto instanceof UntypedFormArray) {\n\t\t\t\tconst idx = injectInto.controls.findIndex(e => e === this.formGroup);\n\t\t\t\tinjectInto.removeAt(idx);\n\t\t\t} else if (injectInto instanceof UntypedFormGroup) {\n\t\t\t\tif (typeof injectAt !== 'string') {\n\t\t\t\t\tthrow new Error(`cannot index FormGroup with ${typeof injectAt}`);\n\t\t\t\t}\n\t\t\t\tinjectInto.removeControl(injectAt);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate addSupportForPatchValueInterceptor(): void {\n\t\tconst fn = this.formGroup.patchValue;\n\t\tconst newFn = (\n\t\t\tvalue: {\n\t\t\t\t[key: string]: any;\n\t\t\t},\n\t\t\toptions?: {\n\t\t\t\tonlySelf?: boolean;\n\t\t\t\temitEvent?: boolean;\n\t\t\t}\n\t\t): void => {\n\t\t\tthis.patchValueInterceptor(value).then((val) => {\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tfn.call(this.formGroup, val, options);\n\t\t\t\t});\n\t\t\t});\n\t\t};\n\t\tthis.formGroup.patchValue = newFn;\n\t}\n\n\tpublic registerControl(formControl: UntypedFormControl, formElement: FormElementComponent): void {\n\t\tthis.activeControls.push({formControl, formElement});\n\t\tif (this.parent) {\n\t\t\tthis.parent.registerControl(formControl, formElement);\n\t\t}\n\t\tif (this.readOnly) {\n\t\t\tformControl.disable();\n\t\t}\n\t\tconst enableFn: (opts?: { onlySelf?: boolean; emitEvent?: boolean }) => void = formControl.enable;\n\t\tformControl.enable = (opts?: { onlySelf?: boolean; emitEvent?: boolean }) => {\n\t\t\tif (!this.readOnly) {\n\t\t\t\tenableFn.call(formControl, opts);\n\t\t\t}\n\t\t};\n\t}\n\n\tpublic unregisterControl(formControl: UntypedFormControl): void {\n\t\tthis.activeControls = this.activeControls.filter((e) => e.formControl !== formControl);\n\t\tif (this.parent) {\n\t\t\tthis.parent.unregisterControl(formControl);\n\t\t}\n\t}\n\n\tprivate addFormGroupControls(formGroup: UntypedFormGroup, result: Array<UntypedFormControl>): void {\n\t\tObject.values(formGroup.controls).forEach((value) => {\n\t\t\tif (value instanceof UntypedFormGroup) {\n\t\t\t\tthis.addFormGroupControls(value, result);\n\t\t\t} else if (value instanceof UntypedFormArray) {\n\t\t\t\tthis.addFormArrayControls(value, result);\n\t\t\t} else if (value instanceof UntypedFormControl) {\n\t\t\t\tthis.addFormControl(value, result);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate addFormArrayControls(formArray: UntypedFormArray, result: Array<UntypedFormControl>): void {\n\t\tformArray.controls.forEach((value) => {\n\t\t\tif (value instanceof UntypedFormGroup) {\n\t\t\t\tthis.addFormGroupControls(value, result);\n\t\t\t} else if (value instanceof UntypedFormArray) {\n\t\t\t\tthis.addFormArrayControls(value, result);\n\t\t\t} else if (value instanceof UntypedFormControl) {\n\t\t\t\tthis.addFormControl(value, result);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate getAllFormControls(): Array<UntypedFormControl> {\n\t\tconst result = [];\n\t\tthis.addFormGroupControls(this.formGroup, result);\n\t\treturn result;\n\t}\n\n\tprivate addFormControl(control: UntypedFormControl, result: Array<UntypedFormControl>): void {\n\t\tresult.push(control);\n\t}\n\n\tprivate disableInactiveFormControl(control: UntypedFormControl): void {\n\t\tif (!this.activeControls.some((e) => e.formControl === control)) {\n\t\t\tcontrol.disable();\n\t\t}\n\t}\n\n\ttrySubmit(): Promise<any> {\n\t\tthis.formGroup.markAllAsTouched();\n\t\tconst allControls: Array<UntypedFormControl> = this.getAllFormControls();\n\t\tconst originalDisabledStates = allControls.map(e => {\n\t\t\treturn {control: e, disabled: e.disabled};\n\t\t});\n\t\tallControls.forEach(e => this.disableInactiveFormControl(e));\n\t\tallControls.forEach(e => e.updateValueAndValidity());\n\t\tconst formGroupValue = this.formGroup.value;\n\t\tconst renderedAndEnabledValues = this.getRenderedFieldValuesFormGroup(this.formGroup, true);\n\t\tconst renderedButDisabledValues = this.getRenderedFieldValuesFormGroup(this.formGroup, false);\n\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tif (this.formGroup.pending) {\n\t\t\t\tconst sub = this.formGroup.statusChanges.subscribe((res) => {\n\t\t\t\t\tif (res !== 'PENDING') {\n\t\t\t\t\t\tsub.unsubscribe();\n\t\t\t\t\t\tthis.handleSubmission(originalDisabledStates, renderedAndEnabledValues, renderedButDisabledValues, formGroupValue)\n\t\t\t\t\t\t.then(resolve)\n\t\t\t\t\t\t.catch(reject);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tthis.handleSubmission(originalDisabledStates, renderedAndEnabledValues, renderedButDisabledValues, formGroupValue)\n\t\t\t\t.then(resolve)\n\t\t\t\t.catch(reject);\n\t\t\t}\n\t\t});\n\n\t}\n\n\tprivate handleSubmission(\n\t\toriginalDisabledStates: Array<{ control: FormControl<any>; disabled: boolean }>,\n\t\trenderedAndEnabledValues: Record<any, any>,\n\t\trenderedButDisabledValues: Record<any, any>,\n\t\tformGroupValue): Promise<any>\n\t{\n\t\tif (this.formGroup.invalid) {\n\t\t\tthis.activeControls.find((e) => !e.formControl.valid)?.formElement?.scrollTo();\n\t\t\tthis.setDisabledStatesForAllControls(originalDisabledStates);\n\t\t\treturn Promise.reject(invalidFieldsSymbol);\n\t\t} else {\n\t\t\tthis.setDisabledStatesForAllControls(originalDisabledStates);\n\t\t\tconst renderedValues = deepMerge(renderedAndEnabledValues, renderedButDisabledValues);\n\t\t\treturn Promise.resolve([formGroupValue, renderedValues]);\n\t\t}\n\t}\n\n\tprivate getRenderedFieldValuesFormGroup(formGroup: FormGroup, enabled: boolean, valueObject = {}): object {\n\t\tObject.entries(formGroup.controls).forEach(([name, control]) => {\n\t\t\tif (control instanceof FormControl && control.enabled === enabled && this.activeControls.some(e => e.formControl === control)) {\n\t\t\t\tvalueObject[name] = control.value;\n\t\t\t} else if (control instanceof FormArray) {\n\t\t\t\tvalueObject[name] = [];\n\t\t\t\tthis.getRenderedFieldValuesFormArray(control, enabled, valueObject[name]);\n\t\t\t} else if (control instanceof FormGroup) {\n\t\t\t\tvalueObject[name] = {};\n\t\t\t\tthis.getRenderedFieldValuesFormGroup(control, enabled, valueObject[name]);\n\t\t\t}\n\t\t});\n\t\treturn valueObject;\n\t}\n\n\tprivate getRenderedFieldValuesFormArray(formArray: FormArray, enabled: boolean, valueArray: Array<any>): void {\n\t\tformArray.controls.forEach((control: AbstractControl) => {\n\t\t\tif (control instanceof FormControl && control.enabled === enabled && this.activeControls.some(e => e.formControl === control)) {\n\t\t\t\tvalueArray.push(control.value);\n\t\t\t} else if (control instanceof FormArray) {\n\t\t\t\tconst newArray = [];\n\t\t\t\tvalueArray.push(newArray);\n\t\t\t\tthis.getRenderedFieldValuesFormArray(control, enabled, newArray);\n\t\t\t} else if (control instanceof FormGroup) {\n\t\t\t\tconst newObject = {};\n\t\t\t\tvalueArray.push(newObject);\n\t\t\t\tthis.getRenderedFieldValuesFormGroup(control, enabled, newObject);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate setDisabledStatesForAllControls(originalDisabledStates: Array<{ control: AbstractControl; disabled: boolean }>): void {\n\t\toriginalDisabledStates.forEach((e) => {\n\t\t\tif (e.disabled) {\n\t\t\t\te.control.disable();\n\t\t\t} else {\n\t\t\t\te.control.enable();\n\t\t\t}\n\t\t});\n\t}\n}\n","<form>\n\t<ng-content></ng-content>\n</form>\n\n\n"]}
272
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form.component.js","sourceRoot":"","sources":["../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/form/form.component.ts","../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/form/form.component.html"],"names":[],"mappings":"AAAA,OAAO,EACN,SAAS,EACT,SAAS,EAAE,YAAY,EACvB,KAAK,EAIL,QAAQ,EACR,MAAM,EAEN,QAAQ,EACR,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkB,SAAS,EAAE,WAAW,EAAE,SAAS,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,gBAAgB,EAAC,MAAM,gBAAgB,CAAC;AAE1I,OAAO,EAAC,UAAU,EAAC,MAAM,gBAAgB,CAAC;AAC1C,OAAO,EAAE,SAAS,EAAE,MAAM,iBAAiB,CAAC;;;AAE5C,MAAM,CAAC,MAAM,mBAAmB,GAAG,MAAM,CAAC,0BAA0B,CAAC,CAAC;AAMtE,MAAM,OAAO,gBAAgB;;6GAAhB,gBAAgB;iGAAhB,gBAAgB;2FAAhB,gBAAgB;kBAJ5B,SAAS;mBAAC;oBACV,8CAA8C;oBAC9C,QAAQ,EAAE,cAAc;iBACxB;8BAES,UAAU;sBAAlB,KAAK;gBACG,EAAE;sBAAV,KAAK;;AAQP,MAAM,OAAO,aAAa;IAczB,YAA4C,MAAqB,EAAsB,kBAAoC;QAA/E,WAAM,GAAN,MAAM,CAAe;QAAsB,uBAAkB,GAAlB,kBAAkB,CAAkB;QAb3G,aAAQ,GAAG,KAAK,CAAC;QACjB,sBAAiB,GAAG,IAAI,CAAC;QACzB,yBAAoB,GAAsC,cAAc,CAAC;QAGxE,eAAU,GAAG,IAAI,YAAY,EAAuB,CAAC;QAEtE,8GAA8G;QACtG,mBAAc,GAGjB,EAAE,CAAC;IAGR,CAAC;IAED,QAAQ;QACP,IAAI,UAAU,CAAC,IAAI,CAAC,qBAAqB,CAAC,EAAE;YAC3C,IAAI,CAAC,kCAAkC,EAAE,CAAC;SAC1C;QACD,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE;YACnE,MAAM,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC;YACtD,MAAM,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC;YAC5C,IAAI,UAAU,YAAY,gBAAgB,EAAE;gBAC3C,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;oBACjC,MAAM,IAAI,KAAK,CAAC,+BAA+B,OAAO,QAAQ,EAAE,CAAC,CAAC;iBAClE;gBACD,IAAI,UAAU,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE;oBACtC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;iBACzB;gBACD,MAAM,iBAAiB,GAAG,UAAU,CAAC,EAAE,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC;gBACzD,IAAI,UAAU,CAAC,iBAAiB,CAAC,EAAE;oBAClC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;iBAC7C;gBACD,UAAU,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;gBAChD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;aACxC;iBAAM,IAAI,UAAU,YAAY,gBAAgB,EAAE;gBAClD,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;oBACjC,MAAM,IAAI,KAAK,CAAC,+BAA+B,OAAO,QAAQ,EAAE,CAAC,CAAC;iBAClE;gBACD,IAAI,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,QAAQ,EAAE;oBACvC,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE,CAAC;iBACzB;gBACD,MAAM,iBAAiB,GAAG,UAAU,CAAC,GAAG,CAAC,QAAQ,CAAC,EAAE,KAAK,CAAC;gBAC1D,IAAI,UAAU,CAAC,iBAAiB,CAAC,EAAE;oBAClC,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC,iBAAiB,CAAC,CAAC;iBAC7C;gBACD,UAAU,CAAC,UAAU,CAAC,QAAQ,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;gBAChD,IAAI,CAAC,UAAU,CAAC,IAAI,CAAC,iBAAiB,CAAC,CAAC;aACxC;SACD;IACF,CAAC;IAED,WAAW,CAAC,aAA4B;QACvC,IAAI,aAAa,CAAC,QAAQ,EAAE,YAAY,KAAK,IAAI,EAAE;YAClD,IAAI,CAAC,cAAc,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,CAAC,OAAO,EAAE,CAAC,CAAC;SAC1D;IACF,CAAC;IAED,WAAW;QACV,IAAI,UAAU,CAAC,IAAI,CAAC,MAAM,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,kBAAkB,CAAC,EAAE;YACnE,MAAM,UAAU,GAAG,IAAI,CAAC,kBAAkB,CAAC,UAAU,CAAC;YACtD,MAAM,QAAQ,GAAG,IAAI,CAAC,kBAAkB,CAAC,EAAE,CAAC;YAC5C,IAAI,UAAU,YAAY,gBAAgB,EAAE;gBAC3C,MAAM,GAAG,GAAG,UAAU,CAAC,QAAQ,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,KAAK,IAAI,CAAC,SAAS,CAAC,CAAC;gBACrE,UAAU,CAAC,QAAQ,CAAC,GAAG,CAAC,CAAC;aACzB;iBAAM,IAAI,UAAU,YAAY,gBAAgB,EAAE;gBAClD,IAAI,OAAO,QAAQ,KAAK,QAAQ,EAAE;oBACjC,MAAM,IAAI,KAAK,CAAC,+BAA+B,OAAO,QAAQ,EAAE,CAAC,CAAC;iBAClE;gBACD,UAAU,CAAC,aAAa,CAAC,QAAQ,CAAC,CAAC;aACnC;SACD;IACF,CAAC;IAEO,kCAAkC;QACzC,MAAM,EAAE,GAAG,IAAI,CAAC,SAAS,CAAC,UAAU,CAAC;QACrC,MAAM,KAAK,GAAG,CACb,KAEC,EACD,OAGC,EACM,EAAE;YACT,IAAI,CAAC,qBAAqB,CAAC,KAAK,CAAC,CAAC,IAAI,CAAC,CAAC,GAAG,EAAE,EAAE;gBAC9C,UAAU,CAAC,GAAG,EAAE;oBACf,EAAE,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE,GAAG,EAAE,OAAO,CAAC,CAAC;gBACvC,CAAC,CAAC,CAAC;YACJ,CAAC,CAAC,CAAC;QACJ,CAAC,CAAC;QACF,IAAI,CAAC,SAAS,CAAC,UAAU,GAAG,KAAK,CAAC;IACnC,CAAC;IAEM,eAAe,CAAC,WAA+B,EAAE,WAAiC;QACxF,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,EAAC,WAAW,EAAE,WAAW,EAAC,CAAC,CAAC;QACrD,IAAI,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,WAAW,EAAE,WAAW,CAAC,CAAC;SACtD;QACD,IAAI,IAAI,CAAC,QAAQ,EAAE;YAClB,WAAW,CAAC,OAAO,EAAE,CAAC;SACtB;QACD,MAAM,QAAQ,GAAiE,WAAW,CAAC,MAAM,CAAC;QAClG,WAAW,CAAC,MAAM,GAAG,CAAC,IAAkD,EAAE,EAAE;YAC3E,IAAI,CAAC,IAAI,CAAC,QAAQ,EAAE;gBACnB,QAAQ,CAAC,IAAI,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;aACjC;QACF,CAAC,CAAC;IACH,CAAC;IAEM,iBAAiB,CAAC,WAA+B;QACvD,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,cAAc,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,WAAW,CAAC,CAAC;QACvF,IAAI,IAAI,CAAC,MAAM,EAAE;YAChB,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;SAC3C;IACF,CAAC;IAEO,oBAAoB,CAAC,SAA2B,EAAE,MAAiC;QAC1F,MAAM,CAAC,MAAM,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACnD,IAAI,KAAK,YAAY,gBAAgB,EAAE;gBACtC,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACzC;iBAAM,IAAI,KAAK,YAAY,gBAAgB,EAAE;gBAC7C,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACzC;iBAAM,IAAI,KAAK,YAAY,kBAAkB,EAAE;gBAC/C,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACnC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAEO,oBAAoB,CAAC,SAA2B,EAAE,MAAiC;QAC1F,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,KAAK,EAAE,EAAE;YACpC,IAAI,KAAK,YAAY,gBAAgB,EAAE;gBACtC,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACzC;iBAAM,IAAI,KAAK,YAAY,gBAAgB,EAAE;gBAC7C,IAAI,CAAC,oBAAoB,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACzC;iBAAM,IAAI,KAAK,YAAY,kBAAkB,EAAE;gBAC/C,IAAI,CAAC,cAAc,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;aACnC;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAEO,kBAAkB;QACzB,MAAM,MAAM,GAAG,EAAE,CAAC;QAClB,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,SAAS,EAAE,MAAM,CAAC,CAAC;QAClD,OAAO,MAAM,CAAC;IACf,CAAC;IAEO,cAAc,CAAC,OAA2B,EAAE,MAAiC;QACpF,MAAM,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;IACtB,CAAC;IAEO,0BAA0B,CAAC,OAA2B;QAC7D,IAAI,CAAC,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,OAAO,CAAC,EAAE;YAChE,OAAO,CAAC,OAAO,EAAE,CAAC;SAClB;IACF,CAAC;IAED,SAAS;QACR,IAAI,CAAC,SAAS,CAAC,gBAAgB,EAAE,CAAC;QAClC,MAAM,WAAW,GAA8B,IAAI,CAAC,kBAAkB,EAAE,CAAC;QACzE,MAAM,sBAAsB,GAAG,WAAW,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE;YAClD,OAAO,EAAC,OAAO,EAAE,CAAC,EAAE,QAAQ,EAAE,CAAC,CAAC,QAAQ,EAAC,CAAC;QAC3C,CAAC,CAAC,CAAC;QACH,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,0BAA0B,CAAC,CAAC,CAAC,CAAC,CAAC;QAC7D,WAAW,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,sBAAsB,EAAE,CAAC,CAAC;QACrD,MAAM,cAAc,GAAG,IAAI,CAAC,SAAS,CAAC,KAAK,CAAC;QAC5C,MAAM,wBAAwB,GAAG,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,SAAS,EAAE,IAAI,CAAC,CAAC;QAC5F,MAAM,yBAAyB,GAAG,IAAI,CAAC,+BAA+B,CAAC,IAAI,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QAE9F,OAAO,IAAI,OAAO,CAAC,CAAC,OAAO,EAAE,MAAM,EAAE,EAAE;YACtC,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE;gBAC3B,MAAM,GAAG,GAAG,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,GAAG,EAAE,EAAE;oBAC1D,IAAI,GAAG,KAAK,SAAS,EAAE;wBACtB,GAAG,CAAC,WAAW,EAAE,CAAC;wBAClB,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,wBAAwB,EAAE,yBAAyB,EAAE,cAAc,CAAC;6BACjH,IAAI,CAAC,OAAO,CAAC;6BACb,KAAK,CAAC,MAAM,CAAC,CAAC;qBACf;gBACF,CAAC,CAAC,CAAC;aACH;iBAAM;gBACN,IAAI,CAAC,gBAAgB,CAAC,sBAAsB,EAAE,wBAAwB,EAAE,yBAAyB,EAAE,cAAc,CAAC;qBACjH,IAAI,CAAC,OAAO,CAAC;qBACb,KAAK,CAAC,MAAM,CAAC,CAAC;aACf;QACF,CAAC,CAAC,CAAC;IAEJ,CAAC;IAEO,gBAAgB,CACvB,sBAA+E,EAC/E,wBAA0C,EAC1C,yBAA2C,EAC3C,cAAc;QAEd,IAAI,IAAI,CAAC,SAAS,CAAC,OAAO,EAAE;YAC3B,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,CAAC,WAAW,CAAC,KAAK,CAAC,EAAE,WAAW,EAAE,QAAQ,EAAE,CAAC;YAC/E,IAAI,CAAC,+BAA+B,CAAC,sBAAsB,CAAC,CAAC;YAC7D,OAAO,OAAO,CAAC,MAAM,CAAC,mBAAmB,CAAC,CAAC;SAC3C;aAAM;YACN,IAAI,CAAC,+BAA+B,CAAC,sBAAsB,CAAC,CAAC;YAC7D,MAAM,cAAc,GAAG,SAAS,CAAC,wBAAwB,EAAE,yBAAyB,CAAC,CAAC;YACtF,OAAO,OAAO,CAAC,OAAO,CAAC,CAAC,cAAc,EAAE,cAAc,CAAC,CAAC,CAAC;SACzD;IACF,CAAC;IAEO,+BAA+B,CAAC,SAAoB,EAAE,OAAgB,EAAE,WAAW,GAAG,EAAE;QAC/F,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,QAAQ,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,IAAI,EAAE,OAAO,CAAC,EAAE,EAAE;YAC9D,IAAI,OAAO,YAAY,WAAW,IAAI,OAAO,CAAC,OAAO,KAAK,OAAO,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,OAAO,CAAC,EAAE;gBAC9H,WAAW,CAAC,IAAI,CAAC,GAAG,OAAO,CAAC,KAAK,CAAC;aAClC;iBAAM,IAAI,OAAO,YAAY,SAAS,EAAE;gBACxC,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;gBACvB,IAAI,CAAC,+BAA+B,CAAC,OAAO,EAAE,OAAO,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;aAC1E;iBAAM,IAAI,OAAO,YAAY,SAAS,EAAE;gBACxC,WAAW,CAAC,IAAI,CAAC,GAAG,EAAE,CAAC;gBACvB,IAAI,CAAC,+BAA+B,CAAC,OAAO,EAAE,OAAO,EAAE,WAAW,CAAC,IAAI,CAAC,CAAC,CAAC;aAC1E;QACF,CAAC,CAAC,CAAC;QACH,OAAO,WAAW,CAAC;IACpB,CAAC;IAEO,+BAA+B,CAAC,SAAoB,EAAE,OAAgB,EAAE,UAAsB;QACrG,SAAS,CAAC,QAAQ,CAAC,OAAO,CAAC,CAAC,OAAwB,EAAE,EAAE;YACvD,IAAI,OAAO,YAAY,WAAW,IAAI,OAAO,CAAC,OAAO,KAAK,OAAO,IAAI,IAAI,CAAC,cAAc,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,WAAW,KAAK,OAAO,CAAC,EAAE;gBAC9H,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;aAC/B;iBAAM,IAAI,OAAO,YAAY,SAAS,EAAE;gBACxC,MAAM,QAAQ,GAAG,EAAE,CAAC;gBACpB,UAAU,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;gBAC1B,IAAI,CAAC,+BAA+B,CAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,CAAC,CAAC;aACjE;iBAAM,IAAI,OAAO,YAAY,SAAS,EAAE;gBACxC,MAAM,SAAS,GAAG,EAAE,CAAC;gBACrB,UAAU,CAAC,IAAI,CAAC,SAAS,CAAC,CAAC;gBAC3B,IAAI,CAAC,+BAA+B,CAAC,OAAO,EAAE,OAAO,EAAE,SAAS,CAAC,CAAC;aAClE;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;IAEO,+BAA+B,CAAC,sBAA8E;QACrH,sBAAsB,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;YACpC,IAAI,CAAC,CAAC,QAAQ,EAAE;gBACf,CAAC,CAAC,OAAO,CAAC,OAAO,EAAE,CAAC;aACpB;iBAAM;gBACN,CAAC,CAAC,OAAO,CAAC,MAAM,EAAE,CAAC;aACnB;QACF,CAAC,CAAC,CAAC;IACJ,CAAC;;0GAtPW,aAAa;8FAAb,aAAa,4SCjC1B,oDAKA;2FD4Ba,aAAa;kBALzB,SAAS;+BACC,UAAU;;0BAkBP,QAAQ;;0BAAI,QAAQ;;0BAAmC,QAAQ;4CAb5D,QAAQ;sBAAvB,KAAK;gBACU,iBAAiB;sBAAhC,KAAK;gBACU,oBAAoB;sBAAnC,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,qBAAqB;sBAApC,KAAK;gBACW,UAAU;sBAA1B,MAAM","sourcesContent":["import {\n\tComponent,\n\tDirective, EventEmitter,\n\tInput,\n\tOnChanges,\n\tOnDestroy,\n\tOnInit,\n\tOptional,\n\tOutput,\n\tSimpleChanges,\n\tSkipSelf\n} from '@angular/core';\nimport {AbstractControl, FormArray, FormControl, FormGroup, UntypedFormArray, UntypedFormControl, UntypedFormGroup} from '@angular/forms';\nimport {FormElementComponent} from './form-element/form-element.component';\nimport {isValueSet} from '../util/values';\nimport { deepMerge } from '../util/objects';\n\nexport const invalidFieldsSymbol = Symbol('Not all fields are valid');\n\n@Directive({\n\t// tslint:disable-next-line:directive-selector\n\tselector: 'klp-sub-form',\n})\nexport class SubFormDirective {\n\t@Input() injectInto: UntypedFormArray | UntypedFormGroup;\n\t@Input() at: number | string;\n}\n\n@Component({\n\tselector: 'klp-form',\n\ttemplateUrl: './form.component.html',\n\tstyleUrls: ['./form.component.scss'],\n})\nexport class FormComponent implements OnInit, OnDestroy, OnChanges {\n\t@Input() public readOnly = false;\n\t@Input() public showErrorMessages = true;\n\t@Input() public errorMessageLocation: 'belowCaption' | 'rightOfCaption' = 'belowCaption';\n\t@Input() public formGroup: UntypedFormGroup;\n\t@Input() public patchValueInterceptor: (values: any) => Promise<any>;\n\t@Output() public onInjected = new EventEmitter<Record<string, any>>();\n\n\t// we keep track of what form controls are actually rendered. Only those count when looking at form validation\n\tprivate activeControls: Array<{\n\t\tformControl: UntypedFormControl;\n\t\tformElement: FormElementComponent;\n\t}> = [];\n\n\tconstructor(@SkipSelf() @Optional() private parent: FormComponent, @Optional() private subFormPlaceholder: SubFormDirective) {\n\t}\n\n\tngOnInit(): void {\n\t\tif (isValueSet(this.patchValueInterceptor)) {\n\t\t\tthis.addSupportForPatchValueInterceptor();\n\t\t}\n\t\tif (isValueSet(this.parent) && isValueSet(this.subFormPlaceholder)) {\n\t\t\tconst injectInto = this.subFormPlaceholder.injectInto;\n\t\t\tconst injectAt = this.subFormPlaceholder.at;\n\t\t\tif (injectInto instanceof UntypedFormArray) {\n\t\t\t\tif (typeof injectAt !== 'number') {\n\t\t\t\t\tthrow new Error(`cannot index FormArray with ${typeof injectAt}`);\n\t\t\t\t}\n\t\t\t\tif (injectInto.at(injectAt)?.disabled) {\n\t\t\t\t\tthis.formGroup.disable();\n\t\t\t\t}\n\t\t\t\tconst valueBeforeInject = injectInto.at(injectAt)?.value;\n\t\t\t\tif (isValueSet(valueBeforeInject)) {\n\t\t\t\t\tthis.formGroup.patchValue(valueBeforeInject);\n\t\t\t\t}\n\t\t\t\tinjectInto.setControl(injectAt, this.formGroup);\n\t\t\t\tthis.onInjected.emit(valueBeforeInject);\n\t\t\t} else if (injectInto instanceof UntypedFormGroup) {\n\t\t\t\tif (typeof injectAt !== 'string') {\n\t\t\t\t\tthrow new Error(`cannot index FormGroup with ${typeof injectAt}`);\n\t\t\t\t}\n\t\t\t\tif (injectInto.get(injectAt)?.disabled) {\n\t\t\t\t\tthis.formGroup.disable();\n\t\t\t\t}\n\t\t\t\tconst valueBeforeInject = injectInto.get(injectAt)?.value;\n\t\t\t\tif (isValueSet(valueBeforeInject)) {\n\t\t\t\t\tthis.formGroup.patchValue(valueBeforeInject);\n\t\t\t\t}\n\t\t\t\tinjectInto.setControl(injectAt, this.formGroup);\n\t\t\t\tthis.onInjected.emit(valueBeforeInject);\n\t\t\t}\n\t\t}\n\t}\n\n\tngOnChanges(simpleChanges: SimpleChanges): void {\n\t\tif (simpleChanges.readOnly?.currentValue === true) {\n\t\t\tthis.activeControls.forEach(e => e.formControl.disable());\n\t\t}\n\t}\n\n\tngOnDestroy(): void {\n\t\tif (isValueSet(this.parent) && isValueSet(this.subFormPlaceholder)) {\n\t\t\tconst injectInto = this.subFormPlaceholder.injectInto;\n\t\t\tconst injectAt = this.subFormPlaceholder.at;\n\t\t\tif (injectInto instanceof UntypedFormArray) {\n\t\t\t\tconst idx = injectInto.controls.findIndex(e => e === this.formGroup);\n\t\t\t\tinjectInto.removeAt(idx);\n\t\t\t} else if (injectInto instanceof UntypedFormGroup) {\n\t\t\t\tif (typeof injectAt !== 'string') {\n\t\t\t\t\tthrow new Error(`cannot index FormGroup with ${typeof injectAt}`);\n\t\t\t\t}\n\t\t\t\tinjectInto.removeControl(injectAt);\n\t\t\t}\n\t\t}\n\t}\n\n\tprivate addSupportForPatchValueInterceptor(): void {\n\t\tconst fn = this.formGroup.patchValue;\n\t\tconst newFn = (\n\t\t\tvalue: {\n\t\t\t\t[key: string]: any;\n\t\t\t},\n\t\t\toptions?: {\n\t\t\t\tonlySelf?: boolean;\n\t\t\t\temitEvent?: boolean;\n\t\t\t}\n\t\t): void => {\n\t\t\tthis.patchValueInterceptor(value).then((val) => {\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tfn.call(this.formGroup, val, options);\n\t\t\t\t});\n\t\t\t});\n\t\t};\n\t\tthis.formGroup.patchValue = newFn;\n\t}\n\n\tpublic registerControl(formControl: UntypedFormControl, formElement: FormElementComponent): void {\n\t\tthis.activeControls.push({formControl, formElement});\n\t\tif (this.parent) {\n\t\t\tthis.parent.registerControl(formControl, formElement);\n\t\t}\n\t\tif (this.readOnly) {\n\t\t\tformControl.disable();\n\t\t}\n\t\tconst enableFn: (opts?: { onlySelf?: boolean; emitEvent?: boolean }) => void = formControl.enable;\n\t\tformControl.enable = (opts?: { onlySelf?: boolean; emitEvent?: boolean }) => {\n\t\t\tif (!this.readOnly) {\n\t\t\t\tenableFn.call(formControl, opts);\n\t\t\t}\n\t\t};\n\t}\n\n\tpublic unregisterControl(formControl: UntypedFormControl): void {\n\t\tthis.activeControls = this.activeControls.filter((e) => e.formControl !== formControl);\n\t\tif (this.parent) {\n\t\t\tthis.parent.unregisterControl(formControl);\n\t\t}\n\t}\n\n\tprivate addFormGroupControls(formGroup: UntypedFormGroup, result: Array<UntypedFormControl>): void {\n\t\tObject.values(formGroup.controls).forEach((value) => {\n\t\t\tif (value instanceof UntypedFormGroup) {\n\t\t\t\tthis.addFormGroupControls(value, result);\n\t\t\t} else if (value instanceof UntypedFormArray) {\n\t\t\t\tthis.addFormArrayControls(value, result);\n\t\t\t} else if (value instanceof UntypedFormControl) {\n\t\t\t\tthis.addFormControl(value, result);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate addFormArrayControls(formArray: UntypedFormArray, result: Array<UntypedFormControl>): void {\n\t\tformArray.controls.forEach((value) => {\n\t\t\tif (value instanceof UntypedFormGroup) {\n\t\t\t\tthis.addFormGroupControls(value, result);\n\t\t\t} else if (value instanceof UntypedFormArray) {\n\t\t\t\tthis.addFormArrayControls(value, result);\n\t\t\t} else if (value instanceof UntypedFormControl) {\n\t\t\t\tthis.addFormControl(value, result);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate getAllFormControls(): Array<UntypedFormControl> {\n\t\tconst result = [];\n\t\tthis.addFormGroupControls(this.formGroup, result);\n\t\treturn result;\n\t}\n\n\tprivate addFormControl(control: UntypedFormControl, result: Array<UntypedFormControl>): void {\n\t\tresult.push(control);\n\t}\n\n\tprivate disableInactiveFormControl(control: UntypedFormControl): void {\n\t\tif (!this.activeControls.some((e) => e.formControl === control)) {\n\t\t\tcontrol.disable();\n\t\t}\n\t}\n\n\ttrySubmit(): Promise<any> {\n\t\tthis.formGroup.markAllAsTouched();\n\t\tconst allControls: Array<UntypedFormControl> = this.getAllFormControls();\n\t\tconst originalDisabledStates = allControls.map(e => {\n\t\t\treturn {control: e, disabled: e.disabled};\n\t\t});\n\t\tallControls.forEach(e => this.disableInactiveFormControl(e));\n\t\tallControls.forEach(e => e.updateValueAndValidity());\n\t\tconst formGroupValue = this.formGroup.value;\n\t\tconst renderedAndEnabledValues = this.getRenderedFieldValuesFormGroup(this.formGroup, true);\n\t\tconst renderedButDisabledValues = this.getRenderedFieldValuesFormGroup(this.formGroup, false);\n\n\t\treturn new Promise((resolve, reject) => {\n\t\t\tif (this.formGroup.pending) {\n\t\t\t\tconst sub = this.formGroup.statusChanges.subscribe((res) => {\n\t\t\t\t\tif (res !== 'PENDING') {\n\t\t\t\t\t\tsub.unsubscribe();\n\t\t\t\t\t\tthis.handleSubmission(originalDisabledStates, renderedAndEnabledValues, renderedButDisabledValues, formGroupValue)\n\t\t\t\t\t\t.then(resolve)\n\t\t\t\t\t\t.catch(reject);\n\t\t\t\t\t}\n\t\t\t\t});\n\t\t\t} else {\n\t\t\t\tthis.handleSubmission(originalDisabledStates, renderedAndEnabledValues, renderedButDisabledValues, formGroupValue)\n\t\t\t\t.then(resolve)\n\t\t\t\t.catch(reject);\n\t\t\t}\n\t\t});\n\n\t}\n\n\tprivate handleSubmission(\n\t\toriginalDisabledStates: Array<{ control: FormControl<any>; disabled: boolean }>,\n\t\trenderedAndEnabledValues: Record<any, any>,\n\t\trenderedButDisabledValues: Record<any, any>,\n\t\tformGroupValue): Promise<any>\n\t{\n\t\tif (this.formGroup.invalid) {\n\t\t\tthis.activeControls.find((e) => !e.formControl.valid)?.formElement?.scrollTo();\n\t\t\tthis.setDisabledStatesForAllControls(originalDisabledStates);\n\t\t\treturn Promise.reject(invalidFieldsSymbol);\n\t\t} else {\n\t\t\tthis.setDisabledStatesForAllControls(originalDisabledStates);\n\t\t\tconst renderedValues = deepMerge(renderedAndEnabledValues, renderedButDisabledValues);\n\t\t\treturn Promise.resolve([formGroupValue, renderedValues]);\n\t\t}\n\t}\n\n\tprivate getRenderedFieldValuesFormGroup(formGroup: FormGroup, enabled: boolean, valueObject = {}): object {\n\t\tObject.entries(formGroup.controls).forEach(([name, control]) => {\n\t\t\tif (control instanceof FormControl && control.enabled === enabled && this.activeControls.some(e => e.formControl === control)) {\n\t\t\t\tvalueObject[name] = control.value;\n\t\t\t} else if (control instanceof FormArray) {\n\t\t\t\tvalueObject[name] = [];\n\t\t\t\tthis.getRenderedFieldValuesFormArray(control, enabled, valueObject[name]);\n\t\t\t} else if (control instanceof FormGroup) {\n\t\t\t\tvalueObject[name] = {};\n\t\t\t\tthis.getRenderedFieldValuesFormGroup(control, enabled, valueObject[name]);\n\t\t\t}\n\t\t});\n\t\treturn valueObject;\n\t}\n\n\tprivate getRenderedFieldValuesFormArray(formArray: FormArray, enabled: boolean, valueArray: Array<any>): void {\n\t\tformArray.controls.forEach((control: AbstractControl) => {\n\t\t\tif (control instanceof FormControl && control.enabled === enabled && this.activeControls.some(e => e.formControl === control)) {\n\t\t\t\tvalueArray.push(control.value);\n\t\t\t} else if (control instanceof FormArray) {\n\t\t\t\tconst newArray = [];\n\t\t\t\tvalueArray.push(newArray);\n\t\t\t\tthis.getRenderedFieldValuesFormArray(control, enabled, newArray);\n\t\t\t} else if (control instanceof FormGroup) {\n\t\t\t\tconst newObject = {};\n\t\t\t\tvalueArray.push(newObject);\n\t\t\t\tthis.getRenderedFieldValuesFormGroup(control, enabled, newObject);\n\t\t\t}\n\t\t});\n\t}\n\n\tprivate setDisabledStatesForAllControls(originalDisabledStates: Array<{ control: AbstractControl; disabled: boolean }>): void {\n\t\toriginalDisabledStates.forEach((e) => {\n\t\t\tif (e.disabled) {\n\t\t\t\te.control.disable();\n\t\t\t} else {\n\t\t\t\te.control.enable();\n\t\t\t}\n\t\t});\n\t}\n}\n","<form>\n\t<ng-content></ng-content>\n</form>\n\n\n"]}
@@ -176,7 +176,7 @@ class FormComponent {
176
176
  this.formGroup.patchValue(valueBeforeInject);
177
177
  }
178
178
  injectInto.setControl(injectAt, this.formGroup);
179
- this.onInjected.emit();
179
+ this.onInjected.emit(valueBeforeInject);
180
180
  }
181
181
  else if (injectInto instanceof UntypedFormGroup) {
182
182
  if (typeof injectAt !== 'string') {
@@ -190,7 +190,7 @@ class FormComponent {
190
190
  this.formGroup.patchValue(valueBeforeInject);
191
191
  }
192
192
  injectInto.setControl(injectAt, this.formGroup);
193
- this.onInjected.emit();
193
+ this.onInjected.emit(valueBeforeInject);
194
194
  }
195
195
  }
196
196
  }
@@ -1012,6 +1012,7 @@ class SelectComponent extends ValueAccessorBase {
1012
1012
  const maxWidth = Math.max(...widths);
1013
1013
  const dropdownPanel = this.elRef.nativeElement.querySelector('ng-dropdown-panel');
1014
1014
  if (dropdownPanel) {
1015
+ dropdownPanel.style.minWidth = `${this.elRef.nativeElement.clientWidth}px`;
1015
1016
  dropdownPanel.style.width = `${Math.max(this.elRef.nativeElement.clientWidth, maxWidth + 40, dropdownPanel.getBoundingClientRect().width)}px`;
1016
1017
  }
1017
1018
  let limitingParentContainer = this.elRef.nativeElement;
@@ -1022,9 +1023,8 @@ class SelectComponent extends ValueAccessorBase {
1022
1023
  const spaceInParent = limitingParentContainer.clientWidth;
1023
1024
  const spaceLeftOfElRef = ((_a = this.elRef) === null || _a === void 0 ? void 0 : _a.nativeElement.getBoundingClientRect().left) - limitingParentContainer.getBoundingClientRect().left;
1024
1025
  const spaceRightOfElRef = spaceInParent - spaceLeftOfElRef;
1025
- const shiftToLeft = (dropdownPanel === null || dropdownPanel === void 0 ? void 0 : dropdownPanel.clientWidth) - spaceRightOfElRef + 20;
1026
- if (shiftToLeft > 0) {
1027
- dropdownPanel.style.left = `-${shiftToLeft}px`;
1026
+ if (spaceRightOfElRef < (dropdownPanel === null || dropdownPanel === void 0 ? void 0 : dropdownPanel.clientWidth)) {
1027
+ dropdownPanel.style.right = `0px`;
1028
1028
  }
1029
1029
  }
1030
1030
  });