@klippa/ngx-enhancy-forms 14.22.5 → 14.22.7
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 +20 -7
- package/esm2020/lib/withTooltip.component.mjs +29 -8
- package/fesm2015/klippa-ngx-enhancy-forms.mjs +47 -14
- package/fesm2015/klippa-ngx-enhancy-forms.mjs.map +1 -1
- package/fesm2020/klippa-ngx-enhancy-forms.mjs +47 -13
- package/fesm2020/klippa-ngx-enhancy-forms.mjs.map +1 -1
- package/lib/form/form-element/form-element.component.d.ts +1 -0
- package/lib/withTooltip.component.d.ts +2 -1
- package/package.json +1 -1
|
@@ -129,20 +129,33 @@ export class FormElementComponent {
|
|
|
129
129
|
return this.getErrorToShow() === error && !this.customErrorHandlers.some((e) => e.error === error);
|
|
130
130
|
}
|
|
131
131
|
getScrollableParent(node) {
|
|
132
|
-
if (node
|
|
133
|
-
return
|
|
132
|
+
if (node === window.document.documentElement) {
|
|
133
|
+
return window.document.documentElement;
|
|
134
134
|
}
|
|
135
|
-
|
|
135
|
+
const overflowY = getComputedStyle(node).overflowY;
|
|
136
|
+
if (node.clientHeight < node.scrollHeight && (overflowY === 'auto' || overflowY === 'scroll')) {
|
|
136
137
|
return node;
|
|
137
138
|
}
|
|
138
139
|
else {
|
|
139
140
|
return this.getScrollableParent(node.parentNode);
|
|
140
141
|
}
|
|
141
142
|
}
|
|
143
|
+
getPageOffset(elem) {
|
|
144
|
+
let topOffset = elem.getBoundingClientRect().top;
|
|
145
|
+
while (elem !== document.documentElement) {
|
|
146
|
+
elem = elem.parentElement;
|
|
147
|
+
topOffset += elem.scrollTop;
|
|
148
|
+
}
|
|
149
|
+
return topOffset;
|
|
150
|
+
}
|
|
142
151
|
scrollTo() {
|
|
143
|
-
this.internalComponentRef.nativeElement
|
|
144
|
-
|
|
145
|
-
|
|
152
|
+
const parent = this.getScrollableParent(this.internalComponentRef.nativeElement);
|
|
153
|
+
const pageOffsetElement = this.getPageOffset(this.internalComponentRef.nativeElement);
|
|
154
|
+
const pageOffsetParent = parent === window.document.documentElement ? 0 : this.getPageOffset(parent);
|
|
155
|
+
parent.scrollTo({
|
|
156
|
+
top: pageOffsetElement - pageOffsetParent - 30,
|
|
157
|
+
behavior: 'smooth'
|
|
158
|
+
});
|
|
146
159
|
}
|
|
147
160
|
isRequired() {
|
|
148
161
|
if (isValueSet(this.input)) {
|
|
@@ -255,4 +268,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
|
|
|
255
268
|
type: ContentChild,
|
|
256
269
|
args: [NG_VALUE_ACCESSOR]
|
|
257
270
|
}] } });
|
|
258
|
-
//# 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 == null) {\n\t\t\treturn null;\n\t\t}\n\t\tif (node.scrollHeight > node.clientHeight) {\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\tthis.internalComponentRef.nativeElement.scrollIntoView(true);\n\t\t// to give some breathing room, we scroll 100px more to the top\n\t\tthis.getScrollableParent(this.internalComponentRef.nativeElement)?.scrollBy(0, -100);\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"]}
|
|
271
|
+
//# 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":"AAAA,OAAO,EAEN,SAAS,EACT,YAAY,EAEZ,MAAM,EACN,cAAc,EACd,KAAK,EACL,QAAQ,EACR,WAAW,EACX,SAAS,EACT,MAAM,eAAe,CAAC;AACvB,OAAO,EAAkB,iBAAiB,EAAqB,MAAM,gBAAgB,CAAC;AAGtF,OAAO,EAAC,UAAU,EAAE,oBAAoB,EAAC,MAAM,mBAAmB,CAAC;AAEnE,OAAO,EAAC,qBAAqB,EAAC,MAAM,oBAAoB,CAAC;AACzD,OAAO,EAAC,wBAAwB,EAAC,MAAM,gBAAgB,CAAC;;;;;;;AAGxD,MAAM,CAAC,MAAM,mBAAmB,GAAG,IAAI,cAAc,CAAsB,qBAAqB,CAAC,CAAC;AAElG,MAAM,CAAC,MAAM,sBAAsB,GAAsB;IACxD,GAAG,EAAE,gCAAgC;IACrC,GAAG,EAAE,iCAAiC;IACtC,QAAQ,EAAE,UAAU;IACpB,KAAK,EAAE,2BAA2B;IAClC,SAAS,EAAE,gDAAgD;IAC3D,SAAS,EAAE,iDAAiD;IAC5D,OAAO,EAAE,yBAAyB;IAClC,aAAa,EAAE,sBAAsB;IACrC,IAAI,EAAE,oBAAoB;CAC1B,CAAC;AAOF,MAAM,OAAO,oBAAoB;IAwBhC,YACqB,MAAqB,EACQ,cAAmC,EAC5E,KAAiB;QAFL,WAAM,GAAN,MAAM,CAAe;QACQ,mBAAc,GAAd,cAAc,CAAqB;QAC5E,UAAK,GAAL,KAAK,CAAY;QAxBV,cAAS,GAA8B,YAAY,CAAC;QACpD,mBAAc,GAA2B,aAAa,CAAC;QACvD,sBAAiB,GAAqB,QAAQ,CAAC;QAC/C,sBAAiB,GAAoD,OAAO,CAAC;QAC7E,wBAAmB,GAAG,KAAK,CAAC;QAC5B,0BAAqB,GAAG,KAAK,CAAC;QAUvC,kBAAa,GAAsB,sBAAsB,CAAC;QAC1D,wBAAmB,GAA4D,EAAE,CAAC;QAGjF,eAAU,GAA8C,SAAS,CAAC;QA6LnE,+BAA0B,GAAG,CAAC,WAAoB,EAAE,EAAE;YAC5D,IAAI,CAAC,iBAAiB,GAAG,CAAC,WAAW,CAAC;QACvC,CAAC,CAAA;QAwBM,0BAAqB,GAAG,GAAS,EAAE;YACzC,IAAI,IAAI,CAAC,UAAU,KAAK,YAAY,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;gBACtE,OAAO;aACP;YACD,MAAM,YAAY,GAAG,IAAI,CAAC,cAAc,EAAE,aAAa,CAAC,qBAAqB,EAAE,CAAC,GAAG,GAAG,IAAI,CAAC,WAAW,EAAE,aAAa,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC;YAClJ,IAAI,IAAI,CAAC,YAAY,EAAE,aAAa,EAAE;gBACrC,IAAI,CAAC,YAAY,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,cAAc,YAAY,KAAK,CAAC;aAClF;QACF,CAAC,CAAC;IAxNF,CAAC;IAED,KAAK,CAAC,eAAe;QACpB,MAAM,qBAAqB,EAAE,CAAC;QAC9B,IAAI,CAAC,UAAU,EAAE,UAAU,CAAC,IAAI,CAAC,OAAO,CAAC,CAAC;QAC1C,IAAI,CAAC,UAAU,EAAE,OAAO,CAAC,YAAY,EAAE,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YACvD,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QAEH,CAAC,GAAG,wBAAwB,CAAC,IAAI,CAAC,KAAK,CAAC,aAAa,CAAC,EAAE,MAAM,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,qBAAqB,CAAC,CAAC,CAAC;IACxI,CAAC;IAEM,uBAAuB;QAC7B,OAAO,IAAI,CAAC,MAAM,EAAE,iBAAiB,KAAK,KAAK,CAAC;IACjD,CAAC;IAEM,oBAAoB,CAAC,OAAe,EAAE,UAA+B;QAC3E,OAAO,MAAM,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC,MAAM,CAAC,CAAC,GAAG,EAAE,GAAG,EAAE,EAAE;YAClD,OAAO,GAAG,CAAC,OAAO,CAAC,IAAI,GAAG,GAAG,EAAE,UAAU,CAAC,GAAG,CAAC,CAAC,CAAC;QACjD,CAAC,EAAE,OAAO,CAAC,CAAC;IACb,CAAC;IAEM,eAAe,CAAC,WAA+B,EAAE,QAAgC,IAAI;QAC3F,IAAI,CAAC,eAAe,GAAG,WAAW,CAAC;QACnC,IAAI,CAAC,MAAM,CAAC,eAAe,CAAC,WAAW,EAAE,IAAI,CAAC,CAAC;QAC/C,IAAI,CAAC,KAAK,GAAG,KAAK,CAAC;QAGnB,IAAI,CAAC,eAAe,CAAC,aAAa,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE;YAClD,IAAI,CAAC,mBAAmB,EAAE,CAAC;QAC5B,CAAC,CAAC,CAAC;QACH,IAAI,CAAC,mBAAmB,EAAE,CAAC;IAC5B,CAAC;IAEM,mBAAmB;QACzB,IAAI,oBAAoB,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,EAAE;YAChD,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;YAC5B,OAAO;SACP;QACD,IAAI,UAAU,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,EAAE;YACxC,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC;YAC/B,OAAO;SACP;QACD,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IAC7B,CAAC;IAEM,iBAAiB,CAAC,WAA+B;QACvD,IAAI,CAAC,eAAe,GAAG,IAAI,CAAC;QAC5B,IAAI,CAAC,MAAM,CAAC,iBAAiB,CAAC,WAAW,CAAC,CAAC;IAC5C,CAAC;IAEM,kBAAkB;QACxB,OAAO,IAAI,CAAC,eAAe,CAAC;IAC7B,CAAC;IAEM,gBAAgB;QACtB,OAAO,IAAI,CAAC,KAAK,CAAC;IACnB,CAAC;IAEM,oBAAoB,CAAC,KAAa,EAAE,WAA6B;QACvE,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,EAAC,KAAK,EAAE,WAAW,EAAC,CAAC,CAAC;IACrD,CAAC;IAEM,eAAe,CAAC,WAA6B;QACnD,IAAI,CAAC,UAAU,GAAG,WAAW,CAAC;IAC/B,CAAC;IAEM,gBAAgB;QACtB,OAAO,IAAI,CAAC,MAAM,EAAE,gBAAgB,CAAC,IAAI,CAAC,eAAe,CAAC,CAAC;IAC5D,CAAC;IAEM,6BAA6B;QACnC,IAAI,IAAI,CAAC,MAAM,EAAE,gBAAgB,CAAC,IAAI,CAAC,eAAe,CAAC,YAAY,WAAW,EAAE;YAC/E,OAAO,IAAI,CAAC,MAAM,EAAE,gBAAgB,CAAC,IAAI,CAAC,eAAe,CAAqB,CAAC;SAC/E;QACD,MAAM,IAAI,KAAK,CAAC,8BAA8B,CAAC,CAAC;IACjD,CAAC;IAEM,6BAA6B;QACnC,OAAO,IAAI,CAAC,gBAAgB,EAAE,YAAY,WAAW,CAAC;IACvD,CAAC;IAED,cAAc;QACb,MAAM,UAAU,GAAG,MAAM,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,MAAM,IAAI,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACtE,IAAI,IAAI,CAAC,eAAe,EAAE,OAAO,KAAK,IAAI,EAAE;YAC3C,OAAO,IAAI,CAAC;SACZ;QACD,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE,MAAM,EAAE;YAClC,OAAO,IAAI,CAAC;SACZ;QACD,OAAO,UAAU,CAAC;IACnB,CAAC;IAED,qBAAqB,CAAC,KAAa;QAClC,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;IAChE,CAAC;IAED,gBAAgB,CAAC,KAAa;QAC7B,OAAO,IAAI,CAAC,cAAc,EAAE,KAAK,KAAK,IAAI,CAAC,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC;IACpG,CAAC;IAED,mBAAmB,CAAC,IAAI;QACvB,IAAI,IAAI,KAAK,MAAM,CAAC,QAAQ,CAAC,eAAe,EAAE;YAC7C,OAAO,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC;SACvC;QACD,MAAM,SAAS,GAAG,gBAAgB,CAAC,IAAI,CAAC,CAAC,SAAS,CAAC;QACnD,IAAI,IAAI,CAAC,YAAY,GAAG,IAAI,CAAC,YAAY,IAAI,CAAC,SAAS,KAAK,MAAM,IAAI,SAAS,KAAK,QAAQ,CAAC,EAAE;YAC9F,OAAO,IAAI,CAAC;SACZ;aAAM;YACN,OAAO,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,UAAU,CAAC,CAAC;SACjD;IACF,CAAC;IAED,aAAa,CAAC,IAAI;QACjB,IAAI,SAAS,GAAG,IAAI,CAAC,qBAAqB,EAAE,CAAC,GAAG,CAAC;QAEjD,OAAO,IAAI,KAAK,QAAQ,CAAC,eAAe,EAAE;YACzC,IAAI,GAAG,IAAI,CAAC,aAAa,CAAC;YAC1B,SAAS,IAAI,IAAI,CAAC,SAAS,CAAC;SAC5B;QACD,OAAO,SAAS,CAAC;IAClB,CAAC;IAED,QAAQ;QACP,MAAM,MAAM,GAAG,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,CAAC;QACjF,MAAM,iBAAiB,GAAG,IAAI,CAAC,aAAa,CAAC,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,CAAC;QACtF,MAAM,gBAAgB,GAAG,MAAM,KAAK,MAAM,CAAC,QAAQ,CAAC,eAAe,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,IAAI,CAAC,aAAa,CAAC,MAAM,CAAC,CAAC;QAErG,MAAM,CAAC,QAAQ,CAAC;YACf,GAAG,EAAE,iBAAiB,GAAG,gBAAgB,GAAG,EAAE;YAC9C,QAAQ,EAAE,QAAQ;SAClB,CAAC,CAAC;IACJ,CAAC;IAED,UAAU;QACT,IAAI,UAAU,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;YAC3B,OAAO,IAAI,CAAC,KAAK,CAAC,YAAY,CAAC,UAAU,CAAC,CAAC;SAC3C;QACD,OAAO,KAAK,CAAC;IACd,CAAC;IAED,eAAe,CAAC,GAA4B;QAC3C,IAAI,GAAG,KAAK,WAAW,EAAE;YACxB,OAAO,IAAI,CAAC,eAAe,CAAC,MAAM,EAAE,SAAS,CAAC;SAC9C;QACD,OAAO,IAAI,CAAC,cAAc,EAAE,CAAC,GAAG,CAAC,EAAE,EAAE,IAAI,IAAI,CAAC,aAAa,CAAC,GAAG,CAAC,CAAC;IAClE,CAAC;IAEM,gBAAgB;QACtB,OAAO,IAAI,CAAC,MAAM,EAAE,oBAAoB,IAAI,cAAc,CAAC;IAC5D,CAAC;IAEM,4BAA4B;QAClC,OAAO,IAAI,CAAC,UAAU,KAAK,YAAY,CAAC;IACzC,CAAC;IAEM,wBAAwB;QAC9B,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE,IAAI,CAAC,IAAI,CAAC,qBAAqB,EAAE;YAClE,OAAO,KAAK,CAAC;SACb;QACD,IAAI,IAAI,CAAC,UAAU,KAAK,SAAS,EAAE;YAClC,OAAO,KAAK,CAAC;SACb;QACD,IAAI,oBAAoB,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC,EAAE;YAChD,OAAO,CAAC,IAAI,CAAC,iBAAiB,CAAC;SAC/B;QACD,IAAI,UAAU,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,EAAE;YACxC,OAAO,IAAI,CAAC;SACZ;QACD,OAAO,KAAK,CAAC;IACd,CAAC;IAEM,sBAAsB;QAC5B,IAAI,IAAI,CAAC,qBAAqB,EAAE;YAC/B,OAAO,KAAK,CAAC;SACb;QACD,IAAI,IAAI,CAAC,SAAS,KAAK,UAAU,IAAI,IAAI,CAAC,gBAAgB,EAAE,KAAK,gBAAgB,EAAE;YAClF,OAAO,KAAK,CAAC;SACb;QACD,OAAO,IAAI,CAAC;IACb,CAAC;IAMM,sBAAsB;QAC5B,OAAO,UAAU,CAAC,IAAI,CAAC,gBAAgB,EAAE,CAAC,CAAC;IAC5C,CAAC;IAEM,UAAU;QAChB,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;IAC7B,CAAC;IAEM,WAAW;QACjB,IAAI,CAAC,IAAI,CAAC,qBAAqB,IAAI,CAAC,IAAI,CAAC,sBAAsB,EAAE,EAAE;YAClE,OAAO;SACP;QACD,IAAI,IAAI,CAAC,iBAAiB,EAAE;YAC3B,OAAO;SACP;QACD,IAAI,IAAI,CAAC,UAAU,KAAK,YAAY,EAAE;YACrC,IAAI,CAAC,UAAU,GAAG,SAAS,CAAC;SAC5B;aAAM;YACN,IAAI,CAAC,UAAU,GAAG,YAAY,CAAC;SAC/B;IACF,CAAC;;iHA3OW,oBAAoB,+DA0BvB,mBAAmB;qGA1BhB,oBAAoB,sWAelB,iBAAiB,uqBCvDhC,48LAqGA;2FD7Da,oBAAoB;kBALhC,SAAS;+BACC,kBAAkB;;0BA6B1B,QAAQ;;0BACR,MAAM;2BAAC,mBAAmB;;0BAAG,QAAQ;qEAxBvB,OAAO;sBAAtB,KAAK;gBACU,SAAS;sBAAxB,KAAK;gBACU,cAAc;sBAA7B,KAAK;gBACU,iBAAiB;sBAAhC,KAAK;gBACU,iBAAiB;sBAAhC,KAAK;gBACU,mBAAmB;sBAAlC,KAAK;gBACU,qBAAqB;sBAApC,KAAK;gBACoC,oBAAoB;sBAA7D,SAAS;uBAAC,sBAAsB;gBACJ,OAAO;sBAAnC,SAAS;uBAAC,SAAS;gBACiC,+BAA+B;sBAAnF,SAAS;uBAAC,iCAAiC;gBACR,cAAc;sBAAjD,SAAS;uBAAC,gBAAgB;gBACM,WAAW;sBAA3C,SAAS;uBAAC,aAAa;gBACU,YAAY;sBAA7C,SAAS;uBAAC,cAAc;gBACQ,UAAU;sBAA1C,YAAY;uBAAC,iBAAiB","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\tgetPageOffset(elem): number {\n\t\tlet topOffset = elem.getBoundingClientRect().top;\n\n\t\twhile (elem !== document.documentElement) {\n\t\t\telem = elem.parentElement;\n\t\t\ttopOffset += elem.scrollTop;\n\t\t}\n\t\treturn topOffset;\n\t}\n\n\tscrollTo(): void {\n\t\tconst parent = this.getScrollableParent(this.internalComponentRef.nativeElement);\n\t\tconst pageOffsetElement = this.getPageOffset(this.internalComponentRef.nativeElement);\n\t\tconst pageOffsetParent = parent === window.document.documentElement ? 0 : this.getPageOffset(parent);\n\n\t\tparent.scrollTo({\n\t\t\ttop: pageOffsetElement - pageOffsetParent - 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"]}
|
|
@@ -12,6 +12,7 @@ export class WithTooltipDirective {
|
|
|
12
12
|
this.el = el;
|
|
13
13
|
this.appRef = appRef;
|
|
14
14
|
this.klpWithTooltip = 'orange';
|
|
15
|
+
this.position = 'top';
|
|
15
16
|
el.nativeElement.addEventListener('mouseenter', () => {
|
|
16
17
|
let textToDisplay;
|
|
17
18
|
if (!this.templateInstance) {
|
|
@@ -44,8 +45,14 @@ export class WithTooltipDirective {
|
|
|
44
45
|
this.div.style.color = `${colors[this.klpWithTooltip].noAlpha}`;
|
|
45
46
|
this.div.style.position = 'fixed';
|
|
46
47
|
this.div.style.left = `${el.nativeElement.getBoundingClientRect().x}px`;
|
|
47
|
-
this.
|
|
48
|
-
|
|
48
|
+
if (this.position === 'top') {
|
|
49
|
+
this.div.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;
|
|
50
|
+
this.div.style.transform = `translate(calc(-100% + ${el.nativeElement.getBoundingClientRect().width}px), calc(-100% - 0.3rem))`;
|
|
51
|
+
}
|
|
52
|
+
else if (this.position === 'bottom') {
|
|
53
|
+
this.div.style.top = `${el.nativeElement.getBoundingClientRect().y + el.nativeElement.getBoundingClientRect().height}px`;
|
|
54
|
+
this.div.style.transform = `translate(calc(-100% + ${el.nativeElement.getBoundingClientRect().width}px), calc(0% + 0.3rem))`;
|
|
55
|
+
}
|
|
49
56
|
this.div.style.maxWidth = '200px';
|
|
50
57
|
this.div.style.whiteSpace = 'break-spaces';
|
|
51
58
|
this.div.style.backgroundColor = 'white';
|
|
@@ -72,8 +79,14 @@ export class WithTooltipDirective {
|
|
|
72
79
|
this.triangle.style.zIndex = `${zIndexStart + 1}`;
|
|
73
80
|
this.triangle.style.position = 'fixed';
|
|
74
81
|
this.triangle.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;
|
|
75
|
-
this.
|
|
76
|
-
|
|
82
|
+
if (this.position === 'top') {
|
|
83
|
+
this.triangle.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;
|
|
84
|
+
this.triangle.style.transform = `translate(-50%, calc(-100% + 0.1rem))`;
|
|
85
|
+
}
|
|
86
|
+
else if (this.position === 'bottom') {
|
|
87
|
+
this.triangle.style.top = `${el.nativeElement.getBoundingClientRect().y + el.nativeElement.getBoundingClientRect().height}px`;
|
|
88
|
+
this.triangle.style.transform = `translate(-50%, 0rem) rotate(180deg)`;
|
|
89
|
+
}
|
|
77
90
|
this.triangle.style.width = '0';
|
|
78
91
|
this.triangle.style.height = '0';
|
|
79
92
|
this.triangle.style.borderLeft = `${triangleSize} solid transparent`;
|
|
@@ -84,8 +97,14 @@ export class WithTooltipDirective {
|
|
|
84
97
|
this.triangleWhite.style.zIndex = `${zIndexStart + 3}`;
|
|
85
98
|
this.triangleWhite.style.position = 'fixed';
|
|
86
99
|
this.triangleWhite.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;
|
|
87
|
-
this.
|
|
88
|
-
|
|
100
|
+
if (this.position === 'top') {
|
|
101
|
+
this.triangleWhite.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;
|
|
102
|
+
this.triangleWhite.style.transform = `translate(-50%, calc(-100% + 0.1rem - 2px))`;
|
|
103
|
+
}
|
|
104
|
+
else if (this.position === 'bottom') {
|
|
105
|
+
this.triangleWhite.style.top = `${el.nativeElement.getBoundingClientRect().y + el.nativeElement.getBoundingClientRect().height}px`;
|
|
106
|
+
this.triangleWhite.style.transform = `translate(-50%, -2px) rotate(180deg)`;
|
|
107
|
+
}
|
|
89
108
|
this.triangleWhite.style.width = '0';
|
|
90
109
|
this.triangleWhite.style.height = '0';
|
|
91
110
|
this.triangleWhite.style.borderLeft = `${triangleSize} solid transparent`;
|
|
@@ -127,7 +146,7 @@ export class WithTooltipDirective {
|
|
|
127
146
|
}
|
|
128
147
|
}
|
|
129
148
|
WithTooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: WithTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.ApplicationRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
130
|
-
WithTooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.8", type: WithTooltipDirective, selector: "[klpWithTooltip]", inputs: { klpWithTooltip: "klpWithTooltip", tooltipText: "tooltipText", tooltipTemplate: "tooltipTemplate" }, usesOnChanges: true, ngImport: i0 });
|
|
149
|
+
WithTooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.8", type: WithTooltipDirective, selector: "[klpWithTooltip]", inputs: { klpWithTooltip: "klpWithTooltip", tooltipText: "tooltipText", tooltipTemplate: "tooltipTemplate", position: "position" }, usesOnChanges: true, ngImport: i0 });
|
|
131
150
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: WithTooltipDirective, decorators: [{
|
|
132
151
|
type: Directive,
|
|
133
152
|
args: [{
|
|
@@ -139,5 +158,7 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
|
|
|
139
158
|
type: Input
|
|
140
159
|
}], tooltipTemplate: [{
|
|
141
160
|
type: Input
|
|
161
|
+
}], position: [{
|
|
162
|
+
type: Input
|
|
142
163
|
}] } });
|
|
143
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"withTooltip.component.js","sourceRoot":"","sources":["../../../../../projects/klippa/ngx-enhancy-forms/src/lib/withTooltip.component.ts"],"names":[],"mappings":"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","sourcesContent":["import {ApplicationRef, Directive, ElementRef, Input, OnChanges, SimpleChanges, TemplateRef} from \"@angular/core\";\nimport {stringIsSetAndFilled} from \"./util/values\";\n\nconst triangleSize = '12px';\nconst zIndexStart = 99999999;\n\nconst colors = {\n\torange: { noAlpha: 'rgb(255, 128, 0)', withAlpha: 'rgba(255, 128, 0, 0.1254901961)'},\n\tblack: { noAlpha: 'rgb(40, 40, 40)', withAlpha: 'rgba(40, 40, 40, 0.1254901961)'},\n};\n\n@Directive({\n\tselector: '[klpWithTooltip]'\n})\nexport class WithTooltipDirective implements OnChanges{\n\tprivate div: HTMLElement;\n\tprivate triangle: HTMLElement;\n\tprivate triangleWhite: HTMLElement;\n\t@Input() klpWithTooltip: 'orange'| 'black' = 'orange';\n\t@Input() tooltipText: string;\n\t@Input() tooltipTemplate: TemplateRef<any>;\n\tprivate templateInstance: HTMLElement;\n\tconstructor(private el: ElementRef, private appRef: ApplicationRef) {\n\t\tel.nativeElement.addEventListener('mouseenter', () => {\n\t\t\tlet textToDisplay: string;\n\t\t\tif (!this.templateInstance) {\n\t\t\t\ttextToDisplay = this.tooltipText || el.nativeElement.innerText.trim();\n\t\t\t}\n\t\t\tif (!stringIsSetAndFilled(this.klpWithTooltip)) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (!stringIsSetAndFilled(textToDisplay) && !this.tooltipTemplate) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (stringIsSetAndFilled(this.tooltipText)) {\n\t\t\t\tif (this.tooltipText === el.nativeElement.innerText) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t} else if (this.tooltipTemplate) {\n\t\t\t\t// no need to check here, just render the template\n\t\t\t} else {\n\t\t\t\tif (el.nativeElement.offsetWidth >= el.nativeElement.scrollWidth) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (getComputedStyle(el.nativeElement).position === 'static') {\n\t\t\t\tel.nativeElement.style.position = 'relative';\n\t\t\t}\n\n\t\t\tthis.div = document.createElement('div');\n\t\t\tthis.div.style.zIndex = `${zIndexStart + 2}`;\n\t\t\tthis.div.style.color = `${colors[this.klpWithTooltip].noAlpha}`;\n\t\t\tthis.div.style.position = 'fixed';\n\t\t\tthis.div.style.left = `${el.nativeElement.getBoundingClientRect().x}px`;\n\t\t\tthis.div.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;\n\t\t\tthis.div.style.transform = `translate(calc(-100% + ${el.nativeElement.getBoundingClientRect().width}px), calc(-100% - 0.3rem))`;\n\t\t\tthis.div.style.maxWidth = '200px';\n\t\t\tthis.div.style.whiteSpace = 'break-spaces';\n\t\t\tthis.div.style.backgroundColor = 'white';\n\t\t\tthis.div.style.border = `1px solid ${colors[this.klpWithTooltip].withAlpha}`;\n\t\t\tthis.div.style.boxShadow = `2px 3px 10px 0px ${colors[this.klpWithTooltip].withAlpha}`;\n\t\t\tthis.div.style.padding = '0.3rem 0.5rem';\n\t\t\tthis.div.style.boxSizing = 'border-box';\n\t\t\tthis.div.style.borderRadius = '3px';\n\t\t\tif (stringIsSetAndFilled(textToDisplay)) {\n\t\t\t\tthis.div.textContent = textToDisplay;\n\t\t\t} else if (this.templateInstance) {\n\t\t\t\tthis.div.style.maxWidth = 'none';\n\t\t\t\tthis.div.style.visibility = 'hidden';\n\t\t\t\tthis.div.appendChild(this.templateInstance);\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tconst color = getComputedStyle(this.templateInstance).backgroundColor || getComputedStyle(this.templateInstance).background;\n\t\t\t\t\tthis.div.style.backgroundColor = color;\n\t\t\t\t\tthis.div.style.visibility = 'visible';\n\t\t\t\t});\n\t\t\t}\n\t\t\tel.nativeElement.prepend(this.div);\n\n\t\t\tthis.triangle = document.createElement('div');\n\t\t\tthis.triangle.style.zIndex = `${zIndexStart + 1}`;\n\t\t\tthis.triangle.style.position = 'fixed';\n\t\t\tthis.triangle.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;\n\t\t\tthis.triangle.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;\n\t\t\tthis.triangle.style.transform = `translate(-50%, calc(-100% + 0.1rem))`;\n\t\t\tthis.triangle.style.width = '0';\n\t\t\tthis.triangle.style.height = '0';\n\t\t\tthis.triangle.style.borderLeft = `${triangleSize} solid transparent`;\n\t\t\tthis.triangle.style.borderRight = `${triangleSize} solid transparent`;\n\t\t\tthis.triangle.style.borderTop = `${triangleSize} solid ${colors[this.klpWithTooltip].withAlpha}`;\n\t\t\tel.nativeElement.prepend(this.triangle);\n\n\t\t\tthis.triangleWhite = document.createElement('div');\n\t\t\tthis.triangleWhite.style.zIndex = `${zIndexStart + 3}`;\n\t\t\tthis.triangleWhite.style.position = 'fixed';\n\t\t\tthis.triangleWhite.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;\n\t\t\tthis.triangleWhite.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;\n\t\t\tthis.triangleWhite.style.transform = `translate(-50%, calc(-100% + 0.1rem - 2px))`;\n\t\t\tthis.triangleWhite.style.width = '0';\n\t\t\tthis.triangleWhite.style.height = '0';\n\t\t\tthis.triangleWhite.style.borderLeft = `${triangleSize} solid transparent`;\n\t\t\tthis.triangleWhite.style.borderRight = `${triangleSize} solid transparent`;\n\n\t\t\tif (stringIsSetAndFilled(textToDisplay)) {\n\t\t\t\tthis.triangleWhite.style.borderTop = `${triangleSize} solid white`;\n\t\t\t} else if (this.templateInstance) {\n\t\t\t\tthis.div.style.visibility = 'hidden';\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tconst color = getComputedStyle(this.templateInstance).backgroundColor || getComputedStyle(this.templateInstance).background;\n\t\t\t\t\tthis.triangleWhite.style.borderTop = `${triangleSize} solid ${color}`;\n\t\t\t\t\tthis.div.style.visibility = 'visible';\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tel.nativeElement.prepend(this.triangleWhite);\n\t\t});\n\n\t\tel.nativeElement.addEventListener('mouseleave', () => {\n\t\t\ttry {\n\t\t\t\tel.nativeElement.removeChild(this.div);\n\t\t\t} catch (ex) {}\n\t\t\ttry {\n\t\t\t\tel.nativeElement.removeChild(this.triangle);\n\t\t\t} catch (ex) {}\n\t\t\ttry {\n\t\t\t\tel.nativeElement.removeChild(this.triangleWhite);\n\t\t\t} catch (ex) {}\n\t\t});\n\t}\n\n\tpublic ngOnChanges(simpleChanges: SimpleChanges): void {\n\t\tif (simpleChanges.tooltipTemplate?.currentValue) {\n\t\t\tconst viewRef = this.tooltipTemplate.createEmbeddedView(null);\n\t\t\tthis.appRef.attachView(viewRef);\n\t\t\tthis.templateInstance = viewRef.rootNodes[0];\n\t\t}\n\t}\n}\n"]}
|
|
164
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"withTooltip.component.js","sourceRoot":"","sources":["../../../../../projects/klippa/ngx-enhancy-forms/src/lib/withTooltip.component.ts"],"names":[],"mappings":"AAAA,OAAO,EAAiB,SAAS,EAAc,KAAK,EAAwC,MAAM,eAAe,CAAC;AAClH,OAAO,EAAC,oBAAoB,EAAC,MAAM,eAAe,CAAC;;AAEnD,MAAM,YAAY,GAAG,MAAM,CAAC;AAC5B,MAAM,WAAW,GAAG,QAAQ,CAAC;AAE7B,MAAM,MAAM,GAAG;IACd,MAAM,EAAE,EAAE,OAAO,EAAE,kBAAkB,EAAE,SAAS,EAAE,iCAAiC,EAAC;IACpF,KAAK,EAAE,EAAE,OAAO,EAAE,iBAAiB,EAAE,SAAS,EAAE,gCAAgC,EAAC;CACjF,CAAC;AAKF,MAAM,OAAO,oBAAoB;IAShC,YAAoB,EAAc,EAAU,MAAsB;QAA9C,OAAE,GAAF,EAAE,CAAY;QAAU,WAAM,GAAN,MAAM,CAAgB;QALzD,mBAAc,GAAsB,QAAQ,CAAC;QAG7C,aAAQ,GAAqB,KAAK,CAAC;QAG3C,EAAE,CAAC,aAAa,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE;YACpD,IAAI,aAAqB,CAAC;YAC1B,IAAI,CAAC,IAAI,CAAC,gBAAgB,EAAE;gBAC3B,aAAa,GAAG,IAAI,CAAC,WAAW,IAAI,EAAE,CAAC,aAAa,CAAC,SAAS,CAAC,IAAI,EAAE,CAAC;aACtE;YACD,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,cAAc,CAAC,EAAE;gBAC/C,OAAO;aACP;YACD,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,IAAI,CAAC,IAAI,CAAC,eAAe,EAAE;gBAClE,OAAO;aACP;YACD,IAAI,oBAAoB,CAAC,IAAI,CAAC,WAAW,CAAC,EAAE;gBAC3C,IAAI,IAAI,CAAC,WAAW,KAAK,EAAE,CAAC,aAAa,CAAC,SAAS,EAAE;oBACpD,OAAO;iBACP;aACD;iBAAM,IAAI,IAAI,CAAC,eAAe,EAAE;gBAChC,kDAAkD;aAClD;iBAAM;gBACN,IAAI,EAAE,CAAC,aAAa,CAAC,WAAW,IAAI,EAAE,CAAC,aAAa,CAAC,WAAW,EAAE;oBACjE,OAAO;iBACP;aACD;YACD,IAAI,gBAAgB,CAAC,EAAE,CAAC,aAAa,CAAC,CAAC,QAAQ,KAAK,QAAQ,EAAE;gBAC7D,EAAE,CAAC,aAAa,CAAC,KAAK,CAAC,QAAQ,GAAG,UAAU,CAAC;aAC7C;YAED,IAAI,CAAC,GAAG,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACzC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,WAAW,GAAG,CAAC,EAAE,CAAC;YAC7C,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,OAAO,EAAE,CAAC;YAChE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;YAClC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,IAAI,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,CAAC,IAAI,CAAC;YACxE,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;gBAC5B,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,CAAC,IAAI,CAAC;gBACvE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,GAAG,0BAA0B,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,4BAA4B,CAAC;aAChI;iBAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,QAAQ,EAAE;gBACtC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM,IAAI,CAAC;gBACzH,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,GAAG,0BAA0B,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,yBAAyB,CAAC;aAC7H;YACD,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;YAClC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,GAAG,cAAc,CAAC;YAC3C,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,eAAe,GAAG,OAAO,CAAC;YACzC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,MAAM,GAAG,aAAa,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,SAAS,EAAE,CAAC;YAC7E,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,GAAG,oBAAoB,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,SAAS,EAAE,CAAC;YACvF,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,OAAO,GAAG,eAAe,CAAC;YACzC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,SAAS,GAAG,YAAY,CAAC;YACxC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,YAAY,GAAG,KAAK,CAAC;YACpC,IAAI,oBAAoB,CAAC,aAAa,CAAC,EAAE;gBACxC,IAAI,CAAC,GAAG,CAAC,WAAW,GAAG,aAAa,CAAC;aACrC;iBAAM,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBACjC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,QAAQ,GAAG,MAAM,CAAC;gBACjC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC;gBACrC,IAAI,CAAC,GAAG,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC;gBAC5C,UAAU,CAAC,GAAG,EAAE;oBACf,MAAM,KAAK,GAAG,gBAAgB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,eAAe,IAAI,gBAAgB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,UAAU,CAAC;oBAC5H,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,eAAe,GAAG,KAAK,CAAC;oBACvC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,GAAG,SAAS,CAAC;gBACvC,CAAC,CAAC,CAAC;aACH;YACD,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAEnC,IAAI,CAAC,QAAQ,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YAC9C,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,WAAW,GAAG,CAAC,EAAE,CAAC;YAClD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;YACvC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,IAAI,GAAG,QAAQ,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,YAAY,CAAC;YAC3I,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;gBAC5B,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,CAAC,IAAI,CAAC;gBAC5E,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,GAAG,uCAAuC,CAAC;aACxE;iBAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,QAAQ,EAAE;gBACtC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM,IAAI,CAAC;gBAC9H,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,GAAG,sCAAsC,CAAC;aACvE;YACD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC;YAChC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC;YACjC,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,UAAU,GAAG,GAAG,YAAY,oBAAoB,CAAC;YACrE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,YAAY,oBAAoB,CAAC;YACtE,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,SAAS,GAAG,GAAG,YAAY,UAAU,MAAM,CAAC,IAAI,CAAC,cAAc,CAAC,CAAC,SAAS,EAAE,CAAC;YACjG,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;YAExC,IAAI,CAAC,aAAa,GAAG,QAAQ,CAAC,aAAa,CAAC,KAAK,CAAC,CAAC;YACnD,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,WAAW,GAAG,CAAC,EAAE,CAAC;YACvD,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,QAAQ,GAAG,OAAO,CAAC;YAC5C,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,IAAI,GAAG,QAAQ,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,KAAK,YAAY,CAAC;YAChJ,IAAI,IAAI,CAAC,QAAQ,KAAK,KAAK,EAAE;gBAC5B,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,CAAC,IAAI,CAAC;gBACjF,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,6CAA6C,CAAC;aACnF;iBAAM,IAAI,IAAI,CAAC,QAAQ,KAAK,QAAQ,EAAE;gBACtC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,GAAG,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,CAAC,GAAG,EAAE,CAAC,aAAa,CAAC,qBAAqB,EAAE,CAAC,MAAM,IAAI,CAAC;gBACnI,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,sCAAsC,CAAC;aAC5E;YACD,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,GAAG,CAAC;YACrC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,MAAM,GAAG,GAAG,CAAC;YACtC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,UAAU,GAAG,GAAG,YAAY,oBAAoB,CAAC;YAC1E,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,GAAG,GAAG,YAAY,oBAAoB,CAAC;YAE3E,IAAI,oBAAoB,CAAC,aAAa,CAAC,EAAE;gBACxC,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,GAAG,YAAY,cAAc,CAAC;aACnE;iBAAM,IAAI,IAAI,CAAC,gBAAgB,EAAE;gBACjC,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,GAAG,QAAQ,CAAC;gBACrC,UAAU,CAAC,GAAG,EAAE;oBACf,MAAM,KAAK,GAAG,gBAAgB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,eAAe,IAAI,gBAAgB,CAAC,IAAI,CAAC,gBAAgB,CAAC,CAAC,UAAU,CAAC;oBAC5H,IAAI,CAAC,aAAa,CAAC,KAAK,CAAC,SAAS,GAAG,GAAG,YAAY,UAAU,KAAK,EAAE,CAAC;oBACtE,IAAI,CAAC,GAAG,CAAC,KAAK,CAAC,UAAU,GAAG,SAAS,CAAC;gBACvC,CAAC,CAAC,CAAC;aACH;YAED,EAAE,CAAC,aAAa,CAAC,OAAO,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;QAC9C,CAAC,CAAC,CAAC;QAEH,EAAE,CAAC,aAAa,CAAC,gBAAgB,CAAC,YAAY,EAAE,GAAG,EAAE;YACpD,IAAI;gBACH,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;aACvC;YAAC,OAAO,EAAE,EAAE,GAAE;YACf,IAAI;gBACH,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAC;aAC5C;YAAC,OAAO,EAAE,EAAE,GAAE;YACf,IAAI;gBACH,EAAE,CAAC,aAAa,CAAC,WAAW,CAAC,IAAI,CAAC,aAAa,CAAC,CAAC;aACjD;YAAC,OAAO,EAAE,EAAE,GAAE;QAChB,CAAC,CAAC,CAAC;IACJ,CAAC;IAEM,WAAW,CAAC,aAA4B;QAC9C,IAAI,aAAa,CAAC,eAAe,EAAE,YAAY,EAAE;YAChD,MAAM,OAAO,GAAG,IAAI,CAAC,eAAe,CAAC,kBAAkB,CAAC,IAAI,CAAC,CAAC;YAC9D,IAAI,CAAC,MAAM,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;YAChC,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC,SAAS,CAAC,CAAC,CAAC,CAAC;SAC7C;IACF,CAAC;;iHAzIW,oBAAoB;qGAApB,oBAAoB;2FAApB,oBAAoB;kBAHhC,SAAS;mBAAC;oBACV,QAAQ,EAAE,kBAAkB;iBAC5B;8HAKS,cAAc;sBAAtB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,eAAe;sBAAvB,KAAK;gBACG,QAAQ;sBAAhB,KAAK","sourcesContent":["import {ApplicationRef, Directive, ElementRef, Input, OnChanges, SimpleChanges, TemplateRef} from \"@angular/core\";\nimport {stringIsSetAndFilled} from \"./util/values\";\n\nconst triangleSize = '12px';\nconst zIndexStart = 99999999;\n\nconst colors = {\n\torange: { noAlpha: 'rgb(255, 128, 0)', withAlpha: 'rgba(255, 128, 0, 0.1254901961)'},\n\tblack: { noAlpha: 'rgb(40, 40, 40)', withAlpha: 'rgba(40, 40, 40, 0.1254901961)'},\n};\n\n@Directive({\n\tselector: '[klpWithTooltip]'\n})\nexport class WithTooltipDirective implements OnChanges{\n\tprivate div: HTMLElement;\n\tprivate triangle: HTMLElement;\n\tprivate triangleWhite: HTMLElement;\n\t@Input() klpWithTooltip: 'orange'| 'black' = 'orange';\n\t@Input() tooltipText: string;\n\t@Input() tooltipTemplate: TemplateRef<any>;\n\t@Input() position: 'top' | 'bottom' = 'top';\n\tprivate templateInstance: HTMLElement;\n\tconstructor(private el: ElementRef, private appRef: ApplicationRef) {\n\t\tel.nativeElement.addEventListener('mouseenter', () => {\n\t\t\tlet textToDisplay: string;\n\t\t\tif (!this.templateInstance) {\n\t\t\t\ttextToDisplay = this.tooltipText || el.nativeElement.innerText.trim();\n\t\t\t}\n\t\t\tif (!stringIsSetAndFilled(this.klpWithTooltip)) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (!stringIsSetAndFilled(textToDisplay) && !this.tooltipTemplate) {\n\t\t\t\treturn;\n\t\t\t}\n\t\t\tif (stringIsSetAndFilled(this.tooltipText)) {\n\t\t\t\tif (this.tooltipText === el.nativeElement.innerText) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t} else if (this.tooltipTemplate) {\n\t\t\t\t// no need to check here, just render the template\n\t\t\t} else {\n\t\t\t\tif (el.nativeElement.offsetWidth >= el.nativeElement.scrollWidth) {\n\t\t\t\t\treturn;\n\t\t\t\t}\n\t\t\t}\n\t\t\tif (getComputedStyle(el.nativeElement).position === 'static') {\n\t\t\t\tel.nativeElement.style.position = 'relative';\n\t\t\t}\n\n\t\t\tthis.div = document.createElement('div');\n\t\t\tthis.div.style.zIndex = `${zIndexStart + 2}`;\n\t\t\tthis.div.style.color = `${colors[this.klpWithTooltip].noAlpha}`;\n\t\t\tthis.div.style.position = 'fixed';\n\t\t\tthis.div.style.left = `${el.nativeElement.getBoundingClientRect().x}px`;\n\t\t\tif (this.position === 'top') {\n\t\t\t\tthis.div.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;\n\t\t\t\tthis.div.style.transform = `translate(calc(-100% + ${el.nativeElement.getBoundingClientRect().width}px), calc(-100% - 0.3rem))`;\n\t\t\t} else if (this.position === 'bottom') {\n\t\t\t\tthis.div.style.top = `${el.nativeElement.getBoundingClientRect().y + el.nativeElement.getBoundingClientRect().height}px`;\n\t\t\t\tthis.div.style.transform = `translate(calc(-100% + ${el.nativeElement.getBoundingClientRect().width}px), calc(0% + 0.3rem))`;\n\t\t\t}\n\t\t\tthis.div.style.maxWidth = '200px';\n\t\t\tthis.div.style.whiteSpace = 'break-spaces';\n\t\t\tthis.div.style.backgroundColor = 'white';\n\t\t\tthis.div.style.border = `1px solid ${colors[this.klpWithTooltip].withAlpha}`;\n\t\t\tthis.div.style.boxShadow = `2px 3px 10px 0px ${colors[this.klpWithTooltip].withAlpha}`;\n\t\t\tthis.div.style.padding = '0.3rem 0.5rem';\n\t\t\tthis.div.style.boxSizing = 'border-box';\n\t\t\tthis.div.style.borderRadius = '3px';\n\t\t\tif (stringIsSetAndFilled(textToDisplay)) {\n\t\t\t\tthis.div.textContent = textToDisplay;\n\t\t\t} else if (this.templateInstance) {\n\t\t\t\tthis.div.style.maxWidth = 'none';\n\t\t\t\tthis.div.style.visibility = 'hidden';\n\t\t\t\tthis.div.appendChild(this.templateInstance);\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tconst color = getComputedStyle(this.templateInstance).backgroundColor || getComputedStyle(this.templateInstance).background;\n\t\t\t\t\tthis.div.style.backgroundColor = color;\n\t\t\t\t\tthis.div.style.visibility = 'visible';\n\t\t\t\t});\n\t\t\t}\n\t\t\tel.nativeElement.prepend(this.div);\n\n\t\t\tthis.triangle = document.createElement('div');\n\t\t\tthis.triangle.style.zIndex = `${zIndexStart + 1}`;\n\t\t\tthis.triangle.style.position = 'fixed';\n\t\t\tthis.triangle.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;\n\t\t\tif (this.position === 'top') {\n\t\t\t\tthis.triangle.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;\n\t\t\t\tthis.triangle.style.transform = `translate(-50%, calc(-100% + 0.1rem))`;\n\t\t\t} else if (this.position === 'bottom') {\n\t\t\t\tthis.triangle.style.top = `${el.nativeElement.getBoundingClientRect().y + el.nativeElement.getBoundingClientRect().height}px`;\n\t\t\t\tthis.triangle.style.transform = `translate(-50%, 0rem) rotate(180deg)`;\n\t\t\t}\n\t\t\tthis.triangle.style.width = '0';\n\t\t\tthis.triangle.style.height = '0';\n\t\t\tthis.triangle.style.borderLeft = `${triangleSize} solid transparent`;\n\t\t\tthis.triangle.style.borderRight = `${triangleSize} solid transparent`;\n\t\t\tthis.triangle.style.borderTop = `${triangleSize} solid ${colors[this.klpWithTooltip].withAlpha}`;\n\t\t\tel.nativeElement.prepend(this.triangle);\n\n\t\t\tthis.triangleWhite = document.createElement('div');\n\t\t\tthis.triangleWhite.style.zIndex = `${zIndexStart + 3}`;\n\t\t\tthis.triangleWhite.style.position = 'fixed';\n\t\t\tthis.triangleWhite.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;\n\t\t\tif (this.position === 'top') {\n\t\t\t\tthis.triangleWhite.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;\n\t\t\t\tthis.triangleWhite.style.transform = `translate(-50%, calc(-100% + 0.1rem - 2px))`;\n\t\t\t} else if (this.position === 'bottom') {\n\t\t\t\tthis.triangleWhite.style.top = `${el.nativeElement.getBoundingClientRect().y + el.nativeElement.getBoundingClientRect().height}px`;\n\t\t\t\tthis.triangleWhite.style.transform = `translate(-50%, -2px) rotate(180deg)`;\n\t\t\t}\n\t\t\tthis.triangleWhite.style.width = '0';\n\t\t\tthis.triangleWhite.style.height = '0';\n\t\t\tthis.triangleWhite.style.borderLeft = `${triangleSize} solid transparent`;\n\t\t\tthis.triangleWhite.style.borderRight = `${triangleSize} solid transparent`;\n\n\t\t\tif (stringIsSetAndFilled(textToDisplay)) {\n\t\t\t\tthis.triangleWhite.style.borderTop = `${triangleSize} solid white`;\n\t\t\t} else if (this.templateInstance) {\n\t\t\t\tthis.div.style.visibility = 'hidden';\n\t\t\t\tsetTimeout(() => {\n\t\t\t\t\tconst color = getComputedStyle(this.templateInstance).backgroundColor || getComputedStyle(this.templateInstance).background;\n\t\t\t\t\tthis.triangleWhite.style.borderTop = `${triangleSize} solid ${color}`;\n\t\t\t\t\tthis.div.style.visibility = 'visible';\n\t\t\t\t});\n\t\t\t}\n\n\t\t\tel.nativeElement.prepend(this.triangleWhite);\n\t\t});\n\n\t\tel.nativeElement.addEventListener('mouseleave', () => {\n\t\t\ttry {\n\t\t\t\tel.nativeElement.removeChild(this.div);\n\t\t\t} catch (ex) {}\n\t\t\ttry {\n\t\t\t\tel.nativeElement.removeChild(this.triangle);\n\t\t\t} catch (ex) {}\n\t\t\ttry {\n\t\t\t\tel.nativeElement.removeChild(this.triangleWhite);\n\t\t\t} catch (ex) {}\n\t\t});\n\t}\n\n\tpublic ngOnChanges(simpleChanges: SimpleChanges): void {\n\t\tif (simpleChanges.tooltipTemplate?.currentValue) {\n\t\t\tconst viewRef = this.tooltipTemplate.createEmbeddedView(null);\n\t\t\tthis.appRef.attachView(viewRef);\n\t\t\tthis.templateInstance = viewRef.rootNodes[0];\n\t\t}\n\t}\n}\n"]}
|
|
@@ -690,21 +690,33 @@ class FormElementComponent {
|
|
|
690
690
|
return this.getErrorToShow() === error && !this.customErrorHandlers.some((e) => e.error === error);
|
|
691
691
|
}
|
|
692
692
|
getScrollableParent(node) {
|
|
693
|
-
if (node
|
|
694
|
-
return
|
|
693
|
+
if (node === window.document.documentElement) {
|
|
694
|
+
return window.document.documentElement;
|
|
695
695
|
}
|
|
696
|
-
|
|
696
|
+
const overflowY = getComputedStyle(node).overflowY;
|
|
697
|
+
if (node.clientHeight < node.scrollHeight && (overflowY === 'auto' || overflowY === 'scroll')) {
|
|
697
698
|
return node;
|
|
698
699
|
}
|
|
699
700
|
else {
|
|
700
701
|
return this.getScrollableParent(node.parentNode);
|
|
701
702
|
}
|
|
702
703
|
}
|
|
704
|
+
getPageOffset(elem) {
|
|
705
|
+
let topOffset = elem.getBoundingClientRect().top;
|
|
706
|
+
while (elem !== document.documentElement) {
|
|
707
|
+
elem = elem.parentElement;
|
|
708
|
+
topOffset += elem.scrollTop;
|
|
709
|
+
}
|
|
710
|
+
return topOffset;
|
|
711
|
+
}
|
|
703
712
|
scrollTo() {
|
|
704
|
-
|
|
705
|
-
this.internalComponentRef.nativeElement
|
|
706
|
-
|
|
707
|
-
|
|
713
|
+
const parent = this.getScrollableParent(this.internalComponentRef.nativeElement);
|
|
714
|
+
const pageOffsetElement = this.getPageOffset(this.internalComponentRef.nativeElement);
|
|
715
|
+
const pageOffsetParent = parent === window.document.documentElement ? 0 : this.getPageOffset(parent);
|
|
716
|
+
parent.scrollTo({
|
|
717
|
+
top: pageOffsetElement - pageOffsetParent - 30,
|
|
718
|
+
behavior: 'smooth'
|
|
719
|
+
});
|
|
708
720
|
}
|
|
709
721
|
isRequired() {
|
|
710
722
|
if (isValueSet(this.input)) {
|
|
@@ -2510,6 +2522,7 @@ class WithTooltipDirective {
|
|
|
2510
2522
|
this.el = el;
|
|
2511
2523
|
this.appRef = appRef;
|
|
2512
2524
|
this.klpWithTooltip = 'orange';
|
|
2525
|
+
this.position = 'top';
|
|
2513
2526
|
el.nativeElement.addEventListener('mouseenter', () => {
|
|
2514
2527
|
let textToDisplay;
|
|
2515
2528
|
if (!this.templateInstance) {
|
|
@@ -2542,8 +2555,14 @@ class WithTooltipDirective {
|
|
|
2542
2555
|
this.div.style.color = `${colors[this.klpWithTooltip].noAlpha}`;
|
|
2543
2556
|
this.div.style.position = 'fixed';
|
|
2544
2557
|
this.div.style.left = `${el.nativeElement.getBoundingClientRect().x}px`;
|
|
2545
|
-
this.
|
|
2546
|
-
|
|
2558
|
+
if (this.position === 'top') {
|
|
2559
|
+
this.div.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;
|
|
2560
|
+
this.div.style.transform = `translate(calc(-100% + ${el.nativeElement.getBoundingClientRect().width}px), calc(-100% - 0.3rem))`;
|
|
2561
|
+
}
|
|
2562
|
+
else if (this.position === 'bottom') {
|
|
2563
|
+
this.div.style.top = `${el.nativeElement.getBoundingClientRect().y + el.nativeElement.getBoundingClientRect().height}px`;
|
|
2564
|
+
this.div.style.transform = `translate(calc(-100% + ${el.nativeElement.getBoundingClientRect().width}px), calc(0% + 0.3rem))`;
|
|
2565
|
+
}
|
|
2547
2566
|
this.div.style.maxWidth = '200px';
|
|
2548
2567
|
this.div.style.whiteSpace = 'break-spaces';
|
|
2549
2568
|
this.div.style.backgroundColor = 'white';
|
|
@@ -2570,8 +2589,14 @@ class WithTooltipDirective {
|
|
|
2570
2589
|
this.triangle.style.zIndex = `${zIndexStart + 1}`;
|
|
2571
2590
|
this.triangle.style.position = 'fixed';
|
|
2572
2591
|
this.triangle.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;
|
|
2573
|
-
this.
|
|
2574
|
-
|
|
2592
|
+
if (this.position === 'top') {
|
|
2593
|
+
this.triangle.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;
|
|
2594
|
+
this.triangle.style.transform = `translate(-50%, calc(-100% + 0.1rem))`;
|
|
2595
|
+
}
|
|
2596
|
+
else if (this.position === 'bottom') {
|
|
2597
|
+
this.triangle.style.top = `${el.nativeElement.getBoundingClientRect().y + el.nativeElement.getBoundingClientRect().height}px`;
|
|
2598
|
+
this.triangle.style.transform = `translate(-50%, 0rem) rotate(180deg)`;
|
|
2599
|
+
}
|
|
2575
2600
|
this.triangle.style.width = '0';
|
|
2576
2601
|
this.triangle.style.height = '0';
|
|
2577
2602
|
this.triangle.style.borderLeft = `${triangleSize} solid transparent`;
|
|
@@ -2582,8 +2607,14 @@ class WithTooltipDirective {
|
|
|
2582
2607
|
this.triangleWhite.style.zIndex = `${zIndexStart + 3}`;
|
|
2583
2608
|
this.triangleWhite.style.position = 'fixed';
|
|
2584
2609
|
this.triangleWhite.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;
|
|
2585
|
-
this.
|
|
2586
|
-
|
|
2610
|
+
if (this.position === 'top') {
|
|
2611
|
+
this.triangleWhite.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;
|
|
2612
|
+
this.triangleWhite.style.transform = `translate(-50%, calc(-100% + 0.1rem - 2px))`;
|
|
2613
|
+
}
|
|
2614
|
+
else if (this.position === 'bottom') {
|
|
2615
|
+
this.triangleWhite.style.top = `${el.nativeElement.getBoundingClientRect().y + el.nativeElement.getBoundingClientRect().height}px`;
|
|
2616
|
+
this.triangleWhite.style.transform = `translate(-50%, -2px) rotate(180deg)`;
|
|
2617
|
+
}
|
|
2587
2618
|
this.triangleWhite.style.width = '0';
|
|
2588
2619
|
this.triangleWhite.style.height = '0';
|
|
2589
2620
|
this.triangleWhite.style.borderLeft = `${triangleSize} solid transparent`;
|
|
@@ -2626,7 +2657,7 @@ class WithTooltipDirective {
|
|
|
2626
2657
|
}
|
|
2627
2658
|
}
|
|
2628
2659
|
WithTooltipDirective.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: WithTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.ApplicationRef }], target: i0.ɵɵFactoryTarget.Directive });
|
|
2629
|
-
WithTooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.8", type: WithTooltipDirective, selector: "[klpWithTooltip]", inputs: { klpWithTooltip: "klpWithTooltip", tooltipText: "tooltipText", tooltipTemplate: "tooltipTemplate" }, usesOnChanges: true, ngImport: i0 });
|
|
2660
|
+
WithTooltipDirective.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "14.2.8", type: WithTooltipDirective, selector: "[klpWithTooltip]", inputs: { klpWithTooltip: "klpWithTooltip", tooltipText: "tooltipText", tooltipTemplate: "tooltipTemplate", position: "position" }, usesOnChanges: true, ngImport: i0 });
|
|
2630
2661
|
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImport: i0, type: WithTooltipDirective, decorators: [{
|
|
2631
2662
|
type: Directive,
|
|
2632
2663
|
args: [{
|
|
@@ -2638,6 +2669,8 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "14.2.8", ngImpor
|
|
|
2638
2669
|
type: Input
|
|
2639
2670
|
}], tooltipTemplate: [{
|
|
2640
2671
|
type: Input
|
|
2672
|
+
}], position: [{
|
|
2673
|
+
type: Input
|
|
2641
2674
|
}] } });
|
|
2642
2675
|
|
|
2643
2676
|
class NgxEnhancyFormsModule {
|