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

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 (64) hide show
  1. package/bundles/simpleangularcontrols-sac-common.umd.js +696 -412
  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 +1 -1
  6. package/common/baseinputcontrol.d.ts +0 -4
  7. package/common/basemodelcontrol.d.ts +25 -1
  8. package/common/baseuploadcontrol.d.ts +0 -5
  9. package/controls/checkbox/checkbox.d.ts +12 -3
  10. package/controls/datetime/date.d.ts +0 -4
  11. package/controls/datetime/datetime.d.ts +0 -4
  12. package/controls/datetime/time.d.ts +0 -4
  13. package/controls/grid/grid.d.ts +38 -36
  14. package/controls/grid/gridbutton.d.ts +13 -13
  15. package/controls/grid/gridcolumn.d.ts +8 -8
  16. package/controls/grid/gridcolumnaction.d.ts +3 -3
  17. package/controls/grid/gridcolumnbase.d.ts +45 -37
  18. package/controls/grid/gridimage.d.ts +2 -2
  19. package/controls/grid/model.d.ts +51 -42
  20. package/controls/grid/paging.d.ts +41 -43
  21. package/controls/input/inputsearch.d.ts +13 -4
  22. package/controls/layout/formlayout.d.ts +13 -1
  23. package/controls/static/formcontainer.d.ts +2 -6
  24. package/controls/tooltip/tooltip.d.ts +88 -63
  25. package/esm2015/common/basedatetimecontrol.js +1 -1
  26. package/esm2015/common/baseinputcontrol.js +2 -7
  27. package/esm2015/common/basemodelcontrol.js +44 -7
  28. package/esm2015/common/baseuploadcontrol.js +2 -3
  29. package/esm2015/controls/checkbox/checkbox.js +29 -6
  30. package/esm2015/controls/datetime/date.js +2 -3
  31. package/esm2015/controls/datetime/datetime.js +2 -3
  32. package/esm2015/controls/datetime/time.js +2 -3
  33. package/esm2015/controls/grid/grid.js +21 -21
  34. package/esm2015/controls/grid/gridbutton.js +19 -13
  35. package/esm2015/controls/grid/gridcolumn.js +14 -7
  36. package/esm2015/controls/grid/gridcolumnaction.js +6 -5
  37. package/esm2015/controls/grid/gridcolumnbase.js +67 -55
  38. package/esm2015/controls/grid/gridimage.js +3 -3
  39. package/esm2015/controls/grid/model.js +51 -30
  40. package/esm2015/controls/grid/paging.js +40 -42
  41. package/esm2015/controls/input/inputsearch.js +35 -6
  42. package/esm2015/controls/layout/formlayout.js +14 -3
  43. package/esm2015/controls/static/formcontainer.js +11 -10
  44. package/esm2015/controls/tooltip/tooltip.js +260 -189
  45. package/esm2015/interfaces/ISacConfigurationService.js +1 -1
  46. package/esm2015/interfaces/ISacIconService.js +1 -1
  47. package/esm2015/public_api.js +10 -3
  48. package/esm2015/services/sac-configuration.service.js +25 -1
  49. package/esm2015/services/sac-icon.service.js +13 -1
  50. package/esm2015/simpleangularcontrols-sac-common.js +1 -7
  51. package/esm2015/utilities/guid.js +4 -2
  52. package/esm2015/validation/isDateValid.js +9 -1
  53. package/fesm2015/simpleangularcontrols-sac-common.js +652 -395
  54. package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
  55. package/interfaces/ISacConfigurationService.d.ts +16 -0
  56. package/interfaces/ISacIconService.d.ts +8 -0
  57. package/package.json +4 -4
  58. package/public_api.d.ts +7 -1
  59. package/services/sac-configuration.service.d.ts +32 -0
  60. package/services/sac-icon.service.d.ts +16 -0
  61. package/simpleangularcontrols-sac-common-10.0.0-rc.11.tgz +0 -0
  62. package/simpleangularcontrols-sac-common.d.ts +0 -6
  63. package/simpleangularcontrols-sac-common.metadata.json +1 -1
  64. package/simpleangularcontrols-sac-common-10.0.0-rc.1.tgz +0 -0
