@amboss/design-system 1.19.0 → 1.20.0
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/build/cjs/src/components/Popover/Popover.js +22 -0
- package/build/cjs/src/components/Toggletip/BasePopover.js +144 -0
- package/build/cjs/src/components/Toggletip/Toggletip.js +8 -121
- package/build/cjs/src/components/Tooltip/TooltipContent.js +55 -26
- package/build/cjs/src/components/Tooltip/utils.js +23 -13
- package/build/cjs/src/components/UserHighlightTooltip/UserHighlightTooltip.js +115 -4
- package/build/cjs/src/index.js +2 -0
- package/build/esm/src/components/Popover/Popover.d.ts +6 -0
- package/build/esm/src/components/Popover/Popover.js +16 -0
- package/build/esm/src/components/Popover/Popover.js.map +1 -0
- package/build/esm/src/components/Toggletip/BasePopover.d.ts +16 -0
- package/build/esm/src/components/Toggletip/BasePopover.js +137 -0
- package/build/esm/src/components/Toggletip/BasePopover.js.map +1 -0
- package/build/esm/src/components/Toggletip/Toggletip.d.ts +5 -13
- package/build/esm/src/components/Toggletip/Toggletip.js +8 -121
- package/build/esm/src/components/Toggletip/Toggletip.js.map +1 -1
- package/build/esm/src/components/Tooltip/TooltipContent.d.ts +6 -1
- package/build/esm/src/components/Tooltip/TooltipContent.js +57 -28
- package/build/esm/src/components/Tooltip/TooltipContent.js.map +1 -1
- package/build/esm/src/components/Tooltip/utils.d.ts +3 -3
- package/build/esm/src/components/Tooltip/utils.js +22 -12
- package/build/esm/src/components/Tooltip/utils.js.map +1 -1
- package/build/esm/src/components/UserHighlightTooltip/UserHighlightTooltip.d.ts +8 -3
- package/build/esm/src/components/UserHighlightTooltip/UserHighlightTooltip.js +116 -5
- package/build/esm/src/components/UserHighlightTooltip/UserHighlightTooltip.js.map +1 -1
- package/build/esm/src/index.d.ts +1 -0
- package/build/esm/src/index.js +1 -0
- package/build/esm/src/index.js.map +1 -1
- package/package.json +1 -1
|
@@ -0,0 +1,22 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var _extends = require('@babel/runtime/helpers/extends');
|
|
4
|
+
var React = require('react');
|
|
5
|
+
var BasePopover = require('../Toggletip/BasePopover.js');
|
|
6
|
+
|
|
7
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
8
|
+
|
|
9
|
+
var _extends__default = /*#__PURE__*/_interopDefault(_extends);
|
|
10
|
+
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
11
|
+
|
|
12
|
+
function Popover(props) {
|
|
13
|
+
return /*#__PURE__*/React__default.default.createElement(BasePopover.BasePopover, _extends__default.default({
|
|
14
|
+
name: "Popover",
|
|
15
|
+
maxWidth: 400,
|
|
16
|
+
defaultVerticalPlacement: "bottom",
|
|
17
|
+
hasInvertedSubTheme: false,
|
|
18
|
+
borderRadius: "s"
|
|
19
|
+
}, props));
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
exports.Popover = Popover;
|
|
@@ -0,0 +1,144 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
var _extends = require('@babel/runtime/helpers/extends');
|
|
4
|
+
var React = require('react');
|
|
5
|
+
var FocusTrap = require('focus-trap-react');
|
|
6
|
+
var TooltipContent = require('../Tooltip/TooltipContent.js');
|
|
7
|
+
|
|
8
|
+
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
9
|
+
|
|
10
|
+
var _extends__default = /*#__PURE__*/_interopDefault(_extends);
|
|
11
|
+
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
12
|
+
var FocusTrap__default = /*#__PURE__*/_interopDefault(FocusTrap);
|
|
13
|
+
|
|
14
|
+
const FocusTrapContent = /*#__PURE__*/React__default.default.forwardRef((_ref, ref) => {
|
|
15
|
+
let {
|
|
16
|
+
children
|
|
17
|
+
} = _ref;
|
|
18
|
+
return /*#__PURE__*/React__default.default.createElement("div", {
|
|
19
|
+
ref: ref
|
|
20
|
+
}, children);
|
|
21
|
+
});
|
|
22
|
+
function BasePopover(_ref2) {
|
|
23
|
+
let {
|
|
24
|
+
placement = "auto",
|
|
25
|
+
content,
|
|
26
|
+
children,
|
|
27
|
+
contentPadding = "m",
|
|
28
|
+
maxWidth,
|
|
29
|
+
externalTriggerRef,
|
|
30
|
+
portalContainer,
|
|
31
|
+
name = "Popover",
|
|
32
|
+
isVisible: isPopoverVisible,
|
|
33
|
+
dismissOnOutsideClick = true,
|
|
34
|
+
"data-e2e-test-id": dataE2eTestId,
|
|
35
|
+
hasInvertedSubTheme,
|
|
36
|
+
defaultVerticalPlacement,
|
|
37
|
+
onVisibilityChange,
|
|
38
|
+
preventScroll = false,
|
|
39
|
+
...restContentProps
|
|
40
|
+
} = _ref2;
|
|
41
|
+
const tooltipId = React.useMemo(() => `DS${name}_${Math.floor(Date.now() * Math.random())}`, [name]);
|
|
42
|
+
const [isVisible, setVisible] = React.useState(isPopoverVisible);
|
|
43
|
+
const internalTriggerRef = React.useRef(null);
|
|
44
|
+
const triggerRef = externalTriggerRef || internalTriggerRef;
|
|
45
|
+
const isOutsideClickOnTrigger = React.useRef(false);
|
|
46
|
+
const toggleVisibility = React.useCallback(status => {
|
|
47
|
+
setVisible(status);
|
|
48
|
+
if (onVisibilityChange) {
|
|
49
|
+
onVisibilityChange(status);
|
|
50
|
+
}
|
|
51
|
+
}, [onVisibilityChange]);
|
|
52
|
+
|
|
53
|
+
// Outside click is also fired when the Popover is open and trigger is clicked. `isOutsideClickOnTrigger` saves this condition and we check for it so as to not toggle the Popover twice.
|
|
54
|
+
const handleTriggerClick = React.useCallback(() => {
|
|
55
|
+
if (!isOutsideClickOnTrigger.current) {
|
|
56
|
+
toggleVisibility(!isVisible);
|
|
57
|
+
} else {
|
|
58
|
+
// reset this value so that Popover can open in next click
|
|
59
|
+
isOutsideClickOnTrigger.current = false;
|
|
60
|
+
}
|
|
61
|
+
}, [toggleVisibility, isVisible]);
|
|
62
|
+
const handleClickOutsideDeactivates = React.useCallback(evt => {
|
|
63
|
+
if (triggerRef.current.contains(evt.target)) {
|
|
64
|
+
isOutsideClickOnTrigger.current = true;
|
|
65
|
+
}
|
|
66
|
+
return true;
|
|
67
|
+
}, [triggerRef, isOutsideClickOnTrigger]);
|
|
68
|
+
React.useEffect(() => {
|
|
69
|
+
toggleVisibility(isPopoverVisible);
|
|
70
|
+
}, [isPopoverVisible, toggleVisibility]);
|
|
71
|
+
React.useEffect(() => {
|
|
72
|
+
let trigger;
|
|
73
|
+
if (externalTriggerRef?.current && !children) {
|
|
74
|
+
trigger = externalTriggerRef.current;
|
|
75
|
+
trigger.setAttribute("tabindex", "0");
|
|
76
|
+
trigger.addEventListener("click", handleTriggerClick);
|
|
77
|
+
}
|
|
78
|
+
return () => {
|
|
79
|
+
if (trigger) {
|
|
80
|
+
trigger.removeEventListener("click", handleTriggerClick);
|
|
81
|
+
}
|
|
82
|
+
};
|
|
83
|
+
}, [externalTriggerRef, children, handleTriggerClick]);
|
|
84
|
+
React.useEffect(() => {
|
|
85
|
+
if (externalTriggerRef?.current && !children) {
|
|
86
|
+
const trigger = externalTriggerRef.current;
|
|
87
|
+
if (isVisible) {
|
|
88
|
+
trigger.setAttribute("aria-expanded", true);
|
|
89
|
+
trigger.setAttribute("aria-controls", tooltipId);
|
|
90
|
+
} else {
|
|
91
|
+
trigger.removeAttribute("aria-expanded");
|
|
92
|
+
trigger.removeAttribute("aria-controls");
|
|
93
|
+
}
|
|
94
|
+
}
|
|
95
|
+
}, [externalTriggerRef, children, tooltipId, isVisible]);
|
|
96
|
+
const triggerElm = children ? /*#__PURE__*/React__default.default.cloneElement(children, {
|
|
97
|
+
ref: triggerRef,
|
|
98
|
+
...(isVisible && {
|
|
99
|
+
"aria-expanded": true,
|
|
100
|
+
"aria-controls": tooltipId
|
|
101
|
+
}),
|
|
102
|
+
tabIndex: 0,
|
|
103
|
+
onClick: evt => {
|
|
104
|
+
handleTriggerClick();
|
|
105
|
+
if (children.props.onClick) {
|
|
106
|
+
children.props.onClick(evt);
|
|
107
|
+
}
|
|
108
|
+
}
|
|
109
|
+
}) : null;
|
|
110
|
+
const contentElm = /*#__PURE__*/React__default.default.createElement(FocusTrap__default.default, {
|
|
111
|
+
focusTrapOptions: {
|
|
112
|
+
clickOutsideDeactivates: dismissOnOutsideClick && handleClickOutsideDeactivates,
|
|
113
|
+
// de-active focus trap on outside click
|
|
114
|
+
allowOutsideClick: true,
|
|
115
|
+
escapeDeactivates: true,
|
|
116
|
+
// de-activate focus trap on escape key
|
|
117
|
+
fallbackFocus: `#${tooltipId}`,
|
|
118
|
+
// set focus to tooltip content container if it has no focusable element
|
|
119
|
+
onDeactivate: () => {
|
|
120
|
+
toggleVisibility(false);
|
|
121
|
+
},
|
|
122
|
+
preventScroll
|
|
123
|
+
}
|
|
124
|
+
}, /*#__PURE__*/React__default.default.createElement(FocusTrapContent, null, content));
|
|
125
|
+
const tooltipElm = /*#__PURE__*/React__default.default.createElement(TooltipContent.TooltipContent, _extends__default.default({}, restContentProps, {
|
|
126
|
+
// eslint-disable-line react/jsx-props-no-spreading
|
|
127
|
+
defaultVerticalPlacement: defaultVerticalPlacement,
|
|
128
|
+
dataDSId: name,
|
|
129
|
+
content: contentElm,
|
|
130
|
+
contentPadding: contentPadding,
|
|
131
|
+
maxWidth: maxWidth,
|
|
132
|
+
placement: placement,
|
|
133
|
+
portalContainer: portalContainer,
|
|
134
|
+
dataE2eTestId: dataE2eTestId,
|
|
135
|
+
hasInvertedSubTheme: hasInvertedSubTheme,
|
|
136
|
+
isVisible: isVisible,
|
|
137
|
+
tooltipId: tooltipId,
|
|
138
|
+
tabIndex: -1,
|
|
139
|
+
triggerRef: triggerRef
|
|
140
|
+
}));
|
|
141
|
+
return /*#__PURE__*/React__default.default.createElement(React__default.default.Fragment, null, triggerElm, tooltipElm);
|
|
142
|
+
}
|
|
143
|
+
|
|
144
|
+
exports.BasePopover = BasePopover;
|
|
@@ -1,132 +1,19 @@
|
|
|
1
1
|
'use strict';
|
|
2
2
|
|
|
3
|
+
var _extends = require('@babel/runtime/helpers/extends');
|
|
3
4
|
var React = require('react');
|
|
4
|
-
var
|
|
5
|
-
var TooltipContent = require('../Tooltip/TooltipContent.js');
|
|
5
|
+
var BasePopover = require('./BasePopover.js');
|
|
6
6
|
|
|
7
7
|
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
8
8
|
|
|
9
|
+
var _extends__default = /*#__PURE__*/_interopDefault(_extends);
|
|
9
10
|
var React__default = /*#__PURE__*/_interopDefault(React);
|
|
10
|
-
var FocusTrap__default = /*#__PURE__*/_interopDefault(FocusTrap);
|
|
11
11
|
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
ref: ref
|
|
18
|
-
}, children);
|
|
19
|
-
});
|
|
20
|
-
function Toggletip(_ref2) {
|
|
21
|
-
let {
|
|
22
|
-
placement = "auto",
|
|
23
|
-
content,
|
|
24
|
-
children,
|
|
25
|
-
contentPadding = "m",
|
|
26
|
-
maxWidth,
|
|
27
|
-
externalTriggerRef,
|
|
28
|
-
portalContainer,
|
|
29
|
-
isVisible: isToggletipVisible,
|
|
30
|
-
dismissOnOutsideClick = true,
|
|
31
|
-
"data-e2e-test-id": dataE2eTestId,
|
|
32
|
-
onVisibilityChange
|
|
33
|
-
} = _ref2;
|
|
34
|
-
const tooltipId = React.useMemo(() => `DSToggletip_${Math.floor(Date.now() * Math.random())}`, []);
|
|
35
|
-
const [isVisible, setVisible] = React.useState(isToggletipVisible);
|
|
36
|
-
const internalTriggerRef = React.useRef(null);
|
|
37
|
-
const triggerRef = externalTriggerRef || internalTriggerRef;
|
|
38
|
-
const isOutsideClickOnTrigger = React.useRef(false);
|
|
39
|
-
const toggleVisibility = React.useCallback(status => {
|
|
40
|
-
setVisible(status);
|
|
41
|
-
if (onVisibilityChange) {
|
|
42
|
-
onVisibilityChange(status);
|
|
43
|
-
}
|
|
44
|
-
}, [onVisibilityChange]);
|
|
45
|
-
|
|
46
|
-
// Outside click is also fired when the Toggletip is open and trigger is clicked. `isOutsideClickOnTrigger` saves this condition and we check for it so as to not toggle the Toggletip twice.
|
|
47
|
-
const handleTriggerClick = React.useCallback(() => {
|
|
48
|
-
if (!isOutsideClickOnTrigger.current) {
|
|
49
|
-
toggleVisibility(!isVisible);
|
|
50
|
-
} else {
|
|
51
|
-
// reset this value so that Toggletip can open in next click
|
|
52
|
-
isOutsideClickOnTrigger.current = false;
|
|
53
|
-
}
|
|
54
|
-
}, [toggleVisibility, isVisible]);
|
|
55
|
-
const handleClickOutsideDeactivates = React.useCallback(evt => {
|
|
56
|
-
if (triggerRef.current.contains(evt.target)) {
|
|
57
|
-
isOutsideClickOnTrigger.current = true;
|
|
58
|
-
}
|
|
59
|
-
return true;
|
|
60
|
-
}, [triggerRef, isOutsideClickOnTrigger]);
|
|
61
|
-
React.useEffect(() => {
|
|
62
|
-
toggleVisibility(isToggletipVisible);
|
|
63
|
-
}, [isToggletipVisible, toggleVisibility]);
|
|
64
|
-
React.useEffect(() => {
|
|
65
|
-
let trigger;
|
|
66
|
-
if (externalTriggerRef?.current && !children) {
|
|
67
|
-
trigger = externalTriggerRef.current;
|
|
68
|
-
trigger.setAttribute("tabindex", "0");
|
|
69
|
-
trigger.addEventListener("click", handleTriggerClick);
|
|
70
|
-
}
|
|
71
|
-
return () => {
|
|
72
|
-
if (trigger) {
|
|
73
|
-
trigger.removeEventListener("click", handleTriggerClick);
|
|
74
|
-
}
|
|
75
|
-
};
|
|
76
|
-
}, [externalTriggerRef, children, handleTriggerClick]);
|
|
77
|
-
React.useEffect(() => {
|
|
78
|
-
if (externalTriggerRef?.current && !children) {
|
|
79
|
-
const trigger = externalTriggerRef.current;
|
|
80
|
-
if (isVisible) {
|
|
81
|
-
trigger.setAttribute("aria-expanded", true);
|
|
82
|
-
trigger.setAttribute("aria-controls", tooltipId);
|
|
83
|
-
} else {
|
|
84
|
-
trigger.removeAttribute("aria-expanded");
|
|
85
|
-
trigger.removeAttribute("aria-controls");
|
|
86
|
-
}
|
|
87
|
-
}
|
|
88
|
-
}, [externalTriggerRef, children, tooltipId, isVisible]);
|
|
89
|
-
const triggerElm = children ? /*#__PURE__*/React__default.default.cloneElement(children, {
|
|
90
|
-
ref: triggerRef,
|
|
91
|
-
...(isVisible && {
|
|
92
|
-
"aria-expanded": true,
|
|
93
|
-
"aria-controls": tooltipId
|
|
94
|
-
}),
|
|
95
|
-
tabIndex: 0,
|
|
96
|
-
onClick: evt => {
|
|
97
|
-
handleTriggerClick();
|
|
98
|
-
if (children.props.onClick) {
|
|
99
|
-
children.props.onClick(evt);
|
|
100
|
-
}
|
|
101
|
-
}
|
|
102
|
-
}) : null;
|
|
103
|
-
const contentElm = /*#__PURE__*/React__default.default.createElement(FocusTrap__default.default, {
|
|
104
|
-
focusTrapOptions: {
|
|
105
|
-
clickOutsideDeactivates: dismissOnOutsideClick && handleClickOutsideDeactivates,
|
|
106
|
-
// de-active focus trap on outside click
|
|
107
|
-
allowOutsideClick: true,
|
|
108
|
-
escapeDeactivates: true,
|
|
109
|
-
// de-activate focus trap on escape key
|
|
110
|
-
fallbackFocus: `#${tooltipId}`,
|
|
111
|
-
// set focus to tooltip content container if it has no focusable element
|
|
112
|
-
onDeactivate: () => {
|
|
113
|
-
toggleVisibility(false);
|
|
114
|
-
}
|
|
115
|
-
}
|
|
116
|
-
}, /*#__PURE__*/React__default.default.createElement(FocusTrapContent, null, content));
|
|
117
|
-
const tooltipElm = /*#__PURE__*/React__default.default.createElement(TooltipContent.TooltipContent, {
|
|
118
|
-
dataDSId: "Toggletip",
|
|
119
|
-
content: contentElm,
|
|
120
|
-
contentPadding: contentPadding,
|
|
121
|
-
maxWidth: maxWidth,
|
|
122
|
-
placement: placement,
|
|
123
|
-
portalContainer: portalContainer,
|
|
124
|
-
dataE2eTestId: dataE2eTestId,
|
|
125
|
-
isVisible: isVisible,
|
|
126
|
-
tooltipId: tooltipId,
|
|
127
|
-
triggerRef: triggerRef
|
|
128
|
-
});
|
|
129
|
-
return /*#__PURE__*/React__default.default.createElement(React__default.default.Fragment, null, triggerElm, tooltipElm);
|
|
12
|
+
function Toggletip(props) {
|
|
13
|
+
return /*#__PURE__*/React__default.default.createElement(BasePopover.BasePopover, _extends__default.default({
|
|
14
|
+
name: "Toggletip",
|
|
15
|
+
defaultVerticalPlacement: "top"
|
|
16
|
+
}, props));
|
|
130
17
|
}
|
|
131
18
|
|
|
132
19
|
exports.Toggletip = Toggletip;
|
|
@@ -9,6 +9,7 @@ var useWindow = require('../../shared/useWindow.js');
|
|
|
9
9
|
var SubThemeProvider = require('../SubThemeProvider/SubThemeProvider.js');
|
|
10
10
|
var _zindex = require('../../../build-tokens/_zindex.json.js');
|
|
11
11
|
var utils = require('./utils.js');
|
|
12
|
+
var Container = require('../Container/Container.js');
|
|
12
13
|
|
|
13
14
|
function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
|
|
14
15
|
|
|
@@ -28,8 +29,9 @@ const StyledContainer = /*#__PURE__*/_styled__default.default("div", process.env
|
|
|
28
29
|
theme,
|
|
29
30
|
horizontalPlacement,
|
|
30
31
|
verticalPlacement,
|
|
32
|
+
maxWidth,
|
|
31
33
|
contentPadding,
|
|
32
|
-
|
|
34
|
+
hasInvertedSubTheme = true
|
|
33
35
|
} = _ref;
|
|
34
36
|
const animationDistance = verticalPlacement === "top" ? `${utils.ANIMATION_DISTANCE}px` : `-${utils.ANIMATION_DISTANCE}px`;
|
|
35
37
|
const animation = react.keyframes({
|
|
@@ -42,25 +44,28 @@ const StyledContainer = /*#__PURE__*/_styled__default.default("div", process.env
|
|
|
42
44
|
s: theme.variables.size.spacing.xxs,
|
|
43
45
|
m: theme.variables.size.spacing.s
|
|
44
46
|
};
|
|
47
|
+
const invertedSubThemeStyles = {
|
|
48
|
+
padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,
|
|
49
|
+
...(contentPadding && {
|
|
50
|
+
padding: contentPaddingMap[contentPadding]
|
|
51
|
+
}),
|
|
52
|
+
borderRadius: theme.variables.size.borderRadius.xs,
|
|
53
|
+
backgroundColor: theme.values.color.background.primary.default
|
|
54
|
+
};
|
|
45
55
|
return {
|
|
46
56
|
position: "absolute",
|
|
47
57
|
zIndex: _zindex.default.tooltip.value,
|
|
48
58
|
opacity: 0,
|
|
49
59
|
animation: `${ANIMATION_DURATION}ms ease-out forwards ${animation}`,
|
|
50
|
-
borderRadius: theme.variables.size.borderRadius.xs,
|
|
51
|
-
backgroundColor: theme.values.color.background.primary.default,
|
|
52
60
|
maxWidth,
|
|
53
61
|
width: "initial",
|
|
54
62
|
boxSizing: "border-box",
|
|
55
|
-
|
|
56
|
-
...(contentPadding && {
|
|
57
|
-
padding: contentPaddingMap[contentPadding]
|
|
58
|
-
}),
|
|
63
|
+
...(hasInvertedSubTheme && invertedSubThemeStyles),
|
|
59
64
|
...(horizontalPlacement === "center" && {
|
|
60
65
|
transform: "translate(-50%)"
|
|
61
66
|
})
|
|
62
67
|
};
|
|
63
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TooltipContent.tsx"],"names":[],"mappings":"AAuEwB","file":"TooltipContent.tsx","sourcesContent":["import React, {\n  useState,\n  useRef,\n  useLayoutEffect,\n  useEffect,\n  MutableRefObject,\n  ReactElement,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport { createPortal } from \"react-dom\";\nimport { useDocument } from \"../../shared/useDocument\";\nimport { useWindow } from \"../../shared/useWindow\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport zIndices from \"../../../build-tokens/_zindex.json\";\n\nimport {\n  ARROW_SIZE,\n  ARROW_OFFSET,\n  ANIMATION_DISTANCE,\n  getTooltipStyle,\n} from \"./utils\";\n\nexport type TooltipContentProps = {\n  content: ReactElement;\n  triggerRef: MutableRefObject<any>;\n  /* Placement */\n  placement?:\n    | \"auto\"\n    | \"top\"\n    | \"bottom\"\n    | \"top-left\"\n    | \"top-right\"\n    | \"bottom-left\"\n    | \"bottom-right\";\n  /* Custom portal container to render tooltip into */\n  portalContainer?: HTMLElement;\n  dataE2eTestId?: string;\n  dataDSId: string;\n  isVisible?: boolean;\n  tooltipId?: string;\n  \"aria-hidden\"?: boolean;\n  role?: string;\n  tabIndex?: number;\n  // Content padding\n  contentPadding?: \"s\" | \"m\";\n  maxWidth?: number;\n  onTooltipPointerEnter?: React.PointerEventHandler<HTMLDivElement>;\n  onTooltipPointerLeave?: React.PointerEventHandler<HTMLDivElement>;\n};\n\nexport type TooltipStyle = {\n  top: number;\n  left: number;\n  horizontalPlacement: \"left\" | \"right\" | \"center\";\n  verticalPlacement: \"top\" | \"bottom\";\n};\n\ntype StyledContainerProps = Pick<\n  TooltipContentProps,\n  \"contentPadding\" | \"maxWidth\"\n> & {\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n};\n\nconst ANIMATION_DURATION = 200;\nconst SHOW_HIDE_DELAY = 200;\nconst MAX_CONTENT_WIDTH = 224;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n  ({\n    theme,\n    horizontalPlacement,\n    verticalPlacement,\n    contentPadding,\n    maxWidth,\n  }) => {\n    const animationDistance =\n      verticalPlacement === \"top\"\n        ? `${ANIMATION_DISTANCE}px`\n        : `-${ANIMATION_DISTANCE}px`;\n    const animation = keyframes({\n      to: {\n        opacity: 1,\n        transform:\n          horizontalPlacement === \"center\"\n            ? `translate(-50%, ${animationDistance})`\n            : `translateY(${animationDistance})`,\n      },\n    });\n\n    const contentPaddingMap = {\n      s: theme.variables.size.spacing.xxs,\n      m: theme.variables.size.spacing.s,\n    };\n\n    return {\n      position: \"absolute\",\n      zIndex: zIndices.tooltip.value,\n      opacity: 0,\n      animation: `${ANIMATION_DURATION}ms ease-out forwards ${animation}`,\n      borderRadius: theme.variables.size.borderRadius.xs,\n      backgroundColor: theme.values.color.background.primary.default,\n      maxWidth,\n      width: \"initial\",\n      boxSizing: \"border-box\",\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,\n\n      ...(contentPadding && {\n        padding: contentPaddingMap[contentPadding],\n      }),\n      ...(horizontalPlacement === \"center\" && {\n        transform: \"translate(-50%)\",\n      }),\n    };\n  }\n);\n\ntype StyledArrowProps = {\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n};\n\nconst StyledArrow = styled.div<StyledArrowProps>(\n  ({ theme, verticalPlacement, horizontalPlacement }) => ({\n    position: \"absolute\",\n    width: 0,\n    height: 0,\n    borderLeft: `${ARROW_SIZE}px solid transparent`,\n    borderRight: `${ARROW_SIZE}px solid transparent`,\n\n    ...(verticalPlacement === \"top\" && {\n      top: \"100%\",\n      borderTop: `${ARROW_SIZE}px solid ${theme.values.color.background.primary.default}`,\n    }),\n\n    ...(verticalPlacement === \"bottom\" && {\n      top: `-${ARROW_SIZE}px`,\n      borderBottom: `${ARROW_SIZE}px solid ${theme.values.color.background.primary.default}`,\n    }),\n\n    ...(horizontalPlacement === \"center\" && {\n      left: \"50%\",\n      transform: \"translate(-50%)\",\n    }),\n\n    ...(horizontalPlacement === \"right\" && {\n      left: `${ARROW_OFFSET}px`,\n    }),\n\n    ...(horizontalPlacement === \"left\" && {\n      right: `${ARROW_OFFSET}px`,\n    }),\n  })\n);\n\nconst initialStyle: TooltipStyle = {\n  top: 0,\n  left: 0,\n  verticalPlacement: \"top\",\n  horizontalPlacement: \"center\",\n};\n\nlet lastTooltipHideTimestamp = 0;\n\n/* Disable animation if time between last close and new open is less than 500ms + SHOW_HIDE_DELAY */\nfunction getAnimationDuration() {\n  let animationDuration = `${ANIMATION_DURATION}ms`;\n\n  if (lastTooltipHideTimestamp) {\n    const timeSinceLastTooltip = Date.now() - lastTooltipHideTimestamp;\n\n    if (timeSinceLastTooltip < 500 + SHOW_HIDE_DELAY) {\n      animationDuration = \"0ms\";\n    }\n  }\n  return animationDuration;\n}\n\n/** This component is used to display the overlay for both Toggletip and Tooltip components */\nexport function TooltipContent({\n  placement = \"auto\",\n  content,\n  tooltipId,\n  triggerRef,\n  portalContainer,\n  dataE2eTestId,\n  dataDSId,\n  isVisible,\n  \"aria-hidden\": ariaHidden,\n  role,\n  tabIndex,\n  contentPadding,\n  maxWidth = MAX_CONTENT_WIDTH,\n  onTooltipPointerEnter,\n  onTooltipPointerLeave,\n}: TooltipContentProps): React.ReactElement {\n  const [style, setStyle] = useState(initialStyle);\n  const tooltipRef = useRef(null);\n  const document = useDocument();\n  const window = useWindow();\n  const debounceTimeoutId = useRef(null);\n\n  const calculateStyle = useCallback(() => {\n    if (triggerRef.current && tooltipRef.current) {\n      // calculate tooltip style\n      setStyle(\n        getTooltipStyle(placement, triggerRef, tooltipRef, document, window)\n      );\n      debounceTimeoutId.current = null;\n    }\n  }, [triggerRef, tooltipRef, document, window, placement]);\n\n  const debouncedCalculateStyle = useCallback(() => {\n    if (!debounceTimeoutId.current) {\n      debounceTimeoutId.current = setTimeout(calculateStyle, 200);\n    }\n  }, [calculateStyle]);\n\n  // This layout effect to re-render with updated position after determining content width\n  useLayoutEffect(() => {\n    if (isVisible) {\n      calculateStyle();\n    }\n  }, [isVisible, calculateStyle, contentPadding, content]);\n\n  // Re-position tooltip if it moves out of the viewport by 10% and on window resize\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      typeof IntersectionObserver !== \"undefined\" &&\n      isVisible &&\n      tooltipRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) => {\n          entries.forEach(() => {\n            calculateStyle();\n          });\n        },\n        {\n          threshold: 0.9,\n        }\n      );\n\n      observer.observe(tooltipRef.current);\n      window.addEventListener(\"resize\", debouncedCalculateStyle);\n      window.addEventListener(\"scroll\", debouncedCalculateStyle, true); // use capture here to detect scroll on any parent\n    } else if (!isVisible) {\n      // log time when tooltip closes\n      lastTooltipHideTimestamp = Date.now();\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n      window.removeEventListener(\"resize\", debouncedCalculateStyle);\n      window.removeEventListener(\"scroll\", debouncedCalculateStyle);\n      clearTimeout(debounceTimeoutId.current);\n    };\n  }, [isVisible, calculateStyle, debouncedCalculateStyle, window, tooltipRef]);\n\n  let portal = null;\n\n  if (isVisible) {\n    const tooltipElm = (\n      <SubThemeProvider name=\"inverted\">\n        <StyledContainer\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id={dataDSId}\n          style={{\n            top: style.top,\n            left: style.left,\n            animationDuration: getAnimationDuration(),\n          }}\n          ref={tooltipRef}\n          id={tooltipId}\n          role={role}\n          aria-hidden={ariaHidden}\n          tabIndex={tabIndex}\n          horizontalPlacement={style.horizontalPlacement}\n          verticalPlacement={style.verticalPlacement}\n          contentPadding={contentPadding}\n          maxWidth={maxWidth}\n          onPointerEnter={onTooltipPointerEnter}\n          onPointerLeave={onTooltipPointerLeave}\n        >\n          {content}\n          <StyledArrow\n            horizontalPlacement={style.horizontalPlacement}\n            verticalPlacement={style.verticalPlacement}\n          />\n        </StyledContainer>\n      </SubThemeProvider>\n    );\n\n    portal = createPortal(tooltipElm, portalContainer || document.body);\n  }\n\n  return portal;\n}\n"]} */");
|
|
68
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TooltipContent.tsx"],"names":[],"mappings":"AA+EwB","file":"TooltipContent.tsx","sourcesContent":["import React, {\n  MutableRefObject,\n  ReactElement,\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport { createPortal } from \"react-dom\";\nimport { useDocument } from \"../../shared/useDocument\";\nimport { useWindow } from \"../../shared/useWindow\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport zIndices from \"../../../build-tokens/_zindex.json\";\n\nimport {\n  ANIMATION_DISTANCE,\n  ARROW_SIZE,\n  ARROW_SIZE_BIG,\n  getArrowOffset,\n  getTooltipStyle,\n} from \"./utils\";\nimport { Container } from \"../Container/Container\";\nimport { BorderRadius } from \"../../types\";\n\nexport type TooltipContentProps = {\n  content: ReactElement;\n  triggerRef: MutableRefObject<any>;\n  /* Placement */\n  placement?:\n    | \"auto\"\n    | \"top\"\n    | \"bottom\"\n    | \"top-left\"\n    | \"top-right\"\n    | \"bottom-left\"\n    | \"bottom-right\";\n  /* Custom portal container to render tooltip into */\n  portalContainer?: HTMLElement;\n  dataE2eTestId?: string;\n  dataDSId: string;\n  isVisible?: boolean;\n  tooltipId?: string;\n  \"aria-hidden\"?: boolean;\n  role?: string;\n  tabIndex?: number;\n  // Content padding\n  contentPadding?: \"s\" | \"m\";\n  hasInvertedSubTheme?: boolean;\n  maxWidth?: number;\n  defaultVerticalPlacement?: TooltipStyle[\"verticalPlacement\"];\n  onTooltipPointerEnter?: React.PointerEventHandler<HTMLDivElement>;\n  onTooltipPointerLeave?: React.PointerEventHandler<HTMLDivElement>;\n  hideArrow?: boolean;\n  borderRadius?: BorderRadius;\n};\n\nexport type TooltipStyle = {\n  top: number;\n  left: number;\n  horizontalPlacement: \"left\" | \"right\" | \"center\";\n  verticalPlacement: \"top\" | \"bottom\";\n};\n\ntype StyledContainerProps = Pick<\n  TooltipContentProps,\n  \"contentPadding\" | \"maxWidth\" | \"hasInvertedSubTheme\"\n> & {\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n};\n\nconst ANIMATION_DURATION = 200;\nconst SHOW_HIDE_DELAY = 200;\nconst MAX_CONTENT_WIDTH = 224;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n  ({\n    theme,\n    horizontalPlacement,\n    verticalPlacement,\n    maxWidth,\n    contentPadding,\n    hasInvertedSubTheme = true,\n  }) => {\n    const animationDistance =\n      verticalPlacement === \"top\"\n        ? `${ANIMATION_DISTANCE}px`\n        : `-${ANIMATION_DISTANCE}px`;\n    const animation = keyframes({\n      to: {\n        opacity: 1,\n        transform:\n          horizontalPlacement === \"center\"\n            ? `translate(-50%, ${animationDistance})`\n            : `translateY(${animationDistance})`,\n      },\n    });\n\n    const contentPaddingMap = {\n      s: theme.variables.size.spacing.xxs,\n      m: theme.variables.size.spacing.s,\n    };\n\n    const invertedSubThemeStyles = {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,\n      ...(contentPadding && {\n        padding: contentPaddingMap[contentPadding],\n      }),\n      borderRadius: theme.variables.size.borderRadius.xs,\n      backgroundColor: theme.values.color.background.primary.default,\n    };\n\n    return {\n      position: \"absolute\",\n      zIndex: zIndices.tooltip.value,\n      opacity: 0,\n      animation: `${ANIMATION_DURATION}ms ease-out forwards ${animation}`,\n      maxWidth,\n      width: \"initial\",\n      boxSizing: \"border-box\",\n      ...(hasInvertedSubTheme && invertedSubThemeStyles),\n      ...(horizontalPlacement === \"center\" && {\n        transform: \"translate(-50%)\",\n      }),\n    };\n  }\n);\n\ntype StyledArrowProps = {\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  size?: 0 | typeof ARROW_SIZE | typeof ARROW_SIZE_BIG;\n};\n\nconst StyledArrow = styled.div<StyledArrowProps>(\n  ({ theme, verticalPlacement, horizontalPlacement, size = ARROW_SIZE }) => {\n    const offset = getArrowOffset(size);\n    return {\n      position: \"absolute\",\n      width: 0,\n      height: 0,\n      borderLeft: `${size}px solid transparent`,\n      borderRight: `${size}px solid transparent`,\n\n      ...(verticalPlacement === \"top\" && {\n        top: \"100%\",\n        borderTop: `${size}px solid ${theme.values.color.background.primary.default}`,\n      }),\n\n      ...(verticalPlacement === \"bottom\" && {\n        top: `-${size}px`,\n        borderBottom: `${size}px solid ${theme.values.color.background.primary.default}`,\n      }),\n\n      ...(horizontalPlacement === \"center\" && {\n        left: \"50%\",\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(horizontalPlacement === \"right\" && {\n        left: `${offset}px`,\n      }),\n\n      ...(horizontalPlacement === \"left\" && {\n        right: `${offset}px`,\n      }),\n    };\n  }\n);\n\nconst initialStyle: TooltipStyle = {\n  top: 0,\n  left: 0,\n  verticalPlacement: \"top\",\n  horizontalPlacement: \"center\",\n};\n\nlet lastTooltipHideTimestamp = 0;\n\n/* Disable animation if time between last close and new open is less than 500ms + SHOW_HIDE_DELAY */\nfunction getAnimationDuration() {\n  let animationDuration = `${ANIMATION_DURATION}ms`;\n\n  if (lastTooltipHideTimestamp) {\n    const timeSinceLastTooltip = Date.now() - lastTooltipHideTimestamp;\n\n    if (timeSinceLastTooltip < 500 + SHOW_HIDE_DELAY) {\n      animationDuration = \"0ms\";\n    }\n  }\n  return animationDuration;\n}\n\n/** This component is used to display the overlay for both Toggletip and Tooltip components */\nexport function TooltipContent({\n  placement = \"auto\",\n  content,\n  tooltipId,\n  triggerRef,\n  portalContainer,\n  dataE2eTestId,\n  dataDSId,\n  isVisible,\n  \"aria-hidden\": ariaHidden,\n  role,\n  tabIndex,\n  contentPadding,\n  maxWidth = MAX_CONTENT_WIDTH,\n  hasInvertedSubTheme = true,\n  defaultVerticalPlacement,\n  onTooltipPointerEnter,\n  onTooltipPointerLeave,\n  hideArrow = false,\n  borderRadius = \"xs\",\n}: TooltipContentProps): React.ReactElement {\n  const [style, setStyle] = useState(initialStyle);\n  const tooltipRef = useRef(null);\n  const document = useDocument();\n  const window = useWindow();\n  const debounceTimeoutId = useRef(null);\n\n  const arrowSize = useMemo(() => {\n    if (hideArrow) {\n      return 0;\n    }\n    return hasInvertedSubTheme ? ARROW_SIZE : ARROW_SIZE_BIG;\n  }, [hasInvertedSubTheme, hideArrow]);\n\n  const calculateStyle = useCallback(() => {\n    if (triggerRef.current && tooltipRef.current) {\n      // calculate tooltip style\n      setStyle(\n        getTooltipStyle(\n          placement,\n          defaultVerticalPlacement,\n          triggerRef,\n          tooltipRef,\n          document,\n          window,\n          arrowSize\n        )\n      );\n      debounceTimeoutId.current = null;\n    }\n  }, [\n    triggerRef,\n    tooltipRef,\n    document,\n    window,\n    placement,\n    arrowSize,\n    defaultVerticalPlacement,\n  ]);\n\n  const debouncedCalculateStyle = useCallback(() => {\n    if (!debounceTimeoutId.current) {\n      debounceTimeoutId.current = setTimeout(calculateStyle, 200);\n    }\n  }, [calculateStyle]);\n\n  // This layout effect to re-render with updated position after determining content width\n  useLayoutEffect(() => {\n    if (isVisible) {\n      calculateStyle();\n    }\n  }, [isVisible, calculateStyle, contentPadding, content]);\n\n  // Re-position tooltip if it moves out of the viewport by 10% and on window resize\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      typeof IntersectionObserver !== \"undefined\" &&\n      isVisible &&\n      tooltipRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) => {\n          entries.forEach(() => {\n            calculateStyle();\n          });\n        },\n        {\n          threshold: 0.9,\n        }\n      );\n\n      observer.observe(tooltipRef.current);\n      window.addEventListener(\"resize\", debouncedCalculateStyle);\n      window.addEventListener(\"scroll\", debouncedCalculateStyle, true); // use capture here to detect scroll on any parent\n    } else if (!isVisible) {\n      // log time when tooltip closes\n      lastTooltipHideTimestamp = Date.now();\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n      window.removeEventListener(\"resize\", debouncedCalculateStyle);\n      window.removeEventListener(\"scroll\", debouncedCalculateStyle);\n      clearTimeout(debounceTimeoutId.current);\n    };\n  }, [isVisible, calculateStyle, debouncedCalculateStyle, window, tooltipRef]);\n\n  let portal = null;\n\n  const OuterWrapper = useMemo(\n    () =>\n      ({ children }: { children: ReactElement }) =>\n        hasInvertedSubTheme ? (\n          <SubThemeProvider name=\"inverted\">{children}</SubThemeProvider>\n        ) : (\n          <>{children}</>\n        ),\n    [hasInvertedSubTheme]\n  );\n\n  if (isVisible) {\n    const tooltipElm = (\n      <OuterWrapper>\n        <StyledContainer\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id={dataDSId}\n          style={{\n            top: style.top,\n            left: style.left,\n            animationDuration: getAnimationDuration(),\n          }}\n          ref={tooltipRef}\n          id={tooltipId}\n          role={role}\n          aria-hidden={ariaHidden}\n          hasInvertedSubTheme={hasInvertedSubTheme}\n          tabIndex={tabIndex}\n          horizontalPlacement={style.horizontalPlacement}\n          verticalPlacement={style.verticalPlacement}\n          maxWidth={maxWidth}\n          contentPadding={contentPadding}\n          onPointerEnter={onTooltipPointerEnter}\n          onPointerLeave={onTooltipPointerLeave}\n        >\n          {hasInvertedSubTheme ? (\n            content\n          ) : (\n            <Container elevation={3} borderRadius={borderRadius}>\n              {content}\n            </Container>\n          )}\n          {!hideArrow && (\n            <StyledArrow\n              data-e2e-test-id={`${dataE2eTestId}_arrow`}\n              horizontalPlacement={style.horizontalPlacement}\n              verticalPlacement={style.verticalPlacement}\n              size={arrowSize}\n            />\n          )}\n        </StyledContainer>\n      </OuterWrapper>\n    );\n\n    portal = createPortal(tooltipElm, portalContainer || document.body);\n  }\n\n  return portal;\n}\n"]} */");
|
|
64
69
|
const StyledArrow = /*#__PURE__*/_styled__default.default("div", process.env.NODE_ENV === "production" ? {
|
|
65
70
|
target: "e1k814k40"
|
|
66
71
|
} : {
|
|
@@ -70,34 +75,36 @@ const StyledArrow = /*#__PURE__*/_styled__default.default("div", process.env.NOD
|
|
|
70
75
|
let {
|
|
71
76
|
theme,
|
|
72
77
|
verticalPlacement,
|
|
73
|
-
horizontalPlacement
|
|
78
|
+
horizontalPlacement,
|
|
79
|
+
size = utils.ARROW_SIZE
|
|
74
80
|
} = _ref2;
|
|
81
|
+
const offset = utils.getArrowOffset(size);
|
|
75
82
|
return {
|
|
76
83
|
position: "absolute",
|
|
77
84
|
width: 0,
|
|
78
85
|
height: 0,
|
|
79
|
-
borderLeft: `${
|
|
80
|
-
borderRight: `${
|
|
86
|
+
borderLeft: `${size}px solid transparent`,
|
|
87
|
+
borderRight: `${size}px solid transparent`,
|
|
81
88
|
...(verticalPlacement === "top" && {
|
|
82
89
|
top: "100%",
|
|
83
|
-
borderTop: `${
|
|
90
|
+
borderTop: `${size}px solid ${theme.values.color.background.primary.default}`
|
|
84
91
|
}),
|
|
85
92
|
...(verticalPlacement === "bottom" && {
|
|
86
|
-
top: `-${
|
|
87
|
-
borderBottom: `${
|
|
93
|
+
top: `-${size}px`,
|
|
94
|
+
borderBottom: `${size}px solid ${theme.values.color.background.primary.default}`
|
|
88
95
|
}),
|
|
89
96
|
...(horizontalPlacement === "center" && {
|
|
90
97
|
left: "50%",
|
|
91
98
|
transform: "translate(-50%)"
|
|
92
99
|
}),
|
|
93
100
|
...(horizontalPlacement === "right" && {
|
|
94
|
-
left: `${
|
|
101
|
+
left: `${offset}px`
|
|
95
102
|
}),
|
|
96
103
|
...(horizontalPlacement === "left" && {
|
|
97
|
-
right: `${
|
|
104
|
+
right: `${offset}px`
|
|
98
105
|
})
|
|
99
106
|
};
|
|
100
|
-
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TooltipContent.tsx"],"names":[],"mappings":"AA6HoB","file":"TooltipContent.tsx","sourcesContent":["import React, {\n  useState,\n  useRef,\n  useLayoutEffect,\n  useEffect,\n  MutableRefObject,\n  ReactElement,\n  useCallback,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport { createPortal } from \"react-dom\";\nimport { useDocument } from \"../../shared/useDocument\";\nimport { useWindow } from \"../../shared/useWindow\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport zIndices from \"../../../build-tokens/_zindex.json\";\n\nimport {\n  ARROW_SIZE,\n  ARROW_OFFSET,\n  ANIMATION_DISTANCE,\n  getTooltipStyle,\n} from \"./utils\";\n\nexport type TooltipContentProps = {\n  content: ReactElement;\n  triggerRef: MutableRefObject<any>;\n  /* Placement */\n  placement?:\n    | \"auto\"\n    | \"top\"\n    | \"bottom\"\n    | \"top-left\"\n    | \"top-right\"\n    | \"bottom-left\"\n    | \"bottom-right\";\n  /* Custom portal container to render tooltip into */\n  portalContainer?: HTMLElement;\n  dataE2eTestId?: string;\n  dataDSId: string;\n  isVisible?: boolean;\n  tooltipId?: string;\n  \"aria-hidden\"?: boolean;\n  role?: string;\n  tabIndex?: number;\n  // Content padding\n  contentPadding?: \"s\" | \"m\";\n  maxWidth?: number;\n  onTooltipPointerEnter?: React.PointerEventHandler<HTMLDivElement>;\n  onTooltipPointerLeave?: React.PointerEventHandler<HTMLDivElement>;\n};\n\nexport type TooltipStyle = {\n  top: number;\n  left: number;\n  horizontalPlacement: \"left\" | \"right\" | \"center\";\n  verticalPlacement: \"top\" | \"bottom\";\n};\n\ntype StyledContainerProps = Pick<\n  TooltipContentProps,\n  \"contentPadding\" | \"maxWidth\"\n> & {\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n};\n\nconst ANIMATION_DURATION = 200;\nconst SHOW_HIDE_DELAY = 200;\nconst MAX_CONTENT_WIDTH = 224;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n  ({\n    theme,\n    horizontalPlacement,\n    verticalPlacement,\n    contentPadding,\n    maxWidth,\n  }) => {\n    const animationDistance =\n      verticalPlacement === \"top\"\n        ? `${ANIMATION_DISTANCE}px`\n        : `-${ANIMATION_DISTANCE}px`;\n    const animation = keyframes({\n      to: {\n        opacity: 1,\n        transform:\n          horizontalPlacement === \"center\"\n            ? `translate(-50%, ${animationDistance})`\n            : `translateY(${animationDistance})`,\n      },\n    });\n\n    const contentPaddingMap = {\n      s: theme.variables.size.spacing.xxs,\n      m: theme.variables.size.spacing.s,\n    };\n\n    return {\n      position: \"absolute\",\n      zIndex: zIndices.tooltip.value,\n      opacity: 0,\n      animation: `${ANIMATION_DURATION}ms ease-out forwards ${animation}`,\n      borderRadius: theme.variables.size.borderRadius.xs,\n      backgroundColor: theme.values.color.background.primary.default,\n      maxWidth,\n      width: \"initial\",\n      boxSizing: \"border-box\",\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,\n\n      ...(contentPadding && {\n        padding: contentPaddingMap[contentPadding],\n      }),\n      ...(horizontalPlacement === \"center\" && {\n        transform: \"translate(-50%)\",\n      }),\n    };\n  }\n);\n\ntype StyledArrowProps = {\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n};\n\nconst StyledArrow = styled.div<StyledArrowProps>(\n  ({ theme, verticalPlacement, horizontalPlacement }) => ({\n    position: \"absolute\",\n    width: 0,\n    height: 0,\n    borderLeft: `${ARROW_SIZE}px solid transparent`,\n    borderRight: `${ARROW_SIZE}px solid transparent`,\n\n    ...(verticalPlacement === \"top\" && {\n      top: \"100%\",\n      borderTop: `${ARROW_SIZE}px solid ${theme.values.color.background.primary.default}`,\n    }),\n\n    ...(verticalPlacement === \"bottom\" && {\n      top: `-${ARROW_SIZE}px`,\n      borderBottom: `${ARROW_SIZE}px solid ${theme.values.color.background.primary.default}`,\n    }),\n\n    ...(horizontalPlacement === \"center\" && {\n      left: \"50%\",\n      transform: \"translate(-50%)\",\n    }),\n\n    ...(horizontalPlacement === \"right\" && {\n      left: `${ARROW_OFFSET}px`,\n    }),\n\n    ...(horizontalPlacement === \"left\" && {\n      right: `${ARROW_OFFSET}px`,\n    }),\n  })\n);\n\nconst initialStyle: TooltipStyle = {\n  top: 0,\n  left: 0,\n  verticalPlacement: \"top\",\n  horizontalPlacement: \"center\",\n};\n\nlet lastTooltipHideTimestamp = 0;\n\n/* Disable animation if time between last close and new open is less than 500ms + SHOW_HIDE_DELAY */\nfunction getAnimationDuration() {\n  let animationDuration = `${ANIMATION_DURATION}ms`;\n\n  if (lastTooltipHideTimestamp) {\n    const timeSinceLastTooltip = Date.now() - lastTooltipHideTimestamp;\n\n    if (timeSinceLastTooltip < 500 + SHOW_HIDE_DELAY) {\n      animationDuration = \"0ms\";\n    }\n  }\n  return animationDuration;\n}\n\n/** This component is used to display the overlay for both Toggletip and Tooltip components */\nexport function TooltipContent({\n  placement = \"auto\",\n  content,\n  tooltipId,\n  triggerRef,\n  portalContainer,\n  dataE2eTestId,\n  dataDSId,\n  isVisible,\n  \"aria-hidden\": ariaHidden,\n  role,\n  tabIndex,\n  contentPadding,\n  maxWidth = MAX_CONTENT_WIDTH,\n  onTooltipPointerEnter,\n  onTooltipPointerLeave,\n}: TooltipContentProps): React.ReactElement {\n  const [style, setStyle] = useState(initialStyle);\n  const tooltipRef = useRef(null);\n  const document = useDocument();\n  const window = useWindow();\n  const debounceTimeoutId = useRef(null);\n\n  const calculateStyle = useCallback(() => {\n    if (triggerRef.current && tooltipRef.current) {\n      // calculate tooltip style\n      setStyle(\n        getTooltipStyle(placement, triggerRef, tooltipRef, document, window)\n      );\n      debounceTimeoutId.current = null;\n    }\n  }, [triggerRef, tooltipRef, document, window, placement]);\n\n  const debouncedCalculateStyle = useCallback(() => {\n    if (!debounceTimeoutId.current) {\n      debounceTimeoutId.current = setTimeout(calculateStyle, 200);\n    }\n  }, [calculateStyle]);\n\n  // This layout effect to re-render with updated position after determining content width\n  useLayoutEffect(() => {\n    if (isVisible) {\n      calculateStyle();\n    }\n  }, [isVisible, calculateStyle, contentPadding, content]);\n\n  // Re-position tooltip if it moves out of the viewport by 10% and on window resize\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      typeof IntersectionObserver !== \"undefined\" &&\n      isVisible &&\n      tooltipRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) => {\n          entries.forEach(() => {\n            calculateStyle();\n          });\n        },\n        {\n          threshold: 0.9,\n        }\n      );\n\n      observer.observe(tooltipRef.current);\n      window.addEventListener(\"resize\", debouncedCalculateStyle);\n      window.addEventListener(\"scroll\", debouncedCalculateStyle, true); // use capture here to detect scroll on any parent\n    } else if (!isVisible) {\n      // log time when tooltip closes\n      lastTooltipHideTimestamp = Date.now();\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n      window.removeEventListener(\"resize\", debouncedCalculateStyle);\n      window.removeEventListener(\"scroll\", debouncedCalculateStyle);\n      clearTimeout(debounceTimeoutId.current);\n    };\n  }, [isVisible, calculateStyle, debouncedCalculateStyle, window, tooltipRef]);\n\n  let portal = null;\n\n  if (isVisible) {\n    const tooltipElm = (\n      <SubThemeProvider name=\"inverted\">\n        <StyledContainer\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id={dataDSId}\n          style={{\n            top: style.top,\n            left: style.left,\n            animationDuration: getAnimationDuration(),\n          }}\n          ref={tooltipRef}\n          id={tooltipId}\n          role={role}\n          aria-hidden={ariaHidden}\n          tabIndex={tabIndex}\n          horizontalPlacement={style.horizontalPlacement}\n          verticalPlacement={style.verticalPlacement}\n          contentPadding={contentPadding}\n          maxWidth={maxWidth}\n          onPointerEnter={onTooltipPointerEnter}\n          onPointerLeave={onTooltipPointerLeave}\n        >\n          {content}\n          <StyledArrow\n            horizontalPlacement={style.horizontalPlacement}\n            verticalPlacement={style.verticalPlacement}\n          />\n        </StyledContainer>\n      </SubThemeProvider>\n    );\n\n    portal = createPortal(tooltipElm, portalContainer || document.body);\n  }\n\n  return portal;\n}\n"]} */");
|
|
107
|
+
}, process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["TooltipContent.tsx"],"names":[],"mappings":"AA0IoB","file":"TooltipContent.tsx","sourcesContent":["import React, {\n  MutableRefObject,\n  ReactElement,\n  useCallback,\n  useEffect,\n  useLayoutEffect,\n  useMemo,\n  useRef,\n  useState,\n} from \"react\";\nimport styled from \"@emotion/styled\";\nimport { keyframes } from \"@emotion/react\";\nimport { createPortal } from \"react-dom\";\nimport { useDocument } from \"../../shared/useDocument\";\nimport { useWindow } from \"../../shared/useWindow\";\nimport { SubThemeProvider } from \"../SubThemeProvider/SubThemeProvider\";\nimport zIndices from \"../../../build-tokens/_zindex.json\";\n\nimport {\n  ANIMATION_DISTANCE,\n  ARROW_SIZE,\n  ARROW_SIZE_BIG,\n  getArrowOffset,\n  getTooltipStyle,\n} from \"./utils\";\nimport { Container } from \"../Container/Container\";\nimport { BorderRadius } from \"../../types\";\n\nexport type TooltipContentProps = {\n  content: ReactElement;\n  triggerRef: MutableRefObject<any>;\n  /* Placement */\n  placement?:\n    | \"auto\"\n    | \"top\"\n    | \"bottom\"\n    | \"top-left\"\n    | \"top-right\"\n    | \"bottom-left\"\n    | \"bottom-right\";\n  /* Custom portal container to render tooltip into */\n  portalContainer?: HTMLElement;\n  dataE2eTestId?: string;\n  dataDSId: string;\n  isVisible?: boolean;\n  tooltipId?: string;\n  \"aria-hidden\"?: boolean;\n  role?: string;\n  tabIndex?: number;\n  // Content padding\n  contentPadding?: \"s\" | \"m\";\n  hasInvertedSubTheme?: boolean;\n  maxWidth?: number;\n  defaultVerticalPlacement?: TooltipStyle[\"verticalPlacement\"];\n  onTooltipPointerEnter?: React.PointerEventHandler<HTMLDivElement>;\n  onTooltipPointerLeave?: React.PointerEventHandler<HTMLDivElement>;\n  hideArrow?: boolean;\n  borderRadius?: BorderRadius;\n};\n\nexport type TooltipStyle = {\n  top: number;\n  left: number;\n  horizontalPlacement: \"left\" | \"right\" | \"center\";\n  verticalPlacement: \"top\" | \"bottom\";\n};\n\ntype StyledContainerProps = Pick<\n  TooltipContentProps,\n  \"contentPadding\" | \"maxWidth\" | \"hasInvertedSubTheme\"\n> & {\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n};\n\nconst ANIMATION_DURATION = 200;\nconst SHOW_HIDE_DELAY = 200;\nconst MAX_CONTENT_WIDTH = 224;\n\nconst StyledContainer = styled.div<StyledContainerProps>(\n  ({\n    theme,\n    horizontalPlacement,\n    verticalPlacement,\n    maxWidth,\n    contentPadding,\n    hasInvertedSubTheme = true,\n  }) => {\n    const animationDistance =\n      verticalPlacement === \"top\"\n        ? `${ANIMATION_DISTANCE}px`\n        : `-${ANIMATION_DISTANCE}px`;\n    const animation = keyframes({\n      to: {\n        opacity: 1,\n        transform:\n          horizontalPlacement === \"center\"\n            ? `translate(-50%, ${animationDistance})`\n            : `translateY(${animationDistance})`,\n      },\n    });\n\n    const contentPaddingMap = {\n      s: theme.variables.size.spacing.xxs,\n      m: theme.variables.size.spacing.s,\n    };\n\n    const invertedSubThemeStyles = {\n      padding: `${theme.variables.size.spacing.xs} ${theme.variables.size.spacing.s}`,\n      ...(contentPadding && {\n        padding: contentPaddingMap[contentPadding],\n      }),\n      borderRadius: theme.variables.size.borderRadius.xs,\n      backgroundColor: theme.values.color.background.primary.default,\n    };\n\n    return {\n      position: \"absolute\",\n      zIndex: zIndices.tooltip.value,\n      opacity: 0,\n      animation: `${ANIMATION_DURATION}ms ease-out forwards ${animation}`,\n      maxWidth,\n      width: \"initial\",\n      boxSizing: \"border-box\",\n      ...(hasInvertedSubTheme && invertedSubThemeStyles),\n      ...(horizontalPlacement === \"center\" && {\n        transform: \"translate(-50%)\",\n      }),\n    };\n  }\n);\n\ntype StyledArrowProps = {\n  verticalPlacement: TooltipStyle[\"verticalPlacement\"];\n  horizontalPlacement: TooltipStyle[\"horizontalPlacement\"];\n  size?: 0 | typeof ARROW_SIZE | typeof ARROW_SIZE_BIG;\n};\n\nconst StyledArrow = styled.div<StyledArrowProps>(\n  ({ theme, verticalPlacement, horizontalPlacement, size = ARROW_SIZE }) => {\n    const offset = getArrowOffset(size);\n    return {\n      position: \"absolute\",\n      width: 0,\n      height: 0,\n      borderLeft: `${size}px solid transparent`,\n      borderRight: `${size}px solid transparent`,\n\n      ...(verticalPlacement === \"top\" && {\n        top: \"100%\",\n        borderTop: `${size}px solid ${theme.values.color.background.primary.default}`,\n      }),\n\n      ...(verticalPlacement === \"bottom\" && {\n        top: `-${size}px`,\n        borderBottom: `${size}px solid ${theme.values.color.background.primary.default}`,\n      }),\n\n      ...(horizontalPlacement === \"center\" && {\n        left: \"50%\",\n        transform: \"translate(-50%)\",\n      }),\n\n      ...(horizontalPlacement === \"right\" && {\n        left: `${offset}px`,\n      }),\n\n      ...(horizontalPlacement === \"left\" && {\n        right: `${offset}px`,\n      }),\n    };\n  }\n);\n\nconst initialStyle: TooltipStyle = {\n  top: 0,\n  left: 0,\n  verticalPlacement: \"top\",\n  horizontalPlacement: \"center\",\n};\n\nlet lastTooltipHideTimestamp = 0;\n\n/* Disable animation if time between last close and new open is less than 500ms + SHOW_HIDE_DELAY */\nfunction getAnimationDuration() {\n  let animationDuration = `${ANIMATION_DURATION}ms`;\n\n  if (lastTooltipHideTimestamp) {\n    const timeSinceLastTooltip = Date.now() - lastTooltipHideTimestamp;\n\n    if (timeSinceLastTooltip < 500 + SHOW_HIDE_DELAY) {\n      animationDuration = \"0ms\";\n    }\n  }\n  return animationDuration;\n}\n\n/** This component is used to display the overlay for both Toggletip and Tooltip components */\nexport function TooltipContent({\n  placement = \"auto\",\n  content,\n  tooltipId,\n  triggerRef,\n  portalContainer,\n  dataE2eTestId,\n  dataDSId,\n  isVisible,\n  \"aria-hidden\": ariaHidden,\n  role,\n  tabIndex,\n  contentPadding,\n  maxWidth = MAX_CONTENT_WIDTH,\n  hasInvertedSubTheme = true,\n  defaultVerticalPlacement,\n  onTooltipPointerEnter,\n  onTooltipPointerLeave,\n  hideArrow = false,\n  borderRadius = \"xs\",\n}: TooltipContentProps): React.ReactElement {\n  const [style, setStyle] = useState(initialStyle);\n  const tooltipRef = useRef(null);\n  const document = useDocument();\n  const window = useWindow();\n  const debounceTimeoutId = useRef(null);\n\n  const arrowSize = useMemo(() => {\n    if (hideArrow) {\n      return 0;\n    }\n    return hasInvertedSubTheme ? ARROW_SIZE : ARROW_SIZE_BIG;\n  }, [hasInvertedSubTheme, hideArrow]);\n\n  const calculateStyle = useCallback(() => {\n    if (triggerRef.current && tooltipRef.current) {\n      // calculate tooltip style\n      setStyle(\n        getTooltipStyle(\n          placement,\n          defaultVerticalPlacement,\n          triggerRef,\n          tooltipRef,\n          document,\n          window,\n          arrowSize\n        )\n      );\n      debounceTimeoutId.current = null;\n    }\n  }, [\n    triggerRef,\n    tooltipRef,\n    document,\n    window,\n    placement,\n    arrowSize,\n    defaultVerticalPlacement,\n  ]);\n\n  const debouncedCalculateStyle = useCallback(() => {\n    if (!debounceTimeoutId.current) {\n      debounceTimeoutId.current = setTimeout(calculateStyle, 200);\n    }\n  }, [calculateStyle]);\n\n  // This layout effect to re-render with updated position after determining content width\n  useLayoutEffect(() => {\n    if (isVisible) {\n      calculateStyle();\n    }\n  }, [isVisible, calculateStyle, contentPadding, content]);\n\n  // Re-position tooltip if it moves out of the viewport by 10% and on window resize\n  useEffect(() => {\n    let observer: IntersectionObserver;\n\n    if (\n      typeof IntersectionObserver !== \"undefined\" &&\n      isVisible &&\n      tooltipRef.current\n    ) {\n      observer = new IntersectionObserver(\n        (entries) => {\n          entries.forEach(() => {\n            calculateStyle();\n          });\n        },\n        {\n          threshold: 0.9,\n        }\n      );\n\n      observer.observe(tooltipRef.current);\n      window.addEventListener(\"resize\", debouncedCalculateStyle);\n      window.addEventListener(\"scroll\", debouncedCalculateStyle, true); // use capture here to detect scroll on any parent\n    } else if (!isVisible) {\n      // log time when tooltip closes\n      lastTooltipHideTimestamp = Date.now();\n    }\n\n    return () => {\n      if (observer) {\n        observer.disconnect();\n      }\n      window.removeEventListener(\"resize\", debouncedCalculateStyle);\n      window.removeEventListener(\"scroll\", debouncedCalculateStyle);\n      clearTimeout(debounceTimeoutId.current);\n    };\n  }, [isVisible, calculateStyle, debouncedCalculateStyle, window, tooltipRef]);\n\n  let portal = null;\n\n  const OuterWrapper = useMemo(\n    () =>\n      ({ children }: { children: ReactElement }) =>\n        hasInvertedSubTheme ? (\n          <SubThemeProvider name=\"inverted\">{children}</SubThemeProvider>\n        ) : (\n          <>{children}</>\n        ),\n    [hasInvertedSubTheme]\n  );\n\n  if (isVisible) {\n    const tooltipElm = (\n      <OuterWrapper>\n        <StyledContainer\n          data-e2e-test-id={dataE2eTestId}\n          data-ds-id={dataDSId}\n          style={{\n            top: style.top,\n            left: style.left,\n            animationDuration: getAnimationDuration(),\n          }}\n          ref={tooltipRef}\n          id={tooltipId}\n          role={role}\n          aria-hidden={ariaHidden}\n          hasInvertedSubTheme={hasInvertedSubTheme}\n          tabIndex={tabIndex}\n          horizontalPlacement={style.horizontalPlacement}\n          verticalPlacement={style.verticalPlacement}\n          maxWidth={maxWidth}\n          contentPadding={contentPadding}\n          onPointerEnter={onTooltipPointerEnter}\n          onPointerLeave={onTooltipPointerLeave}\n        >\n          {hasInvertedSubTheme ? (\n            content\n          ) : (\n            <Container elevation={3} borderRadius={borderRadius}>\n              {content}\n            </Container>\n          )}\n          {!hideArrow && (\n            <StyledArrow\n              data-e2e-test-id={`${dataE2eTestId}_arrow`}\n              horizontalPlacement={style.horizontalPlacement}\n              verticalPlacement={style.verticalPlacement}\n              size={arrowSize}\n            />\n          )}\n        </StyledContainer>\n      </OuterWrapper>\n    );\n\n    portal = createPortal(tooltipElm, portalContainer || document.body);\n  }\n\n  return portal;\n}\n"]} */");
|
|
101
108
|
const initialStyle = {
|
|
102
109
|
top: 0,
|
|
103
110
|
left: 0,
|
|
@@ -134,21 +141,31 @@ function TooltipContent(_ref3) {
|
|
|
134
141
|
tabIndex,
|
|
135
142
|
contentPadding,
|
|
136
143
|
maxWidth = MAX_CONTENT_WIDTH,
|
|
144
|
+
hasInvertedSubTheme = true,
|
|
145
|
+
defaultVerticalPlacement,
|
|
137
146
|
onTooltipPointerEnter,
|
|
138
|
-
onTooltipPointerLeave
|
|
147
|
+
onTooltipPointerLeave,
|
|
148
|
+
hideArrow = false,
|
|
149
|
+
borderRadius = "xs"
|
|
139
150
|
} = _ref3;
|
|
140
151
|
const [style, setStyle] = React.useState(initialStyle);
|
|
141
152
|
const tooltipRef = React.useRef(null);
|
|
142
153
|
const document = useDocument.useDocument();
|
|
143
154
|
const window = useWindow.useWindow();
|
|
144
155
|
const debounceTimeoutId = React.useRef(null);
|
|
156
|
+
const arrowSize = React.useMemo(() => {
|
|
157
|
+
if (hideArrow) {
|
|
158
|
+
return 0;
|
|
159
|
+
}
|
|
160
|
+
return hasInvertedSubTheme ? utils.ARROW_SIZE : utils.ARROW_SIZE_BIG;
|
|
161
|
+
}, [hasInvertedSubTheme, hideArrow]);
|
|
145
162
|
const calculateStyle = React.useCallback(() => {
|
|
146
163
|
if (triggerRef.current && tooltipRef.current) {
|
|
147
164
|
// calculate tooltip style
|
|
148
|
-
setStyle(utils.getTooltipStyle(placement, triggerRef, tooltipRef, document, window));
|
|
165
|
+
setStyle(utils.getTooltipStyle(placement, defaultVerticalPlacement, triggerRef, tooltipRef, document, window, arrowSize));
|
|
149
166
|
debounceTimeoutId.current = null;
|
|
150
167
|
}
|
|
151
|
-
}, [triggerRef, tooltipRef, document, window, placement]);
|
|
168
|
+
}, [triggerRef, tooltipRef, document, window, placement, arrowSize, defaultVerticalPlacement]);
|
|
152
169
|
const debouncedCalculateStyle = React.useCallback(() => {
|
|
153
170
|
if (!debounceTimeoutId.current) {
|
|
154
171
|
debounceTimeoutId.current = setTimeout(calculateStyle, 200);
|
|
@@ -190,10 +207,16 @@ function TooltipContent(_ref3) {
|
|
|
190
207
|
};
|
|
191
208
|
}, [isVisible, calculateStyle, debouncedCalculateStyle, window, tooltipRef]);
|
|
192
209
|
let portal = null;
|
|
193
|
-
|
|
194
|
-
|
|
210
|
+
const OuterWrapper = React.useMemo(() => _ref4 => {
|
|
211
|
+
let {
|
|
212
|
+
children
|
|
213
|
+
} = _ref4;
|
|
214
|
+
return hasInvertedSubTheme ? /*#__PURE__*/React__default.default.createElement(SubThemeProvider.SubThemeProvider, {
|
|
195
215
|
name: "inverted"
|
|
196
|
-
}, /*#__PURE__*/React__default.default.createElement(
|
|
216
|
+
}, children) : /*#__PURE__*/React__default.default.createElement(React__default.default.Fragment, null, children);
|
|
217
|
+
}, [hasInvertedSubTheme]);
|
|
218
|
+
if (isVisible) {
|
|
219
|
+
const tooltipElm = /*#__PURE__*/React__default.default.createElement(OuterWrapper, null, /*#__PURE__*/React__default.default.createElement(StyledContainer, {
|
|
197
220
|
"data-e2e-test-id": dataE2eTestId,
|
|
198
221
|
"data-ds-id": dataDSId,
|
|
199
222
|
style: {
|
|
@@ -205,16 +228,22 @@ function TooltipContent(_ref3) {
|
|
|
205
228
|
id: tooltipId,
|
|
206
229
|
role: role,
|
|
207
230
|
"aria-hidden": ariaHidden,
|
|
231
|
+
hasInvertedSubTheme: hasInvertedSubTheme,
|
|
208
232
|
tabIndex: tabIndex,
|
|
209
233
|
horizontalPlacement: style.horizontalPlacement,
|
|
210
234
|
verticalPlacement: style.verticalPlacement,
|
|
211
|
-
contentPadding: contentPadding,
|
|
212
235
|
maxWidth: maxWidth,
|
|
236
|
+
contentPadding: contentPadding,
|
|
213
237
|
onPointerEnter: onTooltipPointerEnter,
|
|
214
238
|
onPointerLeave: onTooltipPointerLeave
|
|
215
|
-
}, content
|
|
239
|
+
}, hasInvertedSubTheme ? content : /*#__PURE__*/React__default.default.createElement(Container.Container, {
|
|
240
|
+
elevation: 3,
|
|
241
|
+
borderRadius: borderRadius
|
|
242
|
+
}, content), !hideArrow && /*#__PURE__*/React__default.default.createElement(StyledArrow, {
|
|
243
|
+
"data-e2e-test-id": `${dataE2eTestId}_arrow`,
|
|
216
244
|
horizontalPlacement: style.horizontalPlacement,
|
|
217
|
-
verticalPlacement: style.verticalPlacement
|
|
245
|
+
verticalPlacement: style.verticalPlacement,
|
|
246
|
+
size: arrowSize
|
|
218
247
|
})));
|
|
219
248
|
portal = /*#__PURE__*/ReactDOM.createPortal(tooltipElm, portalContainer || document.body);
|
|
220
249
|
}
|