@klippa/ngx-enhancy-forms 16.9.3 → 16.22.12

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.
Files changed (57) hide show
  1. package/esm2022/lib/elementIsTruncatedCb.component.mjs +49 -0
  2. package/esm2022/lib/elements/button/button.component.mjs +4 -4
  3. package/esm2022/lib/elements/checkbox/checkbox.component.mjs +4 -4
  4. package/esm2022/lib/elements/date-picker/date-picker.component.mjs +5 -5
  5. package/esm2022/lib/elements/date-time-picker/date-time-picker.component.mjs +6 -6
  6. package/esm2022/lib/elements/email/email-input.component.mjs +7 -6
  7. package/esm2022/lib/elements/file-input/file-input.component.mjs +7 -5
  8. package/esm2022/lib/elements/hour-minute-input/hour-minute-input.component.mjs +5 -5
  9. package/esm2022/lib/elements/loading-indicator/loading-indicator.component.mjs +4 -4
  10. package/esm2022/lib/elements/number-input/number-input.component.mjs +4 -4
  11. package/esm2022/lib/elements/password-field/password-field.component.mjs +4 -4
  12. package/esm2022/lib/elements/radio/radio.component.mjs +5 -5
  13. package/esm2022/lib/elements/select/select-footer/select-footer.component.mjs +4 -4
  14. package/esm2022/lib/elements/select/select.component.mjs +136 -40
  15. package/esm2022/lib/elements/sortable-grouped-items/sortable-grouped-items.component.mjs +4 -4
  16. package/esm2022/lib/elements/sortable-items/sortable-items.component.mjs +4 -4
  17. package/esm2022/lib/elements/text-input/text-input.component.mjs +17 -5
  18. package/esm2022/lib/elements/toggle/toggle.component.mjs +13 -7
  19. package/esm2022/lib/elements/value-accessor-base/multiple-value-accessor-base.component.mjs +4 -4
  20. package/esm2022/lib/elements/value-accessor-base/value-accessor-base.component.mjs +16 -4
  21. package/esm2022/lib/form/form-caption/form-caption.component.mjs +4 -4
  22. package/esm2022/lib/form/form-element/form-element.component.mjs +188 -20
  23. package/esm2022/lib/form/form-error/form-error.component.mjs +4 -4
  24. package/esm2022/lib/form/form-submit-button/form-submit-button.component.mjs +8 -5
  25. package/esm2022/lib/form/form.component.mjs +78 -11
  26. package/esm2022/lib/material.module.mjs +5 -5
  27. package/esm2022/lib/ngx-enhancy-forms.module.mjs +21 -8
  28. package/esm2022/lib/onRender.component.mjs +19 -0
  29. package/esm2022/lib/types.mjs +1 -1
  30. package/esm2022/lib/util/angular.mjs +9 -0
  31. package/esm2022/lib/util/dom.mjs +15 -0
  32. package/esm2022/lib/warning-icon/warning-icon.component.mjs +17 -0
  33. package/esm2022/lib/withTooltip.component.mjs +106 -24
  34. package/esm2022/public-api.mjs +3 -1
  35. package/fesm2022/klippa-ngx-enhancy-forms.mjs +773 -223
  36. package/fesm2022/klippa-ngx-enhancy-forms.mjs.map +1 -1
  37. package/lib/elementIsTruncatedCb.component.d.ts +12 -0
  38. package/lib/elements/file-input/file-input.component.d.ts +2 -1
  39. package/lib/elements/radio/radio.component.d.ts +1 -0
  40. package/lib/elements/select/select.component.d.ts +18 -3
  41. package/lib/elements/text-input/text-input.component.d.ts +6 -2
  42. package/lib/elements/toggle/toggle.component.d.ts +2 -1
  43. package/lib/elements/value-accessor-base/value-accessor-base.component.d.ts +6 -2
  44. package/lib/form/form-caption/form-caption.component.d.ts +2 -2
  45. package/lib/form/form-element/form-element.component.d.ts +40 -13
  46. package/lib/form/form-error/form-error.component.d.ts +2 -2
  47. package/lib/form/form-submit-button/form-submit-button.component.d.ts +2 -1
  48. package/lib/form/form.component.d.ts +10 -3
  49. package/lib/ngx-enhancy-forms.module.d.ts +9 -6
  50. package/lib/onRender.component.d.ts +8 -0
  51. package/lib/types.d.ts +1 -0
  52. package/lib/util/angular.d.ts +2 -0
  53. package/lib/util/dom.d.ts +2 -0
  54. package/lib/warning-icon/warning-icon.component.d.ts +6 -0
  55. package/lib/withTooltip.component.d.ts +12 -5
  56. package/package.json +1 -1
  57. package/public-api.d.ts +2 -0
