@simpleangularcontrols/sac-common 10.0.0-rc.11 → 10.0.0-rc.13

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 (86) hide show
  1. package/bundles/simpleangularcontrols-sac-common.umd.js +1425 -1088
  2. package/bundles/simpleangularcontrols-sac-common.umd.js.map +1 -1
  3. package/bundles/simpleangularcontrols-sac-common.umd.min.js +1 -1
  4. package/bundles/simpleangularcontrols-sac-common.umd.min.js.map +1 -1
  5. package/common/basedatetimecontrol.d.ts +99 -13
  6. package/common/basemodelcontrol.d.ts +33 -29
  7. package/controls/checkbox/radiobutton.d.ts +61 -26
  8. package/controls/contextmenu/contextmenu.d.ts +26 -19
  9. package/controls/contextmenu/contextmenu.interface.d.ts +3 -0
  10. package/controls/contextmenu/contextmenuitem.d.ts +5 -0
  11. package/controls/contextmenu/contextmenuitembutton.d.ts +21 -20
  12. package/controls/datetime/date.d.ts +28 -27
  13. package/controls/datetime/datetime.d.ts +27 -27
  14. package/controls/datetime/time.d.ts +26 -26
  15. package/controls/dialog/dialog.d.ts +31 -43
  16. package/controls/layout/formlayout.d.ts +4 -0
  17. package/controls/list/buildvaluestring.d.ts +6 -0
  18. package/controls/list/dropdown.d.ts +9 -51
  19. package/controls/list/dropdownoptions.d.ts +38 -0
  20. package/controls/list/dropdownoptions.ngfactory.d.ts +1 -0
  21. package/controls/static/formcontainer.d.ts +11 -3
  22. package/controls/tooltip/tooltip.d.ts +33 -51
  23. package/controls/treeview/treeview.d.ts +87 -121
  24. package/esm2015/common/basedatetimecontrol.js +178 -30
  25. package/esm2015/common/basemodelcontrol.js +71 -56
  26. package/esm2015/controls/checkbox/radiobutton.js +94 -45
  27. package/esm2015/controls/contextmenu/contextmenu.interface.js +1 -0
  28. package/esm2015/controls/contextmenu/contextmenu.interface.ngfactory.js +7 -0
  29. package/esm2015/controls/contextmenu/contextmenu.js +22 -23
  30. package/esm2015/controls/contextmenu/contextmenuitem.js +13 -2
  31. package/esm2015/controls/contextmenu/contextmenuitembutton.js +34 -25
  32. package/esm2015/controls/datetime/date.js +43 -41
  33. package/esm2015/controls/datetime/datetime.js +42 -41
  34. package/esm2015/controls/datetime/time.js +42 -41
  35. package/esm2015/controls/dialog/dialog.js +41 -83
  36. package/esm2015/controls/layout/formlayout.js +7 -6
  37. package/esm2015/controls/list/buildvaluestring.js +18 -0
  38. package/esm2015/controls/{treeview/ngtreeitemaction.ngfactory.js → list/buildvaluestring.ngfactory.js} +1 -1
  39. package/esm2015/controls/list/dropdown.js +16 -114
  40. package/esm2015/controls/list/dropdownoptions.js +72 -0
  41. package/esm2015/controls/{treeview/treeviewchild.ngfactory.js → list/dropdownoptions.ngfactory.js} +1 -1
  42. package/esm2015/controls/static/formcontainer.js +16 -6
  43. package/esm2015/controls/tooltip/tooltip.js +60 -250
  44. package/esm2015/controls/treeview/treeview.js +232 -247
  45. package/esm2015/interfaces/ISacConfigurationService.js +1 -1
  46. package/esm2015/interfaces/ISacIconService.js +1 -1
  47. package/esm2015/interfaces/treeviewaction.interface.js +1 -0
  48. package/esm2015/interfaces/treeviewaction.interface.ngfactory.js +7 -0
  49. package/esm2015/public_api.js +6 -6
  50. package/esm2015/services/sac-configuration.service.js +7 -5
  51. package/esm2015/services/sac-icon.service.js +25 -1
  52. package/esm2015/utilities/enums.js +5 -1
  53. package/esm2015/utilities/popuphelper.js +343 -0
  54. package/esm2015/utilities/popuphelper.ngfactory.js +7 -0
  55. package/esm2015/validation/equals.validator.js +14 -0
  56. package/esm2015/validation/equals.validator.ngfactory.js +7 -0
  57. package/esm2015/validation/notequals.validator.js +14 -0
  58. package/esm2015/validation/notequals.validator.ngfactory.js +7 -0
  59. package/esm2015/validation/validation.class.js +30 -6
  60. package/fesm2015/simpleangularcontrols-sac-common.js +1398 -1075
  61. package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
  62. package/interfaces/ISacConfigurationService.d.ts +4 -0
  63. package/interfaces/ISacIconService.d.ts +16 -0
  64. package/interfaces/treeviewaction.interface.d.ts +4 -0
  65. package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
  66. package/package.json +1 -1
  67. package/public_api.d.ts +5 -5
  68. package/services/sac-configuration.service.d.ts +8 -0
  69. package/services/sac-icon.service.d.ts +33 -1
  70. package/simpleangularcontrols-sac-common-10.0.0-rc.13.tgz +0 -0
  71. package/simpleangularcontrols-sac-common.metadata.json +1 -1
  72. package/utilities/enums.d.ts +3 -1
  73. package/utilities/popuphelper.d.ts +83 -0
  74. package/utilities/popuphelper.ngfactory.d.ts +1 -0
  75. package/validation/equals.validator.d.ts +2 -0
  76. package/validation/equals.validator.ngfactory.d.ts +1 -0
  77. package/validation/notequals.validator.d.ts +2 -0
  78. package/validation/notequals.validator.ngfactory.d.ts +1 -0
  79. package/validation/validation.class.d.ts +19 -0
  80. package/controls/treeview/ngtreeitemaction.d.ts +0 -40
  81. package/controls/treeview/treeviewchild.d.ts +0 -12
  82. package/esm2015/controls/treeview/ngtreeitemaction.js +0 -60
  83. package/esm2015/controls/treeview/treeviewchild.js +0 -18
  84. package/simpleangularcontrols-sac-common-10.0.0-rc.11.tgz +0 -0
  85. /package/controls/{treeview/ngtreeitemaction.ngfactory.d.ts → contextmenu/contextmenu.interface.ngfactory.d.ts} +0 -0
  86. /package/controls/{treeview/treeviewchild.ngfactory.d.ts → list/buildvaluestring.ngfactory.d.ts} +0 -0
@@ -1,6 +1,7 @@
1
- import { ChangeDetectorRef, Directive, ElementRef, Input, ViewChild, } from '@angular/core';
2
1
  import { convertToBoolean } from '../../utilities/convertion';
3
2
  import { TooltipPosition } from '../../utilities/enums';
3
+ import { PopUpHelper } from '../../utilities/popuphelper';
4
+ import { ChangeDetectorRef, Directive, ElementRef, Input, ViewChild, } from '@angular/core';
4
5
  /**
5
6
  * Tooltip Component
6
7
  *
@@ -22,29 +23,15 @@ export class SacTooltipCommon {
22
23
  constructor(cdRef, ref) {
23
24
  this.cdRef = cdRef;
24
25
  this.ref = ref;
26
+ // #region Properties
25
27
  /**
26
- * Defines whether the tooltip is visible
28
+ * Helper class to display tooltip on correct position
27
29
  */
28
- this._isTooltipVisible = false;
30
+ this.popupHelper = new PopUpHelper();
29
31
  /**
30
- * method if content has changed and proportions need to be reset in the UI.
31
- */
32
- this.onContentChange = () => {
33
- // Do nothing if is not visible
34
- if (!this._isTooltipVisible) {
35
- return;
36
- }
37
- setTimeout(() => {
38
- this.getLeftPosition();
39
- this.getTopPosition();
40
- });
41
- };
42
- /**
43
- * Position of the tooltip. Values: left|top|right|bottom|auto
44
- *
45
- * Value 'auto' can be combined with another value.
32
+ * Defines whether the tooltip is visible
46
33
  */
47
- this.position = 'right|auto';
34
+ this._isTooltipVisible = false;
48
35
  /**
49
36
  * Position of the tooltip on the left
50
37
  */
@@ -61,9 +48,42 @@ export class SacTooltipCommon {
61
48
  * Position of the tooltip at the top
62
49
  */
63
50
  this.TopPos = 0;
51
+ /**
52
+ * Position of the picker arrow at the left
53
+ */
54
+ this.posArrowLeft = null;
55
+ /**
56
+ * Position of the picker arrow at the top
57
+ */
58
+ this.posArrowTop = null;
59
+ /**
60
+ * Position of the tooltip. Values: left|top|right|bottom|auto
61
+ *
62
+ * Value 'auto' can be combined with another value.
63
+ */
64
+ this.position = 'right|auto';
65
+ /**
66
+ * method if content has changed and proportions need to be reset in the UI.
67
+ */
68
+ this.onContentChange = () => {
69
+ // Do nothing if is not visible
70
+ if (!this._isTooltipVisible) {
71
+ return;
72
+ }
73
+ setTimeout(() => {
74
+ this.getLeftPosition();
75
+ this.getTopPosition();
76
+ });
77
+ };
64
78
  }