@@ -1,18 +1,20 @@
1
- import { ChangeDetectorRef, Directive, ElementRef, Input, ViewChild } from '@angular/core';
1
+ import { ChangeDetectorRef, Directive, ElementRef, Input, ViewChild, } from '@angular/core';
2
2
  import { convertToBoolean } from '../../utilities/convertion';
3
3
  import { TooltipPosition } from '../../utilities/enums';
4
4
  /**
5
5
  * Tooltip Component
6
6
  *
7
- * Benötigt im HTML Markup folgende Identifier
8
- * - container: Container für ng-content in welchem das Element angezeigt wird, wo der Tooltip angehängt wird.
9
- * - tooltip: Container für Tooltip
7
+ * Requires the following identifiers in the HTML markup
8
+ * - container: Container for ng-content in which the element is displayed where the tooltip is attached.
9
+ * - tooltip: Container for tooltip
10
10
  *
11
- * Tooltip muss in 2 Schritten angezeigt werden. In einem ersten Schritt wird der Tooltip Markup erzeugt mit (ngIf). In einem 2. Schritt
12
- * kann der Tooltip dann über die CSS visibility angezeigt werden. Wird dies nicht so gemacht, kann es bei gewissen Browsern zu einem Flacker Effekt führen.
11
+ * Tooltip must be displayed in 2 steps. In a first step the tooltip markup is created with (ngIf). In a 2nd step
12
+ * 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.
13
13
  *
14
14
  */
15
15
  export class SacTooltipCommon {
16
+ // #endregion Properties
17
+ // #region Constructors
16
18
  /**
17
19
  * Konstruktor
18
20
  * @param ref Element Referenz
@@ -21,55 +23,55 @@ export class SacTooltipCommon {
21
23
  this.cdRef = cdRef;
22
24
  this.ref = ref;
23
25
  /**
24
- * Property für Enum in Angular HTML Template
25
- */
26
- this.TooltipPosition = TooltipPosition;
27
- /**
28
- * Definiert ob der Tooltip sichtbar ist
26
+ * Defines whether the tooltip is visible
29
27
  */
30
28
  this._isTooltipVisible = false;
31
29
  /**
32
- * Position des Tooltips oben
30
+ * method if content has changed and proportions need to be reset in the UI.
33
31
  */
34
- this.TopPos = 0;
35
- /**
36
- * Position des Tooltips links
37
- */
38
- this.LeftPos = 0;
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
+ };
39
42
  /**
40
- * Position des Tooltips. Werte: left|top|right|bottom|auto
43
+ * Position of the tooltip. Values: left|top|right|bottom|auto
41
44
  *
42
- * Wert 'auto' kann mit einem anderen Wert kombiniert werden.
45
+ * Value 'auto' can be combined with another value.
43
46
  */
44
47
  this.position = 'right|auto';
45
48
  /**
46
- * Definiert ob der Tooltip sichtbar sein soll
49
+ * Position of the tooltip on the left
47
50
  */
48
51
  this.IsTooltipContentVisible = false;
49
52
  /**
50
- * Methode wenn Content geändert hat und Proporties im UI neu gesetzt werden müssen.
53
+ * Position des Tooltips links
51
54
  */
52
- this.onContentChange = () => {
53
- setTimeout(() => {
54
- this.getLeftPosition();
55
- this.getTopPosition();
56
- });
57
- };
55
+ this.LeftPos = 0;
56
+ /**
57
+ * Property for enum in Angular HTML template
58
+ */
59
+ this.TooltipPosition = TooltipPosition;
60
+ /**
61
+ * Position of the tooltip at the top
62
+ */
63
+ this.TopPos = 0;
58
64
  }
65
+ // #endregion Constructors
66
+ // #region Public Getters And Setters
59
67
  /**
60
- * Setter für Inline Mode für Tooltip
68
+ * Setter for inline mode for tooltip
61
69
  */
