@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.
- package/bundles/simpleangularcontrols-sac-common.umd.js +1425 -1088
- package/bundles/simpleangularcontrols-sac-common.umd.js.map +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js +1 -1
- package/bundles/simpleangularcontrols-sac-common.umd.min.js.map +1 -1
- package/common/basedatetimecontrol.d.ts +99 -13
- package/common/basemodelcontrol.d.ts +33 -29
- package/controls/checkbox/radiobutton.d.ts +61 -26
- package/controls/contextmenu/contextmenu.d.ts +26 -19
- package/controls/contextmenu/contextmenu.interface.d.ts +3 -0
- package/controls/contextmenu/contextmenuitem.d.ts +5 -0
- package/controls/contextmenu/contextmenuitembutton.d.ts +21 -20
- package/controls/datetime/date.d.ts +28 -27
- package/controls/datetime/datetime.d.ts +27 -27
- package/controls/datetime/time.d.ts +26 -26
- package/controls/dialog/dialog.d.ts +31 -43
- package/controls/layout/formlayout.d.ts +4 -0
- package/controls/list/buildvaluestring.d.ts +6 -0
- package/controls/list/dropdown.d.ts +9 -51
- package/controls/list/dropdownoptions.d.ts +38 -0
- package/controls/list/dropdownoptions.ngfactory.d.ts +1 -0
- package/controls/static/formcontainer.d.ts +11 -3
- package/controls/tooltip/tooltip.d.ts +33 -51
- package/controls/treeview/treeview.d.ts +87 -121
- package/esm2015/common/basedatetimecontrol.js +178 -30
- package/esm2015/common/basemodelcontrol.js +71 -56
- package/esm2015/controls/checkbox/radiobutton.js +94 -45
- package/esm2015/controls/contextmenu/contextmenu.interface.js +1 -0
- package/esm2015/controls/contextmenu/contextmenu.interface.ngfactory.js +7 -0
- package/esm2015/controls/contextmenu/contextmenu.js +22 -23
- package/esm2015/controls/contextmenu/contextmenuitem.js +13 -2
- package/esm2015/controls/contextmenu/contextmenuitembutton.js +34 -25
- package/esm2015/controls/datetime/date.js +43 -41
- package/esm2015/controls/datetime/datetime.js +42 -41
- package/esm2015/controls/datetime/time.js +42 -41
- package/esm2015/controls/dialog/dialog.js +41 -83
- package/esm2015/controls/layout/formlayout.js +7 -6
- package/esm2015/controls/list/buildvaluestring.js +18 -0
- package/esm2015/controls/{treeview/ngtreeitemaction.ngfactory.js → list/buildvaluestring.ngfactory.js} +1 -1
- package/esm2015/controls/list/dropdown.js +16 -114
- package/esm2015/controls/list/dropdownoptions.js +72 -0
- package/esm2015/controls/{treeview/treeviewchild.ngfactory.js → list/dropdownoptions.ngfactory.js} +1 -1
- package/esm2015/controls/static/formcontainer.js +16 -6
- package/esm2015/controls/tooltip/tooltip.js +60 -250
- package/esm2015/controls/treeview/treeview.js +232 -247
- package/esm2015/interfaces/ISacConfigurationService.js +1 -1
- package/esm2015/interfaces/ISacIconService.js +1 -1
- package/esm2015/interfaces/treeviewaction.interface.js +1 -0
- package/esm2015/interfaces/treeviewaction.interface.ngfactory.js +7 -0
- package/esm2015/public_api.js +6 -6
- package/esm2015/services/sac-configuration.service.js +7 -5
- package/esm2015/services/sac-icon.service.js +25 -1
- package/esm2015/utilities/enums.js +5 -1
- package/esm2015/utilities/popuphelper.js +343 -0
- package/esm2015/utilities/popuphelper.ngfactory.js +7 -0
- package/esm2015/validation/equals.validator.js +14 -0
- package/esm2015/validation/equals.validator.ngfactory.js +7 -0
- package/esm2015/validation/notequals.validator.js +14 -0
- package/esm2015/validation/notequals.validator.ngfactory.js +7 -0
- package/esm2015/validation/validation.class.js +30 -6
- package/fesm2015/simpleangularcontrols-sac-common.js +1398 -1075
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +4 -0
- package/interfaces/ISacIconService.d.ts +16 -0
- package/interfaces/treeviewaction.interface.d.ts +4 -0
- package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
- package/package.json +1 -1
- package/public_api.d.ts +5 -5
- package/services/sac-configuration.service.d.ts +8 -0
- package/services/sac-icon.service.d.ts +33 -1
- package/simpleangularcontrols-sac-common-10.0.0-rc.13.tgz +0 -0
- package/simpleangularcontrols-sac-common.metadata.json +1 -1
- package/utilities/enums.d.ts +3 -1
- package/utilities/popuphelper.d.ts +83 -0
- package/utilities/popuphelper.ngfactory.d.ts +1 -0
- package/validation/equals.validator.d.ts +2 -0
- package/validation/equals.validator.ngfactory.d.ts +1 -0
- package/validation/notequals.validator.d.ts +2 -0
- package/validation/notequals.validator.ngfactory.d.ts +1 -0
- package/validation/validation.class.d.ts +19 -0
- package/controls/treeview/ngtreeitemaction.d.ts +0 -40
- package/controls/treeview/treeviewchild.d.ts +0 -12
- package/esm2015/controls/treeview/ngtreeitemaction.js +0 -60
- package/esm2015/controls/treeview/treeviewchild.js +0 -18
- package/simpleangularcontrols-sac-common-10.0.0-rc.11.tgz +0 -0
- /package/controls/{treeview/ngtreeitemaction.ngfactory.d.ts → contextmenu/contextmenu.interface.ngfactory.d.ts} +0 -0
- /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
|
-
*
|
|
28
|
+
* Helper class to display tooltip on correct position
|
|
27
29
|
*/
|
|
28
|
-
this.
|
|
30
|
+
this.popupHelper = new PopUpHelper();
|
|
29
31
|
/**
|
|
30
|
-
*
|
|
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.
|
|
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
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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
|
|
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
|
-
|
|
328
|
-
|
|
329
|
-
|
|
330
|
-
|
|
331
|
-
|
|
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
|
-
|
|
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
|
-
|
|
361
|
-
|
|
362
|
-
|
|
363
|
-
|
|
364
|
-
|
|
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
|
-
|
|
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
|
-
|
|
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":"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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"]}
|
|
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"]}
|