65
79
  // #endregion Constructors
66
80
  // #region Public Getters And Setters
81
+ /**
82
+ * Property for inline mode for tooltip. Sets the display mode on the wrapper element to `inline`
83
+ */
84
+ get inlinemode() {
85
+ return this._inlinemode;
86
+ }
67
87
  /**
68
88
  * Setter for inline mode for tooltip
69
89
  */
@@ -81,12 +101,6 @@ export class SacTooltipCommon {
81
101
  this.onContentChange();
82
102
  this.cdRef.detectChanges();
83
103
  }
84
- /**
85
- * Property for inline mode for tooltip. Sets the display mode on the wrapper element to `inline`
86
- */
87
- get inlinemode() {
88
- return this._inlinemode;
89
- }
90
104
  get tooltop() {
91
105
  return this.tooltipcontainer;
92
106
  }
@@ -96,50 +110,7 @@ export class SacTooltipCommon {
96
110
  * Returns the position of the tooltip
97
111
  */
98
112
  GetTooltipPosition() {
99
- const validPositions = this.ValidatePositions();
100
- // tslint:disable-next-line:no-bitwise
101
- if (this.HasPosition(TooltipPosition.right) &&
102
- validPositions & TooltipPosition.right) {
103
- return TooltipPosition.right;
104
- }
105
- // tslint:disable-next-line:no-bitwise
106
- if (this.HasPosition(TooltipPosition.top) &&
107
- validPositions & TooltipPosition.top) {
108
- return TooltipPosition.top;
109
- }
110
- // tslint:disable-next-line:no-bitwise
111
- if (this.HasPosition(TooltipPosition.left) &&
112
- validPositions & TooltipPosition.left) {
113
- return TooltipPosition.left;
114
- }
115
- // tslint:disable-next-line:no-bitwise
116
- if (this.HasPosition(TooltipPosition.bottom) &&
117
- validPositions & TooltipPosition.bottom) {
118
- return TooltipPosition.bottom;
119
- }
120
- // Get Auto Position or Default
121
- if (this.IsAutoPosition()) {
122
- // tslint:disable-next-line:no-bitwise
123
- if (validPositions & TooltipPosition.right) {
124
- return TooltipPosition.right;
125
- }
126
- // tslint:disable-next-line:no-bitwise
127
- if (validPositions & TooltipPosition.top) {
128
- return TooltipPosition.top;
129
- }
130
- // tslint:disable-next-line:no-bitwise
131
- if (validPositions & TooltipPosition.left) {
132
- return TooltipPosition.left;
133
- }
134
- // tslint:disable-next-line:no-bitwise
135
- if (validPositions & TooltipPosition.bottom) {
136
- return TooltipPosition.bottom;
137
- }
138
- return TooltipPosition.right;
139
- }
140
- else {
141
- return this.GetPosition();
142
- }
113
+ return this.popupHelper.getDisplayPosition(this.content, this.tooltipcontainer, this.getTooltipOffset(), this.getTooltipOffset(), this.position, true);
143
114
  }
144
115
  /**
145
116
  * Hide tooltip
@@ -170,24 +141,13 @@ export class SacTooltipCommon {
170
141
  * Calculates the height of the tooltip
171
142
  */
172
143
  getToolTipHeight() {
173
- var _a;
174
- if (this.tooltipcontainer) {
175
- return (_a = this.tooltipcontainer.nativeElement.firstElementChild.clientHeight) !== null && _a !== void 0 ? _a : 0;
176
- }
177
- else {
178
- return 0;
179
- }
144
+ return this.popupHelper.getPopupHeight(this.tooltipcontainer);
180
145
  }
181
146
  /**
182
147
  * Calculates the width of the tooltips
183
148
  */
184
149
  getToolTipWidth() {
185
- if (this.tooltipcontainer) {
186
- return this.tooltipcontainer.nativeElement.firstElementChild.clientWidth;
187
- }
188
- else {
189
- return 0;
190
- }
150
+ return this.popupHelper.getPopupWidth(this.tooltipcontainer);
191
151
  }
192
152
  /**
193
153
  * Detect Changes after view checked. Prevent ExpressionChangedAfterItHasBeenCheckedError error
@@ -232,187 +192,37 @@ export class SacTooltipCommon {
232
192
  document.body.appendChild(this.tooltipcontainer.nativeElement);
233
193
  }
234
194
  }
235
- // #endregion Protected Abstract Methods
195
+ // #endregion Protected Methods
236
196
  // #region Private Methods
237
- /**
238
- * Returns the defined position for the tooltip
239
- */
240
- GetPosition() {
241
- const positions = this.position.split('|');
242
- if (this.HasPosition(TooltipPosition.left)) {
243
- return TooltipPosition.left;
244
- }
245
- if (this.HasPosition(TooltipPosition.top)) {
246
- return TooltipPosition.top;
247
- }
248
- if (this.HasPosition(TooltipPosition.right)) {
249
- return TooltipPosition.right;
250
- }
251
- if (this.HasPosition(TooltipPosition.bottom)) {
252
- return TooltipPosition.bottom;
253
- }
254
- // Default Position if empty
255
- return TooltipPosition.right;
256
- }
257
- /**
258
- * Returns whether the position has been configured
259
- *
260
- * @param position Position to be checked
261
- */
262
- HasPosition(position) {
263
- const positions = this.position.split('|');
264
- if (position === TooltipPosition.right && positions.indexOf('right') >= 0) {
265
- return true;
266
- }
267
- if (position === TooltipPosition.top && positions.indexOf('top') >= 0) {
268
- return true;
269
- }
270
- if (position === TooltipPosition.left && positions.indexOf('left') >= 0) {
271
- return true;
272
- }
273
- if (position === TooltipPosition.bottom &&
274
- positions.indexOf('bottom') >= 0) {
275
- return true;
276
- }
277
- return false;
278
- }
279
- /**
280
- * Defines whether AutoPosition is active
281
- */
282
- IsAutoPosition() {
283
- const positions = this.position.split('|');
284
- return positions.indexOf('auto') >= 0;
285
- }
286
- /**
287
- * Checks whether the position is valid or whether the tooltip on the position has space
288
- */
289
- ValidatePositions() {
290
- // Check if Container is false
291
- if (this.tooltipcontainer === undefined) {
292
- return TooltipPosition.right;
293
- }
294
- let allowedPositions = TooltipPosition.none;
295
- const basePosition = this.content.nativeElement.firstElementChild.getBoundingClientRect();
296
- const tooltipRect = this.tooltipcontainer.nativeElement.firstElementChild.getBoundingClientRect();
297
- const leftPosOk = basePosition.left - tooltipRect.width + (this.getTooltipOffset() * -1) > 0;
298
- const rightPosOk = basePosition.right + tooltipRect.width + this.getTooltipOffset() < window.innerWidth;
299
- const topPosOk = basePosition.top - tooltipRect.height > 0;
300
- const bottomPosOk = basePosition.bottom + tooltipRect.height < window.innerHeight;
301
- const leftHalfPosOk = basePosition.left - tooltipRect.width / 2 > 0;
302
- const rightHalfPosOk = basePosition.right + tooltipRect.width / 2 < window.innerWidth;
303
- const topHalfPosOk = basePosition.top - tooltipRect.height / 2 > 0;
304
- const bottomHalfPosOk = basePosition.bottom + tooltipRect.height / 2 < window.innerHeight;
305
- if (leftPosOk && topHalfPosOk && bottomHalfPosOk) {
306
- // tslint:disable-next-line:no-bitwise
307
- allowedPositions = allowedPositions | TooltipPosition.left;
308
- }
309
- if (rightPosOk && topHalfPosOk && bottomHalfPosOk) {
310
- // tslint:disable-next-line:no-bitwise
311
- allowedPositions = allowedPositions | TooltipPosition.right;
312
- }
313
- if (topPosOk && leftHalfPosOk && rightHalfPosOk) {
314
- // tslint:disable-next-line:no-bitwise
315
- allowedPositions = allowedPositions | TooltipPosition.top;
316
- }
317
- if (bottomPosOk && leftHalfPosOk && rightHalfPosOk) {
318
- // tslint:disable-next-line:no-bitwise
319
- allowedPositions = allowedPositions | TooltipPosition.bottom;
320
- }
321
- return allowedPositions;
322
- }
323
197
  /**
324
198
  * Calculates the position of the tooltip from links
325
199
  */
326
200
  getLeftPosition() {
327
- if (this.content !== null && this.content !== undefined) {
328
- const item = this.content.nativeElement;
329
- if (item.children.length >= 1) {
330
- const childItem = item.firstElementChild;
331
- const contentPosition = childItem.getBoundingClientRect();
332
- switch (this.GetTooltipPosition()) {
333
- case TooltipPosition.top:
334
- this.LeftPos = contentPosition.left + contentPosition.width / 2 - this.getToolTipWidth() / 2;
335
- return (contentPosition.left + contentPosition.width / 2 - this.getToolTipWidth() / 2);
336
- case TooltipPosition.right:
337
- this.LeftPos = contentPosition.left + contentPosition.width + this.getTooltipOffset();
338
- return contentPosition.left + contentPosition.width + this.getTooltipOffset();
339
- case TooltipPosition.bottom:
340
- this.LeftPos = contentPosition.left + contentPosition.width / 2 - this.getToolTipWidth() / 2;
341
- return (contentPosition.left + contentPosition.width / 2 - this.getToolTipWidth() / 2);
342
- case TooltipPosition.left:
343
- this.LeftPos = contentPosition.left - this.getToolTipWidth() + (this.getTooltipOffset() * -1);
344
- return contentPosition.left - this.getToolTipWidth() + (this.getTooltipOffset() * -1);
345
- }
346
- return this.content.nativeElement.offsetTop;
347
- }
348
- else {
349
- return this.content.nativeElement.offsetTop;
350
- }
201
+ const value = this.popupHelper.getPositionLeft(this.content, this.tooltipcontainer, this.ref, this.getTooltipOffset(), this.getTooltipOffset(), this.position, true);
202
+ this.LeftPos = value;
203
+ const requiredPosition = this.GetTooltipPosition();
204
+ if (requiredPosition === TooltipPosition.left || requiredPosition === TooltipPosition.right) {
205
+ this.posArrowTop = this.getToolTipHeight() / 2 - 6.5;
351
206
  }
352
207
  else {
353
- return this.ref.nativeElement.offsetLeft;
208
+ this.posArrowTop = null;
354
209
  }
210
+ return value;
355
211
  }
356
212
  /**
357
213
  * Calculates the position of the tooltip from the top
358
214
  */
359
215
  getTopPosition() {
360
- if (this.content !== null && this.content !== undefined) {
361
- const item = this.content.nativeElement;
362
- if (item.children.length >= 1) {
363
- const childItem = item.firstElementChild;
364
- const contentPosition = childItem.getBoundingClientRect();
365
- // Get Position with Scroll (Scrollbars inside page should be substracted)
366
- const contentPositionTop = childItem.offsetTop + this.getOffsetTopParent(childItem.offsetParent) - this.getScrollTopParent(childItem.parentElement);
367
- switch (this.GetTooltipPosition()) {
368
- case TooltipPosition.top:
369
- this.TopPos = contentPositionTop - this.getToolTipHeight() + (this.getTooltipOffset() * -1);
370
- return contentPositionTop - this.getToolTipHeight() + (this.getTooltipOffset() * -1);
371
- case TooltipPosition.right:
372
- this.TopPos = contentPositionTop + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);
373
- return contentPositionTop + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);
374
- case TooltipPosition.bottom:
375
- this.TopPos = contentPositionTop + contentPosition.height + this.getTooltipOffset();
376
- return contentPositionTop + contentPosition.height + this.getTooltipOffset();
377
- case TooltipPosition.left:
378
- this.TopPos = contentPositionTop + contentPosition.height / 2 - this.getToolTipHeight() / 2;
379
- return (contentPositionTop + contentPosition.height / 2 - this.getToolTipHeight() / 2);
380
- }
381
- return (childItem.clientTop + childItem.offsetTop - (this.getToolTipHeight() / 2 - childItem.clientHeight / 2));
382
- }
383
- else {
384
- return this.content.nativeElement.offsetTop;
385
- }
216
+ const value = this.popupHelper.getPositionTop(this.content, this.tooltipcontainer, this.ref, this.getTooltipOffset(), this.getTooltipOffset(), this.position, true);
217
+ this.TopPos = value;
218
+ const requiredPosition = this.GetTooltipPosition();
219
+ if (requiredPosition === TooltipPosition.bottom || requiredPosition === TooltipPosition.top) {
220
+ this.posArrowLeft = this.getToolTipWidth() / 2 - 6.5;
386
221
  }
387
222
  else {
388
- return this.ref.nativeElement.offsetTop;
389
- }
390
- }
391
- /**
392
- * Calculates the top of the page inside all elements
393
- * @param element HTML Element
394
- * @returns summarized top value for absolute position
395
- */
396
- getOffsetTopParent(element) {
397
- if (!element.offsetParent) {
398
- return element.offsetTop;
223
+ this.posArrowLeft = null;
399
224
  }
400
- const parentValue = this.getOffsetTopParent(element.offsetParent);
401
- let offset = element.offsetTop;
402
- return parentValue + offset;
403
- }
404
- /**
405
- * Caclulate Scrollbars inside tree
406
- * @param element HTML Element
407
- * @returns Scroll top value of element with all childs
408
- */
409
- getScrollTopParent(element) {
410
- // Body Scroll should not be calculated
411
- if (!element.parentElement) {
412
- return 0;
413
- }
414
- const parentValue = this.getScrollTopParent(element.parentElement);
415
- return parentValue + element.scrollTop;
225
+ return value;
416
226
  }
417
227
  }