@@ -1,59 +1,128 @@
1
1
  import { Directive, Input } from "@angular/core";
2
+ import { stringIsSetAndFilled } from "./util/values";
2
3
  import * as i0 from "@angular/core";
3
4
  const triangleSize = '12px';
5
+ const zIndexStart = 99999999;
6
+ const colors = {
7
+ orange: { noAlpha: 'rgb(255, 128, 0)', withAlpha: 'rgba(255, 128, 0, 0.1254901961)' },
8
+ black: { noAlpha: 'rgb(40, 40, 40)', withAlpha: 'rgba(40, 40, 40, 0.1254901961)' },
9
+ };
4
10
  export class WithTooltipDirective {
5
- constructor(el) {
6
- this.klpWithTooltip = true;
11
+ constructor(el, appRef) {
12
+ this.el = el;
13
+ this.appRef = appRef;
14
+ this.klpWithTooltip = 'orange';
15
+ this.position = 'top';
7
16
  el.nativeElement.addEventListener('mouseenter', () => {
8
- if (!this.klpWithTooltip) {
17
+ let textToDisplay;
18
+ if (!this.templateInstance) {
19
+ textToDisplay = this.tooltipText || el.nativeElement.innerText.trim();
20
+ }
21
+ if (!stringIsSetAndFilled(this.klpWithTooltip)) {
22
+ return;
23
+ }
24
+ if (!stringIsSetAndFilled(textToDisplay) && !this.tooltipTemplate) {
9
25
  return;
10
26
  }
27
+ if (stringIsSetAndFilled(this.tooltipText)) {
28
+ if (this.tooltipText === el.nativeElement.innerText) {
29
+ return;
30
+ }
31
+ }
32
+ else if (this.tooltipTemplate) {
33
+ // no need to check here, just render the template
34
+ }
35
+ else {
36
+ if (el.nativeElement.offsetWidth >= el.nativeElement.scrollWidth) {
37
+ return;
38
+ }
39
+ }
11
40
  if (getComputedStyle(el.nativeElement).position === 'static') {
12
41
  el.nativeElement.style.position = 'relative';
13
42
  }
14
43
  this.div = document.createElement('div');
15
- this.div.style.zIndex = '2';
16
- this.div.style.color = '#ff8000';
44
+ this.div.style.zIndex = `${zIndexStart + 2}`;
45
+ this.div.style.color = `${colors[this.klpWithTooltip].noAlpha}`;
17
46
  this.div.style.position = 'fixed';
18
47
  this.div.style.left = `${el.nativeElement.getBoundingClientRect().x}px`;
19
- this.div.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;
20
- this.div.style.transform = `translate(calc(-100% + ${el.nativeElement.getBoundingClientRect().width}px), calc(-100% - 0.3rem))`;
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
+ }
21
56
  this.div.style.maxWidth = '200px';
22
57
  this.div.style.whiteSpace = 'break-spaces';
23
58
  this.div.style.backgroundColor = 'white';
24
- this.div.style.border = '1px solid rgba(255, 128, 0, 0.1254901961)';
25
- this.div.style.boxShadow = `2px 3px 10px 0px rgba(255, 128, 0, 0.1254901961)`;
59
+ this.div.style.border = `1px solid ${colors[this.klpWithTooltip].withAlpha}`;
60
+ this.div.style.boxShadow = `2px 3px 10px 0px ${colors[this.klpWithTooltip].withAlpha}`;
26
61
  this.div.style.padding = '0.3rem 0.5rem';
27
62
  this.div.style.boxSizing = 'border-box';
28
63
  this.div.style.borderRadius = '3px';
29
- this.div.textContent = el.nativeElement.innerText;
64
+ if (stringIsSetAndFilled(textToDisplay)) {
65
+ this.div.textContent = textToDisplay;
66
+ }
67
+ else if (this.templateInstance) {
68
+ this.div.style.maxWidth = 'none';
69
+ this.div.style.visibility = 'hidden';
70
+ this.div.appendChild(this.templateInstance);
71
+ setTimeout(() => {
72
+ const color = getComputedStyle(this.templateInstance).backgroundColor || getComputedStyle(this.templateInstance).background;
73
+ this.div.style.backgroundColor = color;
74
+ this.div.style.visibility = 'visible';
75
+ });
76
+ }
30
77
  el.nativeElement.prepend(this.div);
31
78
  this.triangle = document.createElement('div');
32
- this.triangle.style.zIndex = '1';
79
+ this.triangle.style.zIndex = `${zIndexStart + 1}`;
33
80
  this.triangle.style.position = 'fixed';
34
81
  this.triangle.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;
35
- this.triangle.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;
36
- this.triangle.style.transform = `translate(-50%, calc(-100% + 0.1rem))`;
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
+ }
37
90
  this.triangle.style.width = '0';
38
91
  this.triangle.style.height = '0';
39
92
  this.triangle.style.borderLeft = `${triangleSize} solid transparent`;
40
93
  this.triangle.style.borderRight = `${triangleSize} solid transparent`;
41
- this.triangle.style.borderTop = `${triangleSize} solid rgba(255, 128, 0, 0.1254901961)`;
94
+ this.triangle.style.borderTop = `${triangleSize} solid ${colors[this.klpWithTooltip].withAlpha}`;
42
95
  el.nativeElement.prepend(this.triangle);
43
96
  this.triangleWhite = document.createElement('div');
44
- this.triangleWhite.style.zIndex = '3';
97
+ this.triangleWhite.style.zIndex = `${zIndexStart + 3}`;
45
98
  this.triangleWhite.style.position = 'fixed';
46
99
  this.triangleWhite.style.left = `calc(${el.nativeElement.getBoundingClientRect().x + el.nativeElement.getBoundingClientRect().width}px - 2rem)`;
47
- this.triangleWhite.style.top = `${el.nativeElement.getBoundingClientRect().y}px`;
48
- this.triangleWhite.style.transform = `translate(-50%, calc(-100% + 0.1rem - 2px))`;
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
+ }
49
108
  this.triangleWhite.style.width = '0';
50
109
  this.triangleWhite.style.height = '0';
51
110
  this.triangleWhite.style.borderLeft = `${triangleSize} solid transparent`;
52
111
  this.triangleWhite.style.borderRight = `${triangleSize} solid transparent`;
53
- this.triangleWhite.style.borderTop = `${triangleSize} solid white`;
112
+ if (stringIsSetAndFilled(textToDisplay)) {
113
+ this.triangleWhite.style.borderTop = `${triangleSize} solid white`;
114
+ }
115
+ else if (this.templateInstance) {
116
+ this.div.style.visibility = 'hidden';
117
+ setTimeout(() => {
118
+ const color = getComputedStyle(this.templateInstance).backgroundColor || getComputedStyle(this.templateInstance).background;
119
+ this.triangleWhite.style.borderTop = `${triangleSize} solid ${color}`;
120
+ this.div.style.visibility = 'visible';
121
+ });
122
+ }
54
123
  el.nativeElement.prepend(this.triangleWhite);
55
124
  });
56
- el.nativeElement.addEventListener('mouseout', () => {
125
+ el.nativeElement.addEventListener('mouseleave', () => {
57
126
  try {
58
127
  el.nativeElement.removeChild(this.div);
59
128
  }
@@ -68,15 +137,28 @@ export class WithTooltipDirective {
68
137
  catch (ex) { }
69
138
  });
70
139
  }
71
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: WithTooltipDirective, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Directive }); }
72
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.0.1", type: WithTooltipDirective, selector: "[klpWithTooltip]", inputs: { klpWithTooltip: "klpWithTooltip" }, ngImport: i0 }); }
140
+ ngOnChanges(simpleChanges) {
141
+ if (simpleChanges.tooltipTemplate?.currentValue) {
142
+ const viewRef = this.tooltipTemplate.createEmbeddedView(null);
143
+ this.appRef.attachView(viewRef);
144
+ this.templateInstance = viewRef.rootNodes[0];
145
+ }
146
+ }
147
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WithTooltipDirective, deps: [{ token: i0.ElementRef }, { token: i0.ApplicationRef }], target: i0.ɵɵFactoryTarget.Directive }); }
148
+ static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.12", type: WithTooltipDirective, selector: "[klpWithTooltip]", inputs: { klpWithTooltip: "klpWithTooltip", tooltipText: "tooltipText", tooltipTemplate: "tooltipTemplate", position: "position" }, usesOnChanges: true, ngImport: i0 }); }
73
149
  }
