@simpleangularcontrols/sac-common 10.0.0-rc.2 → 10.0.0-rc.21
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 +2232 -1604
- 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 +100 -14
- package/common/baseinputcontrol.d.ts +0 -4
- package/common/basemodelcontrol.d.ts +55 -27
- package/common/baseuploadcontrol.d.ts +71 -55
- package/controls/checkbox/checkbox.d.ts +12 -3
- 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 -31
- package/controls/datetime/datetime.d.ts +27 -31
- package/controls/datetime/time.d.ts +26 -30
- package/controls/dialog/dialog.d.ts +31 -43
- 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/input.d.ts +3 -3
- package/controls/input/inputarea.d.ts +5 -5
- package/controls/input/inputpassword.d.ts +7 -7
- package/controls/input/inputsearch.d.ts +13 -4
- package/controls/layout/formlayout.d.ts +17 -1
- 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/multilanguage/multilanguageinput.d.ts +2 -2
- package/controls/multilanguage/multilanguageinputarea.d.ts +4 -4
- package/controls/static/formcontainer.d.ts +7 -3
- package/controls/tooltip/tooltip.d.ts +76 -69
- package/controls/treeview/treeview.d.ts +107 -107
- package/esm2015/common/basedatetimecontrol.js +185 -30
- package/esm2015/common/baseinputcontrol.js +2 -7
- package/esm2015/common/basemodelcontrol.js +109 -57
- package/esm2015/common/baseuploadcontrol.js +92 -59
- package/esm2015/controls/checkbox/checkbox.js +29 -6
- 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 +44 -43
- package/esm2015/controls/datetime/datetime.js +43 -43
- package/esm2015/controls/datetime/time.js +43 -43
- package/esm2015/controls/dialog/dialog.js +41 -83
- 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/input.js +6 -8
- package/esm2015/controls/input/inputarea.js +19 -12
- package/esm2015/controls/input/inputpassword.js +12 -12
- package/esm2015/controls/input/inputsearch.js +35 -6
- package/esm2015/controls/layout/formlayout.js +20 -8
- 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/multilanguage/multilanguageinput.js +8 -14
- package/esm2015/controls/multilanguage/multilanguageinputarea.js +9 -15
- package/esm2015/controls/static/formcontainer.js +16 -5
- package/esm2015/controls/tooltip/tooltip.js +126 -245
- package/esm2015/controls/treeview/treeview.js +276 -231
- package/esm2015/interfaces/ISacConfigurationService.js +1 -1
- package/esm2015/interfaces/ISacIconService.js +1 -1
- package/esm2015/interfaces/ISacUploadEventCompleteState.js +1 -0
- package/esm2015/interfaces/ISacUploadEventCompleteState.ngfactory.js +7 -0
- package/esm2015/interfaces/ISacValidationKeyService.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 +15 -8
- package/esm2015/services/sac-configuration.service.js +31 -5
- package/esm2015/services/sac-icon.service.js +37 -1
- package/esm2015/services/sac-localisation.service.js +69 -180
- package/esm2015/services/sac-validationkey.service.js +12 -9
- package/esm2015/simpleangularcontrols-sac-common.js +1 -7
- package/esm2015/utilities/enums.js +5 -1
- package/esm2015/utilities/guid.js +4 -2
- 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/isDateValid.js +9 -1
- package/esm2015/validation/mintextlength.validator.js +23 -0
- package/esm2015/validation/mintextlength.validator.ngfactory.js +7 -0
- package/esm2015/validation/notequals.validator.js +14 -0
- package/esm2015/validation/{minlength.validator.ngfactory.js → notequals.validator.ngfactory.js} +1 -1
- package/esm2015/validation/validation.class.js +35 -6
- package/fesm2015/simpleangularcontrols-sac-common.js +2070 -1498
- package/fesm2015/simpleangularcontrols-sac-common.js.map +1 -1
- package/interfaces/ISacConfigurationService.d.ts +20 -0
- package/interfaces/ISacIconService.d.ts +24 -0
- package/interfaces/ISacUploadEventCompleteState.d.ts +5 -0
- package/interfaces/ISacUploadEventCompleteState.ngfactory.d.ts +1 -0
- package/interfaces/ISacValidationKeyService.d.ts +2 -2
- package/interfaces/treeviewaction.interface.d.ts +4 -0
- package/interfaces/treeviewaction.interface.ngfactory.d.ts +1 -0
- package/package.json +2 -2
- package/public_api.d.ts +13 -6
- package/services/sac-configuration.service.d.ts +40 -0
- package/services/sac-icon.service.d.ts +49 -1
- package/services/sac-localisation.service.d.ts +10 -10
- package/services/sac-validationkey.service.d.ts +7 -7
- package/simpleangularcontrols-sac-common-10.0.0-rc.21.tgz +0 -0
- package/simpleangularcontrols-sac-common.d.ts +0 -6
- 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/mintextlength.validator.d.ts +2 -0
- package/validation/mintextlength.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 +22 -3
- 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/esm2015/validation/minlength.validator.js +0 -21
- package/simpleangularcontrols-sac-common-10.0.0-rc.2.tgz +0 -0
- package/validation/minlength.validator.d.ts +0 -2
- /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
- /package/{validation/minlength.validator.ngfactory.d.ts → controls/list/dropdownoptions.ngfactory.d.ts} +0 -0
|
@@ -1,18 +1,21 @@
|
|
|
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
|
*
|
|
7
|
-
*
|
|
8
|
-
* - container: Container
|
|
9
|
-
* - tooltip: Container
|
|
8
|
+
* Requires the following identifiers in the HTML markup
|
|
9
|
+
* - container: Container for ng-content in which the element is displayed where the tooltip is attached.
|
|
10
|
+
* - tooltip: Container for tooltip
|
|
10
11
|
*
|
|
11
|
-
* Tooltip
|
|
12
|
-
*
|
|
12
|
+
* Tooltip must be displayed in 2 steps. In a first step the tooltip markup is created with (ngIf). In a 2nd step
|
|
13
|
+
* 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
14
|
*
|
|
14
15
|
*/
|
|
15
16
|
export class SacTooltipCommon {
|
|
17
|
+
// #endregion Properties
|
|
18
|
+
// #region Constructors
|
|
16
19
|
/**
|
|
17
20
|
* Konstruktor
|
|
18
21
|
* @param ref Element Referenz
|
|
@@ -20,56 +23,75 @@ export class SacTooltipCommon {
|
|
|
20
23
|
constructor(cdRef, ref) {
|
|
21
24
|
this.cdRef = cdRef;
|
|
22
25
|
this.ref = ref;
|
|
26
|
+
// #region Properties
|
|
23
27
|
/**
|
|
24
|
-
*
|
|
28
|
+
* Helper class to display tooltip on correct position
|
|
25
29
|
*/
|
|
26
|
-
this.
|
|
30
|
+
this.popupHelper = new PopUpHelper();
|
|
27
31
|
/**
|
|
28
|
-
*
|
|
32
|
+
* Defines whether the tooltip is visible
|
|
29
33
|
*/
|
|
30
34
|
this._isTooltipVisible = false;
|
|
31
35
|
/**
|
|
32
|
-
* Position
|
|
36
|
+
* Position of the tooltip on the left
|
|
33
37
|
*/
|
|
34
|
-
this.
|
|
38
|
+
this.IsTooltipContentVisible = false;
|
|
35
39
|
/**
|
|
36
40
|
* Position des Tooltips links
|
|
37
41
|
*/
|
|
38
42
|
this.LeftPos = 0;
|
|
39
43
|
/**
|
|
40
|
-
*
|
|
41
|
-
*
|
|
42
|
-
* Wert 'auto' kann mit einem anderen Wert kombiniert werden.
|
|
44
|
+
* Property for enum in Angular HTML template
|
|
43
45
|
*/
|
|
44
|
-
this.
|
|
46
|
+
this.TooltipPosition = TooltipPosition;
|
|
45
47
|
/**
|
|
46
|
-
*
|
|
48
|
+
* Position of the tooltip at the top
|
|
47
49
|
*/
|
|
48
|
-
this.
|
|
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';
|
|
49
65
|
/**
|
|
50
|
-
*
|
|
66
|
+
* method if content has changed and proportions need to be reset in the UI.
|
|
51
67
|
*/
|
|
52
68
|
this.onContentChange = () => {
|
|
69
|
+
// Do nothing if is not visible
|
|
70
|
+
if (!this._isTooltipVisible) {
|
|
71
|
+
return;
|
|
72
|
+
}
|
|
53
73
|
setTimeout(() => {
|
|
54
74
|
this.getLeftPosition();
|
|
55
75
|
this.getTopPosition();
|
|
56
76
|
});
|
|
57
77
|
};
|
|
58
78
|
}
|
|
79
|
+
// #endregion Constructors
|
|
80
|
+
// #region Public Getters And Setters
|
|
59
81
|
/**
|
|
60
|
-
*
|
|
82
|
+
* Property for inline mode for tooltip. Sets the display mode on the wrapper element to `inline`
|
|
61
83
|
*/
|
|
62
|
-
|
|
63
|
-
this._inlinemode
|
|
84
|
+
get inlinemode() {
|
|
85
|
+
return this._inlinemode;
|
|
64
86
|
}
|
|
65
87
|
/**
|
|
66
|
-
*
|
|
88
|
+
* Setter for inline mode for tooltip
|
|
67
89
|
*/
|
|
68
|
-
|
|
69
|
-
|
|
90
|
+
set inlinemode(value) {
|
|
91
|
+
this._inlinemode = convertToBoolean(value);
|
|
70
92
|
}
|
|
71
93
|
/**
|
|
72
|
-
* Setter
|
|
94
|
+
* Setter for the name of the container for the tooltip. Is required as the tooltip can be hidden via ngIf.
|
|
73
95
|
*/
|
|
74
96
|
set tooltip(content) {
|
|
75
97
|
if (content !== undefined) {
|
|
@@ -79,127 +101,36 @@ export class SacTooltipCommon {
|
|
|
79
101
|
this.onContentChange();
|
|
80
102
|
this.cdRef.detectChanges();
|
|
81
103
|
}
|
|
82
|
-
|
|
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
|
-
}
|
|
104
|
+
get tooltop() {
|
|
105
|
+
return this.tooltipcontainer;
|
|
169
106
|
}
|
|
107
|
+
// #endregion Public Getters And Setters
|
|
108
|
+
// #region Public Methods
|
|
170
109
|
/**
|
|
171
|
-
*
|
|
110
|
+
* Returns the position of the tooltip
|
|
172
111
|
*/
|
|
173
|
-
|
|
174
|
-
|
|
175
|
-
return this.tooltipcontainer.nativeElement.clientHeight;
|
|
176
|
-
}
|
|
177
|
-
else {
|
|
178
|
-
return 0;
|
|
179
|
-
}
|
|
112
|
+
GetTooltipPosition() {
|
|
113
|
+
return this.popupHelper.getDisplayPosition(this.content, this.tooltipcontainer, this.getTooltipOffset(), this.getTooltipOffset(), this.position, true);
|
|
180
114
|
}
|
|
181
115
|
/**
|
|
182
|
-
*
|
|
116
|
+
* Hide tooltip
|
|
183
117
|
*/
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
}
|
|
188
|
-
else {
|
|
189
|
-
return 0;
|
|
190
|
-
}
|
|
118
|
+
HideTooltip() {
|
|
119
|
+
this._isTooltipVisible = false;
|
|
120
|
+
this.IsTooltipContentVisible = false;
|
|
191
121
|
}
|
|
192
122
|
/**
|
|
193
|
-
*
|
|
123
|
+
* Defines whether the tooltip is present in the markup
|
|
194
124
|
*/
|
|
195
125
|
IsTooltipVisible() {
|
|
196
126
|
return this._isTooltipVisible;
|
|
197
127
|
}
|
|
198
128
|
/**
|
|
199
|
-
*
|
|
129
|
+
* Show tooltip
|
|
200
130
|
*/
|
|
201
131
|
ShowTooltip() {
|
|
202
132
|
this._isTooltipVisible = true;
|
|
133
|
+
this.cdRef.detectChanges();
|
|
203
134
|
setTimeout(() => {
|
|
204
135
|
this.getLeftPosition();
|
|
205
136
|
this.getTopPosition();
|
|
@@ -207,141 +138,91 @@ export class SacTooltipCommon {
|
|
|
207
138
|
});
|
|
208
139
|
}
|
|
209
140
|
/**
|
|
210
|
-
*
|
|
141
|
+
* Calculates the height of the tooltip
|
|
211
142
|
*/
|
|
212
|
-
|
|
213
|
-
this.
|
|
214
|
-
this.IsTooltipContentVisible = false;
|
|
143
|
+
getToolTipHeight() {
|
|
144
|
+
return this.popupHelper.getPopupHeight(this.tooltipcontainer);
|
|
215
145
|
}
|
|
216
146
|
/**
|
|
217
|
-
*
|
|
147
|
+
* Calculates the width of the tooltips
|
|
218
148
|
*/
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
// tslint:disable-next-line:no-bitwise
|
|
222
|
-
if (this.HasPosition(TooltipPosition.right) && (validPositions & TooltipPosition.right)) {
|
|
223
|
-
return TooltipPosition.right;
|
|
224
|
-
}
|
|
225
|
-
// tslint:disable-next-line:no-bitwise
|
|
226
|
-
if (this.HasPosition(TooltipPosition.top) && (validPositions & TooltipPosition.top)) {
|
|
227
|
-
return TooltipPosition.top;
|
|
228
|
-
}
|
|
229
|
-
// tslint:disable-next-line:no-bitwise
|
|
230
|
-
if (this.HasPosition(TooltipPosition.left) && (validPositions & TooltipPosition.left)) {
|
|
231
|
-
return TooltipPosition.left;
|
|
232
|
-
}
|
|
233
|
-
// tslint:disable-next-line:no-bitwise
|
|
234
|
-
if (this.HasPosition(TooltipPosition.bottom) && (validPositions & TooltipPosition.bottom)) {
|
|
235
|
-
return TooltipPosition.bottom;
|
|
236
|
-
}
|
|
237
|
-
// Get Auto Position or Default
|
|
238
|
-
if (this.IsAutoPosition()) {
|
|
239
|
-
// tslint:disable-next-line:no-bitwise
|
|
240
|
-
if (validPositions & TooltipPosition.right) {
|
|
241
|
-
return TooltipPosition.right;
|
|
242
|
-
}
|
|
243
|
-
// tslint:disable-next-line:no-bitwise
|
|
244
|
-
if (validPositions & TooltipPosition.top) {
|
|
245
|
-
return TooltipPosition.top;
|
|
246
|
-
}
|
|
247
|
-
// tslint:disable-next-line:no-bitwise
|
|
248
|
-
if (validPositions & TooltipPosition.left) {
|
|
249
|
-
return TooltipPosition.left;
|
|
250
|
-
}
|
|
251
|
-
// tslint:disable-next-line:no-bitwise
|
|
252
|
-
if (validPositions & TooltipPosition.bottom) {
|
|
253
|
-
return TooltipPosition.bottom;
|
|
254
|
-
}
|
|
255
|
-
return TooltipPosition.right;
|
|
256
|
-
}
|
|
257
|
-
else {
|
|
258
|
-
return this.GetPosition();
|
|
259
|
-
}
|
|
149
|
+
getToolTipWidth() {
|
|
150
|
+
return this.popupHelper.getPopupWidth(this.tooltipcontainer);
|
|
260
151
|
}
|
|
261
152
|
/**
|
|
262
|
-
*
|
|
153
|
+
* Detect Changes after view checked. Prevent ExpressionChangedAfterItHasBeenCheckedError error
|
|
263
154
|
*/
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
155
|
+
ngAfterViewChecked() {
|
|
156
|
+
// Do nothing if is not visibile
|
|
157
|
+
if (!this._isTooltipVisible) {
|
|
158
|
+
return;
|
|
159
|
+
}
|
|
160
|
+
this.cdRef.detectChanges();
|
|
267
161
|
}
|
|
268
162
|
/**
|
|
269
|
-
*
|
|
163
|
+
* Detect UI Changes to Calculate Tooltip correct
|
|
270
164
|
*/
|
|
271
|
-
|
|
272
|
-
|
|
273
|
-
if (this.
|
|
274
|
-
return
|
|
275
|
-
}
|
|
276
|
-
if (this.HasPosition(TooltipPosition.top)) {
|
|
277
|
-
return TooltipPosition.top;
|
|
278
|
-
}
|
|
279
|
-
if (this.HasPosition(TooltipPosition.right)) {
|
|
280
|
-
return TooltipPosition.right;
|
|
281
|
-
}
|
|
282
|
-
if (this.HasPosition(TooltipPosition.bottom)) {
|
|
283
|
-
return TooltipPosition.bottom;
|
|
165
|
+
ngDoCheck() {
|
|
166
|
+
// Do nothing if is not visibile
|
|
167
|
+
if (!this._isTooltipVisible) {
|
|
168
|
+
return;
|
|
284
169
|
}
|
|
285
|
-
|
|
286
|
-
|
|
170
|
+
this.getLeftPosition();
|
|
171
|
+
this.getTopPosition();
|
|
287
172
|
}
|
|
288
173
|
/**
|
|
289
|
-
*
|
|
290
|
-
*
|
|
291
|
-
* @param position Position auf welche geprüft wird
|
|
174
|
+
* Event when the control is destroyed.
|
|
292
175
|
*/
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
return true;
|
|
300
|
-
}
|
|
301
|
-
if (position === TooltipPosition.left && positions.indexOf('left') >= 0) {
|
|
302
|
-
return true;
|
|
303
|
-
}
|
|
304
|
-
if (position === TooltipPosition.bottom && positions.indexOf('bottom') >= 0) {
|
|
305
|
-
return true;
|
|
176
|
+
ngOnDestroy() {
|
|
177
|
+
// Unregister Event Listener
|
|
178
|
+
window.removeEventListener('scroll', this.onContentChange, true);
|
|
179
|
+
window.removeEventListener('resize', this.onContentChange, true);
|
|
180
|
+
if (this.tooltipcontainer !== undefined) {
|
|
181
|
+
document.body.removeChild(this.tooltipcontainer.nativeElement);
|
|
306
182
|
}
|
|
307
|
-
return false;
|
|
308
183
|
}
|
|
309
184
|
/**
|
|
310
|
-
*
|
|
185
|
+
* Event when the control is initialized
|
|
311
186
|
*/
|
|
312
|
-
|
|
313
|
-
//
|
|
314
|
-
|
|
315
|
-
|
|
187
|
+
ngOnInit() {
|
|
188
|
+
// Register Event Listener
|
|
189
|
+
window.addEventListener('scroll', this.onContentChange, true);
|
|
190
|
+
window.addEventListener('resize', this.onContentChange, true);
|
|
191
|
+
if (this.tooltipcontainer !== undefined) {
|
|
192
|
+
document.body.appendChild(this.tooltipcontainer.nativeElement);
|
|
316
193
|
}
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
|
|
321
|
-
|
|
322
|
-
|
|
323
|
-
|
|
324
|
-
const
|
|
325
|
-
|
|
326
|
-
const
|
|
327
|
-
|
|
328
|
-
|
|
329
|
-
// tslint:disable-next-line:no-bitwise
|
|
330
|
-
allowedPositions = allowedPositions | TooltipPosition.left;
|
|
194
|
+
}
|
|
195
|
+
// #endregion Protected Methods
|
|
196
|
+
// #region Private Methods
|
|
197
|
+
/**
|
|
198
|
+
* Calculates the position of the tooltip from links
|
|
199
|
+
*/
|
|
200
|
+
getLeftPosition() {
|
|
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;
|
|
331
206
|
}
|
|
332
|
-
|
|
333
|
-
|
|
334
|
-
allowedPositions = allowedPositions | TooltipPosition.right;
|
|
207
|
+
else {
|
|
208
|
+
this.posArrowTop = null;
|
|
335
209
|
}
|
|
336
|
-
|
|
337
|
-
|
|
338
|
-
|
|
210
|
+
return value;
|
|
211
|
+
}
|
|
212
|
+
/**
|
|
213
|
+
* Calculates the position of the tooltip from the top
|
|
214
|
+
*/
|
|
215
|
+
getTopPosition() {
|
|
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;
|
|
339
221
|
}
|
|
340
|
-
|
|
341
|
-
|
|
342
|
-
allowedPositions = allowedPositions | TooltipPosition.bottom;
|
|
222
|
+
else {
|
|
223
|
+
this.posArrowLeft = null;
|
|
343
224
|
}
|
|
344
|
-
return
|
|
225
|
+
return value;
|
|
345
226
|
}
|
|
346
227
|
}
|
|
347
228
|
SacTooltipCommon.decorators = [
|
|
@@ -352,10 +233,10 @@ SacTooltipCommon.ctorParameters = () => [
|
|
|
352
233
|
{ type: ElementRef }
|
|
353
234
|
];
|
|
354
235
|
SacTooltipCommon.propDecorators = {
|
|
236
|
+
content: [{ type: ViewChild, args: ['container', { static: true },] }],
|
|
355
237
|
position: [{ type: Input }],
|
|
356
238
|
tooltiptext: [{ type: Input }],
|
|
357
239
|
inlinemode: [{ type: Input }],
|
|
358
|
-
|
|
359
|
-
tooltip: [{ type: ViewChild, args: ['tooltip', { static: true },] }]
|
|
240
|
+
tooltip: [{ type: ViewChild, args: ['tooltip', { static: false },] }]
|
|
360
241
|
};
|
|
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"]}
|
|
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"]}
|