@klippa/ngx-enhancy-forms 14.22.9 → 14.22.10
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.
- package/esm2020/lib/form/form-element/form-element.component.mjs +1 -3
- package/fesm2015/klippa-ngx-enhancy-forms.mjs +0 -2
- package/fesm2015/klippa-ngx-enhancy-forms.mjs.map +1 -1
- package/fesm2020/klippa-ngx-enhancy-forms.mjs +0 -2
- package/fesm2020/klippa-ngx-enhancy-forms.mjs.map +1 -1
- package/package.json +1 -1
|
@@ -146,8 +146,6 @@ export class FormElementComponent {
|
|
|
146
146
|
const elementTop = this.internalComponentRef.nativeElement.getBoundingClientRect().top;
|
|
147
147
|
const parentScrollTop = parent.scrollTop;
|
|
148
148
|
const answer = elementTop - parentTop + parentScrollTop;
|
|
149
|
-
console.log('answer', parentTop, elementTop, parentScrollTop, answer);
|
|
150
|
-
console.log(parent, this.internalComponentRef.nativeElement);
|
|
151
149
|
parent.scrollTo({
|
|
152
150
|
top: answer - 30,
|
|
153
151
|
behavior: 'smooth'
|
|
@@ -264,4 +262,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
|
|
|
264
262
|
type: ContentChild,
|
|
265
263
|
args: [NG_VALUE_ACCESSOR]
|
|
266
264
|
}] } });
|
|
267
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-element.component.js","sourceRoot":"","sources":["../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/form/form-element/form-element.component.ts","../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/form/form-element/form-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterViewInit,\n\tComponent,\n\tContentChild,\n\tElementRef,\n\tInject,\n\tInjectionToken,\n\tInput,\n\tOptional,\n\tTemplateRef,\n\tViewChild\n} from '@angular/core';\nimport {AbstractControl, NG_VALUE_ACCESSOR, UntypedFormControl} from '@angular/forms';\nimport {ValueAccessorBase} from '../../elements/value-accessor-base/value-accessor-base.component';\nimport {CustomErrorMessages, FormErrorMessages} from '../../types';\nimport {isValueSet, stringIsSetAndFilled} from '../../util/values';\nimport {FormComponent} from '../form.component';\nimport {awaitableForNextCycle} from '../../util/angular';\nimport {getAllLimitingContainers} from '../../util/dom';\n\n\nexport const FORM_ERROR_MESSAGES = new InjectionToken<CustomErrorMessages>('form.error.messages');\n\nexport const DEFAULT_ERROR_MESSAGES: FormErrorMessages = {\n\tmin: 'Use a number larger than %min%',\n\tmax: 'Use a number smaller than %max%',\n\trequired: 'Required',\n\temail: 'Use a valid email address',\n\tminLength: 'Has to be longer than %minLength% character(s)',\n\tmaxLength: 'Has to be shorter than %maxLength% character(s)',\n\tpattern: 'This input is not valid',\n\tmatchPassword: 'Passwords must match',\n\tdate: 'Enter a valid date',\n};\n\n@Component({\n\tselector: 'klp-form-element',\n\ttemplateUrl: './form-element.component.html',\n\tstyleUrls: ['./form-element.component.scss'],\n})\nexport class FormElementComponent implements AfterViewInit {\n\tpublic attachedControl: AbstractControl;\n\t@Input() public caption: string;\n\t@Input() public direction: 'horizontal' | 'vertical' = 'horizontal';\n\t@Input() public captionSpacing: 'percentages' | 'none' = 'percentages';\n\t@Input() public verticalAlignment: 'center' | 'top' = 'center';\n\t@Input() public spaceDistribution: '40-60' | '34-66' | '30-70' | 'fixedInputWidth' = '40-60';\n\t@Input() public swapInputAndCaption = false;\n\t@Input() public errorMessageAsTooltip = false;\n\t@ViewChild('internalComponentRef') public internalComponentRef: ElementRef;\n\t@ViewChild('tailTpl') public tailTpl: TemplateRef<any>;\n\t@ViewChild('captionDummyForSpaceCalculation') public captionDummyForSpaceCalculation: ElementRef;\n\t@ViewChild('absoluteAnchor') public absoluteAnchor: ElementRef;\n\t@ViewChild('fixedAnchor') public fixedAnchor: ElementRef;\n\t@ViewChild('fixedWrapper') public fixedWrapper: ElementRef;\n\t@ContentChild(NG_VALUE_ACCESSOR) fieldInput: ValueAccessorBase<any>;\n\n\tpublic captionRef: TemplateRef<any>;\n\tpublic errorMessages: FormErrorMessages = DEFAULT_ERROR_MESSAGES;\n\tpublic customErrorHandlers: Array<{ error: string; templateRef: TemplateRef<any> }> = [];\n\tprivate input: ValueAccessorBase<any>;\n\tpublic errorFullyVisible: boolean;\n\tprivate popupState: 'lockedOpen' | 'lockedClosed' | 'onHover' = 'onHover';\n\n\tconstructor(\n\t\t@Optional() private parent: FormComponent,\n\t\t@Inject(FORM_ERROR_MESSAGES) @Optional() private customMessages: CustomErrorMessages,\n\t\tprivate elRef: ElementRef,\n\t) {\n\t}\n\n\tasync ngAfterViewInit(): Promise<void> {\n\t\tawait awaitableForNextCycle();\n\t\tthis.fieldInput?.setTailTpl(this.tailTpl);\n\t\tthis.fieldInput?.onTouch.asObservable().subscribe((e) => {\n\t\t\tthis.determinePopupState();\n\t\t});\n\n\t\t[...getAllLimitingContainers(this.elRef.nativeElement), window].forEach(e => e.addEventListener('scroll', this.setErrorTooltipOffset));\n\t}\n\n\tpublic shouldShowErrorMessages(): boolean {\n\t\treturn this.parent?.showErrorMessages !== false;\n\t}\n\n\tpublic substituteParameters(message: string, parameters: Record<string, any>): string {\n\t\treturn Object.keys(parameters).reduce((msg, key) => {\n\t\t\treturn msg.replace(`%${key}%`, parameters[key]);\n\t\t}, message);\n\t}\n\n\tpublic registerControl(formControl: UntypedFormControl, input: ValueAccessorBase<any> = null): void {\n\t\tthis.attachedControl = formControl;\n\t\tthis.parent.registerControl(formControl, this);\n\t\tthis.input = input;\n\n\n\t\tthis.attachedControl.statusChanges.subscribe((e) => {\n\t\t\tthis.determinePopupState();\n\t\t});\n\t\tthis.determinePopupState();\n\t}\n\n\tpublic determinePopupState(): void {\n\t\tif (stringIsSetAndFilled(this.getErrorToShow())) {\n\t\t\tthis.popupState = 'onHover';\n\t\t\treturn;\n\t\t}\n\t\tif (isValueSet(this.getWarningToShow())) {\n\t\t\tthis.popupState = 'lockedOpen';\n\t\t\treturn;\n\t\t}\n\t\tthis.popupState = 'onHover';\n\t}\n\n\tpublic unregisterControl(formControl: UntypedFormControl): void {\n\t\tthis.attachedControl = null;\n\t\tthis.parent.unregisterControl(formControl);\n\t}\n\n\tpublic getAttachedControl(): AbstractControl {\n\t\treturn this.attachedControl;\n\t}\n\n\tpublic getAttachedInput(): ValueAccessorBase<any> {\n\t\treturn this.input;\n\t}\n\n\tpublic registerErrorHandler(error: string, templateRef: TemplateRef<any>): void {\n\t\tthis.customErrorHandlers.push({error, templateRef});\n\t}\n\n\tpublic registerCaption(templateRef: TemplateRef<any>): void {\n\t\tthis.captionRef = templateRef;\n\t}\n\n\tpublic getWarningToShow(): string | TemplateRef<any> {\n\t\treturn this.parent?.getWarningToShow(this.attachedControl);\n\t}\n\n\tpublic getWarningToShowAsTemplateRef(): TemplateRef<any> {\n\t\tif (this.parent?.getWarningToShow(this.attachedControl) instanceof TemplateRef) {\n\t\t\treturn this.parent?.getWarningToShow(this.attachedControl) as TemplateRef<any>;\n\t\t}\n\t\tthrow new Error('Warning is not a TemplateRef');\n\t}\n\n\tpublic getWarningToShowIsTemplateRef(): boolean {\n\t\treturn this.getWarningToShow() instanceof TemplateRef;\n\t}\n\n\tgetErrorToShow(): string {\n\t\tconst firstError = Object.keys(this.attachedControl?.errors ?? {})[0];\n\t\tif (this.attachedControl?.touched !== true) {\n\t\t\treturn null;\n\t\t}\n\t\tif (!this.attachedControl?.errors) {\n\t\t\treturn null;\n\t\t}\n\t\treturn firstError;\n\t}\n\n\tgetCustomErrorHandler(error: string): { error: string; templateRef: TemplateRef<any> } {\n\t\treturn this.customErrorHandlers.find((e) => e.error === error);\n\t}\n\n\tshowDefaultError(error: string): boolean {\n\t\treturn this.getErrorToShow() === error && !this.customErrorHandlers.some((e) => e.error === error);\n\t}\n\n\tgetScrollableParent(node): any {\n\t\tif (node === window.document.documentElement) {\n\t\t\treturn window.document.documentElement;\n\t\t}\n\t\tconst overflowY = getComputedStyle(node).overflowY;\n\t\tif (node.clientHeight < node.scrollHeight && (overflowY === 'auto' || overflowY === 'scroll')) {\n\t\t\treturn node;\n\t\t} else {\n\t\t\treturn this.getScrollableParent(node.parentNode);\n\t\t}\n\t}\n\n\tscrollTo(): void {\n\t\tconst parent = this.getScrollableParent(this.internalComponentRef.nativeElement);\n\t\tconst parentTop = parent === window.document.documentElement ? 0 : parent.getBoundingClientRect().top;\n\t\tconst elementTop = this.internalComponentRef.nativeElement.getBoundingClientRect().top;\n\t\tconst parentScrollTop = parent.scrollTop;\n\t\tconst answer = elementTop - parentTop + parentScrollTop;\n\t\tconsole.log('answer', parentTop, elementTop, parentScrollTop, answer);\n\t\tconsole.log(parent, this.internalComponentRef.nativeElement);\n\n\t\tparent.scrollTo({\n\t\t\ttop: answer - 30,\n\t\t\tbehavior: 'smooth'\n\t\t});\n\t}\n\n\tisRequired(): boolean {\n\t\tif (isValueSet(this.input)) {\n\t\t\treturn this.input.hasValidator('required');\n\t\t}\n\t\treturn false;\n\t}\n\n\tgetErrorMessage(key: keyof FormErrorMessages): string {\n\t\tif (key === 'formLevel') {\n\t\t\treturn this.attachedControl.errors?.formLevel;\n\t\t}\n\t\treturn this.customMessages?.[key]?.() ?? this.errorMessages[key];\n\t}\n\n\tpublic getErrorLocation(): 'belowCaption' | 'rightOfCaption' {\n\t\treturn this.parent?.errorMessageLocation ?? 'belowCaption';\n\t}\n\n\tpublic shouldShowErrorTooltipOpened(): boolean {\n\t\treturn this.popupState === 'lockedOpen';\n\t}\n\n\tpublic hasHoverableErrorTooltip(): boolean {\n\t\tif (!this.hasRightOfCaptionError() && !this.errorMessageAsTooltip) {\n\t\t\treturn false;\n\t\t}\n\t\tif (this.popupState !== 'onHover') {\n\t\t\treturn false;\n\t\t}\n\t\tif (stringIsSetAndFilled(this.getErrorToShow())) {\n\t\t\treturn !this.errorFullyVisible;\n\t\t}\n\t\tif (isValueSet(this.getWarningToShow())) {\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tpublic hasRightOfCaptionError(): boolean {\n\t\tif (this.errorMessageAsTooltip) {\n\t\t\treturn false;\n\t\t}\n\t\tif (this.direction !== 'vertical' || this.getErrorLocation() !== 'rightOfCaption') {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t}\n\n\tpublic setErrorMessageIsTruncated = (isTruncated: boolean) => {\n\t\tthis.errorFullyVisible = !isTruncated;\n\t}\n\n\tpublic shouldShowWarningPopup(): boolean {\n\t\treturn isValueSet(this.getWarningToShow());\n\t}\n\n\tpublic closePopup(): void {\n\t\tthis.popupState = 'onHover';\n\t}\n\n\tpublic togglePopup(): void {\n\t\tif (!this.errorMessageAsTooltip && !this.hasRightOfCaptionError()) {\n\t\t\treturn;\n\t\t}\n\t\tif (this.errorFullyVisible) {\n\t\t\treturn;\n\t\t}\n\t\tif (this.popupState === 'lockedOpen') {\n\t\t\tthis.popupState = 'onHover';\n\t\t} else {\n\t\t\tthis.popupState = 'lockedOpen';\n\t\t}\n\t}\n\n\tpublic setErrorTooltipOffset = (): void => {\n\t\tif (this.popupState !== 'lockedOpen' && this.popupState !== 'onHover') {\n\t\t\treturn;\n\t\t}\n\t\tconst popupOffsetY = this.absoluteAnchor?.nativeElement.getBoundingClientRect().top - this.fixedAnchor?.nativeElement.getBoundingClientRect().top;\n\t\tif (this.fixedWrapper?.nativeElement) {\n\t\t\tthis.fixedWrapper.nativeElement.style.transform = `translateY(${popupOffsetY}px)`;\n\t\t}\n\t};\n}\n","<div\n\tclass=\"componentContainer\"\n\t[ngClass]=\"{\n\t\thasCaption: caption || captionRef,\n\t\tvertical: direction === 'vertical',\n\t\thorizontal: direction === 'horizontal',\n\t\ttopAlignment: verticalAlignment === 'top',\n\t\treverseOrder: swapInputAndCaption,\n\t\thasErrors: getErrorToShow() && attachedControl.touched,\n\t\tpercentageSpacing: captionSpacing === 'percentages' && spaceDistribution !== 'fixedInputWidth',\n\t\t'd40-60': spaceDistribution === '40-60',\n\t\t'd30-70': spaceDistribution === '30-70',\n\t\t'd34-66': spaceDistribution === '34-66',\n\t\t'fixedInputWidth': spaceDistribution === 'fixedInputWidth'\n\t}\"\n>\n\t<div class=\"errorAboveInputContainer\" *ngIf=\"direction === 'horizontal' && !errorMessageAsTooltip\">\n\t\t<div class=\"spacer\"></div>\n\t\t<ng-container [ngTemplateOutlet]=\"errorRef\"></ng-container>\n\t</div>\n\n\t<div class=\"captionInputAndError\" #internalComponentRef>\n\t\t<div class=\"captionDummyForSpaceCalculation\" #captionDummyForSpaceCalculation *ngIf=\"hasRightOfCaptionError()\">\n\t\t\t<ng-container [ngTemplateOutlet]=\"captionTpl\" [ngTemplateOutletContext]=\"{forCalculation: true}\"></ng-container>\n\t\t</div>\n\t\t<ng-container [ngTemplateOutlet]=\"captionTpl\"></ng-container>\n\t\t<ng-container *ngIf=\"direction === 'vertical' && getErrorLocation() === 'belowCaption' && !errorMessageAsTooltip\" [ngTemplateOutlet]=\"errorRef\"></ng-container>\n\t\t<div class=\"inputContainer\" (mouseenter)=\"setErrorTooltipOffset()\">\n\t\t\t<ng-container *ngIf=\"errorMessageAsTooltip && shouldShowErrorMessages() && getErrorToShow()\">\n\t\t\t\t<div class=\"errorTooltipTriangle\"></div>\n\t\t\t\t<div class=\"errorTooltipTriangleWhite\"></div>\n\t\t\t\t<div class=\"errorTooltip\">\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"errorRef\"></ng-container>\n\t\t\t\t</div>\n\t\t\t</ng-container>\n\t\t\t<ng-content></ng-content>\n\t\t</div>\n\t</div>\n</div>\n\n<ng-template #captionTpl let-forCalculation=\"forCalculation\">\n\t<div class=\"caption\"\n\t\t*ngIf=\"caption || captionRef\"\n\t\t[ngClass]=\"{\n\t\t\twithErrorRightOfCaption: getErrorLocation() === 'rightOfCaption'\n\t\t}\"\n\t>\n\t\t<div *ngIf=\"captionRef\" class=\"captionRefContainer\">\n\t\t\t<ng-container [ngTemplateOutlet]=\"captionRef\"></ng-container>\n\t\t\t<div *ngIf=\"isRequired()\">&nbsp;*</div>\n\t\t</div>\n\t\t<div *ngIf=\"!captionRef\" class=\"captionText\">{{caption}}<span *ngIf=\"isRequired()\">&nbsp;*</span></div>\n\t\t<div class=\"rightOfCaptionError\" *ngIf=\"hasRightOfCaptionError()\" [ngClass]=\"{errorFullyVisible: errorFullyVisible}\">\n\t\t\t<ng-container [ngTemplateOutlet]=\"errorRef\" [ngTemplateOutletContext]=\"{forCalculation: forCalculation}\"></ng-container>\n\t\t</div>\n\t</div>\n</ng-template>\n\n<ng-template #errorRef let-forCalculation=\"forCalculation\">\n\t<div *ngIf=\"shouldShowErrorMessages() && getErrorToShow()\" class=\"errorContainer\" [elementIsTruncatedCb]=\"forCalculation ? setErrorMessageIsTruncated : null\" [ngClass]=\"{horizontal: direction === 'horizontal', hasCaption: caption || captionRef, 'd30-70': spaceDistribution === '30-70', 'd34-66': spaceDistribution === '34-66'}\">\n\t\t<div *ngIf=\"showDefaultError('min')\">{{substituteParameters(getErrorMessage(\"min\"), {min: attachedControl.errors.min.min})}}</div>\n\t\t<div *ngIf=\"showDefaultError('max')\">{{substituteParameters(getErrorMessage(\"max\"), {max: attachedControl.errors.max.max})}}</div>\n\t\t<div *ngIf=\"showDefaultError('required')\">{{getErrorMessage(\"required\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('email')\">{{getErrorMessage(\"email\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('minlength')\">{{substituteParameters(getErrorMessage(\"minLength\"), {minLength: attachedControl.errors.minlength.requiredLength})}}</div>\n\t\t<div *ngIf=\"showDefaultError('maxlength')\">{{substituteParameters(getErrorMessage(\"maxLength\"), {maxLength: attachedControl.errors.maxlength.requiredLength})}}</div>\n\t\t<div *ngIf=\"showDefaultError('pattern')\">{{getErrorMessage(\"pattern\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('MatchPassword')\">{{getErrorMessage(\"matchPassword\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('date')\">{{getErrorMessage(\"date\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('message')\">{{attachedControl.errors.message.value}}</div>\n\t\t<div *ngIf=\"showDefaultError('formLevel')\">{{getErrorMessage(\"formLevel\")}}</div>\n\t\t<div [ngTemplateOutlet]=\"getCustomErrorHandler(getErrorToShow())?.templateRef\"></div>\n\t</div>\n</ng-template>\n\n<ng-template #tailTpl>\n\t<div class=\"errorTooltipContainer\" [ngClass]=\"{alwaysOpen: shouldShowErrorTooltipOpened()}\">\n\t\t<ng-container *ngIf=\"hasHoverableErrorTooltip() || shouldShowErrorTooltipOpened()\">\n\t\t\t<div class=\"errorTooltipTriangle\"></div>\n\t\t\t<div class=\"errorTooltipTriangleWhite\"></div>\n\n\t\t\t<div class=\"absoluteAnchor\" #absoluteAnchor></div>\n\t\t\t<div class=\"fixedAnchor\" #fixedAnchor [onRenderFn]=\"setErrorTooltipOffset\"></div>\n\t\t\t<div class=\"fixedWrapper\" #fixedWrapper>\n\t\t\t\t<div class=\"errorTooltip\" [ngClass]=\"{noPointerEvents: !shouldShowErrorTooltipOpened()}\">\n\t\t\t\t\t<div class=\"errorTooltipInner\">\n\t\t\t\t\t\t<i class=\"closeBtn\" (click)=\"closePopup();\">×</i>\n\t\t\t\t\t\t<ng-container *ngIf=\"getErrorToShow()\" [ngTemplateOutlet]=\"errorRef\"></ng-container>\n\t\t\t\t\t\t<div *ngIf=\"!getErrorToShow() && shouldShowWarningPopup()\">\n\t\t\t\t\t\t\t<ng-container *ngIf=\"getWarningToShowIsTemplateRef()\" [ngTemplateOutlet]=\"getWarningToShowAsTemplateRef()\"></ng-container>\n\t\t\t\t\t\t\t<span *ngIf=\"!getWarningToShowIsTemplateRef()\">{{getWarningToShow()}}</span>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t</ng-container>\n\t\t<klp-form-warning-icon variant=\"fill\" *ngIf=\"getErrorToShow()\" (click)=\"togglePopup()\"></klp-form-warning-icon>\n\t\t<klp-form-warning-icon variant=\"line\" *ngIf=\"!getErrorToShow() && getWarningToShow()\" (click)=\"togglePopup()\"></klp-form-warning-icon>\n\t</div>\n</ng-template>\n"]}
|
|
265
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"form-element.component.js","sourceRoot":"","sources":["../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/form/form-element/form-element.component.ts","../../../../../../../projects/klippa/ngx-enhancy-forms/src/lib/form/form-element/form-element.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\n\tAfterViewInit,\n\tComponent,\n\tContentChild,\n\tElementRef,\n\tInject,\n\tInjectionToken,\n\tInput,\n\tOptional,\n\tTemplateRef,\n\tViewChild\n} from '@angular/core';\nimport {AbstractControl, NG_VALUE_ACCESSOR, UntypedFormControl} from '@angular/forms';\nimport {ValueAccessorBase} from '../../elements/value-accessor-base/value-accessor-base.component';\nimport {CustomErrorMessages, FormErrorMessages} from '../../types';\nimport {isValueSet, stringIsSetAndFilled} from '../../util/values';\nimport {FormComponent} from '../form.component';\nimport {awaitableForNextCycle} from '../../util/angular';\nimport {getAllLimitingContainers} from '../../util/dom';\n\n\nexport const FORM_ERROR_MESSAGES = new InjectionToken<CustomErrorMessages>('form.error.messages');\n\nexport const DEFAULT_ERROR_MESSAGES: FormErrorMessages = {\n\tmin: 'Use a number larger than %min%',\n\tmax: 'Use a number smaller than %max%',\n\trequired: 'Required',\n\temail: 'Use a valid email address',\n\tminLength: 'Has to be longer than %minLength% character(s)',\n\tmaxLength: 'Has to be shorter than %maxLength% character(s)',\n\tpattern: 'This input is not valid',\n\tmatchPassword: 'Passwords must match',\n\tdate: 'Enter a valid date',\n};\n\n@Component({\n\tselector: 'klp-form-element',\n\ttemplateUrl: './form-element.component.html',\n\tstyleUrls: ['./form-element.component.scss'],\n})\nexport class FormElementComponent implements AfterViewInit {\n\tpublic attachedControl: AbstractControl;\n\t@Input() public caption: string;\n\t@Input() public direction: 'horizontal' | 'vertical' = 'horizontal';\n\t@Input() public captionSpacing: 'percentages' | 'none' = 'percentages';\n\t@Input() public verticalAlignment: 'center' | 'top' = 'center';\n\t@Input() public spaceDistribution: '40-60' | '34-66' | '30-70' | 'fixedInputWidth' = '40-60';\n\t@Input() public swapInputAndCaption = false;\n\t@Input() public errorMessageAsTooltip = false;\n\t@ViewChild('internalComponentRef') public internalComponentRef: ElementRef;\n\t@ViewChild('tailTpl') public tailTpl: TemplateRef<any>;\n\t@ViewChild('captionDummyForSpaceCalculation') public captionDummyForSpaceCalculation: ElementRef;\n\t@ViewChild('absoluteAnchor') public absoluteAnchor: ElementRef;\n\t@ViewChild('fixedAnchor') public fixedAnchor: ElementRef;\n\t@ViewChild('fixedWrapper') public fixedWrapper: ElementRef;\n\t@ContentChild(NG_VALUE_ACCESSOR) fieldInput: ValueAccessorBase<any>;\n\n\tpublic captionRef: TemplateRef<any>;\n\tpublic errorMessages: FormErrorMessages = DEFAULT_ERROR_MESSAGES;\n\tpublic customErrorHandlers: Array<{ error: string; templateRef: TemplateRef<any> }> = [];\n\tprivate input: ValueAccessorBase<any>;\n\tpublic errorFullyVisible: boolean;\n\tprivate popupState: 'lockedOpen' | 'lockedClosed' | 'onHover' = 'onHover';\n\n\tconstructor(\n\t\t@Optional() private parent: FormComponent,\n\t\t@Inject(FORM_ERROR_MESSAGES) @Optional() private customMessages: CustomErrorMessages,\n\t\tprivate elRef: ElementRef,\n\t) {\n\t}\n\n\tasync ngAfterViewInit(): Promise<void> {\n\t\tawait awaitableForNextCycle();\n\t\tthis.fieldInput?.setTailTpl(this.tailTpl);\n\t\tthis.fieldInput?.onTouch.asObservable().subscribe((e) => {\n\t\t\tthis.determinePopupState();\n\t\t});\n\n\t\t[...getAllLimitingContainers(this.elRef.nativeElement), window].forEach(e => e.addEventListener('scroll', this.setErrorTooltipOffset));\n\t}\n\n\tpublic shouldShowErrorMessages(): boolean {\n\t\treturn this.parent?.showErrorMessages !== false;\n\t}\n\n\tpublic substituteParameters(message: string, parameters: Record<string, any>): string {\n\t\treturn Object.keys(parameters).reduce((msg, key) => {\n\t\t\treturn msg.replace(`%${key}%`, parameters[key]);\n\t\t}, message);\n\t}\n\n\tpublic registerControl(formControl: UntypedFormControl, input: ValueAccessorBase<any> = null): void {\n\t\tthis.attachedControl = formControl;\n\t\tthis.parent.registerControl(formControl, this);\n\t\tthis.input = input;\n\n\n\t\tthis.attachedControl.statusChanges.subscribe((e) => {\n\t\t\tthis.determinePopupState();\n\t\t});\n\t\tthis.determinePopupState();\n\t}\n\n\tpublic determinePopupState(): void {\n\t\tif (stringIsSetAndFilled(this.getErrorToShow())) {\n\t\t\tthis.popupState = 'onHover';\n\t\t\treturn;\n\t\t}\n\t\tif (isValueSet(this.getWarningToShow())) {\n\t\t\tthis.popupState = 'lockedOpen';\n\t\t\treturn;\n\t\t}\n\t\tthis.popupState = 'onHover';\n\t}\n\n\tpublic unregisterControl(formControl: UntypedFormControl): void {\n\t\tthis.attachedControl = null;\n\t\tthis.parent.unregisterControl(formControl);\n\t}\n\n\tpublic getAttachedControl(): AbstractControl {\n\t\treturn this.attachedControl;\n\t}\n\n\tpublic getAttachedInput(): ValueAccessorBase<any> {\n\t\treturn this.input;\n\t}\n\n\tpublic registerErrorHandler(error: string, templateRef: TemplateRef<any>): void {\n\t\tthis.customErrorHandlers.push({error, templateRef});\n\t}\n\n\tpublic registerCaption(templateRef: TemplateRef<any>): void {\n\t\tthis.captionRef = templateRef;\n\t}\n\n\tpublic getWarningToShow(): string | TemplateRef<any> {\n\t\treturn this.parent?.getWarningToShow(this.attachedControl);\n\t}\n\n\tpublic getWarningToShowAsTemplateRef(): TemplateRef<any> {\n\t\tif (this.parent?.getWarningToShow(this.attachedControl) instanceof TemplateRef) {\n\t\t\treturn this.parent?.getWarningToShow(this.attachedControl) as TemplateRef<any>;\n\t\t}\n\t\tthrow new Error('Warning is not a TemplateRef');\n\t}\n\n\tpublic getWarningToShowIsTemplateRef(): boolean {\n\t\treturn this.getWarningToShow() instanceof TemplateRef;\n\t}\n\n\tgetErrorToShow(): string {\n\t\tconst firstError = Object.keys(this.attachedControl?.errors ?? {})[0];\n\t\tif (this.attachedControl?.touched !== true) {\n\t\t\treturn null;\n\t\t}\n\t\tif (!this.attachedControl?.errors) {\n\t\t\treturn null;\n\t\t}\n\t\treturn firstError;\n\t}\n\n\tgetCustomErrorHandler(error: string): { error: string; templateRef: TemplateRef<any> } {\n\t\treturn this.customErrorHandlers.find((e) => e.error === error);\n\t}\n\n\tshowDefaultError(error: string): boolean {\n\t\treturn this.getErrorToShow() === error && !this.customErrorHandlers.some((e) => e.error === error);\n\t}\n\n\tgetScrollableParent(node): any {\n\t\tif (node === window.document.documentElement) {\n\t\t\treturn window.document.documentElement;\n\t\t}\n\t\tconst overflowY = getComputedStyle(node).overflowY;\n\t\tif (node.clientHeight < node.scrollHeight && (overflowY === 'auto' || overflowY === 'scroll')) {\n\t\t\treturn node;\n\t\t} else {\n\t\t\treturn this.getScrollableParent(node.parentNode);\n\t\t}\n\t}\n\n\tscrollTo(): void {\n\t\tconst parent = this.getScrollableParent(this.internalComponentRef.nativeElement);\n\t\tconst parentTop = parent === window.document.documentElement ? 0 : parent.getBoundingClientRect().top;\n\t\tconst elementTop = this.internalComponentRef.nativeElement.getBoundingClientRect().top;\n\t\tconst parentScrollTop = parent.scrollTop;\n\t\tconst answer = elementTop - parentTop + parentScrollTop;\n\n\t\tparent.scrollTo({\n\t\t\ttop: answer - 30,\n\t\t\tbehavior: 'smooth'\n\t\t});\n\t}\n\n\tisRequired(): boolean {\n\t\tif (isValueSet(this.input)) {\n\t\t\treturn this.input.hasValidator('required');\n\t\t}\n\t\treturn false;\n\t}\n\n\tgetErrorMessage(key: keyof FormErrorMessages): string {\n\t\tif (key === 'formLevel') {\n\t\t\treturn this.attachedControl.errors?.formLevel;\n\t\t}\n\t\treturn this.customMessages?.[key]?.() ?? this.errorMessages[key];\n\t}\n\n\tpublic getErrorLocation(): 'belowCaption' | 'rightOfCaption' {\n\t\treturn this.parent?.errorMessageLocation ?? 'belowCaption';\n\t}\n\n\tpublic shouldShowErrorTooltipOpened(): boolean {\n\t\treturn this.popupState === 'lockedOpen';\n\t}\n\n\tpublic hasHoverableErrorTooltip(): boolean {\n\t\tif (!this.hasRightOfCaptionError() && !this.errorMessageAsTooltip) {\n\t\t\treturn false;\n\t\t}\n\t\tif (this.popupState !== 'onHover') {\n\t\t\treturn false;\n\t\t}\n\t\tif (stringIsSetAndFilled(this.getErrorToShow())) {\n\t\t\treturn !this.errorFullyVisible;\n\t\t}\n\t\tif (isValueSet(this.getWarningToShow())) {\n\t\t\treturn true;\n\t\t}\n\t\treturn false;\n\t}\n\n\tpublic hasRightOfCaptionError(): boolean {\n\t\tif (this.errorMessageAsTooltip) {\n\t\t\treturn false;\n\t\t}\n\t\tif (this.direction !== 'vertical' || this.getErrorLocation() !== 'rightOfCaption') {\n\t\t\treturn false;\n\t\t}\n\t\treturn true;\n\t}\n\n\tpublic setErrorMessageIsTruncated = (isTruncated: boolean) => {\n\t\tthis.errorFullyVisible = !isTruncated;\n\t}\n\n\tpublic shouldShowWarningPopup(): boolean {\n\t\treturn isValueSet(this.getWarningToShow());\n\t}\n\n\tpublic closePopup(): void {\n\t\tthis.popupState = 'onHover';\n\t}\n\n\tpublic togglePopup(): void {\n\t\tif (!this.errorMessageAsTooltip && !this.hasRightOfCaptionError()) {\n\t\t\treturn;\n\t\t}\n\t\tif (this.errorFullyVisible) {\n\t\t\treturn;\n\t\t}\n\t\tif (this.popupState === 'lockedOpen') {\n\t\t\tthis.popupState = 'onHover';\n\t\t} else {\n\t\t\tthis.popupState = 'lockedOpen';\n\t\t}\n\t}\n\n\tpublic setErrorTooltipOffset = (): void => {\n\t\tif (this.popupState !== 'lockedOpen' && this.popupState !== 'onHover') {\n\t\t\treturn;\n\t\t}\n\t\tconst popupOffsetY = this.absoluteAnchor?.nativeElement.getBoundingClientRect().top - this.fixedAnchor?.nativeElement.getBoundingClientRect().top;\n\t\tif (this.fixedWrapper?.nativeElement) {\n\t\t\tthis.fixedWrapper.nativeElement.style.transform = `translateY(${popupOffsetY}px)`;\n\t\t}\n\t};\n}\n","<div\n\tclass=\"componentContainer\"\n\t[ngClass]=\"{\n\t\thasCaption: caption || captionRef,\n\t\tvertical: direction === 'vertical',\n\t\thorizontal: direction === 'horizontal',\n\t\ttopAlignment: verticalAlignment === 'top',\n\t\treverseOrder: swapInputAndCaption,\n\t\thasErrors: getErrorToShow() && attachedControl.touched,\n\t\tpercentageSpacing: captionSpacing === 'percentages' && spaceDistribution !== 'fixedInputWidth',\n\t\t'd40-60': spaceDistribution === '40-60',\n\t\t'd30-70': spaceDistribution === '30-70',\n\t\t'd34-66': spaceDistribution === '34-66',\n\t\t'fixedInputWidth': spaceDistribution === 'fixedInputWidth'\n\t}\"\n>\n\t<div class=\"errorAboveInputContainer\" *ngIf=\"direction === 'horizontal' && !errorMessageAsTooltip\">\n\t\t<div class=\"spacer\"></div>\n\t\t<ng-container [ngTemplateOutlet]=\"errorRef\"></ng-container>\n\t</div>\n\n\t<div class=\"captionInputAndError\" #internalComponentRef>\n\t\t<div class=\"captionDummyForSpaceCalculation\" #captionDummyForSpaceCalculation *ngIf=\"hasRightOfCaptionError()\">\n\t\t\t<ng-container [ngTemplateOutlet]=\"captionTpl\" [ngTemplateOutletContext]=\"{forCalculation: true}\"></ng-container>\n\t\t</div>\n\t\t<ng-container [ngTemplateOutlet]=\"captionTpl\"></ng-container>\n\t\t<ng-container *ngIf=\"direction === 'vertical' && getErrorLocation() === 'belowCaption' && !errorMessageAsTooltip\" [ngTemplateOutlet]=\"errorRef\"></ng-container>\n\t\t<div class=\"inputContainer\" (mouseenter)=\"setErrorTooltipOffset()\">\n\t\t\t<ng-container *ngIf=\"errorMessageAsTooltip && shouldShowErrorMessages() && getErrorToShow()\">\n\t\t\t\t<div class=\"errorTooltipTriangle\"></div>\n\t\t\t\t<div class=\"errorTooltipTriangleWhite\"></div>\n\t\t\t\t<div class=\"errorTooltip\">\n\t\t\t\t\t<ng-container [ngTemplateOutlet]=\"errorRef\"></ng-container>\n\t\t\t\t</div>\n\t\t\t</ng-container>\n\t\t\t<ng-content></ng-content>\n\t\t</div>\n\t</div>\n</div>\n\n<ng-template #captionTpl let-forCalculation=\"forCalculation\">\n\t<div class=\"caption\"\n\t\t*ngIf=\"caption || captionRef\"\n\t\t[ngClass]=\"{\n\t\t\twithErrorRightOfCaption: getErrorLocation() === 'rightOfCaption'\n\t\t}\"\n\t>\n\t\t<div *ngIf=\"captionRef\" class=\"captionRefContainer\">\n\t\t\t<ng-container [ngTemplateOutlet]=\"captionRef\"></ng-container>\n\t\t\t<div *ngIf=\"isRequired()\">&nbsp;*</div>\n\t\t</div>\n\t\t<div *ngIf=\"!captionRef\" class=\"captionText\">{{caption}}<span *ngIf=\"isRequired()\">&nbsp;*</span></div>\n\t\t<div class=\"rightOfCaptionError\" *ngIf=\"hasRightOfCaptionError()\" [ngClass]=\"{errorFullyVisible: errorFullyVisible}\">\n\t\t\t<ng-container [ngTemplateOutlet]=\"errorRef\" [ngTemplateOutletContext]=\"{forCalculation: forCalculation}\"></ng-container>\n\t\t</div>\n\t</div>\n</ng-template>\n\n<ng-template #errorRef let-forCalculation=\"forCalculation\">\n\t<div *ngIf=\"shouldShowErrorMessages() && getErrorToShow()\" class=\"errorContainer\" [elementIsTruncatedCb]=\"forCalculation ? setErrorMessageIsTruncated : null\" [ngClass]=\"{horizontal: direction === 'horizontal', hasCaption: caption || captionRef, 'd30-70': spaceDistribution === '30-70', 'd34-66': spaceDistribution === '34-66'}\">\n\t\t<div *ngIf=\"showDefaultError('min')\">{{substituteParameters(getErrorMessage(\"min\"), {min: attachedControl.errors.min.min})}}</div>\n\t\t<div *ngIf=\"showDefaultError('max')\">{{substituteParameters(getErrorMessage(\"max\"), {max: attachedControl.errors.max.max})}}</div>\n\t\t<div *ngIf=\"showDefaultError('required')\">{{getErrorMessage(\"required\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('email')\">{{getErrorMessage(\"email\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('minlength')\">{{substituteParameters(getErrorMessage(\"minLength\"), {minLength: attachedControl.errors.minlength.requiredLength})}}</div>\n\t\t<div *ngIf=\"showDefaultError('maxlength')\">{{substituteParameters(getErrorMessage(\"maxLength\"), {maxLength: attachedControl.errors.maxlength.requiredLength})}}</div>\n\t\t<div *ngIf=\"showDefaultError('pattern')\">{{getErrorMessage(\"pattern\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('MatchPassword')\">{{getErrorMessage(\"matchPassword\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('date')\">{{getErrorMessage(\"date\")}}</div>\n\t\t<div *ngIf=\"showDefaultError('message')\">{{attachedControl.errors.message.value}}</div>\n\t\t<div *ngIf=\"showDefaultError('formLevel')\">{{getErrorMessage(\"formLevel\")}}</div>\n\t\t<div [ngTemplateOutlet]=\"getCustomErrorHandler(getErrorToShow())?.templateRef\"></div>\n\t</div>\n</ng-template>\n\n<ng-template #tailTpl>\n\t<div class=\"errorTooltipContainer\" [ngClass]=\"{alwaysOpen: shouldShowErrorTooltipOpened()}\">\n\t\t<ng-container *ngIf=\"hasHoverableErrorTooltip() || shouldShowErrorTooltipOpened()\">\n\t\t\t<div class=\"errorTooltipTriangle\"></div>\n\t\t\t<div class=\"errorTooltipTriangleWhite\"></div>\n\n\t\t\t<div class=\"absoluteAnchor\" #absoluteAnchor></div>\n\t\t\t<div class=\"fixedAnchor\" #fixedAnchor [onRenderFn]=\"setErrorTooltipOffset\"></div>\n\t\t\t<div class=\"fixedWrapper\" #fixedWrapper>\n\t\t\t\t<div class=\"errorTooltip\" [ngClass]=\"{noPointerEvents: !shouldShowErrorTooltipOpened()}\">\n\t\t\t\t\t<div class=\"errorTooltipInner\">\n\t\t\t\t\t\t<i class=\"closeBtn\" (click)=\"closePopup();\">×</i>\n\t\t\t\t\t\t<ng-container *ngIf=\"getErrorToShow()\" [ngTemplateOutlet]=\"errorRef\"></ng-container>\n\t\t\t\t\t\t<div *ngIf=\"!getErrorToShow() && shouldShowWarningPopup()\">\n\t\t\t\t\t\t\t<ng-container *ngIf=\"getWarningToShowIsTemplateRef()\" [ngTemplateOutlet]=\"getWarningToShowAsTemplateRef()\"></ng-container>\n\t\t\t\t\t\t\t<span *ngIf=\"!getWarningToShowIsTemplateRef()\">{{getWarningToShow()}}</span>\n\t\t\t\t\t\t</div>\n\t\t\t\t\t</div>\n\t\t\t\t</div>\n\t\t\t</div>\n\n\t\t</ng-container>\n\t\t<klp-form-warning-icon variant=\"fill\" *ngIf=\"getErrorToShow()\" (click)=\"togglePopup()\"></klp-form-warning-icon>\n\t\t<klp-form-warning-icon variant=\"line\" *ngIf=\"!getErrorToShow() && getWarningToShow()\" (click)=\"togglePopup()\"></klp-form-warning-icon>\n\t</div>\n</ng-template>\n"]}
|
|
@@ -707,8 +707,6 @@ class FormElementComponent {
|
|
|
707
707
|
const elementTop = this.internalComponentRef.nativeElement.getBoundingClientRect().top;
|
|
708
708
|
const parentScrollTop = parent.scrollTop;
|
|
709
709
|
const answer = elementTop - parentTop + parentScrollTop;
|
|
710
|
-
console.log('answer', parentTop, elementTop, parentScrollTop, answer);
|
|
711
|
-
console.log(parent, this.internalComponentRef.nativeElement);
|
|
712
710
|
parent.scrollTo({
|
|
713
711
|
top: answer - 30,
|
|
714
712
|
behavior: 'smooth'
|