62
70
  set inlinemode(value) {
63
71
  this._inlinemode = convertToBoolean(value);
64
72
  }
65
73
  /**
66
- * Getter für Inline Mode für Tooltip
67
- */
68
- get inlinemode() {
69
- return this._inlinemode;
70
- }
71
- /**
72
- * Setter für Name des Containers für den Tooltip. Wird benötigt, da Tooltip via NGIF ausgeblendet werden kann.
74
+ * Setter for the name of the container for the tooltip. Is required as the tooltip can be hidden via ngIf.
73
75
  */
74
76
  set tooltip(content) {
75
77
  if (content !== undefined) {
@@ -80,158 +82,39 @@ export class SacTooltipCommon {
80
82
  this.cdRef.detectChanges();
81
83
  }
82
84
  /**
83
- * Ervent wenn das Control initialisert wird
84
- */
85
- ngOnInit() {
86
- // Register Event Listener
87
- window.addEventListener('scroll', this.onContentChange, true);
88
- window.addEventListener('resize', this.onContentChange, true);
89
- if (this.tooltipcontainer !== undefined) {
90
- document.body.appendChild(this.tooltipcontainer.nativeElement);
91
- }
92
- }
93
- /**
94
- * Event wenn das Control zerstört wird.
95
- */
96
- ngOnDestroy() {
97
- // Unregister Event Listener
98
- window.removeEventListener('scroll', this.onContentChange, true);
99
- window.removeEventListener('resize', this.onContentChange, true);
100
- if (this.tooltipcontainer !== undefined) {
101
- document.body.removeChild(this.tooltipcontainer.nativeElement);
102
- }
103
- }
104
- /**
105
- * Berechnet die Position des Tooltips von Oben
106
- */
107
- getTopPosition() {
108
- if (this.content !== null && this.content !== undefined) {
109
- const item = this.content.nativeElement;
110
- if (item.children.length >= 1) {
111
- const childItem = item.firstElementChild;
112
- const contentPosition = childItem.getBoundingClientRect();
113
- switch (this.GetTooltipPosition()) {
114
- case TooltipPosition.top:
115
- this.TopPos = contentPosition.top - this.getToolTipHeight();
116
- return contentPosition.top - this.getToolTipHeight();
117
- case TooltipPosition.right:
118
- this.TopPos = contentPosition.top + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);
119
- return contentPosition.top + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);
120
- case TooltipPosition.bottom:
121
- this.TopPos = contentPosition.top + contentPosition.height;
122
- return contentPosition.top + contentPosition.height;
123
- case TooltipPosition.left:
124
- this.TopPos = contentPosition.top + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);
125
- return contentPosition.top + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);
126
- }
127
- return childItem.clientTop + childItem.offsetTop - ((this.getToolTipHeight() / 2) - (childItem.clientHeight / 2));
128
- }
129
- else {
130
- return this.content.nativeElement.offsetTop;
131
- }
132
- }
133
- else {
134
- return this.ref.nativeElement.offsetTop;
135
- }
136
- }
137
- /**
138
- * Berechnet die Position des Tooltips von Links
139
- */
140
- getLeftPosition() {
141
- if (this.content !== null && this.content !== undefined) {
142
- const item = this.content.nativeElement;
143
- if (item.children.length >= 1) {
144
- const childItem = item.firstElementChild;
145
- const contentPosition = childItem.getBoundingClientRect();
146
- switch (this.GetTooltipPosition()) {
147
- case TooltipPosition.top:
148
- this.LeftPos = contentPosition.left + (contentPosition.width / 2) - (this.getToolTipWidth() / 2);
149
- return contentPosition.left + (contentPosition.width / 2) - (this.getToolTipWidth() / 2);
150
- case TooltipPosition.right:
151
- this.LeftPos = contentPosition.left + contentPosition.width;
152
- return contentPosition.left + contentPosition.width;
153
- case TooltipPosition.bottom:
154
- this.LeftPos = contentPosition.left + (childItem.clientWidth / 2) - (this.getToolTipWidth() / 2);
155
- return contentPosition.left + (childItem.clientWidth / 2) - (this.getToolTipWidth() / 2);
156
- case TooltipPosition.left:
157
- this.LeftPos = contentPosition.left - this.getToolTipWidth();
158
- return contentPosition.left - this.getToolTipWidth();
159
- }
160
- return this.content.nativeElement.offsetTop;
161
- }
162
- else {
163
- return this.content.nativeElement.offsetTop;
164
- }
165
- }
166
- else {
167
- return this.ref.nativeElement.offsetLeft;
168
- }
169
- }
170
- /**
171
- * Berechnet die Höhe des Tooltips
172
- */
173
- getToolTipHeight() {
174
- if (this.tooltipcontainer) {
175
- return this.tooltipcontainer.nativeElement.clientHeight;
176
- }
177
- else {
178
- return 0;
179
- }
180
- }
181
- /**
182
- * Berechnet die Breite die Tooltips
183
- */
184
- getToolTipWidth() {
185
- if (this.tooltipcontainer) {
186
- return this.tooltipcontainer.nativeElement.clientWidth;
187
- }
188
- else {
189
- return 0;
190
- }
191
- }
192
- /**
193
- * Definiert ob der Tooltip im Markup vorhanden ist
85
+ * Property for inline mode for tooltip. Sets the display mode on the wrapper element to `inline`
194
86
  */
