@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.
- package/bundles/simpleangularcontrols-sac-common.umd.js +696 -412
- 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 +1 -1
- package/common/baseinputcontrol.d.ts +0 -4
- package/common/basemodelcontrol.d.ts +25 -1
- package/common/baseuploadcontrol.d.ts +0 -5
- package/controls/checkbox/checkbox.d.ts +12 -3
- package/controls/datetime/date.d.ts +0 -4
- package/controls/datetime/datetime.d.ts +0 -4
- package/controls/datetime/time.d.ts +0 -4
- package/controls/grid/grid.d.ts +38 -36
- package/controls/grid/gridbutton.d.ts +13 -13
- package/controls/grid/gridcolumn.d.ts +8 -8
- package/controls/grid/gridcolumnaction.d.ts +3 -3
- package/controls/grid/gridcolumnbase.d.ts +45 -37
- package/controls/grid/gridimage.d.ts +2 -2
- package/controls/grid/model.d.ts +51 -42
- package/controls/grid/paging.d.ts +41 -43
- package/controls/input/inputsearch.d.ts +13 -4
- package/controls/layout/formlayout.d.ts +13 -1
- package/controls/static/formcontainer.d.ts +2 -6
- package/controls/tooltip/tooltip.d.ts +88 -63
- package/esm2015/common/basedatetimecontrol.js +1 -1
- package/esm2015/common/baseinputcontrol.js +2 -7
- package/esm2015/common/basemodelcontrol.js +44 -7
- package/esm2015/common/baseuploadcontrol.js +2 -3
- package/esm2015/controls/checkbox/checkbox.js +29 -6
- package/esm2015/controls/datetime/date.js +2 -3
- package/esm2015/controls/datetime/datetime.js +2 -3
- package/esm2015/controls/datetime/time.js +2 -3
- package/esm2015/controls/grid/grid.js +21 -21
- package/esm2015/controls/grid/gridbutton.js +19 -13
- package/esm2015/controls/grid/gridcolumn.js +14 -7
- package/esm2015/controls/grid/gridcolumnaction.js +6 -5
- package/esm2015/controls/grid/gridcolumnbase.js +67 -55
- package/esm2015/controls/grid/gridimage.js +3 -3
- package/esm2015/controls/grid/model.js +51 -30
- package/esm2015/controls/grid/paging.js +40 -42
- package/esm2015/controls/input/inputsearch.js +35 -6
- package/esm2015/controls/layout/formlayout.js +14 -3
- package/esm2015/controls/static/formcontainer.js +11 -10
- package/esm2015/controls/tooltip/tooltip.js +260 -189
- package/esm2015/interfaces/ISacConfigurationService.js +1 -1
- package/esm2015/interfaces/ISacIconService.js +1 -1
- package/esm2015/public_api.js +10 -3
- package/esm2015/services/sac-configuration.service.js +25 -1
- package/esm2015/services/sac-icon.service.js +13 -1
- package/esm2015/simpleangularcontrols-sac-common.js +1 -7
- package/esm2015/utilities/guid.js +4 -2
- package/esm2015/validation/isDateValid.js +9 -1
- package/fesm2015/simpleangularcontrols-sac-common.js +652 -395
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +16 -0
- package/interfaces/ISacIconService.d.ts +8 -0
- package/package.json +4 -4
- package/public_api.d.ts +7 -1
- package/services/sac-configuration.service.d.ts +32 -0
- package/services/sac-icon.service.d.ts +16 -0
- package/simpleangularcontrols-sac-common-10.0.0-rc.11.tgz +0 -0
- package/simpleangularcontrols-sac-common.d.ts +0 -6
- package/simpleangularcontrols-sac-common.metadata.json +1 -1
- 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
|
-
*
|
|
8
|
-
* - container: Container
|
|
9
|
-
* - tooltip: Container
|
|
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
|
|
12
|
-
*
|
|
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
|
-
*
|
|
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
|
-
*
|
|
30
|
+
* method if content has changed and proportions need to be reset in the UI.
|
|
33
31
|
*/
|
|
34
|
-
this.
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
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
|
|
43
|
+
* Position of the tooltip. Values: left|top|right|bottom|auto
|
|
41
44
|
*
|
|
42
|
-
*
|
|
45
|
+
* Value 'auto' can be combined with another value.
|
|
43
46
|
*/
|
|
44
47
|
this.position = 'right|auto';
|
|
45
48
|
/**
|
|
46
|
-
*
|
|
49
|
+
* Position of the tooltip on the left
|
|
47
50
|
*/
|
|
48
51
|
this.IsTooltipContentVisible = false;
|
|
49
52
|
/**
|
|
50
|
-
*
|
|
53
|
+
* Position des Tooltips links
|
|
51
54
|
*/
|
|
52
|
-
this.
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
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
|
|
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
|
-
*
|
|
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
|
-
*
|
|
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
|
-
|
|
196
|
-
return this.
|
|
87
|
+
get inlinemode() {
|
|
88
|
+
return this._inlinemode;
|
|
197
89
|
}
|
|
198
|
-
|
|
199
|
-
|
|
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
|
-
*
|
|
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) &&
|
|
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) &&
|
|
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) &&
|
|
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) &&
|
|
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
|
-
*
|
|
145
|
+
* Hide tooltip
|
|
263
146
|
*/
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
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
|
-
*
|
|
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
|
-
*
|
|
258
|
+
* Returns whether the position has been configured
|
|
290
259
|
*
|
|
291
|
-
* @param position Position
|
|
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 &&
|
|
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
|
-
*
|
|
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 -
|
|
325
|
-
const rightHalfPosOk = basePosition.right +
|
|
326
|
-
const topHalfPosOk = basePosition.top -
|
|
327
|
-
const bottomHalfPosOk = basePosition.bottom +
|
|
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
|
-
|
|
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"]}
|