418
228
  SacTooltipCommon.decorators = [
@@ -423,10 +233,10 @@ SacTooltipCommon.ctorParameters = () => [
423
233
  { type: ElementRef }
424
234
  ];
425
235
  SacTooltipCommon.propDecorators = {
236
+ content: [{ type: ViewChild, args: ['container', { static: true },] }],
426
237
  position: [{ type: Input }],
427
238
  tooltiptext: [{ type: Input }],
428
- content: [{ type: ViewChild, args: ['container', { static: true },] }],
429
239
  inlinemode: [{ type: Input }],
430
240
  tooltip: [{ type: ViewChild, args: ['tooltip', { static: false },] }]
431
241
  };
432
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/tooltip/tooltip.ts"],"names":[],"mappings":"AAAA,OAAO,EAEL,iBAAiB,EACjB,SAAS,EAET,UAAU,EACV,KAAK,EAGL,SAAS,GACV,MAAM,eAAe,CAAC;AACvB,OAAO,EAAE,gBAAgB,EAAE,MAAM,4BAA4B,CAAC;AAC9D,OAAO,EAAE,eAAe,EAAE,MAAM,uBAAuB,CAAC;AAExD;;;;;;;;;;GAUG;AAEH,MAAM,OAAgB,gBAAgB;IAiEpC,wBAAwB;IAExB,uBAAuB;IAEvB;;;OAGG;IACH,YAA6B,KAAwB,EAAmB,GAAe;QAA1D,UAAK,GAAL,KAAK,CAAmB;QAAmB,QAAG,GAAH,GAAG,CAAY;QAlEvF;;WAEG;QACK,sBAAiB,GAAY,KAAK,CAAC;QAC3C;;WAEG;QACc,oBAAe,GAAG,GAAS,EAAE;YAC5C,+BAA+B;YAC/B,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;gBAC3B,OAAO;aACR;YAED,UAAU,CAAC,GAAG,EAAE;gBACd,IAAI,CAAC,eAAe,EAAE,CAAC;gBACvB,IAAI,CAAC,cAAc,EAAE,CAAC;YACxB,CAAC,CAAC,CAAC;QACL,CAAC,CAAC;QAMF;;;;WAIG;QAEI,aAAQ,GAAW,YAAY,CAAC;QAYvC;;WAEG;QACI,4BAAuB,GAAY,KAAK,CAAC;QAChD;;WAEG;QACI,YAAO,GAAW,CAAC,CAAC;QAC3B;;WAEG;QACI,oBAAe,GAAG,eAAe,CAAC;QACzC;;WAEG;QACI,WAAM,GAAW,CAAC,CAAC;IAUiE,CAAC;IAE5F,0BAA0B;IAE1B,qCAAqC;IAErC;;OAEG;IACH,IACW,UAAU,CAAC,KAAc;QAClC,IAAI,CAAC,WAAW,GAAG,gBAAgB,CAAC,KAAK,CAAC,CAAC;IAC7C,CAAC;IAED;;OAEG;IACH,IACW,OAAO,CAAC,OAAmB;QACpC,IAAI,OAAO,KAAK,SAAS,EAAE;YACzB,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;SAClD;QAED,IAAI,CAAC,gBAAgB,GAAG,OAAO,CAAC;QAChC,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED;;OAEG;IACH,IAAW,UAAU;QACnB,OAAO,IAAI,CAAC,WAAW,CAAC;IAC1B,CAAC;IAED,IAAW,OAAO;QAChB,OAAO,IAAI,CAAC,gBAAgB,CAAC;IAC/B,CAAC;IAED,wCAAwC;IAExC,yBAAyB;IAEzB;;OAEG;IACI,kBAAkB;QACvB,MAAM,cAAc,GAAoB,IAAI,CAAC,iBAAiB,EAAE,CAAC;QAEjE,sCAAsC;QACtC,IACE,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC;YACvC,cAAc,GAAG,eAAe,CAAC,KAAK,EACtC;YACA,OAAO,eAAe,CAAC,KAAK,CAAC;SAC9B;QAED,sCAAsC;QACtC,IACE,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,GAAG,CAAC;YACrC,cAAc,GAAG,eAAe,CAAC,GAAG,EACpC;YACA,OAAO,eAAe,CAAC,GAAG,CAAC;SAC5B;QAED,sCAAsC;QACtC,IACE,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC;YACtC,cAAc,GAAG,eAAe,CAAC,IAAI,EACrC;YACA,OAAO,eAAe,CAAC,IAAI,CAAC;SAC7B;QAED,sCAAsC;QACtC,IACE,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,MAAM,CAAC;YACxC,cAAc,GAAG,eAAe,CAAC,MAAM,EACvC;YACA,OAAO,eAAe,CAAC,MAAM,CAAC;SAC/B;QAED,+BAA+B;QAC/B,IAAI,IAAI,CAAC,cAAc,EAAE,EAAE;YACzB,sCAAsC;YACtC,IAAI,cAAc,GAAG,eAAe,CAAC,KAAK,EAAE;gBAC1C,OAAO,eAAe,CAAC,KAAK,CAAC;aAC9B;YAED,sCAAsC;YACtC,IAAI,cAAc,GAAG,eAAe,CAAC,GAAG,EAAE;gBACxC,OAAO,eAAe,CAAC,GAAG,CAAC;aAC5B;YAED,sCAAsC;YACtC,IAAI,cAAc,GAAG,eAAe,CAAC,IAAI,EAAE;gBACzC,OAAO,eAAe,CAAC,IAAI,CAAC;aAC7B;YAED,sCAAsC;YACtC,IAAI,cAAc,GAAG,eAAe,CAAC,MAAM,EAAE;gBAC3C,OAAO,eAAe,CAAC,MAAM,CAAC;aAC/B;YAED,OAAO,eAAe,CAAC,KAAK,CAAC;SAC9B;aAAM;YACL,OAAO,IAAI,CAAC,WAAW,EAAE,CAAC;SAC3B;IACH,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,IAAI,CAAC,iBAAiB,GAAG,KAAK,CAAC;QAC/B,IAAI,CAAC,uBAAuB,GAAG,KAAK,CAAC;IACvC,CAAC;IAED;;OAEG;IACI,gBAAgB;QACrB,OAAO,IAAI,CAAC,iBAAiB,CAAC;IAChC,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,IAAI,CAAC,iBAAiB,GAAG,IAAI,CAAC;QAC9B,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;QAE3B,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,eAAe,EAAE,CAAC;YACvB,IAAI,CAAC,cAAc,EAAE,CAAC;YACtB,IAAI,CAAC,uBAAuB,GAAG,IAAI,CAAC;QACtC,CAAC,CAAC,CAAC;IACL,CAAC;IAED;;OAEG;IACI,gBAAgB;;QACrB,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzB,aAAO,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,iBAAiB,CAAC,YAAY,mCAAI,CAAC,CAAC;SAChF;aAAM;YACL,OAAO,CAAC,CAAC;SACV;IACH,CAAC;IAED;;OAEG;IACI,eAAe;QACpB,IAAI,IAAI,CAAC,gBAAgB,EAAE;YACzB,OAAO,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,iBAAiB,CAAC,WAAW,CAAC;SAC1E;aAAM;YACL,OAAO,CAAC,CAAC;SACV;IACH,CAAC;IAED;;OAEG;IACI,kBAAkB;QACvB,gCAAgC;QAChC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAC3B,OAAO;SACR;QAED,IAAI,CAAC,KAAK,CAAC,aAAa,EAAE,CAAC;IAC7B,CAAC;IAED;;OAEG;IACI,SAAS;QACd,gCAAgC;QAChC,IAAI,CAAC,IAAI,CAAC,iBAAiB,EAAE;YAC3B,OAAO;SACR;QAED,IAAI,CAAC,eAAe,EAAE,CAAC;QACvB,IAAI,CAAC,cAAc,EAAE,CAAC;IACxB,CAAC;IAED;;OAEG;IACI,WAAW;QAChB,4BAA4B;QAC5B,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QACjE,MAAM,CAAC,mBAAmB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAEjE,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,EAAE;YACvC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;SAChE;IACH,CAAC;IAED;;OAEG;IACI,QAAQ;QACb,0BAA0B;QAC1B,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAC9D,MAAM,CAAC,gBAAgB,CAAC,QAAQ,EAAE,IAAI,CAAC,eAAe,EAAE,IAAI,CAAC,CAAC;QAE9D,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,EAAE;YACvC,QAAQ,CAAC,IAAI,CAAC,WAAW,CAAC,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,CAAC;SAChE;IACH,CAAC;IAWD,wCAAwC;IAExC,0BAA0B;IAE1B;;OAEG;IACK,WAAW;QACjB,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAE3C,IAAI,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,IAAI,CAAC,EAAE;YAC1C,OAAO,eAAe,CAAC,IAAI,CAAC;SAC7B;QAED,IAAI,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,GAAG,CAAC,EAAE;YACzC,OAAO,eAAe,CAAC,GAAG,CAAC;SAC5B;QAED,IAAI,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,KAAK,CAAC,EAAE;YAC3C,OAAO,eAAe,CAAC,KAAK,CAAC;SAC9B;QAED,IAAI,IAAI,CAAC,WAAW,CAAC,eAAe,CAAC,MAAM,CAAC,EAAE;YAC5C,OAAO,eAAe,CAAC,MAAM,CAAC;SAC/B;QAED,4BAA4B;QAC5B,OAAO,eAAe,CAAC,KAAK,CAAC;IAC/B,CAAC;IAED;;;;OAIG;IACK,WAAW,CAAC,QAAyB;QAC3C,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAE3C,IAAI,QAAQ,KAAK,eAAe,CAAC,KAAK,IAAI,SAAS,CAAC,OAAO,CAAC,OAAO,CAAC,IAAI,CAAC,EAAE;YACzE,OAAO,IAAI,CAAC;SACb;QAED,IAAI,QAAQ,KAAK,eAAe,CAAC,GAAG,IAAI,SAAS,CAAC,OAAO,CAAC,KAAK,CAAC,IAAI,CAAC,EAAE;YACrE,OAAO,IAAI,CAAC;SACb;QAED,IAAI,QAAQ,KAAK,eAAe,CAAC,IAAI,IAAI,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,EAAE;YACvE,OAAO,IAAI,CAAC;SACb;QAED,IACE,QAAQ,KAAK,eAAe,CAAC,MAAM;YACnC,SAAS,CAAC,OAAO,CAAC,QAAQ,CAAC,IAAI,CAAC,EAChC;YACA,OAAO,IAAI,CAAC;SACb;QAED,OAAO,KAAK,CAAC;IACf,CAAC;IAED;;OAEG;IACK,cAAc;QACpB,MAAM,SAAS,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,GAAG,CAAC,CAAC;QAC3C,OAAO,SAAS,CAAC,OAAO,CAAC,MAAM,CAAC,IAAI,CAAC,CAAC;IACxC,CAAC;IAED;;OAEG;IACK,iBAAiB;QACvB,8BAA8B;QAC9B,IAAI,IAAI,CAAC,gBAAgB,KAAK,SAAS,EAAE;YACvC,OAAO,eAAe,CAAC,KAAK,CAAC;SAC9B;QAED,IAAI,gBAAgB,GAAoB,eAAe,CAAC,IAAI,CAAC;QAC7D,MAAM,YAAY,GAAY,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,iBAAiB,CAAC,qBAAqB,EAAE,CAAC;QACnG,MAAM,WAAW,GAAY,IAAI,CAAC,gBAAgB,CAAC,aAAa,CAAC,iBAAiB,CAAC,qBAAqB,EAAE,CAAC;QAE3G,MAAM,SAAS,GAAY,YAAY,CAAC,IAAI,GAAG,WAAW,CAAC,KAAK,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC,GAAG,CAAC,CAAC;QACtG,MAAM,UAAU,GAAY,YAAY,CAAC,KAAK,GAAG,WAAW,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,MAAM,CAAC,UAAU,CAAC;QACjH,MAAM,QAAQ,GAAY,YAAY,CAAC,GAAG,GAAG,WAAW,CAAC,MAAM,GAAG,CAAC,CAAC;QACpE,MAAM,WAAW,GAAY,YAAY,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,GAAG,MAAM,CAAC,WAAW,CAAC;QAE3F,MAAM,aAAa,GAAY,YAAY,CAAC,IAAI,GAAG,WAAW,CAAC,KAAK,GAAG,CAAC,GAAG,CAAC,CAAC;QAC7E,MAAM,cAAc,GAAY,YAAY,CAAC,KAAK,GAAG,WAAW,CAAC,KAAK,GAAG,CAAC,GAAG,MAAM,CAAC,UAAU,CAAC;QAC/F,MAAM,YAAY,GAAY,YAAY,CAAC,GAAG,GAAG,WAAW,CAAC,MAAM,GAAG,CAAC,GAAG,CAAC,CAAC;QAC5E,MAAM,eAAe,GAAY,YAAY,CAAC,MAAM,GAAG,WAAW,CAAC,MAAM,GAAG,CAAC,GAAG,MAAM,CAAC,WAAW,CAAC;QAEnG,IAAI,SAAS,IAAI,YAAY,IAAI,eAAe,EAAE;YAChD,sCAAsC;YACtC,gBAAgB,GAAG,gBAAgB,GAAG,eAAe,CAAC,IAAI,CAAC;SAC5D;QAED,IAAI,UAAU,IAAI,YAAY,IAAI,eAAe,EAAE;YACjD,sCAAsC;YACtC,gBAAgB,GAAG,gBAAgB,GAAG,eAAe,CAAC,KAAK,CAAC;SAC7D;QAED,IAAI,QAAQ,IAAI,aAAa,IAAI,cAAc,EAAE;YAC/C,sCAAsC;YACtC,gBAAgB,GAAG,gBAAgB,GAAG,eAAe,CAAC,GAAG,CAAC;SAC3D;QAED,IAAI,WAAW,IAAI,aAAa,IAAI,cAAc,EAAE;YAClD,sCAAsC;YACtC,gBAAgB,GAAG,gBAAgB,GAAG,eAAe,CAAC,MAAM,CAAC;SAC9D;QAED,OAAO,gBAAgB,CAAC;IAC1B,CAAC;IAED;;OAEG;IACK,eAAe;QACrB,IAAI,IAAI,CAAC,OAAO,KAAK,IAAI,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE;YACvD,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;YAExC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,IAAI,CAAC,EAAE;gBAC7B,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAgC,CAAC;gBACxD,MAAM,eAAe,GAAY,SAAS,CAAC,qBAAqB,EAAE,CAAC;gBAEnE,QAAQ,IAAI,CAAC,kBAAkB,EAAE,EAAE;oBACjC,KAAK,eAAe,CAAC,GAAG;wBACtB,IAAI,CAAC,OAAO,GAAG,eAAe,CAAC,IAAI,GAAG,eAAe,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;wBAC7F,OAAO,CAAC,eAAe,CAAC,IAAI,GAAG,eAAe,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,CACpF,CAAC;oBACJ,KAAK,eAAe,CAAC,KAAK;wBACxB,IAAI,CAAC,OAAO,GAAG,eAAe,CAAC,IAAI,GAAG,eAAe,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;wBACtF,OAAO,eAAe,CAAC,IAAI,GAAG,eAAe,CAAC,KAAK,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBAChF,KAAK,eAAe,CAAC,MAAM;wBACzB,IAAI,CAAC,OAAO,GAAG,eAAe,CAAC,IAAI,GAAG,eAAe,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC;wBAC7F,OAAO,CAAC,eAAe,CAAC,IAAI,GAAG,eAAe,CAAC,KAAK,GAAG,CAAC,GAAG,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,CAAC,CAAC;oBACzF,KAAK,eAAe,CAAC,IAAI;wBACvB,IAAI,CAAC,OAAO,GAAG,eAAe,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;wBAC9F,OAAO,eAAe,CAAC,IAAI,GAAG,IAAI,CAAC,eAAe,EAAE,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;iBACzF;gBAED,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC;aAC7C;iBAAM;gBACL,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC;aAC7C;SACF;aAAM;YACL,OAAO,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,UAAU,CAAC;SAC1C;IACH,CAAC;IAED;;OAEG;IACK,cAAc;QACpB,IAAI,IAAI,CAAC,OAAO,KAAK,IAAI,IAAI,IAAI,CAAC,OAAO,KAAK,SAAS,EAAE;YACvD,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC;YAExC,IAAI,IAAI,CAAC,QAAQ,CAAC,MAAM,IAAI,CAAC,EAAE;gBAC7B,MAAM,SAAS,GAAG,IAAI,CAAC,iBAAgC,CAAC;gBACxD,MAAM,eAAe,GAAY,SAAS,CAAC,qBAAqB,EAAE,CAAC;gBAEnE,0EAA0E;gBAC1E,MAAM,kBAAkB,GAAG,SAAS,CAAC,SAAS,GAAG,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,YAA2B,CAAC,GAAG,IAAI,CAAC,kBAAkB,CAAC,SAAS,CAAC,aAAa,CAAC,CAAC;gBAEnK,QAAQ,IAAI,CAAC,kBAAkB,EAAE,EAAE;oBACjC,KAAK,eAAe,CAAC,GAAG;wBACtB,IAAI,CAAC,MAAM,GAAG,kBAAkB,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;wBAC5F,OAAO,kBAAkB,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC;oBACvF,KAAK,eAAe,CAAC,KAAK;wBACxB,IAAI,CAAC,MAAM,GAAG,kBAAkB,GAAG,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC;wBAChG,OAAO,kBAAkB,GAAG,CAAC,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC;oBAC3F,KAAK,eAAe,CAAC,MAAM;wBACzB,IAAI,CAAC,MAAM,GAAG,kBAAkB,GAAG,eAAe,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;wBACpF,OAAO,kBAAkB,GAAG,eAAe,CAAC,MAAM,GAAG,IAAI,CAAC,gBAAgB,EAAE,CAAC;oBAC/E,KAAK,eAAe,CAAC,IAAI;wBACvB,IAAI,CAAC,MAAM,GAAG,kBAAkB,GAAG,eAAe,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC;wBAC5F,OAAO,CAAC,kBAAkB,GAAG,eAAe,CAAC,MAAM,GAAG,CAAC,GAAG,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,CAAC,CAAC;iBAC1F;gBAED,OAAO,CAAC,SAAS,CAAC,SAAS,GAAG,SAAS,CAAC,SAAS,GAAG,CAAC,IAAI,CAAC,gBAAgB,EAAE,GAAG,CAAC,GAAG,SAAS,CAAC,YAAY,GAAG,CAAC,CAAC,CAAC,CAAC;aACjH;iBAAM;gBACL,OAAO,IAAI,CAAC,OAAO,CAAC,aAAa,CAAC,SAAS,CAAC;aAC7C;SACF;aAAM;YACL,OAAO,IAAI,CAAC,GAAG,CAAC,aAAa,CAAC,SAAS,CAAC;SACzC;IACH,CAAC;IAED;;;;OAIG;IACK,kBAAkB,CAAC,OAAoB;QAC7C,IAAI,CAAC,OAAO,CAAC,YAAY,EAAE;YACzB,OAAO,OAAO,CAAC,SAAS,CAAC;SAC1B;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,YAA2B,CAAC,CAAC;QACjF,IAAI,MAAM,GAAG,OAAO,CAAC,SAAS,CAAC;QAC/B,OAAO,WAAW,GAAG,MAAM,CAAC;IAC9B,CAAC;IAED;;;;OAIG;IACK,kBAAkB,CAAC,OAAoB;QAC7C,uCAAuC;QACvC,IAAI,CAAC,OAAO,CAAC,aAAa,EAAE;YAC1B,OAAO,CAAC,CAAC;SACV;QAED,MAAM,WAAW,GAAG,IAAI,CAAC,kBAAkB,CAAC,OAAO,CAAC,aAAa,CAAC,CAAC;QACnE,OAAO,WAAW,GAAG,OAAO,CAAC,SAAS,CAAC;IACzC,CAAC;;;YA9fF,SAAS;;;YAvBR,iBAAiB;YAGjB,UAAU;;;uBAwDT,KAAK;0BAKL,KAAK;sBAKL,SAAS,SAAC,WAAW,EAAE,EAAE,MAAM,EAAE,IAAI,EAAE;yBAqCvC,KAAK;sBAQL,SAAS,SAAC,SAAS,EAAE,EAAE,MAAM,EAAE,KAAK,EAAE","sourcesContent":["import {\r\n  AfterViewChecked,\r\n  ChangeDetectorRef,\r\n  Directive,\r\n  DoCheck,\r\n  ElementRef,\r\n  Input,\r\n  OnDestroy,\r\n  OnInit,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { convertToBoolean } from '../../utilities/convertion';\r\nimport { TooltipPosition } from '../../utilities/enums';\r\n\r\n/**\r\n * Tooltip Component\r\n *\r\n * Requires the following identifiers in the HTML markup\r\n * - container: Container for ng-content in which the element is displayed where the tooltip is attached.\r\n * - tooltip: Container for tooltip\r\n *\r\n * Tooltip must be displayed in 2 steps. In a first step the tooltip markup is created with (ngIf). In a 2nd step\r\n * the tooltip can then be displayed via the CSS visibility. If this is not done, it can lead to a flickering effect in certain browsers.\r\n *\r\n */\r\n@Directive()\r\nexport abstract class SacTooltipCommon implements OnInit, OnDestroy, AfterViewChecked, DoCheck {\r\n  // #region Properties\r\n\r\n  /**\r\n   * Inline mode for tooltip\r\n   */\r\n  private _inlinemode: boolean;\r\n  /**\r\n   * Defines whether the tooltip is visible\r\n   */\r\n  private _isTooltipVisible: boolean = false;\r\n  /**\r\n   * method if content has changed and proportions need to be reset in the UI.\r\n   */\r\n  private readonly onContentChange = (): void => {\r\n    // Do nothing if is not visible\r\n    if (!this._isTooltipVisible) {\r\n      return;\r\n    }\r\n\r\n    setTimeout(() => {\r\n      this.getLeftPosition();\r\n      this.getTopPosition();\r\n    });\r\n  };\r\n  /**\r\n   * Containers for the tooltip\r\n   */\r\n  private tooltipcontainer: ElementRef<HTMLElement>;\r\n\r\n  /**\r\n   * Position of the tooltip. Values: left|top|right|bottom|auto\r\n   *\r\n   * Value 'auto' can be combined with another value.\r\n   */\r\n  @Input()\r\n  public position: string = 'right|auto';\r\n  /**\r\n   * Text for ToolTip\r\n   */\r\n  @Input()\r\n  public tooltiptext: string;\r\n  /**\r\n   * Name of the container for content (e.g. icon) on which the tooltip is displayed.\r\n   */\r\n  @ViewChild('container', { static: true })\r\n  public content: ElementRef<HTMLElement>;\r\n\r\n  /**\r\n   * Position of the tooltip on the left\r\n   */\r\n  public IsTooltipContentVisible: boolean = false;\r\n  /**\r\n   * Position des Tooltips links\r\n   */\r\n  public LeftPos: number = 0;\r\n  /**\r\n   * Property for enum in Angular HTML template\r\n   */\r\n  public TooltipPosition = TooltipPosition;\r\n  /**\r\n   * Position of the tooltip at the top\r\n   */\r\n  public TopPos: number = 0;\r\n\r\n  // #endregion Properties\r\n\r\n  // #region Constructors\r\n\r\n  /**\r\n   * Konstruktor\r\n   * @param ref Element Referenz\r\n   */\r\n  constructor(private readonly cdRef: ChangeDetectorRef, private readonly ref: ElementRef) { }\r\n\r\n  // #endregion Constructors\r\n\r\n  // #region Public Getters And Setters\r\n\r\n  /**\r\n   * Setter for inline mode for tooltip\r\n   */\r\n  @Input()\r\n  public set inlinemode(value: boolean) {\r\n    this._inlinemode = convertToBoolean(value);\r\n  }\r\n\r\n  /**\r\n   * Setter for the name of the container for the tooltip. Is required as the tooltip can be hidden via ngIf.\r\n   */\r\n  @ViewChild('tooltip', { static: false })\r\n  public set tooltip(content: ElementRef) {\r\n    if (content !== undefined) {\r\n      document.body.appendChild(content.nativeElement);\r\n    }\r\n\r\n    this.tooltipcontainer = content;\r\n    this.onContentChange();\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Property for inline mode for tooltip. Sets the display mode on the wrapper element to `inline`\r\n   */\r\n  public get inlinemode(): boolean {\r\n    return this._inlinemode;\r\n  }\r\n\r\n  public get tooltop(): ElementRef {\r\n    return this.tooltipcontainer;\r\n  }\r\n\r\n  // #endregion Public Getters And Setters\r\n\r\n  // #region Public Methods\r\n\r\n  /**\r\n   * Returns the position of the tooltip\r\n   */\r\n  public GetTooltipPosition(): TooltipPosition {\r\n    const validPositions: TooltipPosition = this.ValidatePositions();\r\n\r\n    // tslint:disable-next-line:no-bitwise\r\n    if (\r\n      this.HasPosition(TooltipPosition.right) &&\r\n      validPositions & TooltipPosition.right\r\n    ) {\r\n      return TooltipPosition.right;\r\n    }\r\n\r\n    // tslint:disable-next-line:no-bitwise\r\n    if (\r\n      this.HasPosition(TooltipPosition.top) &&\r\n      validPositions & TooltipPosition.top\r\n    ) {\r\n      return TooltipPosition.top;\r\n    }\r\n\r\n    // tslint:disable-next-line:no-bitwise\r\n    if (\r\n      this.HasPosition(TooltipPosition.left) &&\r\n      validPositions & TooltipPosition.left\r\n    ) {\r\n      return TooltipPosition.left;\r\n    }\r\n\r\n    // tslint:disable-next-line:no-bitwise\r\n    if (\r\n      this.HasPosition(TooltipPosition.bottom) &&\r\n      validPositions & TooltipPosition.bottom\r\n    ) {\r\n      return TooltipPosition.bottom;\r\n    }\r\n\r\n    // Get Auto Position or Default\r\n    if (this.IsAutoPosition()) {\r\n      // tslint:disable-next-line:no-bitwise\r\n      if (validPositions & TooltipPosition.right) {\r\n        return TooltipPosition.right;\r\n      }\r\n\r\n      // tslint:disable-next-line:no-bitwise\r\n      if (validPositions & TooltipPosition.top) {\r\n        return TooltipPosition.top;\r\n      }\r\n\r\n      // tslint:disable-next-line:no-bitwise\r\n      if (validPositions & TooltipPosition.left) {\r\n        return TooltipPosition.left;\r\n      }\r\n\r\n      // tslint:disable-next-line:no-bitwise\r\n      if (validPositions & TooltipPosition.bottom) {\r\n        return TooltipPosition.bottom;\r\n      }\r\n\r\n      return TooltipPosition.right;\r\n    } else {\r\n      return this.GetPosition();\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Hide tooltip\r\n   */\r\n  public HideTooltip(): void {\r\n    this._isTooltipVisible = false;\r\n    this.IsTooltipContentVisible = false;\r\n  }\r\n\r\n  /**\r\n   * Defines whether the tooltip is present in the markup\r\n   */\r\n  public IsTooltipVisible(): boolean {\r\n    return this._isTooltipVisible;\r\n  }\r\n\r\n  /**\r\n   * Show tooltip\r\n   */\r\n  public ShowTooltip(): void {\r\n    this._isTooltipVisible = true;\r\n    this.cdRef.detectChanges();\r\n\r\n    setTimeout(() => {\r\n      this.getLeftPosition();\r\n      this.getTopPosition();\r\n      this.IsTooltipContentVisible = true;\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Calculates the height of the tooltip\r\n   */\r\n  public getToolTipHeight(): number {\r\n    if (this.tooltipcontainer) {\r\n      return this.tooltipcontainer.nativeElement.firstElementChild.clientHeight ?? 0;\r\n    } else {\r\n      return 0;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Calculates the width of the tooltips\r\n   */\r\n  public getToolTipWidth(): number {\r\n    if (this.tooltipcontainer) {\r\n      return this.tooltipcontainer.nativeElement.firstElementChild.clientWidth;\r\n    } else {\r\n      return 0;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Detect Changes after view checked. Prevent ExpressionChangedAfterItHasBeenCheckedError error\r\n   */\r\n  public ngAfterViewChecked(): void {\r\n    // Do nothing if is not visibile\r\n    if (!this._isTooltipVisible) {\r\n      return;\r\n    }\r\n\r\n    this.cdRef.detectChanges();\r\n  }\r\n\r\n  /**\r\n   * Detect UI Changes to Calculate Tooltip correct\r\n   */\r\n  public ngDoCheck(): void {\r\n    // Do nothing if is not visibile\r\n    if (!this._isTooltipVisible) {\r\n      return;\r\n    }\r\n\r\n    this.getLeftPosition();\r\n    this.getTopPosition();\r\n  }\r\n\r\n  /**\r\n   * Event when the control is destroyed.\r\n   */\r\n  public ngOnDestroy() {\r\n    // Unregister Event Listener\r\n    window.removeEventListener('scroll', this.onContentChange, true);\r\n    window.removeEventListener('resize', this.onContentChange, true);\r\n\r\n    if (this.tooltipcontainer !== undefined) {\r\n      document.body.removeChild(this.tooltipcontainer.nativeElement);\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Event when the control is initialized\r\n   */\r\n  public ngOnInit() {\r\n    // Register Event Listener\r\n    window.addEventListener('scroll', this.onContentChange, true);\r\n    window.addEventListener('resize', this.onContentChange, true);\r\n\r\n    if (this.tooltipcontainer !== undefined) {\r\n      document.body.appendChild(this.tooltipcontainer.nativeElement);\r\n    }\r\n  }\r\n\r\n  // #endregion Public Methods\r\n\r\n  // #region Protected Abstract Methods\r\n\r\n  /**\r\n   * Offset for Tooltip. Required for BS4/BS5 to create padding\r\n   */\r\n  protected abstract getTooltipOffset(): number;\r\n\r\n  // #endregion Protected Abstract Methods\r\n\r\n  // #region Private Methods\r\n\r\n  /**\r\n   * Returns the defined position for the tooltip\r\n   */\r\n  private GetPosition(): TooltipPosition {\r\n    const positions = this.position.split('|');\r\n\r\n    if (this.HasPosition(TooltipPosition.left)) {\r\n      return TooltipPosition.left;\r\n    }\r\n\r\n    if (this.HasPosition(TooltipPosition.top)) {\r\n      return TooltipPosition.top;\r\n    }\r\n\r\n    if (this.HasPosition(TooltipPosition.right)) {\r\n      return TooltipPosition.right;\r\n    }\r\n\r\n    if (this.HasPosition(TooltipPosition.bottom)) {\r\n      return TooltipPosition.bottom;\r\n    }\r\n\r\n    // Default Position if empty\r\n    return TooltipPosition.right;\r\n  }\r\n\r\n  /**\r\n   * Returns whether the position has been configured\r\n   *\r\n   * @param position Position to be checked\r\n   */\r\n  private HasPosition(position: TooltipPosition): boolean {\r\n    const positions = this.position.split('|');\r\n\r\n    if (position === TooltipPosition.right && positions.indexOf('right') >= 0) {\r\n      return true;\r\n    }\r\n\r\n    if (position === TooltipPosition.top && positions.indexOf('top') >= 0) {\r\n      return true;\r\n    }\r\n\r\n    if (position === TooltipPosition.left && positions.indexOf('left') >= 0) {\r\n      return true;\r\n    }\r\n\r\n    if (\r\n      position === TooltipPosition.bottom &&\r\n      positions.indexOf('bottom') >= 0\r\n    ) {\r\n      return true;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  /**\r\n   * Defines whether AutoPosition is active\r\n   */\r\n  private IsAutoPosition(): boolean {\r\n    const positions = this.position.split('|');\r\n    return positions.indexOf('auto') >= 0;\r\n  }\r\n\r\n  /**\r\n   * Checks whether the position is valid or whether the tooltip on the position has space\r\n   */\r\n  private ValidatePositions(): TooltipPosition {\r\n    // Check if Container is false\r\n    if (this.tooltipcontainer === undefined) {\r\n      return TooltipPosition.right;\r\n    }\r\n\r\n    let allowedPositions: TooltipPosition = TooltipPosition.none;\r\n    const basePosition: DOMRect = this.content.nativeElement.firstElementChild.getBoundingClientRect();\r\n    const tooltipRect: DOMRect = this.tooltipcontainer.nativeElement.firstElementChild.getBoundingClientRect();\r\n\r\n    const leftPosOk: boolean = basePosition.left - tooltipRect.width + (this.getTooltipOffset() * -1) > 0;\r\n    const rightPosOk: boolean = basePosition.right + tooltipRect.width + this.getTooltipOffset() < window.innerWidth;\r\n    const topPosOk: boolean = basePosition.top - tooltipRect.height > 0;\r\n    const bottomPosOk: boolean = basePosition.bottom + tooltipRect.height < window.innerHeight;\r\n\r\n    const leftHalfPosOk: boolean = basePosition.left - tooltipRect.width / 2 > 0;\r\n    const rightHalfPosOk: boolean = basePosition.right + tooltipRect.width / 2 < window.innerWidth;\r\n    const topHalfPosOk: boolean = basePosition.top - tooltipRect.height / 2 > 0;\r\n    const bottomHalfPosOk: boolean = basePosition.bottom + tooltipRect.height / 2 < window.innerHeight;\r\n\r\n    if (leftPosOk && topHalfPosOk && bottomHalfPosOk) {\r\n      // tslint:disable-next-line:no-bitwise\r\n      allowedPositions = allowedPositions | TooltipPosition.left;\r\n    }\r\n\r\n    if (rightPosOk && topHalfPosOk && bottomHalfPosOk) {\r\n      // tslint:disable-next-line:no-bitwise\r\n      allowedPositions = allowedPositions | TooltipPosition.right;\r\n    }\r\n\r\n    if (topPosOk && leftHalfPosOk && rightHalfPosOk) {\r\n      // tslint:disable-next-line:no-bitwise\r\n      allowedPositions = allowedPositions | TooltipPosition.top;\r\n    }\r\n\r\n    if (bottomPosOk && leftHalfPosOk && rightHalfPosOk) {\r\n      // tslint:disable-next-line:no-bitwise\r\n      allowedPositions = allowedPositions | TooltipPosition.bottom;\r\n    }\r\n\r\n    return allowedPositions;\r\n  }\r\n\r\n  /**\r\n   * Calculates the position of the tooltip from links\r\n   */\r\n  private getLeftPosition(): number {\r\n    if (this.content !== null && this.content !== undefined) {\r\n      const item = this.content.nativeElement;\r\n\r\n      if (item.children.length >= 1) {\r\n        const childItem = item.firstElementChild as HTMLElement;\r\n        const contentPosition: DOMRect = childItem.getBoundingClientRect();\r\n\r\n        switch (this.GetTooltipPosition()) {\r\n          case TooltipPosition.top:\r\n            this.LeftPos = contentPosition.left + contentPosition.width / 2 - this.getToolTipWidth() / 2;\r\n            return (contentPosition.left + contentPosition.width / 2 - this.getToolTipWidth() / 2\r\n            );\r\n          case TooltipPosition.right:\r\n            this.LeftPos = contentPosition.left + contentPosition.width + this.getTooltipOffset();\r\n            return contentPosition.left + contentPosition.width + this.getTooltipOffset();\r\n          case TooltipPosition.bottom:\r\n            this.LeftPos = contentPosition.left + contentPosition.width / 2 - this.getToolTipWidth() / 2;\r\n            return (contentPosition.left + contentPosition.width / 2 - this.getToolTipWidth() / 2);\r\n          case TooltipPosition.left:\r\n            this.LeftPos = contentPosition.left - this.getToolTipWidth() + (this.getTooltipOffset() * -1);\r\n            return contentPosition.left - this.getToolTipWidth() + (this.getTooltipOffset() * -1);\r\n        }\r\n\r\n        return this.content.nativeElement.offsetTop;\r\n      } else {\r\n        return this.content.nativeElement.offsetTop;\r\n      }\r\n    } else {\r\n      return this.ref.nativeElement.offsetLeft;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Calculates the position of the tooltip from the top\r\n   */\r\n  private getTopPosition(): number {\r\n    if (this.content !== null && this.content !== undefined) {\r\n      const item = this.content.nativeElement;\r\n\r\n      if (item.children.length >= 1) {\r\n        const childItem = item.firstElementChild as HTMLElement;\r\n        const contentPosition: DOMRect = childItem.getBoundingClientRect();\r\n\r\n        // Get Position with Scroll (Scrollbars inside page should be substracted)\r\n        const contentPositionTop = childItem.offsetTop + this.getOffsetTopParent(childItem.offsetParent as HTMLElement) - this.getScrollTopParent(childItem.parentElement);\r\n\r\n        switch (this.GetTooltipPosition()) {\r\n          case TooltipPosition.top:\r\n            this.TopPos = contentPositionTop - this.getToolTipHeight() + (this.getTooltipOffset() * -1);\r\n            return contentPositionTop - this.getToolTipHeight() + (this.getTooltipOffset() * -1);\r\n          case TooltipPosition.right:\r\n            this.TopPos = contentPositionTop + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);\r\n            return contentPositionTop + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);\r\n          case TooltipPosition.bottom:\r\n            this.TopPos = contentPositionTop + contentPosition.height + this.getTooltipOffset();\r\n            return contentPositionTop + contentPosition.height + this.getTooltipOffset();\r\n          case TooltipPosition.left:\r\n            this.TopPos = contentPositionTop + contentPosition.height / 2 - this.getToolTipHeight() / 2;\r\n            return (contentPositionTop + contentPosition.height / 2 - this.getToolTipHeight() / 2);\r\n        }\r\n\r\n        return (childItem.clientTop + childItem.offsetTop - (this.getToolTipHeight() / 2 - childItem.clientHeight / 2));\r\n      } else {\r\n        return this.content.nativeElement.offsetTop;\r\n      }\r\n    } else {\r\n      return this.ref.nativeElement.offsetTop;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Calculates the top of the page inside all elements\r\n   * @param element HTML Element\r\n   * @returns summarized top value for absolute position\r\n   */\r\n  private getOffsetTopParent(element: HTMLElement): number {\r\n    if (!element.offsetParent) {\r\n      return element.offsetTop;\r\n    }\r\n\r\n    const parentValue = this.getOffsetTopParent(element.offsetParent as HTMLElement);\r\n    let offset = element.offsetTop;\r\n    return parentValue + offset;\r\n  }\r\n\r\n  /**\r\n   * Caclulate Scrollbars inside tree\r\n   * @param element HTML Element\r\n   * @returns Scroll top value of element with all childs\r\n   */\r\n  private getScrollTopParent(element: HTMLElement): number {\r\n    // Body Scroll should not be calculated\r\n    if (!element.parentElement) {\r\n      return 0;\r\n    }\r\n\r\n    const parentValue = this.getScrollTopParent(element.parentElement);\r\n    return parentValue + element.scrollTop;\r\n  }\r\n\r\n\r\n  // #endregion Private Methods\r\n}\r\n"]}
242
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"tooltip.js","sourceRoot":"C:/Projekte/simpleangularcontrols-ng10/ch.jnetwork.sac-controls/projects/sac-common/src/","sources":["controls/tooltip/tooltip.ts"],"names":[],"mappings":"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","sourcesContent":["import { convertToBoolean } from '../../utilities/convertion';\r\nimport { TooltipPosition } from '../../utilities/enums';\r\nimport { PopUpHelper } from '../../utilities/popuphelper';\r\nimport {\r\n    AfterViewChecked,\r\n    ChangeDetectorRef,\r\n    Directive,\r\n    DoCheck,\r\n    ElementRef,\r\n    Input,\r\n    OnDestroy,\r\n    OnInit,\r\n    ViewChild,\r\n} from '@angular/core';\r\n\r\n/**\r\n * Tooltip Component\r\n *\r\n * Requires the following identifiers in the HTML markup\r\n * - container: Container for ng-content in which the element is displayed where the tooltip is attached.\r\n * - tooltip: Container for tooltip\r\n *\r\n * Tooltip must be displayed in 2 steps. In a first step the tooltip markup is created with (ngIf). In a 2nd step\r\n * the tooltip can then be displayed via the CSS visibility. If this is not done, it can lead to a flickering effect in certain browsers.\r\n *\r\n */\r\n@Directive()\r\nexport abstract class SacTooltipCommon implements OnInit, OnDestroy, AfterViewChecked, DoCheck {\r\n    // #region Properties\r\n\r\n    /**\r\n     * Helper class to display tooltip on correct position\r\n     */\r\n    private readonly popupHelper: PopUpHelper = new PopUpHelper();\r\n\r\n    /**\r\n     * Inline mode for tooltip\r\n     */\r\n    private _inlinemode: boolean;\r\n\r\n    /**\r\n     * Defines whether the tooltip is visible\r\n     */\r\n    private _isTooltipVisible: boolean = false;\r\n\r\n    /**\r\n     * Containers for the tooltip\r\n     */\r\n    private tooltipcontainer: ElementRef<HTMLElement>;\r\n\r\n    /**\r\n     * Position of the tooltip on the left\r\n     */\r\n    public IsTooltipContentVisible: boolean = false;\r\n\r\n    /**\r\n     * Position des Tooltips links\r\n     */\r\n    public LeftPos: number = 0;\r\n\r\n    /**\r\n     * Property for enum in Angular HTML template\r\n     */\r\n    public TooltipPosition = TooltipPosition;\r\n\r\n    /**\r\n     * Position of the tooltip at the top\r\n     */\r\n    public TopPos: number = 0;\r\n\r\n    /**\r\n     * Name of the container for content (e.g. icon) on which the tooltip is displayed.\r\n     */\r\n    @ViewChild('container', { static: true })\r\n    public content: ElementRef<HTMLElement>;\r\n\r\n    /**\r\n     * Position of the picker arrow at the left\r\n     */\r\n    public posArrowLeft: number | null = null;\r\n\r\n    /**\r\n     * Position of the picker arrow at the top\r\n     */\r\n    public posArrowTop: number | null = null;\r\n\r\n    /**\r\n     * Position of the tooltip. Values: left|top|right|bottom|auto\r\n     *\r\n     * Value 'auto' can be combined with another value.\r\n     */\r\n    @Input()\r\n    public position: string = 'right|auto';\r\n\r\n    /**\r\n     * Text for ToolTip\r\n     */\r\n    @Input()\r\n    public tooltiptext: string;\r\n\r\n    // #endregion Properties\r\n\r\n    // #region Constructors\r\n\r\n    /**\r\n     * Konstruktor\r\n     * @param ref Element Referenz\r\n     */\r\n    constructor(private readonly cdRef: ChangeDetectorRef, private readonly ref: ElementRef) {}\r\n\r\n    // #endregion Constructors\r\n\r\n    // #region Public Getters And Setters\r\n\r\n    /**\r\n     * Property for inline mode for tooltip. Sets the display mode on the wrapper element to `inline`\r\n     */\r\n    public get inlinemode(): boolean {\r\n        return this._inlinemode;\r\n    }\r\n\r\n    /**\r\n     * Setter for inline mode for tooltip\r\n     */\r\n    @Input()\r\n    public set inlinemode(value: boolean) {\r\n        this._inlinemode = convertToBoolean(value);\r\n    }\r\n\r\n    /**\r\n     * Setter for the name of the container for the tooltip. Is required as the tooltip can be hidden via ngIf.\r\n     */\r\n    @ViewChild('tooltip', { static: false })\r\n    public set tooltip(content: ElementRef) {\r\n        if (content !== undefined) {\r\n            document.body.appendChild(content.nativeElement);\r\n        }\r\n\r\n        this.tooltipcontainer = content;\r\n        this.onContentChange();\r\n        this.cdRef.detectChanges();\r\n    }\r\n\r\n    public get tooltop(): ElementRef {\r\n        return this.tooltipcontainer;\r\n    }\r\n\r\n    // #endregion Public Getters And Setters\r\n\r\n    // #region Public Methods\r\n\r\n    /**\r\n     * Returns the position of the tooltip\r\n     */\r\n    public GetTooltipPosition(): TooltipPosition {\r\n        return this.popupHelper.getDisplayPosition(\r\n            this.content,\r\n            this.tooltipcontainer,\r\n            this.getTooltipOffset(),\r\n            this.getTooltipOffset(),\r\n            this.position,\r\n            true\r\n        );\r\n    }\r\n\r\n    /**\r\n     * Hide tooltip\r\n     */\r\n    public HideTooltip(): void {\r\n        this._isTooltipVisible = false;\r\n        this.IsTooltipContentVisible = false;\r\n    }\r\n\r\n    /**\r\n     * Defines whether the tooltip is present in the markup\r\n     */\r\n    public IsTooltipVisible(): boolean {\r\n        return this._isTooltipVisible;\r\n    }\r\n\r\n    /**\r\n     * Show tooltip\r\n     */\r\n    public ShowTooltip(): void {\r\n        this._isTooltipVisible = true;\r\n        this.cdRef.detectChanges();\r\n\r\n        setTimeout(() => {\r\n            this.getLeftPosition();\r\n            this.getTopPosition();\r\n            this.IsTooltipContentVisible = true;\r\n        });\r\n    }\r\n\r\n    /**\r\n     * Calculates the height of the tooltip\r\n     */\r\n    public getToolTipHeight(): number {\r\n        return this.popupHelper.getPopupHeight(this.tooltipcontainer);\r\n    }\r\n\r\n    /**\r\n     * Calculates the width of the tooltips\r\n     */\r\n    public getToolTipWidth(): number {\r\n        return this.popupHelper.getPopupWidth(this.tooltipcontainer);\r\n    }\r\n\r\n    /**\r\n     * Detect Changes after view checked. Prevent ExpressionChangedAfterItHasBeenCheckedError error\r\n     */\r\n    public ngAfterViewChecked(): void {\r\n        // Do nothing if is not visibile\r\n        if (!this._isTooltipVisible) {\r\n            return;\r\n        }\r\n\r\n        this.cdRef.detectChanges();\r\n    }\r\n\r\n    /**\r\n     * Detect UI Changes to Calculate Tooltip correct\r\n     */\r\n    public ngDoCheck(): void {\r\n        // Do nothing if is not visibile\r\n        if (!this._isTooltipVisible) {\r\n            return;\r\n        }\r\n\r\n        this.getLeftPosition();\r\n        this.getTopPosition();\r\n    }\r\n\r\n    /**\r\n     * Event when the control is destroyed.\r\n     */\r\n    public ngOnDestroy() {\r\n        // Unregister Event Listener\r\n        window.removeEventListener('scroll', this.onContentChange, true);\r\n        window.removeEventListener('resize', this.onContentChange, true);\r\n\r\n        if (this.tooltipcontainer !== undefined) {\r\n            document.body.removeChild(this.tooltipcontainer.nativeElement);\r\n        }\r\n    }\r\n\r\n    /**\r\n     * Event when the control is initialized\r\n     */\r\n    public ngOnInit() {\r\n        // Register Event Listener\r\n        window.addEventListener('scroll', this.onContentChange, true);\r\n        window.addEventListener('resize', this.onContentChange, true);\r\n\r\n        if (this.tooltipcontainer !== undefined) {\r\n            document.body.appendChild(this.tooltipcontainer.nativeElement);\r\n        }\r\n    }\r\n\r\n    // #endregion Public Methods\r\n\r\n    // #region Protected Methods\r\n\r\n    /**\r\n     * Offset for Tooltip. Required for BS4/BS5 to create padding\r\n     */\r\n    protected abstract getTooltipOffset(): number;\r\n\r\n    // #endregion Protected Methods\r\n\r\n    // #region Private Methods\r\n\r\n    /**\r\n     * Calculates the position of the tooltip from links\r\n     */\r\n    private getLeftPosition(): number {\r\n        const value = this.popupHelper.getPositionLeft(\r\n            this.content,\r\n            this.tooltipcontainer,\r\n            this.ref,\r\n            this.getTooltipOffset(),\r\n            this.getTooltipOffset(),\r\n            this.position,\r\n            true\r\n        );\r\n        this.LeftPos = value;\r\n\r\n        const requiredPosition = this.GetTooltipPosition();\r\n        if (requiredPosition === TooltipPosition.left || requiredPosition === TooltipPosition.right) {\r\n            this.posArrowTop = this.getToolTipHeight() / 2 - 6.5;\r\n        } else {\r\n            this.posArrowTop = null;\r\n        }\r\n\r\n        return value;\r\n    }\r\n\r\n    /**\r\n     * Calculates the position of the tooltip from the top\r\n     */\r\n    private getTopPosition(): number {\r\n        const value = this.popupHelper.getPositionTop(\r\n            this.content,\r\n            this.tooltipcontainer,\r\n            this.ref,\r\n            this.getTooltipOffset(),\r\n            this.getTooltipOffset(),\r\n            this.position,\r\n            true\r\n        );\r\n        this.TopPos = value;\r\n\r\n        const requiredPosition = this.GetTooltipPosition();\r\n        if (requiredPosition === TooltipPosition.bottom || requiredPosition === TooltipPosition.top) {\r\n            this.posArrowLeft = this.getToolTipWidth() / 2 - 6.5;\r\n        } else {\r\n            this.posArrowLeft = null;\r\n        }\r\n\r\n        return value;\r\n    }\r\n\r\n    /**\r\n     * method if content has changed and proportions need to be reset in the UI.\r\n     */\r\n    private readonly onContentChange = (): void => {\r\n        // Do nothing if is not visible\r\n        if (!this._isTooltipVisible) {\r\n            return;\r\n        }\r\n\r\n        setTimeout(() => {\r\n            this.getLeftPosition();\r\n            this.getTopPosition();\r\n        });\r\n    };\r\n\r\n    // #endregion Private Methods\r\n}\r\n"]}