74
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.0.1", ngImport: i0, type: WithTooltipDirective, decorators: [{
150
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.12", ngImport: i0, type: WithTooltipDirective, decorators: [{
75
151
  type: Directive,
76
152
  args: [{
77
153
  selector: '[klpWithTooltip]'
78
154
  }]
79
- }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { klpWithTooltip: [{
155
+ }], ctorParameters: function () { return [{ type: i0.ElementRef }, { type: i0.ApplicationRef }]; }, propDecorators: { klpWithTooltip: [{
156
+ type: Input
157
+ }], tooltipText: [{
158
+ type: Input
159
+ }], tooltipTemplate: [{
160
+ type: Input
161
+ }], position: [{
80
162
  type: Input
81
163
  }] } });
82
- //# 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 {Directive, ElementRef, Input} from \"@angular/core\";\n\nconst triangleSize = '12px';\n\n@Directive({\n\tselector: '[klpWithTooltip]'\n})\nexport class WithTooltipDirective {\n\tprivate div: HTMLElement;\n\tprivate triangle: HTMLElement;\n\tprivate triangleWhite: HTMLElement;\n\t@Input() klpWithTooltip = true;\n\tconstructor(el: ElementRef) {\n\t\tel.nativeElement.addEventListener('mouseenter', () => {\n\t\t\tif (!this.klpWithTooltip) {\n\t\t\t\treturn;\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 = '2';\n\t\t\tthis.div.style.color = '#ff8000';\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 rgba(255, 128, 0, 0.1254901961)';\n\t\t\tthis.div.style.boxShadow = `2px 3px 10px 0px rgba(255, 128, 0, 0.1254901961)`;\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\tthis.div.textContent = el.nativeElement.innerText;\n\t\t\tel.nativeElement.prepend(this.div);\n\n\t\t\tthis.triangle = document.createElement('div');\n\t\t\tthis.triangle.style.zIndex = '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 rgba(255, 128, 0, 0.1254901961)`;\n\t\t\tel.nativeElement.prepend(this.triangle);\n\n\t\t\tthis.triangleWhite = document.createElement('div');\n\t\t\tthis.triangleWhite.style.zIndex = '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\t\t\tthis.triangleWhite.style.borderTop = `${triangleSize} solid white`;\n\t\t\tel.nativeElement.prepend(this.triangleWhite);\n\t\t});\n\t\tel.nativeElement.addEventListener('mouseout', () => {\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"]}
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":"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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\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"]}
@@ -22,6 +22,8 @@ export * from './lib/elements/hour-minute-input/hour-minute-input.component';
22
22
  export * from './lib/elements/value-accessor-base/value-accessor-base.component';