195
- IsTooltipVisible() {
196
- return this._isTooltipVisible;
87
+ get inlinemode() {
88
+ return this._inlinemode;
197
89
  }
198
- /**
199
- * Tooltip anzeigen
200
- */
201
- ShowTooltip() {
202
- this._isTooltipVisible = true;
203
- setTimeout(() => {
204
- this.getLeftPosition();
205
- this.getTopPosition();
206
- this.IsTooltipContentVisible = true;
207
- });
90
+ get tooltop() {
91
+ return this.tooltipcontainer;
208
92
  }
93
+ // #endregion Public Getters And Setters
94
+ // #region Public Methods
209
95
  /**
210
- * Tooltip ausblenden
211
- */
212
- HideTooltip() {
213
- this._isTooltipVisible = false;
214
- this.IsTooltipContentVisible = false;
215
- }
216
- /**
217
- * Gibt die Position des Tooltips zurück
96
+ * Returns the position of the tooltip
218
97
  */
219
98
  GetTooltipPosition() {
220
99
  const validPositions = this.ValidatePositions();
221
100
  // tslint:disable-next-line:no-bitwise
222
- if (this.HasPosition(TooltipPosition.right) && (validPositions & TooltipPosition.right)) {
101
+ if (this.HasPosition(TooltipPosition.right) &&
102
+ validPositions & TooltipPosition.right) {
223
103
  return TooltipPosition.right;
224
104
  }
225
105
  // tslint:disable-next-line:no-bitwise
226
- if (this.HasPosition(TooltipPosition.top) && (validPositions & TooltipPosition.top)) {
106
+ if (this.HasPosition(TooltipPosition.top) &&
107
+ validPositions & TooltipPosition.top) {
227
108
  return TooltipPosition.top;
228
109
  }
229
110
  // tslint:disable-next-line:no-bitwise
230
- if (this.HasPosition(TooltipPosition.left) && (validPositions & TooltipPosition.left)) {
111
+ if (this.HasPosition(TooltipPosition.left) &&
112
+ validPositions & TooltipPosition.left) {
231
113
  return TooltipPosition.left;
232
114
  }
233
115
  // tslint:disable-next-line:no-bitwise
234
- if (this.HasPosition(TooltipPosition.bottom) && (validPositions & TooltipPosition.bottom)) {
116
+ if (this.HasPosition(TooltipPosition.bottom) &&
117
+ validPositions & TooltipPosition.bottom) {
235
118
  return TooltipPosition.bottom;
236
119
  }
237
120
  // Get Auto Position or Default
@@ -259,14 +142,100 @@ export class SacTooltipCommon {
259
142
  }
260
143
  }
261
144
  /**
262
- * Definiert ob AutoPosition aktiv ist
145
+ * Hide tooltip
263
146
  */
264
- IsAutoPosition() {
265
- const positions = this.position.split('|');
266
- return positions.indexOf('auto') >= 0;
147
+ HideTooltip() {
148
+ this._isTooltipVisible = false;
149
+ this.IsTooltipContentVisible = false;
150
+ }
151
+ /**
152
+ * Defines whether the tooltip is present in the markup
153
+ */
154
+ IsTooltipVisible() {
155
+ return this._isTooltipVisible;
156
+ }
157
+ /**
158
+ * Show tooltip
159
+ */
160
+ ShowTooltip() {
161
+ this._isTooltipVisible = true;
162
+ this.cdRef.detectChanges();
163
+ setTimeout(() => {
164
+ this.getLeftPosition();
165
+ this.getTopPosition();
166
+ this.IsTooltipContentVisible = true;
167
+ });
168
+ }
169
+ /**
170
+ * Calculates the height of the tooltip
171
+ */
172
+ 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
+ }
180
+ }
181
+ /**
182
+ * Calculates the width of the tooltips
183
+ */
184
+ getToolTipWidth() {
185
+ if (this.tooltipcontainer) {
186
+ return this.tooltipcontainer.nativeElement.firstElementChild.clientWidth;
187
+ }
188
+ else {
189
+ return 0;
190
+ }
191
+ }
192
+ /**
193
+ * Detect Changes after view checked. Prevent ExpressionChangedAfterItHasBeenCheckedError error
194
+ */
195
+ ngAfterViewChecked() {
196
+ // Do nothing if is not visibile
197
+ if (!this._isTooltipVisible) {
198
+ return;
199
+ }
200
+ this.cdRef.detectChanges();
201
+ }
202
+ /**
203
+ * Detect UI Changes to Calculate Tooltip correct
204
+ */
205
+ ngDoCheck() {
206
+ // Do nothing if is not visibile
207
+ if (!this._isTooltipVisible) {
208
+ return;
209
+ }
210
+ this.getLeftPosition();
211
+ this.getTopPosition();
267
212
  }
268
213
  /**
269
- * Gibt die definierte Position für den Tooltip zurück
214
+ * Event when the control is destroyed.
215
+ */
216
+ ngOnDestroy() {
217
+ // Unregister Event Listener
218
+ window.removeEventListener('scroll', this.onContentChange, true);
219
+ window.removeEventListener('resize', this.onContentChange, true);
220
+ if (this.tooltipcontainer !== undefined) {
221
+ document.body.removeChild(this.tooltipcontainer.nativeElement);
222
+ }
223
+ }
224
+ /**
225
+ * Event when the control is initialized
226
+ */
227
+ ngOnInit() {
228
+ // Register Event Listener
229
+ window.addEventListener('scroll', this.onContentChange, true);
230
+ window.addEventListener('resize', this.onContentChange, true);
231
+ if (this.tooltipcontainer !== undefined) {
232
+ document.body.appendChild(this.tooltipcontainer.nativeElement);
233
+ }
234
+ }
235
+ // #endregion Protected Abstract Methods
236
+ // #region Private Methods
237
+ /**
238
+ * Returns the defined position for the tooltip
270
239
  */
271
240
  GetPosition() {
272
241
  const positions = this.position.split('|');
@@ -286,9 +255,9 @@ export class SacTooltipCommon {
286
255
  return TooltipPosition.right;
287
256
  }
288
257
  /**
289
- * Gibt zurück, ob die Position konfiguriert wurde
258
+ * Returns whether the position has been configured
290
259
  *
291
- * @param position Position auf welche geprüft wird
260
+ * @param position Position to be checked
292
261
  */
293
262
  HasPosition(position) {
294
263
  const positions = this.position.split('|');
@@ -301,13 +270,21 @@ export class SacTooltipCommon {
301
270
  if (position === TooltipPosition.left && positions.indexOf('left') >= 0) {
302
271
  return true;
303
272
  }
304
- if (position === TooltipPosition.bottom && positions.indexOf('bottom') >= 0) {
273
+ if (position === TooltipPosition.bottom &&
274
+ positions.indexOf('bottom') >= 0) {
305
275
  return true;
306
276
  }
307
277
  return false;
308
278
  }
309
279
  /**
310
- * Prüft ob die Position gültig ist, resp. der Tooltip auf die Position platz hat
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
311
288
  */
312
289
  ValidatePositions() {
313
290
  // Check if Container is false
@@ -316,15 +293,15 @@ export class SacTooltipCommon {
316
293
  }
317
294
  let allowedPositions = TooltipPosition.none;
318
295
  const basePosition = this.content.nativeElement.firstElementChild.getBoundingClientRect();
319
- const tooltipRect = this.tooltipcontainer.nativeElement.getBoundingClientRect();
320
- const leftPosOk = basePosition.left - tooltipRect.width > 0;
321
- const rightPosOk = basePosition.right + tooltipRect.width < window.innerWidth;
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;
322
299
  const topPosOk = basePosition.top - tooltipRect.height > 0;
323
300
  const bottomPosOk = basePosition.bottom + tooltipRect.height < window.innerHeight;
324
- const leftHalfPosOk = basePosition.left - (tooltipRect.width / 2) > 0;
325
- const rightHalfPosOk = basePosition.right + (tooltipRect.width / 2) < window.innerWidth;
326
- const topHalfPosOk = basePosition.top - (tooltipRect.height / 2) > 0;
327
- const bottomHalfPosOk = basePosition.bottom + (tooltipRect.height / 2) < 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;
328
305
  if (leftPosOk && topHalfPosOk && bottomHalfPosOk) {
329
306
  // tslint:disable-next-line:no-bitwise
330
307
  allowedPositions = allowedPositions | TooltipPosition.left;
@@ -343,6 +320,100 @@ export class SacTooltipCommon {
343
320
  }
344
321
  return allowedPositions;
345
322
  }
323
+ /**
324
+ * Calculates the position of the tooltip from links
325
+ */
326
+ 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
+ }
351
+ }
352
+ else {
353
+ return this.ref.nativeElement.offsetLeft;
354
+ }
355
+ }
356
+ /**
357
+ * Calculates the position of the tooltip from the top
358
+ */
359
+ 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
+ }
386
+ }
387
+ 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;
399
+ }
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;
416
+ }
346
417
  }
347
418
  SacTooltipCommon.decorators = [
348
419
  { type: Directive }
@@ -354,8 +425,8 @@ SacTooltipCommon.ctorParameters = () => [
354
425
  SacTooltipCommon.propDecorators = {
355
426
  position: [{ type: Input }],
356
427
  tooltiptext: [{ type: Input }],
357
- inlinemode: [{ type: Input }],
358
428
  content: [{ type: ViewChild, args: ['container', { static: true },] }],
359
- tooltip: [{ type: ViewChild, args: ['tooltip', { static: true },] }]
429
+ inlinemode: [{ type: Input }],
430
+ tooltip: [{ type: ViewChild, args: ['tooltip', { static: false },] }]
360
431
  };
361
- //# 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 { ChangeDetectorRef, Directive, ElementRef, Input, OnDestroy, OnInit, ViewChild } 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 * Benötigt im HTML Markup folgende Identifier\r\n * - container: Container für ng-content in welchem das Element angezeigt wird, wo der Tooltip angehängt wird.\r\n * - tooltip: Container für Tooltip\r\n *\r\n * Tooltip muss in 2 Schritten angezeigt werden. In einem ersten Schritt wird der Tooltip Markup erzeugt mit (ngIf). In einem 2. Schritt\r\n * kann der Tooltip dann über die CSS visibility angezeigt werden. Wird dies nicht so gemacht, kann es bei gewissen Browsern zu einem Flacker Effekt führen.\r\n *\r\n */\r\n@Directive()\r\nexport class SacTooltipCommon implements OnInit, OnDestroy {\r\n  /**\r\n   * Property für Enum in Angular HTML Template\r\n   */\r\n  TooltipPosition = TooltipPosition;\r\n\r\n  /**\r\n   * Definiert ob der Tooltip sichtbar ist\r\n   */\r\n  private _isTooltipVisible: boolean = false;\r\n\r\n  /**\r\n   * Position des Tooltips oben\r\n   */\r\n  TopPos: number = 0;\r\n\r\n  /**\r\n   * Position des Tooltips links\r\n   */\r\n  LeftPos: number = 0;\r\n\r\n  /**\r\n   * Position des Tooltips. Werte: left|top|right|bottom|auto\r\n   *\r\n   * Wert 'auto' kann mit einem anderen Wert kombiniert werden.\r\n   */\r\n  @Input()\r\n  position: string = 'right|auto';\r\n\r\n  /**\r\n   * Text für ToolTip\r\n   */\r\n  @Input()\r\n  tooltiptext: string;\r\n\r\n  /**\r\n   * Inline Mode für Tooltip\r\n   */\r\n  private _inlinemode: boolean;\r\n\r\n  /**\r\n   * Definiert ob der Tooltip sichtbar sein soll\r\n   */\r\n  IsTooltipContentVisible: boolean = false;\r\n\r\n  /**\r\n   * Setter für Inline Mode für Tooltip\r\n   */\r\n  @Input()\r\n  set inlinemode(value: boolean) {\r\n    this._inlinemode = convertToBoolean(value);\r\n  }\r\n  /**\r\n   * Getter für Inline Mode für Tooltip\r\n   */\r\n  get inlinemode(): boolean {\r\n    return this._inlinemode;\r\n  }\r\n\r\n  /**\r\n   * Name des Containers für Content (z.B. Icon) auf welchem der Tooltip angezeigt wird.\r\n   */\r\n  @ViewChild('container', { static: true }) content: ElementRef<HTMLElement>;\r\n\r\n  /**\r\n   * Name des Containers für den Tooltip\r\n   */\r\n  private tooltipcontainer: ElementRef<HTMLElement>;\r\n\r\n  /**\r\n   * Setter für Name des Containers für den Tooltip. Wird benötigt, da Tooltip via NGIF ausgeblendet werden kann.\r\n   */\r\n  @ViewChild('tooltip', { static: true })\r\n  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   * Konstruktor\r\n   * @param ref Element Referenz\r\n   */\r\n  constructor(private cdRef: ChangeDetectorRef, private ref: ElementRef) { }\r\n\r\n  /**\r\n   * Ervent wenn das Control initialisert wird\r\n   */\r\n  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  /**\r\n   * Event wenn das Control zerstört wird.\r\n   */\r\n  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   * Berechnet die Position des Tooltips von Oben\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: ClientRect = childItem.getBoundingClientRect();\r\n\r\n        switch (this.GetTooltipPosition()) {\r\n          case TooltipPosition.top:\r\n            this.TopPos = contentPosition.top - this.getToolTipHeight();\r\n            return contentPosition.top - this.getToolTipHeight();\r\n          case TooltipPosition.right:\r\n            this.TopPos = contentPosition.top + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);\r\n            return contentPosition.top + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);\r\n          case TooltipPosition.bottom:\r\n            this.TopPos = contentPosition.top + contentPosition.height;\r\n            return contentPosition.top + contentPosition.height;\r\n          case TooltipPosition.left:\r\n            this.TopPos = contentPosition.top + (contentPosition.height / 2) - (this.getToolTipHeight() / 2);\r\n            return contentPosition.top + (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  /**\r\n   * Berechnet die Position des Tooltips von Links\r\n   */\r\n  private getLeftPosition(): number {\r\n\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: ClientRect = 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          case TooltipPosition.right:\r\n            this.LeftPos = contentPosition.left + contentPosition.width;\r\n            return contentPosition.left + contentPosition.width;\r\n          case TooltipPosition.bottom:\r\n            this.LeftPos = contentPosition.left + (childItem.clientWidth / 2) - (this.getToolTipWidth() / 2);\r\n            return contentPosition.left + (childItem.clientWidth / 2) - (this.getToolTipWidth() / 2);\r\n          case TooltipPosition.left:\r\n            this.LeftPos = contentPosition.left - this.getToolTipWidth();\r\n            return contentPosition.left - this.getToolTipWidth();\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  /**\r\n   * Berechnet die Höhe des Tooltips\r\n   */\r\n  private getToolTipHeight(): number {\r\n    if (this.tooltipcontainer) {\r\n      return this.tooltipcontainer.nativeElement.clientHeight;\r\n    } else {\r\n      return 0;\r\n    }\r\n  }\r\n\r\n  /**\r\n   * Berechnet die Breite die Tooltips\r\n   */\r\n  private getToolTipWidth(): number {\r\n    if (this.tooltipcontainer) {\r\n      return this.tooltipcontainer.nativeElement.clientWidth;\r\n    } else {\r\n      return 0;\r\n    }\r\n  }\r\n\r\n\r\n  /**\r\n   * Definiert ob der Tooltip im Markup vorhanden ist\r\n   */\r\n  IsTooltipVisible(): boolean {\r\n    return this._isTooltipVisible;\r\n  }\r\n\r\n  /**\r\n   * Tooltip anzeigen\r\n   */\r\n  ShowTooltip(): void {\r\n    this._isTooltipVisible = true;\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   * Tooltip ausblenden\r\n   */\r\n  HideTooltip(): void {\r\n    this._isTooltipVisible = false;\r\n    this.IsTooltipContentVisible = false;\r\n  }\r\n\r\n  /**\r\n   * Methode wenn Content geändert hat und Proporties im UI neu gesetzt werden müssen.\r\n   */\r\n  private onContentChange = (): void => {\r\n    setTimeout(() => {\r\n      this.getLeftPosition();\r\n      this.getTopPosition();\r\n    });\r\n  }\r\n\r\n  /**\r\n   * Gibt die Position des Tooltips zurück\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 (this.HasPosition(TooltipPosition.right) && (validPositions & TooltipPosition.right)) {\r\n      return TooltipPosition.right;\r\n    }\r\n\r\n    // tslint:disable-next-line:no-bitwise\r\n    if (this.HasPosition(TooltipPosition.top) && (validPositions & TooltipPosition.top)) {\r\n      return TooltipPosition.top;\r\n    }\r\n\r\n    // tslint:disable-next-line:no-bitwise\r\n    if (this.HasPosition(TooltipPosition.left) && (validPositions & TooltipPosition.left)) {\r\n      return TooltipPosition.left;\r\n    }\r\n\r\n    // tslint:disable-next-line:no-bitwise\r\n    if (this.HasPosition(TooltipPosition.bottom) && (validPositions & TooltipPosition.bottom)) {\r\n      return TooltipPosition.bottom;\r\n    }\r\n\r\n    // Get Auto Position or Default\r\n    if (this.IsAutoPosition()) {\r\n\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   * Definiert ob AutoPosition aktiv ist\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   * Gibt die definierte Position für den Tooltip zurück\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   * Gibt zurück, ob die Position konfiguriert wurde\r\n   *\r\n   * @param position Position auf welche geprüft wird\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 (position === TooltipPosition.bottom && positions.indexOf('bottom') >= 0) {\r\n      return true;\r\n    }\r\n\r\n    return false;\r\n  }\r\n\r\n  /**\r\n   * Prüft ob die Position gültig ist, resp. der Tooltip auf die Position platz hat\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: ClientRect = this.content.nativeElement.firstElementChild.getBoundingClientRect();\r\n    const tooltipRect: ClientRect = this.tooltipcontainer.nativeElement.getBoundingClientRect();\r\n\r\n    const leftPosOk: boolean = basePosition.left - tooltipRect.width > 0;\r\n    const rightPosOk: boolean = basePosition.right + tooltipRect.width < 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"]}
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":"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","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"]}