23
23
  export * from './lib/elements/value-accessor-base/multiple-value-accessor-base.component';
24
24
  export * from './lib/withTooltip.component';
25
+ export * from './lib/onRender.component';
26
+ export * from './lib/elementIsTruncatedCb.component';
25
27
  export * from './lib/form/form.component';
26
28
  export * from './lib/form/form-caption/form-caption.component';
27
29
  export * from './lib/form/form-element/form-element.component';
@@ -30,4 +32,4 @@ export * from './lib/form/form-submit-button/form-submit-button.component';
30
32
  export * from './lib/form/form-validation-error/form-validation-error';
31
33
  export * from './lib/validators/dateValidator';
32
34
  export * from './lib/types';
33
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2tsaXBwYS9uZ3gtZW5oYW5jeS1mb3Jtcy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsZ0NBQWdDLENBQUM7QUFFL0MsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyw4REFBOEQsQ0FBQztBQUM3RSxjQUFjLG9EQUFvRCxDQUFDO0FBQ25FLGNBQWMsd0RBQXdELENBQUM7QUFDdkUsY0FBYyw2REFBNkQsQ0FBQztBQUM1RSxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsd0RBQXdELENBQUM7QUFDdkUsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLDhEQUE4RCxDQUFDO0FBQzdFLGNBQWMsa0VBQWtFLENBQUM7QUFDakYsY0FBYywyRUFBMkUsQ0FBQztBQUUxRixjQUFjLDZCQUE2QixDQUFDO0FBRTVDLGNBQWMsMkJBQTJCLENBQUM7QUFDMUMsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyw0REFBNEQsQ0FBQztBQUMzRSxjQUFjLHdEQUF3RCxDQUFDO0FBRXZFLGNBQWMsZ0NBQWdDLENBQUM7QUFFL0MsY0FBYyxhQUFhLENBQUMiLCJzb3VyY2VzQ29udGVudCI6WyIvKlxuICogUHVibGljIEFQSSBTdXJmYWNlIG9mIG5neC1lbmhhbmN5LWZvcm1zXG4gKi9cblxuZXhwb3J0ICogZnJvbSAnLi9saWIvbmd4LWVuaGFuY3ktZm9ybXMubW9kdWxlJztcblxuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvYnV0dG9uL2J1dHRvbi5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvY2hlY2tib3gvY2hlY2tib3guY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL3JhZGlvL3JhZGlvLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9kYXRlLXBpY2tlci9kYXRlLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvZGF0ZS10aW1lLXBpY2tlci9kYXRlLXRpbWUtcGlja2VyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9lbWFpbC9lbWFpbC1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvbG9hZGluZy1pbmRpY2F0b3IvbG9hZGluZy1pbmRpY2F0b3IuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL251bWJlci1pbnB1dC9udW1iZXItaW5wdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL3Bhc3N3b3JkLWZpZWxkL3Bhc3N3b3JkLWZpZWxkLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9zZWxlY3Qvc2VsZWN0LWZvb3Rlci9zZWxlY3QtZm9vdGVyLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9zZWxlY3Qvc2VsZWN0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9zb3J0YWJsZS1pdGVtcy9zb3J0YWJsZS1pdGVtcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvc29ydGFibGUtZ3JvdXBlZC1pdGVtcy9zb3J0YWJsZS1ncm91cGVkLWl0ZW1zLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy90ZXh0LWlucHV0L3RleHQtaW5wdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL3RvZ2dsZS90b2dnbGUuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL2ZpbGUtaW5wdXQvZmlsZS1pbnB1dC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvaG91ci1taW51dGUtaW5wdXQvaG91ci1taW51dGUtaW5wdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL3ZhbHVlLWFjY2Vzc29yLWJhc2UvdmFsdWUtYWNjZXNzb3ItYmFzZS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvdmFsdWUtYWNjZXNzb3ItYmFzZS9tdWx0aXBsZS12YWx1ZS1hY2Nlc3Nvci1iYXNlLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3dpdGhUb29sdGlwLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0vZm9ybS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9ybS9mb3JtLWNhcHRpb24vZm9ybS1jYXB0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtL2Zvcm0tZWxlbWVudC9mb3JtLWVsZW1lbnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0vZm9ybS1lcnJvci9mb3JtLWVycm9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtL2Zvcm0tc3VibWl0LWJ1dHRvbi9mb3JtLXN1Ym1pdC1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0vZm9ybS12YWxpZGF0aW9uLWVycm9yL2Zvcm0tdmFsaWRhdGlvbi1lcnJvcic7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZhbGlkYXRvcnMvZGF0ZVZhbGlkYXRvcic7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzJztcbiJdfQ==
35
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoicHVibGljLWFwaS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3Byb2plY3RzL2tsaXBwYS9uZ3gtZW5oYW5jeS1mb3Jtcy9zcmMvcHVibGljLWFwaS50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQTs7R0FFRztBQUVILGNBQWMsZ0NBQWdDLENBQUM7QUFFL0MsY0FBYyx3Q0FBd0MsQ0FBQztBQUN2RCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsc0NBQXNDLENBQUM7QUFDckQsY0FBYyxrREFBa0QsQ0FBQztBQUNqRSxjQUFjLDREQUE0RCxDQUFDO0FBQzNFLGNBQWMsNENBQTRDLENBQUM7QUFDM0QsY0FBYyw4REFBOEQsQ0FBQztBQUM3RSxjQUFjLG9EQUFvRCxDQUFDO0FBQ25FLGNBQWMsd0RBQXdELENBQUM7QUFDdkUsY0FBYyw2REFBNkQsQ0FBQztBQUM1RSxjQUFjLHdDQUF3QyxDQUFDO0FBQ3ZELGNBQWMsd0RBQXdELENBQUM7QUFDdkUsY0FBYyx3RUFBd0UsQ0FBQztBQUN2RixjQUFjLGdEQUFnRCxDQUFDO0FBQy9ELGNBQWMsd0NBQXdDLENBQUM7QUFDdkQsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLDhEQUE4RCxDQUFDO0FBQzdFLGNBQWMsa0VBQWtFLENBQUM7QUFDakYsY0FBYywyRUFBMkUsQ0FBQztBQUUxRixjQUFjLDZCQUE2QixDQUFDO0FBQzVDLGNBQWMsMEJBQTBCLENBQUM7QUFDekMsY0FBYyxzQ0FBc0MsQ0FBQztBQUVyRCxjQUFjLDJCQUEyQixDQUFDO0FBQzFDLGNBQWMsZ0RBQWdELENBQUM7QUFDL0QsY0FBYyxnREFBZ0QsQ0FBQztBQUMvRCxjQUFjLDRDQUE0QyxDQUFDO0FBQzNELGNBQWMsNERBQTRELENBQUM7QUFDM0UsY0FBYyx3REFBd0QsQ0FBQztBQUV2RSxjQUFjLGdDQUFnQyxDQUFDO0FBRS9DLGNBQWMsYUFBYSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLypcbiAqIFB1YmxpYyBBUEkgU3VyZmFjZSBvZiBuZ3gtZW5oYW5jeS1mb3Jtc1xuICovXG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL25neC1lbmhhbmN5LWZvcm1zLm1vZHVsZSc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL2J1dHRvbi9idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL2NoZWNrYm94L2NoZWNrYm94LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9yYWRpby9yYWRpby5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvZGF0ZS1waWNrZXIvZGF0ZS1waWNrZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL2RhdGUtdGltZS1waWNrZXIvZGF0ZS10aW1lLXBpY2tlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvZW1haWwvZW1haWwtaW5wdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL2xvYWRpbmctaW5kaWNhdG9yL2xvYWRpbmctaW5kaWNhdG9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9udW1iZXItaW5wdXQvbnVtYmVyLWlucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9wYXNzd29yZC1maWVsZC9wYXNzd29yZC1maWVsZC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvc2VsZWN0L3NlbGVjdC1mb290ZXIvc2VsZWN0LWZvb3Rlci5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvc2VsZWN0L3NlbGVjdC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvc29ydGFibGUtaXRlbXMvc29ydGFibGUtaXRlbXMuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL3NvcnRhYmxlLWdyb3VwZWQtaXRlbXMvc29ydGFibGUtZ3JvdXBlZC1pdGVtcy5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZWxlbWVudHMvdGV4dC1pbnB1dC90ZXh0LWlucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy90b2dnbGUvdG9nZ2xlLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy9maWxlLWlucHV0L2ZpbGUtaW5wdXQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL2hvdXItbWludXRlLWlucHV0L2hvdXItbWludXRlLWlucHV0LmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9lbGVtZW50cy92YWx1ZS1hY2Nlc3Nvci1iYXNlL3ZhbHVlLWFjY2Vzc29yLWJhc2UuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRzL3ZhbHVlLWFjY2Vzc29yLWJhc2UvbXVsdGlwbGUtdmFsdWUtYWNjZXNzb3ItYmFzZS5jb21wb25lbnQnO1xuXG5leHBvcnQgKiBmcm9tICcuL2xpYi93aXRoVG9vbHRpcC5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvb25SZW5kZXIuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2VsZW1lbnRJc1RydW5jYXRlZENiLmNvbXBvbmVudCc7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0vZm9ybS5jb21wb25lbnQnO1xuZXhwb3J0ICogZnJvbSAnLi9saWIvZm9ybS9mb3JtLWNhcHRpb24vZm9ybS1jYXB0aW9uLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtL2Zvcm0tZWxlbWVudC9mb3JtLWVsZW1lbnQuY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0vZm9ybS1lcnJvci9mb3JtLWVycm9yLmNvbXBvbmVudCc7XG5leHBvcnQgKiBmcm9tICcuL2xpYi9mb3JtL2Zvcm0tc3VibWl0LWJ1dHRvbi9mb3JtLXN1Ym1pdC1idXR0b24uY29tcG9uZW50JztcbmV4cG9ydCAqIGZyb20gJy4vbGliL2Zvcm0vZm9ybS12YWxpZGF0aW9uLWVycm9yL2Zvcm0tdmFsaWRhdGlvbi1lcnJvcic7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3ZhbGlkYXRvcnMvZGF0ZVZhbGlkYXRvcic7XG5cbmV4cG9ydCAqIGZyb20gJy4vbGliL3R5cGVzJztcbiJdfQ==