@commercetools-uikit/tooltip 16.5.0 → 16.6.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/README.md +2 -1
- package/dist/commercetools-uikit-tooltip.cjs.dev.js +78 -57
- package/dist/commercetools-uikit-tooltip.cjs.prod.js +73 -53
- package/dist/commercetools-uikit-tooltip.esm.js +71 -50
- package/dist/declarations/src/tooltip.d.ts +4 -2
- package/dist/declarations/src/tooltip.styles.d.ts +6 -1
- package/package.json +5 -5
package/README.md
CHANGED
|
@@ -183,7 +183,8 @@ export {
|
|
|
183
183
|
| Props | Type | Required | Default | Description |
|
|
184
184
|
| ---------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | :------: | --------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
|
|
185
185
|
| `children` | `ReactElement` | ✅ | | |
|
|
186
|
-
| `
|
|
186
|
+
| `showAfter` | `number` | | `300` | Delay (in milliseconds) between the start of the user interaction, and showing the tooltip. |
|
|
187
|
+
| `closeAfter` | `number` | | `200` | Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip. |
|
|
187
188
|
| `styles` | `Record` | | | Custom css-in-js object styles for the tooltip body. |
|
|
188
189
|
| `off` | `boolean` | | `false` | Determines if the tooltip should not appear. |
|
|
189
190
|
| `id` | `string` | | | An identifier for the tooltip, used for `aria-describedby`. |
|
|
@@ -14,13 +14,14 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
|
|
|
14
14
|
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
15
15
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
16
16
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
17
|
-
var react = require('react');
|
|
17
|
+
var react$1 = require('react');
|
|
18
18
|
var reactIs = require('react-is');
|
|
19
19
|
var isNil = require('lodash/isNil');
|
|
20
20
|
var usePopper = require('use-popper');
|
|
21
|
-
var react
|
|
21
|
+
var react = require('@emotion/react');
|
|
22
22
|
var hooks = require('@commercetools-uikit/hooks');
|
|
23
23
|
var utils = require('@commercetools-uikit/utils');
|
|
24
|
+
var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
|
|
24
25
|
var _styled = require('@emotion/styled/base');
|
|
25
26
|
var designSystem = require('@commercetools-uikit/design-system');
|
|
26
27
|
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
@@ -41,9 +42,26 @@ var isNil__default = /*#__PURE__*/_interopDefault(isNil);
|
|
|
41
42
|
var usePopper__default = /*#__PURE__*/_interopDefault(usePopper);
|
|
42
43
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
43
44
|
|
|
45
|
+
var _templateObject, _templateObject2;
|
|
44
46
|
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
45
47
|
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
46
48
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
49
|
+
const growIn = react.keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n from {\n transform: scale(0);\n }\n to {\n transform: scale(1);\n }\n"])));
|
|
50
|
+
const growOut = react.keyframes(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n from {\n transform: scale(1);\n }\n to {\n transform: scale(0);\n }\n"])));
|
|
51
|
+
const getAnimation = state => {
|
|
52
|
+
switch (state) {
|
|
53
|
+
case 'opened':
|
|
54
|
+
return {
|
|
55
|
+
animation: "".concat(growIn, " 80ms")
|
|
56
|
+
};
|
|
57
|
+
case 'exiting':
|
|
58
|
+
return {
|
|
59
|
+
animation: "".concat(growOut, " 80ms")
|
|
60
|
+
};
|
|
61
|
+
default:
|
|
62
|
+
return {};
|
|
63
|
+
}
|
|
64
|
+
};
|
|
47
65
|
const getOffsetMargin = _ref => {
|
|
48
66
|
let placement = _ref.placement;
|
|
49
67
|
const position = placement && placement.split('-')[0] || '';
|
|
@@ -63,7 +81,7 @@ const Body = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_EN
|
|
|
63
81
|
} : {
|
|
64
82
|
target: "e14le4p1",
|
|
65
83
|
label: "Body"
|
|
66
|
-
})("font-family:inherit;border-radius:", designSystem.designTokens.borderRadius6, ";padding:", designSystem.designTokens.paddingForTooltip, ";border:none;box-shadow:", designSystem.designTokens.shadowForTooltip, ";font-size:", designSystem.designTokens.fontSize20, ";opacity:0.95;color:", designSystem.designTokens.colorSurface, ";background-color:", designSystem.designTokens.backgroundColorForTooltip, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
84
|
+
})("font-family:inherit;border-radius:", designSystem.designTokens.borderRadius6, ";padding:", designSystem.designTokens.paddingForTooltip, ";border:none;box-shadow:", designSystem.designTokens.shadowForTooltip, ";font-size:", designSystem.designTokens.fontSize20, ";opacity:0.95;color:", designSystem.designTokens.colorSurface, ";background-color:", designSystem.designTokens.backgroundColorForTooltip, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVEOEIiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMsIFRUb29sdGlwU3RhdGUgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG50eXBlIFREZXNpZ25Ub2tlbk5hbWUgPSBrZXlvZiB0eXBlb2YgZGVzaWduVG9rZW5zO1xuXG5jb25zdCBncm93SW4gPSBrZXlmcmFtZXNgXG4gIGZyb20ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gIH1cbiAgdG8ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gIH1cbmA7XG5cbmNvbnN0IGdyb3dPdXQgPSBrZXlmcmFtZXNgXG4gIGZyb20ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gIH1cbiAgdG8ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gIH1cbmA7XG5cbmNvbnN0IGdldEFuaW1hdGlvbiA9IChzdGF0ZTogVFRvb2x0aXBTdGF0ZSkgPT4ge1xuICBzd2l0Y2ggKHN0YXRlKSB7XG4gICAgY2FzZSAnb3BlbmVkJzpcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGFuaW1hdGlvbjogYCR7Z3Jvd0lufSA4MG1zYCxcbiAgICAgIH07XG4gICAgY2FzZSAnZXhpdGluZyc6XG4gICAgICByZXR1cm4ge1xuICAgICAgICBhbmltYXRpb246IGAke2dyb3dPdXR9IDgwbXNgLFxuICAgICAgfTtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIHt9O1xuICB9XG59O1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfWA7XG4gICAgY2FzZSAndG9wJzpcbiAgICBjYXNlICdib3R0b20nOlxuICAgICAgcmV0dXJuIGAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9IDBgO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gJyc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBCb2R5ID0gc3R5bGVkLmRpdmBcbiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVG9vbHRpcH07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93Rm9yVG9vbHRpcH07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIG9wYWNpdHk6IDAuOTU7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JUb29sdGlwfTtcbmA7XG5cbi8vIGhlcmUgd2UgdXNlIG9iamVjdCBzdHlsZXMgc28gd2UgY2FuIHNwcmVhZCB0aGVzZVxuLy8gd2l0aCB0aGUgc3R5bGVzIHdlIGdldCBmcm9tIHJlYWN0LXBvcHBlciA6RFxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnRcbmV4cG9ydCBjb25zdCBnZXRCb2R5U3R5bGVzID0gKHtcbiAgY29uc3RyYWludCxcbiAgcGxhY2VtZW50LFxuICBjdXN0b21TdHlsZXMsXG59OiB7XG4gIGNvbnN0cmFpbnQ6IFRUb29sdGlwUHJvcHNbJ2hvcml6b250YWxDb25zdHJhaW50J107XG4gIHBsYWNlbWVudDogc3RyaW5nO1xuICBjdXN0b21TdHlsZXM/OiBDU1NQcm9wZXJ0aWVzO1xufSk6IENTU1Byb3BlcnRpZXMgPT4ge1xuICBjb25zdCBjb25zdHJhaW50VG9rZW5OYW1lID0gYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YDtcbiAgcmV0dXJuIHtcbiAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgbWFyZ2luOiBgJHtnZXRPZmZzZXRNYXJnaW4oeyBwbGFjZW1lbnQgfSl9ICFpbXBvcnRhbnRgLFxuICAgIG1heFdpZHRoOlxuICAgICAgY29uc3RyYWludFRva2VuTmFtZSBpbiBkZXNpZ25Ub2tlbnNcbiAgICAgICAgPyBkZXNpZ25Ub2tlbnNbY29uc3RyYWludFRva2VuTmFtZSBhcyBURGVzaWduVG9rZW5OYW1lXVxuICAgICAgICA6ICdhdXRvJyxcbiAgICAvLyBzbyBob3ZlcmluZyBvdmVyIHRoZSB0b29sdGlwIHdoZW4gdGhlIHRvb2x0aXAgb3ZlcmxhcHMgdGhlIGNvbXBvbmVudFxuICAgIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbiAgICB3aWR0aDogY29uc3RyYWludCA9PT0gJ2F1dG8nID8gJ2F1dG8nIDogdW5kZWZpbmVkLFxuICAgIHpJbmRleDogMTAwMCxcbiAgICAuLi5jdXN0b21TdHlsZXMsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VG9vbHRpcFN0eWxlcyA9ICh0b29sdGlwU3RhdGU6IFRUb29sdGlwU3RhdGUpID0+XG4gIGdldEFuaW1hdGlvbih0b29sdGlwU3RhdGUpO1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgPiA6ZGlzYWJsZWQge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuIl19 */"));
|
|
67
85
|
|
|
68
86
|
// here we use object styles so we can spread these
|
|
69
87
|
// with the styles we get from react-popper :D
|
|
@@ -85,6 +103,7 @@ const getBodyStyles = _ref2 => {
|
|
|
85
103
|
zIndex: 1000
|
|
86
104
|
}, customStyles);
|
|
87
105
|
};
|
|
106
|
+
const getTooltipStyles = tooltipState => getAnimation(tooltipState);
|
|
88
107
|
const Wrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE_ENV === "production" ? {
|
|
89
108
|
target: "e14le4p0"
|
|
90
109
|
} : {
|
|
@@ -96,7 +115,7 @@ const Wrapper = /*#__PURE__*/_styled__default["default"]("div", process.env.NODE
|
|
|
96
115
|
} : {
|
|
97
116
|
name: "18fwu9s",
|
|
98
117
|
styles: "display:inline-block;cursor:not-allowed;>:disabled{pointer-events:none;}",
|
|
99
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
118
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtHaUMiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMsIFRUb29sdGlwU3RhdGUgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG50eXBlIFREZXNpZ25Ub2tlbk5hbWUgPSBrZXlvZiB0eXBlb2YgZGVzaWduVG9rZW5zO1xuXG5jb25zdCBncm93SW4gPSBrZXlmcmFtZXNgXG4gIGZyb20ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gIH1cbiAgdG8ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gIH1cbmA7XG5cbmNvbnN0IGdyb3dPdXQgPSBrZXlmcmFtZXNgXG4gIGZyb20ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gIH1cbiAgdG8ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gIH1cbmA7XG5cbmNvbnN0IGdldEFuaW1hdGlvbiA9IChzdGF0ZTogVFRvb2x0aXBTdGF0ZSkgPT4ge1xuICBzd2l0Y2ggKHN0YXRlKSB7XG4gICAgY2FzZSAnb3BlbmVkJzpcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGFuaW1hdGlvbjogYCR7Z3Jvd0lufSA4MG1zYCxcbiAgICAgIH07XG4gICAgY2FzZSAnZXhpdGluZyc6XG4gICAgICByZXR1cm4ge1xuICAgICAgICBhbmltYXRpb246IGAke2dyb3dPdXR9IDgwbXNgLFxuICAgICAgfTtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIHt9O1xuICB9XG59O1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfWA7XG4gICAgY2FzZSAndG9wJzpcbiAgICBjYXNlICdib3R0b20nOlxuICAgICAgcmV0dXJuIGAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9IDBgO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gJyc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBCb2R5ID0gc3R5bGVkLmRpdmBcbiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVG9vbHRpcH07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93Rm9yVG9vbHRpcH07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIG9wYWNpdHk6IDAuOTU7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JUb29sdGlwfTtcbmA7XG5cbi8vIGhlcmUgd2UgdXNlIG9iamVjdCBzdHlsZXMgc28gd2UgY2FuIHNwcmVhZCB0aGVzZVxuLy8gd2l0aCB0aGUgc3R5bGVzIHdlIGdldCBmcm9tIHJlYWN0LXBvcHBlciA6RFxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnRcbmV4cG9ydCBjb25zdCBnZXRCb2R5U3R5bGVzID0gKHtcbiAgY29uc3RyYWludCxcbiAgcGxhY2VtZW50LFxuICBjdXN0b21TdHlsZXMsXG59OiB7XG4gIGNvbnN0cmFpbnQ6IFRUb29sdGlwUHJvcHNbJ2hvcml6b250YWxDb25zdHJhaW50J107XG4gIHBsYWNlbWVudDogc3RyaW5nO1xuICBjdXN0b21TdHlsZXM/OiBDU1NQcm9wZXJ0aWVzO1xufSk6IENTU1Byb3BlcnRpZXMgPT4ge1xuICBjb25zdCBjb25zdHJhaW50VG9rZW5OYW1lID0gYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YDtcbiAgcmV0dXJuIHtcbiAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgbWFyZ2luOiBgJHtnZXRPZmZzZXRNYXJnaW4oeyBwbGFjZW1lbnQgfSl9ICFpbXBvcnRhbnRgLFxuICAgIG1heFdpZHRoOlxuICAgICAgY29uc3RyYWludFRva2VuTmFtZSBpbiBkZXNpZ25Ub2tlbnNcbiAgICAgICAgPyBkZXNpZ25Ub2tlbnNbY29uc3RyYWludFRva2VuTmFtZSBhcyBURGVzaWduVG9rZW5OYW1lXVxuICAgICAgICA6ICdhdXRvJyxcbiAgICAvLyBzbyBob3ZlcmluZyBvdmVyIHRoZSB0b29sdGlwIHdoZW4gdGhlIHRvb2x0aXAgb3ZlcmxhcHMgdGhlIGNvbXBvbmVudFxuICAgIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbiAgICB3aWR0aDogY29uc3RyYWludCA9PT0gJ2F1dG8nID8gJ2F1dG8nIDogdW5kZWZpbmVkLFxuICAgIHpJbmRleDogMTAwMCxcbiAgICAuLi5jdXN0b21TdHlsZXMsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VG9vbHRpcFN0eWxlcyA9ICh0b29sdGlwU3RhdGU6IFRUb29sdGlwU3RhdGUpID0+XG4gIGdldEFuaW1hdGlvbih0b29sdGlwU3RhdGUpO1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgPiA6ZGlzYWJsZWQge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuIl19 */",
|
|
100
119
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
101
120
|
});
|
|
102
121
|
|
|
@@ -108,15 +127,16 @@ const TooltipWrapper = props => jsxRuntime.jsx(jsxRuntime.Fragment, {
|
|
|
108
127
|
});
|
|
109
128
|
TooltipWrapper.displayName = 'TooltipWrapperComponent';
|
|
110
129
|
const tooltipDefaultProps = {
|
|
111
|
-
|
|
130
|
+
showAfter: 300,
|
|
131
|
+
closeAfter: 200,
|
|
112
132
|
horizontalConstraint: 'scale',
|
|
113
133
|
off: false,
|
|
114
134
|
placement: 'top'
|
|
115
135
|
};
|
|
116
136
|
const Tooltip = props => {
|
|
117
137
|
var _props$components, _props$components2, _props$components3, _props$components4, _props$components5, _props$components6, _props$styles;
|
|
118
|
-
const
|
|
119
|
-
const
|
|
138
|
+
const enterTimer = react$1.useRef();
|
|
139
|
+
const leaveTimer = react$1.useRef();
|
|
120
140
|
if ((_props$components = props.components) !== null && _props$components !== void 0 && _props$components.BodyComponent) {
|
|
121
141
|
process.env.NODE_ENV !== "production" ? utils.warning(reactIs.isValidElementType(props.components.BodyComponent), "ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.") : void 0;
|
|
122
142
|
}
|
|
@@ -126,8 +146,11 @@ const Tooltip = props => {
|
|
|
126
146
|
if ((_props$components3 = props.components) !== null && _props$components3 !== void 0 && _props$components3.WrapperComponent) {
|
|
127
147
|
process.env.NODE_ENV !== "production" ? utils.warning(reactIs.isValidElementType(props.components.WrapperComponent), "ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.") : void 0;
|
|
128
148
|
}
|
|
129
|
-
react.useEffect(() => {
|
|
149
|
+
react$1.useEffect(() => {
|
|
130
150
|
return () => {
|
|
151
|
+
if (enterTimer.current) {
|
|
152
|
+
clearTimeout(enterTimer.current);
|
|
153
|
+
}
|
|
131
154
|
if (leaveTimer.current) {
|
|
132
155
|
clearTimeout(leaveTimer.current);
|
|
133
156
|
}
|
|
@@ -138,41 +161,30 @@ const Tooltip = props => {
|
|
|
138
161
|
modifiers: props.modifiers
|
|
139
162
|
}),
|
|
140
163
|
reference = _usePopper.reference,
|
|
141
|
-
popper = _usePopper.popper
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
toggle(false);
|
|
148
|
-
}, [toggle]);
|
|
149
|
-
const openTooltip = react.useCallback(() => {
|
|
150
|
-
toggle(true);
|
|
151
|
-
}, [toggle]);
|
|
164
|
+
popper = _usePopper.popper,
|
|
165
|
+
popperInstance = _usePopper.popperInstance;
|
|
166
|
+
const _useState = react$1.useState('closed'),
|
|
167
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
168
|
+
state = _useState2[0],
|
|
169
|
+
setState = _useState2[1];
|
|
152
170
|
const isControlled = !isNil__default["default"](props.isOpen);
|
|
153
|
-
const tooltipIsOpen = isControlled ? props.isOpen :
|
|
171
|
+
const tooltipIsOpen = isControlled ? props.isOpen : state === 'opened' || state === 'exiting';
|
|
154
172
|
const id = hooks.useFieldId(props.id, sequentialId);
|
|
155
173
|
const onClose = props.onClose;
|
|
156
|
-
const handleClose = react.useCallback(event => {
|
|
174
|
+
const handleClose = react$1.useCallback(event => {
|
|
157
175
|
if (!isControlled) {
|
|
158
|
-
|
|
176
|
+
setState('closed');
|
|
159
177
|
}
|
|
160
178
|
if (onClose) {
|
|
161
179
|
onClose(event);
|
|
162
180
|
}
|
|
163
|
-
}, [isControlled,
|
|
181
|
+
}, [isControlled, onClose]);
|
|
164
182
|
const _props$children$props = props.children.props,
|
|
165
183
|
onFocus = _props$children$props.onFocus,
|
|
166
184
|
onMouseOver = _props$children$props.onMouseOver;
|
|
167
|
-
const
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
// We don't want to wait for the next render commit.
|
|
171
|
-
// We would risk displaying two tooltips at the same time (native + this one).
|
|
172
|
-
if (childrenRef && typeof childrenRef === 'function') {
|
|
173
|
-
// @ts-ignore
|
|
174
|
-
childrenRef.setAttribute('title', '');
|
|
175
|
-
}
|
|
185
|
+
const showAfter = props.showAfter,
|
|
186
|
+
onOpen = props.onOpen;
|
|
187
|
+
const handleEnter = react$1.useCallback(event => {
|
|
176
188
|
if (event) {
|
|
177
189
|
if (event.type === 'mouseover' && onMouseOver) {
|
|
178
190
|
onMouseOver(event);
|
|
@@ -180,42 +192,46 @@ const Tooltip = props => {
|
|
|
180
192
|
if (event.type === 'focus' && onFocus) {
|
|
181
193
|
onFocus(event);
|
|
182
194
|
}
|
|
183
|
-
if (
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
195
|
+
if (state !== 'opened' && !isControlled) {
|
|
196
|
+
setState('entering');
|
|
197
|
+
enterTimer.current = _setTimeout__default["default"](() => {
|
|
198
|
+
setState('opened');
|
|
199
|
+
if (onOpen) {
|
|
200
|
+
onOpen(event);
|
|
201
|
+
}
|
|
202
|
+
}, showAfter);
|
|
188
203
|
}
|
|
189
204
|
event.preventDefault();
|
|
190
205
|
event.stopPropagation();
|
|
191
206
|
}
|
|
192
|
-
}, [onFocus, onOpen, onMouseOver, isControlled,
|
|
207
|
+
}, [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]);
|
|
193
208
|
const _props$children$props2 = props.children.props,
|
|
194
209
|
onBlur = _props$children$props2.onBlur,
|
|
195
210
|
onMouseLeave = _props$children$props2.onMouseLeave;
|
|
196
211
|
const closeAfter = props.closeAfter;
|
|
197
|
-
const handleLeave = react.useCallback(event => {
|
|
198
|
-
|
|
199
|
-
|
|
200
|
-
}
|
|
212
|
+
const handleLeave = react$1.useCallback(event => {
|
|
213
|
+
clearTimeout(enterTimer.current);
|
|
214
|
+
clearTimeout(leaveTimer.current);
|
|
201
215
|
if (event.type === 'mouseleave' && onMouseLeave) {
|
|
202
216
|
onMouseLeave(event);
|
|
203
217
|
}
|
|
204
218
|
if (event.type === 'blur' && onBlur) {
|
|
205
219
|
onBlur(event);
|
|
206
220
|
}
|
|
207
|
-
if (closeAfter) {
|
|
221
|
+
if (closeAfter && state === 'opened') {
|
|
208
222
|
leaveTimer.current = _setTimeout__default["default"](() => {
|
|
209
|
-
|
|
223
|
+
const tooltipElement = popperInstance === null || popperInstance === void 0 ? void 0 : popperInstance.popper.querySelector('[data-testid="tooltip-message-wrapper"]');
|
|
224
|
+
tooltipElement.addEventListener('animationend', () => handleClose());
|
|
225
|
+
setState('exiting');
|
|
210
226
|
}, closeAfter);
|
|
211
227
|
} else {
|
|
212
228
|
handleClose(event);
|
|
213
229
|
}
|
|
214
|
-
}, [closeAfter, onBlur, onMouseLeave, handleClose]);
|
|
215
|
-
react.useEffect(() => {
|
|
230
|
+
}, [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]);
|
|
231
|
+
react$1.useEffect(() => {
|
|
216
232
|
// if tooltip was open, and then component
|
|
217
233
|
// updated to be off, we should close the tooltip
|
|
218
|
-
if (
|
|
234
|
+
if (state === 'opened' && props.off) {
|
|
219
235
|
if (closeAfter) {
|
|
220
236
|
leaveTimer.current = _setTimeout__default["default"](() => {
|
|
221
237
|
handleClose();
|
|
@@ -224,7 +240,7 @@ const Tooltip = props => {
|
|
|
224
240
|
handleClose();
|
|
225
241
|
}
|
|
226
242
|
}
|
|
227
|
-
}, [props.off, closeAfter, handleClose,
|
|
243
|
+
}, [props.off, closeAfter, handleClose, state]);
|
|
228
244
|
const childrenProps = {
|
|
229
245
|
// don't pass event listeners to children
|
|
230
246
|
onFocus: null,
|
|
@@ -236,10 +252,10 @@ const Tooltip = props => {
|
|
|
236
252
|
'aria-describedby': tooltipIsOpen ? id : null,
|
|
237
253
|
// for seo and accessibility, we add the tooltip's title
|
|
238
254
|
// as a native title when the title is hidden
|
|
239
|
-
title: !tooltipIsOpen && typeof props.title === 'string' ? props.title : null
|
|
255
|
+
title: !tooltipIsOpen && state !== 'entering' && typeof props.title === 'string' ? props.title : null
|
|
240
256
|
} : {};
|
|
241
257
|
const eventListeners = !props.off ? {
|
|
242
|
-
|
|
258
|
+
onMouseEnter: handleEnter,
|
|
243
259
|
onMouseLeave: handleLeave,
|
|
244
260
|
onFocus: handleEnter,
|
|
245
261
|
onBlur: handleLeave
|
|
@@ -251,20 +267,24 @@ const Tooltip = props => {
|
|
|
251
267
|
children: [jsxRuntime.jsx(WrapperComponent, _objectSpread(_objectSpread({}, eventListeners), {}, {
|
|
252
268
|
// @ts-expect-error: yes, ref can be undefined
|
|
253
269
|
ref: reference.ref,
|
|
254
|
-
children: /*#__PURE__*/react.cloneElement(props.children, _objectSpread(_objectSpread({}, childrenProps), tooltipProps))
|
|
270
|
+
children: /*#__PURE__*/react$1.cloneElement(props.children, _objectSpread(_objectSpread({}, childrenProps), tooltipProps))
|
|
255
271
|
})), tooltipIsOpen && jsxRuntime.jsx(TooltipWrapperComponent, {
|
|
256
272
|
children: jsxRuntime.jsx("div", {
|
|
257
273
|
// ref accepts `LegacyRef`, which is a union of `RefObject` and `string`
|
|
258
274
|
// propper.ref returns `RefObject`
|
|
259
275
|
ref: popper.ref,
|
|
260
|
-
css: /*#__PURE__*/react
|
|
276
|
+
css: /*#__PURE__*/react.css(_objectSpread(_objectSpread({}, popper.styles), getBodyStyles({
|
|
261
277
|
constraint: props.horizontalConstraint,
|
|
262
278
|
placement: popper.placement,
|
|
263
279
|
customStyles: (_props$styles = props.styles) === null || _props$styles === void 0 ? void 0 : _props$styles.body
|
|
264
|
-
})), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AAmUiB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport { Wrapper, Body, getBodyStyles } from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst tooltipDefaultProps: Pick<\n  TTooltipProps,\n  'closeAfter' | 'horizontalConstraint' | 'off' | 'placement'\n> = {\n  closeAfter: 0,\n  horizontalConstraint: 'scale',\n  off: false,\n  placement: 'top',\n};\n\nconst Tooltip = (props: TTooltipProps) => {\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n  const childrenRef = useRef<ReturnType<typeof setTimeout>>();\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper } = usePopper({\n    placement: props.placement,\n    modifiers: props.modifiers,\n  });\n  const [isOpen, toggle] = useToggleState(false);\n  const closeTooltip = useCallback(() => {\n    toggle(false);\n  }, [toggle]);\n  const openTooltip = useCallback(() => {\n    toggle(true);\n  }, [toggle]);\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled ? props.isOpen : isOpen;\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        closeTooltip();\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, closeTooltip, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      // Remove the title ahead of time.\n      // We don't want to wait for the next render commit.\n      // We would risk displaying two tooltips at the same time (native + this one).\n      if (childrenRef && typeof childrenRef === 'function') {\n        // @ts-ignore\n        childrenRef.setAttribute('title', '');\n      }\n\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (!isOpen && !isControlled) {\n          openTooltip();\n        }\n\n        if (onOpen) {\n          onOpen(event);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, isOpen, openTooltip]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n  const { closeAfter } = props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose(event);\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (isOpen && props.off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [props.off, closeAfter, handleClose, toggle, isOpen]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !props.off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen && typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !props.off\n    ? {\n        onMouseOver: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: props.horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <BodyComponent>{props.title}</BodyComponent>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\nTooltip.defaultProps = tooltipDefaultProps;\n\nexport default Tooltip;\n"]} */"),
|
|
280
|
+
})), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AAiViB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst tooltipDefaultProps: Pick<\n  TTooltipProps,\n  'showAfter' | 'closeAfter' | 'horizontalConstraint' | 'off' | 'placement'\n> = {\n  showAfter: 300,\n  closeAfter: 200,\n  horizontalConstraint: 'scale',\n  off: false,\n  placement: 'top',\n};\n\nconst Tooltip = (props: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>();\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: props.placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { showAfter, onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n  const { closeAfter } = props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      clearTimeout(enterTimer.current);\n      clearTimeout(leaveTimer.current);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n          tooltipElement.addEventListener('animationend', () => handleClose());\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && props.off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [props.off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !props.off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !props.off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: props.horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\nTooltip.defaultProps = tooltipDefaultProps;\n\nexport default Tooltip;\n"]} */"),
|
|
265
281
|
"data-placement": popper.placement,
|
|
266
|
-
children: jsxRuntime.jsx(
|
|
267
|
-
children: props.title
|
|
282
|
+
children: jsxRuntime.jsx("div", {
|
|
283
|
+
css: /*#__PURE__*/react.css(_objectSpread({}, getTooltipStyles(state)), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AA4VmB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst tooltipDefaultProps: Pick<\n  TTooltipProps,\n  'showAfter' | 'closeAfter' | 'horizontalConstraint' | 'off' | 'placement'\n> = {\n  showAfter: 300,\n  closeAfter: 200,\n  horizontalConstraint: 'scale',\n  off: false,\n  placement: 'top',\n};\n\nconst Tooltip = (props: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>();\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: props.placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { showAfter, onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n  const { closeAfter } = props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      clearTimeout(enterTimer.current);\n      clearTimeout(leaveTimer.current);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n          tooltipElement.addEventListener('animationend', () => handleClose());\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && props.off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [props.off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !props.off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !props.off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: props.horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\nTooltip.defaultProps = tooltipDefaultProps;\n\nexport default Tooltip;\n"]} */"),
|
|
284
|
+
"data-testid": "tooltip-message-wrapper",
|
|
285
|
+
children: jsxRuntime.jsx(BodyComponent, {
|
|
286
|
+
children: props.title
|
|
287
|
+
})
|
|
268
288
|
})
|
|
269
289
|
})
|
|
270
290
|
})]
|
|
@@ -272,7 +292,8 @@ const Tooltip = props => {
|
|
|
272
292
|
};
|
|
273
293
|
Tooltip.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
274
294
|
children: _pt__default["default"].element.isRequired,
|
|
275
|
-
|
|
295
|
+
showAfter: _pt__default["default"].number,
|
|
296
|
+
closeAfter: _pt__default["default"].number,
|
|
276
297
|
styles: _pt__default["default"].objectOf(_pt__default["default"].any),
|
|
277
298
|
off: _pt__default["default"].bool.isRequired,
|
|
278
299
|
id: _pt__default["default"].string,
|
|
@@ -294,7 +315,7 @@ Tooltip.defaultProps = tooltipDefaultProps;
|
|
|
294
315
|
var Tooltip$1 = Tooltip;
|
|
295
316
|
|
|
296
317
|
// NOTE: This string will be replaced on build time with the package version.
|
|
297
|
-
var version = "16.
|
|
318
|
+
var version = "16.6.0";
|
|
298
319
|
|
|
299
320
|
exports["default"] = Tooltip$1;
|
|
300
321
|
exports.version = version;
|
|
@@ -14,13 +14,14 @@ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/in
|
|
|
14
14
|
var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
|
|
15
15
|
var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
|
|
16
16
|
var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
|
|
17
|
-
var react = require('react');
|
|
17
|
+
var react$1 = require('react');
|
|
18
18
|
require('react-is');
|
|
19
19
|
var isNil = require('lodash/isNil');
|
|
20
20
|
var usePopper = require('use-popper');
|
|
21
|
-
var react
|
|
21
|
+
var react = require('@emotion/react');
|
|
22
22
|
var hooks = require('@commercetools-uikit/hooks');
|
|
23
23
|
var utils = require('@commercetools-uikit/utils');
|
|
24
|
+
var _taggedTemplateLiteral = require('@babel/runtime-corejs3/helpers/taggedTemplateLiteral');
|
|
24
25
|
var _styled = require('@emotion/styled/base');
|
|
25
26
|
var designSystem = require('@commercetools-uikit/design-system');
|
|
26
27
|
var jsxRuntime = require('@emotion/react/jsx-runtime');
|
|
@@ -40,8 +41,25 @@ var isNil__default = /*#__PURE__*/_interopDefault(isNil);
|
|
|
40
41
|
var usePopper__default = /*#__PURE__*/_interopDefault(usePopper);
|
|
41
42
|
var _styled__default = /*#__PURE__*/_interopDefault(_styled);
|
|
42
43
|
|
|
44
|
+
var _templateObject, _templateObject2;
|
|
43
45
|
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default["default"](object); if (_Object$getOwnPropertySymbols__default["default"]) { var symbols = _Object$getOwnPropertySymbols__default["default"](object); enumerableOnly && (symbols = _filterInstanceProperty__default["default"](symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor__default["default"](object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
44
46
|
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty__default["default"](_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors__default["default"] ? _Object$defineProperties__default["default"](target, _Object$getOwnPropertyDescriptors__default["default"](source)) : _forEachInstanceProperty__default["default"](_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty__default["default"](target, key, _Object$getOwnPropertyDescriptor__default["default"](source, key)); }); } return target; }
|
|
47
|
+
const growIn = react.keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n from {\n transform: scale(0);\n }\n to {\n transform: scale(1);\n }\n"])));
|
|
48
|
+
const growOut = react.keyframes(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n from {\n transform: scale(1);\n }\n to {\n transform: scale(0);\n }\n"])));
|
|
49
|
+
const getAnimation = state => {
|
|
50
|
+
switch (state) {
|
|
51
|
+
case 'opened':
|
|
52
|
+
return {
|
|
53
|
+
animation: "".concat(growIn, " 80ms")
|
|
54
|
+
};
|
|
55
|
+
case 'exiting':
|
|
56
|
+
return {
|
|
57
|
+
animation: "".concat(growOut, " 80ms")
|
|
58
|
+
};
|
|
59
|
+
default:
|
|
60
|
+
return {};
|
|
61
|
+
}
|
|
62
|
+
};
|
|
45
63
|
const getOffsetMargin = _ref => {
|
|
46
64
|
let placement = _ref.placement;
|
|
47
65
|
const position = placement && placement.split('-')[0] || '';
|
|
@@ -80,6 +98,7 @@ const getBodyStyles = _ref2 => {
|
|
|
80
98
|
zIndex: 1000
|
|
81
99
|
}, customStyles);
|
|
82
100
|
};
|
|
101
|
+
const getTooltipStyles = tooltipState => getAnimation(tooltipState);
|
|
83
102
|
const Wrapper = /*#__PURE__*/_styled__default["default"]("div", {
|
|
84
103
|
target: "e14le4p0"
|
|
85
104
|
} )({
|
|
@@ -95,20 +114,24 @@ const TooltipWrapper = props => jsxRuntime.jsx(jsxRuntime.Fragment, {
|
|
|
95
114
|
});
|
|
96
115
|
TooltipWrapper.displayName = 'TooltipWrapperComponent';
|
|
97
116
|
const tooltipDefaultProps = {
|
|
98
|
-
|
|
117
|
+
showAfter: 300,
|
|
118
|
+
closeAfter: 200,
|
|
99
119
|
horizontalConstraint: 'scale',
|
|
100
120
|
off: false,
|
|
101
121
|
placement: 'top'
|
|
102
122
|
};
|
|
103
123
|
const Tooltip = props => {
|
|
104
124
|
var _props$components, _props$components2, _props$components3, _props$components4, _props$components5, _props$components6, _props$styles;
|
|
105
|
-
const
|
|
106
|
-
const
|
|
125
|
+
const enterTimer = react$1.useRef();
|
|
126
|
+
const leaveTimer = react$1.useRef();
|
|
107
127
|
if ((_props$components = props.components) !== null && _props$components !== void 0 && _props$components.BodyComponent) ;
|
|
108
128
|
if ((_props$components2 = props.components) !== null && _props$components2 !== void 0 && _props$components2.TooltipWrapperComponent) ;
|
|
109
129
|
if ((_props$components3 = props.components) !== null && _props$components3 !== void 0 && _props$components3.WrapperComponent) ;
|
|
110
|
-
react.useEffect(() => {
|
|
130
|
+
react$1.useEffect(() => {
|
|
111
131
|
return () => {
|
|
132
|
+
if (enterTimer.current) {
|
|
133
|
+
clearTimeout(enterTimer.current);
|
|
134
|
+
}
|
|
112
135
|
if (leaveTimer.current) {
|
|
113
136
|
clearTimeout(leaveTimer.current);
|
|
114
137
|
}
|
|
@@ -119,41 +142,30 @@ const Tooltip = props => {
|
|
|
119
142
|
modifiers: props.modifiers
|
|
120
143
|
}),
|
|
121
144
|
reference = _usePopper.reference,
|
|
122
|
-
popper = _usePopper.popper
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
|
|
128
|
-
toggle(false);
|
|
129
|
-
}, [toggle]);
|
|
130
|
-
const openTooltip = react.useCallback(() => {
|
|
131
|
-
toggle(true);
|
|
132
|
-
}, [toggle]);
|
|
145
|
+
popper = _usePopper.popper,
|
|
146
|
+
popperInstance = _usePopper.popperInstance;
|
|
147
|
+
const _useState = react$1.useState('closed'),
|
|
148
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
149
|
+
state = _useState2[0],
|
|
150
|
+
setState = _useState2[1];
|
|
133
151
|
const isControlled = !isNil__default["default"](props.isOpen);
|
|
134
|
-
const tooltipIsOpen = isControlled ? props.isOpen :
|
|
152
|
+
const tooltipIsOpen = isControlled ? props.isOpen : state === 'opened' || state === 'exiting';
|
|
135
153
|
const id = hooks.useFieldId(props.id, sequentialId);
|
|
136
154
|
const onClose = props.onClose;
|
|
137
|
-
const handleClose = react.useCallback(event => {
|
|
155
|
+
const handleClose = react$1.useCallback(event => {
|
|
138
156
|
if (!isControlled) {
|
|
139
|
-
|
|
157
|
+
setState('closed');
|
|
140
158
|
}
|
|
141
159
|
if (onClose) {
|
|
142
160
|
onClose(event);
|
|
143
161
|
}
|
|
144
|
-
}, [isControlled,
|
|
162
|
+
}, [isControlled, onClose]);
|
|
145
163
|
const _props$children$props = props.children.props,
|
|
146
164
|
onFocus = _props$children$props.onFocus,
|
|
147
165
|
onMouseOver = _props$children$props.onMouseOver;
|
|
148
|
-
const
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
// We don't want to wait for the next render commit.
|
|
152
|
-
// We would risk displaying two tooltips at the same time (native + this one).
|
|
153
|
-
if (childrenRef && typeof childrenRef === 'function') {
|
|
154
|
-
// @ts-ignore
|
|
155
|
-
childrenRef.setAttribute('title', '');
|
|
156
|
-
}
|
|
166
|
+
const showAfter = props.showAfter,
|
|
167
|
+
onOpen = props.onOpen;
|
|
168
|
+
const handleEnter = react$1.useCallback(event => {
|
|
157
169
|
if (event) {
|
|
158
170
|
if (event.type === 'mouseover' && onMouseOver) {
|
|
159
171
|
onMouseOver(event);
|
|
@@ -161,42 +173,46 @@ const Tooltip = props => {
|
|
|
161
173
|
if (event.type === 'focus' && onFocus) {
|
|
162
174
|
onFocus(event);
|
|
163
175
|
}
|
|
164
|
-
if (
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
176
|
+
if (state !== 'opened' && !isControlled) {
|
|
177
|
+
setState('entering');
|
|
178
|
+
enterTimer.current = _setTimeout__default["default"](() => {
|
|
179
|
+
setState('opened');
|
|
180
|
+
if (onOpen) {
|
|
181
|
+
onOpen(event);
|
|
182
|
+
}
|
|
183
|
+
}, showAfter);
|
|
169
184
|
}
|
|
170
185
|
event.preventDefault();
|
|
171
186
|
event.stopPropagation();
|
|
172
187
|
}
|
|
173
|
-
}, [onFocus, onOpen, onMouseOver, isControlled,
|
|
188
|
+
}, [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]);
|
|
174
189
|
const _props$children$props2 = props.children.props,
|
|
175
190
|
onBlur = _props$children$props2.onBlur,
|
|
176
191
|
onMouseLeave = _props$children$props2.onMouseLeave;
|
|
177
192
|
const closeAfter = props.closeAfter;
|
|
178
|
-
const handleLeave = react.useCallback(event => {
|
|
179
|
-
|
|
180
|
-
|
|
181
|
-
}
|
|
193
|
+
const handleLeave = react$1.useCallback(event => {
|
|
194
|
+
clearTimeout(enterTimer.current);
|
|
195
|
+
clearTimeout(leaveTimer.current);
|
|
182
196
|
if (event.type === 'mouseleave' && onMouseLeave) {
|
|
183
197
|
onMouseLeave(event);
|
|
184
198
|
}
|
|
185
199
|
if (event.type === 'blur' && onBlur) {
|
|
186
200
|
onBlur(event);
|
|
187
201
|
}
|
|
188
|
-
if (closeAfter) {
|
|
202
|
+
if (closeAfter && state === 'opened') {
|
|
189
203
|
leaveTimer.current = _setTimeout__default["default"](() => {
|
|
190
|
-
|
|
204
|
+
const tooltipElement = popperInstance === null || popperInstance === void 0 ? void 0 : popperInstance.popper.querySelector('[data-testid="tooltip-message-wrapper"]');
|
|
205
|
+
tooltipElement.addEventListener('animationend', () => handleClose());
|
|
206
|
+
setState('exiting');
|
|
191
207
|
}, closeAfter);
|
|
192
208
|
} else {
|
|
193
209
|
handleClose(event);
|
|
194
210
|
}
|
|
195
|
-
}, [closeAfter, onBlur, onMouseLeave, handleClose]);
|
|
196
|
-
react.useEffect(() => {
|
|
211
|
+
}, [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]);
|
|
212
|
+
react$1.useEffect(() => {
|
|
197
213
|
// if tooltip was open, and then component
|
|
198
214
|
// updated to be off, we should close the tooltip
|
|
199
|
-
if (
|
|
215
|
+
if (state === 'opened' && props.off) {
|
|
200
216
|
if (closeAfter) {
|
|
201
217
|
leaveTimer.current = _setTimeout__default["default"](() => {
|
|
202
218
|
handleClose();
|
|
@@ -205,7 +221,7 @@ const Tooltip = props => {
|
|
|
205
221
|
handleClose();
|
|
206
222
|
}
|
|
207
223
|
}
|
|
208
|
-
}, [props.off, closeAfter, handleClose,
|
|
224
|
+
}, [props.off, closeAfter, handleClose, state]);
|
|
209
225
|
const childrenProps = {
|
|
210
226
|
// don't pass event listeners to children
|
|
211
227
|
onFocus: null,
|
|
@@ -217,10 +233,10 @@ const Tooltip = props => {
|
|
|
217
233
|
'aria-describedby': tooltipIsOpen ? id : null,
|
|
218
234
|
// for seo and accessibility, we add the tooltip's title
|
|
219
235
|
// as a native title when the title is hidden
|
|
220
|
-
title: !tooltipIsOpen && typeof props.title === 'string' ? props.title : null
|
|
236
|
+
title: !tooltipIsOpen && state !== 'entering' && typeof props.title === 'string' ? props.title : null
|
|
221
237
|
} : {};
|
|
222
238
|
const eventListeners = !props.off ? {
|
|
223
|
-
|
|
239
|
+
onMouseEnter: handleEnter,
|
|
224
240
|
onMouseLeave: handleLeave,
|
|
225
241
|
onFocus: handleEnter,
|
|
226
242
|
onBlur: handleLeave
|
|
@@ -232,20 +248,24 @@ const Tooltip = props => {
|
|
|
232
248
|
children: [jsxRuntime.jsx(WrapperComponent, _objectSpread(_objectSpread({}, eventListeners), {}, {
|
|
233
249
|
// @ts-expect-error: yes, ref can be undefined
|
|
234
250
|
ref: reference.ref,
|
|
235
|
-
children: /*#__PURE__*/react.cloneElement(props.children, _objectSpread(_objectSpread({}, childrenProps), tooltipProps))
|
|
251
|
+
children: /*#__PURE__*/react$1.cloneElement(props.children, _objectSpread(_objectSpread({}, childrenProps), tooltipProps))
|
|
236
252
|
})), tooltipIsOpen && jsxRuntime.jsx(TooltipWrapperComponent, {
|
|
237
253
|
children: jsxRuntime.jsx("div", {
|
|
238
254
|
// ref accepts `LegacyRef`, which is a union of `RefObject` and `string`
|
|
239
255
|
// propper.ref returns `RefObject`
|
|
240
256
|
ref: popper.ref,
|
|
241
|
-
css: /*#__PURE__*/react
|
|
257
|
+
css: /*#__PURE__*/react.css(_objectSpread(_objectSpread({}, popper.styles), getBodyStyles({
|
|
242
258
|
constraint: props.horizontalConstraint,
|
|
243
259
|
placement: popper.placement,
|
|
244
260
|
customStyles: (_props$styles = props.styles) === null || _props$styles === void 0 ? void 0 : _props$styles.body
|
|
245
261
|
})), "" , "" ),
|
|
246
262
|
"data-placement": popper.placement,
|
|
247
|
-
children: jsxRuntime.jsx(
|
|
248
|
-
|
|
263
|
+
children: jsxRuntime.jsx("div", {
|
|
264
|
+
css: /*#__PURE__*/react.css(_objectSpread({}, getTooltipStyles(state)), "" , "" ),
|
|
265
|
+
"data-testid": "tooltip-message-wrapper",
|
|
266
|
+
children: jsxRuntime.jsx(BodyComponent, {
|
|
267
|
+
children: props.title
|
|
268
|
+
})
|
|
249
269
|
})
|
|
250
270
|
})
|
|
251
271
|
})]
|
|
@@ -257,7 +277,7 @@ Tooltip.defaultProps = tooltipDefaultProps;
|
|
|
257
277
|
var Tooltip$1 = Tooltip;
|
|
258
278
|
|
|
259
279
|
// NOTE: This string will be replaced on build time with the package version.
|
|
260
|
-
var version = "16.
|
|
280
|
+
var version = "16.6.0";
|
|
261
281
|
|
|
262
282
|
exports["default"] = Tooltip$1;
|
|
263
283
|
exports.version = version;
|
|
@@ -10,20 +10,38 @@ import _forEachInstanceProperty from '@babel/runtime-corejs3/core-js-stable/inst
|
|
|
10
10
|
import _Object$getOwnPropertyDescriptors from '@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors';
|
|
11
11
|
import _Object$defineProperties from '@babel/runtime-corejs3/core-js-stable/object/define-properties';
|
|
12
12
|
import _Object$defineProperty from '@babel/runtime-corejs3/core-js-stable/object/define-property';
|
|
13
|
-
import { useRef, useEffect, useCallback, cloneElement } from 'react';
|
|
13
|
+
import { useRef, useEffect, useState, useCallback, cloneElement } from 'react';
|
|
14
14
|
import { isValidElementType } from 'react-is';
|
|
15
15
|
import isNil from 'lodash/isNil';
|
|
16
16
|
import usePopper from 'use-popper';
|
|
17
|
-
import { css } from '@emotion/react';
|
|
18
|
-
import {
|
|
17
|
+
import { keyframes, css } from '@emotion/react';
|
|
18
|
+
import { useFieldId } from '@commercetools-uikit/hooks';
|
|
19
19
|
import { createSequentialId, warning } from '@commercetools-uikit/utils';
|
|
20
|
+
import _taggedTemplateLiteral from '@babel/runtime-corejs3/helpers/esm/taggedTemplateLiteral';
|
|
20
21
|
import _styled from '@emotion/styled/base';
|
|
21
22
|
import { designTokens } from '@commercetools-uikit/design-system';
|
|
22
23
|
import { jsxs, Fragment, jsx } from '@emotion/react/jsx-runtime';
|
|
23
24
|
|
|
25
|
+
var _templateObject, _templateObject2;
|
|
24
26
|
function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys(object); if (_Object$getOwnPropertySymbols) { var symbols = _Object$getOwnPropertySymbols(object); enumerableOnly && (symbols = _filterInstanceProperty(symbols).call(symbols, function (sym) { return _Object$getOwnPropertyDescriptor(object, sym).enumerable; })), keys.push.apply(keys, symbols); } return keys; }
|
|
25
27
|
function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var _context, _context2; var source = null != arguments[i] ? arguments[i] : {}; i % 2 ? _forEachInstanceProperty(_context = ownKeys$1(Object(source), !0)).call(_context, function (key) { _defineProperty(target, key, source[key]); }) : _Object$getOwnPropertyDescriptors ? _Object$defineProperties(target, _Object$getOwnPropertyDescriptors(source)) : _forEachInstanceProperty(_context2 = ownKeys$1(Object(source))).call(_context2, function (key) { _Object$defineProperty(target, key, _Object$getOwnPropertyDescriptor(source, key)); }); } return target; }
|
|
26
28
|
function _EMOTION_STRINGIFIED_CSS_ERROR__() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
29
|
+
const growIn = keyframes(_templateObject || (_templateObject = _taggedTemplateLiteral(["\n from {\n transform: scale(0);\n }\n to {\n transform: scale(1);\n }\n"])));
|
|
30
|
+
const growOut = keyframes(_templateObject2 || (_templateObject2 = _taggedTemplateLiteral(["\n from {\n transform: scale(1);\n }\n to {\n transform: scale(0);\n }\n"])));
|
|
31
|
+
const getAnimation = state => {
|
|
32
|
+
switch (state) {
|
|
33
|
+
case 'opened':
|
|
34
|
+
return {
|
|
35
|
+
animation: "".concat(growIn, " 80ms")
|
|
36
|
+
};
|
|
37
|
+
case 'exiting':
|
|
38
|
+
return {
|
|
39
|
+
animation: "".concat(growOut, " 80ms")
|
|
40
|
+
};
|
|
41
|
+
default:
|
|
42
|
+
return {};
|
|
43
|
+
}
|
|
44
|
+
};
|
|
27
45
|
const getOffsetMargin = _ref => {
|
|
28
46
|
let placement = _ref.placement;
|
|
29
47
|
const position = placement && placement.split('-')[0] || '';
|
|
@@ -43,7 +61,7 @@ const Body = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ?
|
|
|
43
61
|
} : {
|
|
44
62
|
target: "e14le4p1",
|
|
45
63
|
label: "Body"
|
|
46
|
-
})("font-family:inherit;border-radius:", designTokens.borderRadius6, ";padding:", designTokens.paddingForTooltip, ";border:none;box-shadow:", designTokens.shadowForTooltip, ";font-size:", designTokens.fontSize20, ";opacity:0.95;color:", designTokens.colorSurface, ";background-color:", designTokens.backgroundColorForTooltip, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
64
|
+
})("font-family:inherit;border-radius:", designTokens.borderRadius6, ";padding:", designTokens.paddingForTooltip, ";border:none;box-shadow:", designTokens.shadowForTooltip, ";font-size:", designTokens.fontSize20, ";opacity:0.95;color:", designTokens.colorSurface, ";background-color:", designTokens.backgroundColorForTooltip, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVEOEIiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMsIFRUb29sdGlwU3RhdGUgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG50eXBlIFREZXNpZ25Ub2tlbk5hbWUgPSBrZXlvZiB0eXBlb2YgZGVzaWduVG9rZW5zO1xuXG5jb25zdCBncm93SW4gPSBrZXlmcmFtZXNgXG4gIGZyb20ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gIH1cbiAgdG8ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gIH1cbmA7XG5cbmNvbnN0IGdyb3dPdXQgPSBrZXlmcmFtZXNgXG4gIGZyb20ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gIH1cbiAgdG8ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gIH1cbmA7XG5cbmNvbnN0IGdldEFuaW1hdGlvbiA9IChzdGF0ZTogVFRvb2x0aXBTdGF0ZSkgPT4ge1xuICBzd2l0Y2ggKHN0YXRlKSB7XG4gICAgY2FzZSAnb3BlbmVkJzpcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGFuaW1hdGlvbjogYCR7Z3Jvd0lufSA4MG1zYCxcbiAgICAgIH07XG4gICAgY2FzZSAnZXhpdGluZyc6XG4gICAgICByZXR1cm4ge1xuICAgICAgICBhbmltYXRpb246IGAke2dyb3dPdXR9IDgwbXNgLFxuICAgICAgfTtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIHt9O1xuICB9XG59O1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfWA7XG4gICAgY2FzZSAndG9wJzpcbiAgICBjYXNlICdib3R0b20nOlxuICAgICAgcmV0dXJuIGAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9IDBgO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gJyc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBCb2R5ID0gc3R5bGVkLmRpdmBcbiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVG9vbHRpcH07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93Rm9yVG9vbHRpcH07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIG9wYWNpdHk6IDAuOTU7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JUb29sdGlwfTtcbmA7XG5cbi8vIGhlcmUgd2UgdXNlIG9iamVjdCBzdHlsZXMgc28gd2UgY2FuIHNwcmVhZCB0aGVzZVxuLy8gd2l0aCB0aGUgc3R5bGVzIHdlIGdldCBmcm9tIHJlYWN0LXBvcHBlciA6RFxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnRcbmV4cG9ydCBjb25zdCBnZXRCb2R5U3R5bGVzID0gKHtcbiAgY29uc3RyYWludCxcbiAgcGxhY2VtZW50LFxuICBjdXN0b21TdHlsZXMsXG59OiB7XG4gIGNvbnN0cmFpbnQ6IFRUb29sdGlwUHJvcHNbJ2hvcml6b250YWxDb25zdHJhaW50J107XG4gIHBsYWNlbWVudDogc3RyaW5nO1xuICBjdXN0b21TdHlsZXM/OiBDU1NQcm9wZXJ0aWVzO1xufSk6IENTU1Byb3BlcnRpZXMgPT4ge1xuICBjb25zdCBjb25zdHJhaW50VG9rZW5OYW1lID0gYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YDtcbiAgcmV0dXJuIHtcbiAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgbWFyZ2luOiBgJHtnZXRPZmZzZXRNYXJnaW4oeyBwbGFjZW1lbnQgfSl9ICFpbXBvcnRhbnRgLFxuICAgIG1heFdpZHRoOlxuICAgICAgY29uc3RyYWludFRva2VuTmFtZSBpbiBkZXNpZ25Ub2tlbnNcbiAgICAgICAgPyBkZXNpZ25Ub2tlbnNbY29uc3RyYWludFRva2VuTmFtZSBhcyBURGVzaWduVG9rZW5OYW1lXVxuICAgICAgICA6ICdhdXRvJyxcbiAgICAvLyBzbyBob3ZlcmluZyBvdmVyIHRoZSB0b29sdGlwIHdoZW4gdGhlIHRvb2x0aXAgb3ZlcmxhcHMgdGhlIGNvbXBvbmVudFxuICAgIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbiAgICB3aWR0aDogY29uc3RyYWludCA9PT0gJ2F1dG8nID8gJ2F1dG8nIDogdW5kZWZpbmVkLFxuICAgIHpJbmRleDogMTAwMCxcbiAgICAuLi5jdXN0b21TdHlsZXMsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VG9vbHRpcFN0eWxlcyA9ICh0b29sdGlwU3RhdGU6IFRUb29sdGlwU3RhdGUpID0+XG4gIGdldEFuaW1hdGlvbih0b29sdGlwU3RhdGUpO1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgPiA6ZGlzYWJsZWQge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuIl19 */"));
|
|
47
65
|
|
|
48
66
|
// here we use object styles so we can spread these
|
|
49
67
|
// with the styles we get from react-popper :D
|
|
@@ -65,6 +83,7 @@ const getBodyStyles = _ref2 => {
|
|
|
65
83
|
zIndex: 1000
|
|
66
84
|
}, customStyles);
|
|
67
85
|
};
|
|
86
|
+
const getTooltipStyles = tooltipState => getAnimation(tooltipState);
|
|
68
87
|
const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
69
88
|
target: "e14le4p0"
|
|
70
89
|
} : {
|
|
@@ -76,7 +95,7 @@ const Wrapper = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production
|
|
|
76
95
|
} : {
|
|
77
96
|
name: "18fwu9s",
|
|
78
97
|
styles: "display:inline-block;cursor:not-allowed;>:disabled{pointer-events:none;}",
|
|
79
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
98
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtHaUMiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsga2V5ZnJhbWVzIH0gZnJvbSAnQGVtb3Rpb24vcmVhY3QnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMsIFRUb29sdGlwU3RhdGUgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG50eXBlIFREZXNpZ25Ub2tlbk5hbWUgPSBrZXlvZiB0eXBlb2YgZGVzaWduVG9rZW5zO1xuXG5jb25zdCBncm93SW4gPSBrZXlmcmFtZXNgXG4gIGZyb20ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gIH1cbiAgdG8ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gIH1cbmA7XG5cbmNvbnN0IGdyb3dPdXQgPSBrZXlmcmFtZXNgXG4gIGZyb20ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMSk7XG4gIH1cbiAgdG8ge1xuICAgIHRyYW5zZm9ybTogc2NhbGUoMCk7XG4gIH1cbmA7XG5cbmNvbnN0IGdldEFuaW1hdGlvbiA9IChzdGF0ZTogVFRvb2x0aXBTdGF0ZSkgPT4ge1xuICBzd2l0Y2ggKHN0YXRlKSB7XG4gICAgY2FzZSAnb3BlbmVkJzpcbiAgICAgIHJldHVybiB7XG4gICAgICAgIGFuaW1hdGlvbjogYCR7Z3Jvd0lufSA4MG1zYCxcbiAgICAgIH07XG4gICAgY2FzZSAnZXhpdGluZyc6XG4gICAgICByZXR1cm4ge1xuICAgICAgICBhbmltYXRpb246IGAke2dyb3dPdXR9IDgwbXNgLFxuICAgICAgfTtcbiAgICBkZWZhdWx0OlxuICAgICAgcmV0dXJuIHt9O1xuICB9XG59O1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfWA7XG4gICAgY2FzZSAndG9wJzpcbiAgICBjYXNlICdib3R0b20nOlxuICAgICAgcmV0dXJuIGAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9IDBgO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gJyc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBCb2R5ID0gc3R5bGVkLmRpdmBcbiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVG9vbHRpcH07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93Rm9yVG9vbHRpcH07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIG9wYWNpdHk6IDAuOTU7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JUb29sdGlwfTtcbmA7XG5cbi8vIGhlcmUgd2UgdXNlIG9iamVjdCBzdHlsZXMgc28gd2UgY2FuIHNwcmVhZCB0aGVzZVxuLy8gd2l0aCB0aGUgc3R5bGVzIHdlIGdldCBmcm9tIHJlYWN0LXBvcHBlciA6RFxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnRcbmV4cG9ydCBjb25zdCBnZXRCb2R5U3R5bGVzID0gKHtcbiAgY29uc3RyYWludCxcbiAgcGxhY2VtZW50LFxuICBjdXN0b21TdHlsZXMsXG59OiB7XG4gIGNvbnN0cmFpbnQ6IFRUb29sdGlwUHJvcHNbJ2hvcml6b250YWxDb25zdHJhaW50J107XG4gIHBsYWNlbWVudDogc3RyaW5nO1xuICBjdXN0b21TdHlsZXM/OiBDU1NQcm9wZXJ0aWVzO1xufSk6IENTU1Byb3BlcnRpZXMgPT4ge1xuICBjb25zdCBjb25zdHJhaW50VG9rZW5OYW1lID0gYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YDtcbiAgcmV0dXJuIHtcbiAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgbWFyZ2luOiBgJHtnZXRPZmZzZXRNYXJnaW4oeyBwbGFjZW1lbnQgfSl9ICFpbXBvcnRhbnRgLFxuICAgIG1heFdpZHRoOlxuICAgICAgY29uc3RyYWludFRva2VuTmFtZSBpbiBkZXNpZ25Ub2tlbnNcbiAgICAgICAgPyBkZXNpZ25Ub2tlbnNbY29uc3RyYWludFRva2VuTmFtZSBhcyBURGVzaWduVG9rZW5OYW1lXVxuICAgICAgICA6ICdhdXRvJyxcbiAgICAvLyBzbyBob3ZlcmluZyBvdmVyIHRoZSB0b29sdGlwIHdoZW4gdGhlIHRvb2x0aXAgb3ZlcmxhcHMgdGhlIGNvbXBvbmVudFxuICAgIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbiAgICB3aWR0aDogY29uc3RyYWludCA9PT0gJ2F1dG8nID8gJ2F1dG8nIDogdW5kZWZpbmVkLFxuICAgIHpJbmRleDogMTAwMCxcbiAgICAuLi5jdXN0b21TdHlsZXMsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgZ2V0VG9vbHRpcFN0eWxlcyA9ICh0b29sdGlwU3RhdGU6IFRUb29sdGlwU3RhdGUpID0+XG4gIGdldEFuaW1hdGlvbih0b29sdGlwU3RhdGUpO1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgPiA6ZGlzYWJsZWQge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuIl19 */",
|
|
80
99
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__
|
|
81
100
|
});
|
|
82
101
|
|
|
@@ -88,15 +107,16 @@ const TooltipWrapper = props => jsx(Fragment, {
|
|
|
88
107
|
});
|
|
89
108
|
TooltipWrapper.displayName = 'TooltipWrapperComponent';
|
|
90
109
|
const tooltipDefaultProps = {
|
|
91
|
-
|
|
110
|
+
showAfter: 300,
|
|
111
|
+
closeAfter: 200,
|
|
92
112
|
horizontalConstraint: 'scale',
|
|
93
113
|
off: false,
|
|
94
114
|
placement: 'top'
|
|
95
115
|
};
|
|
96
116
|
const Tooltip = props => {
|
|
97
117
|
var _props$components, _props$components2, _props$components3, _props$components4, _props$components5, _props$components6, _props$styles;
|
|
118
|
+
const enterTimer = useRef();
|
|
98
119
|
const leaveTimer = useRef();
|
|
99
|
-
const childrenRef = useRef();
|
|
100
120
|
if ((_props$components = props.components) !== null && _props$components !== void 0 && _props$components.BodyComponent) {
|
|
101
121
|
process.env.NODE_ENV !== "production" ? warning(isValidElementType(props.components.BodyComponent), "ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.") : void 0;
|
|
102
122
|
}
|
|
@@ -108,6 +128,9 @@ const Tooltip = props => {
|
|
|
108
128
|
}
|
|
109
129
|
useEffect(() => {
|
|
110
130
|
return () => {
|
|
131
|
+
if (enterTimer.current) {
|
|
132
|
+
clearTimeout(enterTimer.current);
|
|
133
|
+
}
|
|
111
134
|
if (leaveTimer.current) {
|
|
112
135
|
clearTimeout(leaveTimer.current);
|
|
113
136
|
}
|
|
@@ -118,41 +141,30 @@ const Tooltip = props => {
|
|
|
118
141
|
modifiers: props.modifiers
|
|
119
142
|
}),
|
|
120
143
|
reference = _usePopper.reference,
|
|
121
|
-
popper = _usePopper.popper
|
|
122
|
-
|
|
123
|
-
|
|
124
|
-
|
|
125
|
-
|
|
126
|
-
|
|
127
|
-
toggle(false);
|
|
128
|
-
}, [toggle]);
|
|
129
|
-
const openTooltip = useCallback(() => {
|
|
130
|
-
toggle(true);
|
|
131
|
-
}, [toggle]);
|
|
144
|
+
popper = _usePopper.popper,
|
|
145
|
+
popperInstance = _usePopper.popperInstance;
|
|
146
|
+
const _useState = useState('closed'),
|
|
147
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
148
|
+
state = _useState2[0],
|
|
149
|
+
setState = _useState2[1];
|
|
132
150
|
const isControlled = !isNil(props.isOpen);
|
|
133
|
-
const tooltipIsOpen = isControlled ? props.isOpen :
|
|
151
|
+
const tooltipIsOpen = isControlled ? props.isOpen : state === 'opened' || state === 'exiting';
|
|
134
152
|
const id = useFieldId(props.id, sequentialId);
|
|
135
153
|
const onClose = props.onClose;
|
|
136
154
|
const handleClose = useCallback(event => {
|
|
137
155
|
if (!isControlled) {
|
|
138
|
-
|
|
156
|
+
setState('closed');
|
|
139
157
|
}
|
|
140
158
|
if (onClose) {
|
|
141
159
|
onClose(event);
|
|
142
160
|
}
|
|
143
|
-
}, [isControlled,
|
|
161
|
+
}, [isControlled, onClose]);
|
|
144
162
|
const _props$children$props = props.children.props,
|
|
145
163
|
onFocus = _props$children$props.onFocus,
|
|
146
164
|
onMouseOver = _props$children$props.onMouseOver;
|
|
147
|
-
const
|
|
165
|
+
const showAfter = props.showAfter,
|
|
166
|
+
onOpen = props.onOpen;
|
|
148
167
|
const handleEnter = useCallback(event => {
|
|
149
|
-
// Remove the title ahead of time.
|
|
150
|
-
// We don't want to wait for the next render commit.
|
|
151
|
-
// We would risk displaying two tooltips at the same time (native + this one).
|
|
152
|
-
if (childrenRef && typeof childrenRef === 'function') {
|
|
153
|
-
// @ts-ignore
|
|
154
|
-
childrenRef.setAttribute('title', '');
|
|
155
|
-
}
|
|
156
168
|
if (event) {
|
|
157
169
|
if (event.type === 'mouseover' && onMouseOver) {
|
|
158
170
|
onMouseOver(event);
|
|
@@ -160,42 +172,46 @@ const Tooltip = props => {
|
|
|
160
172
|
if (event.type === 'focus' && onFocus) {
|
|
161
173
|
onFocus(event);
|
|
162
174
|
}
|
|
163
|
-
if (
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
175
|
+
if (state !== 'opened' && !isControlled) {
|
|
176
|
+
setState('entering');
|
|
177
|
+
enterTimer.current = _setTimeout(() => {
|
|
178
|
+
setState('opened');
|
|
179
|
+
if (onOpen) {
|
|
180
|
+
onOpen(event);
|
|
181
|
+
}
|
|
182
|
+
}, showAfter);
|
|
168
183
|
}
|
|
169
184
|
event.preventDefault();
|
|
170
185
|
event.stopPropagation();
|
|
171
186
|
}
|
|
172
|
-
}, [onFocus, onOpen, onMouseOver, isControlled,
|
|
187
|
+
}, [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]);
|
|
173
188
|
const _props$children$props2 = props.children.props,
|
|
174
189
|
onBlur = _props$children$props2.onBlur,
|
|
175
190
|
onMouseLeave = _props$children$props2.onMouseLeave;
|
|
176
191
|
const closeAfter = props.closeAfter;
|
|
177
192
|
const handleLeave = useCallback(event => {
|
|
178
|
-
|
|
179
|
-
|
|
180
|
-
}
|
|
193
|
+
clearTimeout(enterTimer.current);
|
|
194
|
+
clearTimeout(leaveTimer.current);
|
|
181
195
|
if (event.type === 'mouseleave' && onMouseLeave) {
|
|
182
196
|
onMouseLeave(event);
|
|
183
197
|
}
|
|
184
198
|
if (event.type === 'blur' && onBlur) {
|
|
185
199
|
onBlur(event);
|
|
186
200
|
}
|
|
187
|
-
if (closeAfter) {
|
|
201
|
+
if (closeAfter && state === 'opened') {
|
|
188
202
|
leaveTimer.current = _setTimeout(() => {
|
|
189
|
-
|
|
203
|
+
const tooltipElement = popperInstance === null || popperInstance === void 0 ? void 0 : popperInstance.popper.querySelector('[data-testid="tooltip-message-wrapper"]');
|
|
204
|
+
tooltipElement.addEventListener('animationend', () => handleClose());
|
|
205
|
+
setState('exiting');
|
|
190
206
|
}, closeAfter);
|
|
191
207
|
} else {
|
|
192
208
|
handleClose(event);
|
|
193
209
|
}
|
|
194
|
-
}, [closeAfter, onBlur, onMouseLeave, handleClose]);
|
|
210
|
+
}, [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]);
|
|
195
211
|
useEffect(() => {
|
|
196
212
|
// if tooltip was open, and then component
|
|
197
213
|
// updated to be off, we should close the tooltip
|
|
198
|
-
if (
|
|
214
|
+
if (state === 'opened' && props.off) {
|
|
199
215
|
if (closeAfter) {
|
|
200
216
|
leaveTimer.current = _setTimeout(() => {
|
|
201
217
|
handleClose();
|
|
@@ -204,7 +220,7 @@ const Tooltip = props => {
|
|
|
204
220
|
handleClose();
|
|
205
221
|
}
|
|
206
222
|
}
|
|
207
|
-
}, [props.off, closeAfter, handleClose,
|
|
223
|
+
}, [props.off, closeAfter, handleClose, state]);
|
|
208
224
|
const childrenProps = {
|
|
209
225
|
// don't pass event listeners to children
|
|
210
226
|
onFocus: null,
|
|
@@ -216,10 +232,10 @@ const Tooltip = props => {
|
|
|
216
232
|
'aria-describedby': tooltipIsOpen ? id : null,
|
|
217
233
|
// for seo and accessibility, we add the tooltip's title
|
|
218
234
|
// as a native title when the title is hidden
|
|
219
|
-
title: !tooltipIsOpen && typeof props.title === 'string' ? props.title : null
|
|
235
|
+
title: !tooltipIsOpen && state !== 'entering' && typeof props.title === 'string' ? props.title : null
|
|
220
236
|
} : {};
|
|
221
237
|
const eventListeners = !props.off ? {
|
|
222
|
-
|
|
238
|
+
onMouseEnter: handleEnter,
|
|
223
239
|
onMouseLeave: handleLeave,
|
|
224
240
|
onFocus: handleEnter,
|
|
225
241
|
onBlur: handleLeave
|
|
@@ -241,10 +257,14 @@ const Tooltip = props => {
|
|
|
241
257
|
constraint: props.horizontalConstraint,
|
|
242
258
|
placement: popper.placement,
|
|
243
259
|
customStyles: (_props$styles = props.styles) === null || _props$styles === void 0 ? void 0 : _props$styles.body
|
|
244
|
-
})), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AAmUiB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId, useToggleState } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport { Wrapper, Body, getBodyStyles } from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst tooltipDefaultProps: Pick<\n  TTooltipProps,\n  'closeAfter' | 'horizontalConstraint' | 'off' | 'placement'\n> = {\n  closeAfter: 0,\n  horizontalConstraint: 'scale',\n  off: false,\n  placement: 'top',\n};\n\nconst Tooltip = (props: TTooltipProps) => {\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n  const childrenRef = useRef<ReturnType<typeof setTimeout>>();\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper } = usePopper({\n    placement: props.placement,\n    modifiers: props.modifiers,\n  });\n  const [isOpen, toggle] = useToggleState(false);\n  const closeTooltip = useCallback(() => {\n    toggle(false);\n  }, [toggle]);\n  const openTooltip = useCallback(() => {\n    toggle(true);\n  }, [toggle]);\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled ? props.isOpen : isOpen;\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        closeTooltip();\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, closeTooltip, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      // Remove the title ahead of time.\n      // We don't want to wait for the next render commit.\n      // We would risk displaying two tooltips at the same time (native + this one).\n      if (childrenRef && typeof childrenRef === 'function') {\n        // @ts-ignore\n        childrenRef.setAttribute('title', '');\n      }\n\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (!isOpen && !isControlled) {\n          openTooltip();\n        }\n\n        if (onOpen) {\n          onOpen(event);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, isOpen, openTooltip]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n  const { closeAfter } = props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose(event);\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (isOpen && props.off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [props.off, closeAfter, handleClose, toggle, isOpen]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !props.off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen && typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !props.off\n    ? {\n        onMouseOver: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: props.horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <BodyComponent>{props.title}</BodyComponent>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\nTooltip.defaultProps = tooltipDefaultProps;\n\nexport default Tooltip;\n"]} */"),
|
|
260
|
+
})), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AAiViB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst tooltipDefaultProps: Pick<\n  TTooltipProps,\n  'showAfter' | 'closeAfter' | 'horizontalConstraint' | 'off' | 'placement'\n> = {\n  showAfter: 300,\n  closeAfter: 200,\n  horizontalConstraint: 'scale',\n  off: false,\n  placement: 'top',\n};\n\nconst Tooltip = (props: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>();\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: props.placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { showAfter, onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n  const { closeAfter } = props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      clearTimeout(enterTimer.current);\n      clearTimeout(leaveTimer.current);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n          tooltipElement.addEventListener('animationend', () => handleClose());\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && props.off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [props.off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !props.off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !props.off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: props.horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\nTooltip.defaultProps = tooltipDefaultProps;\n\nexport default Tooltip;\n"]} */"),
|
|
245
261
|
"data-placement": popper.placement,
|
|
246
|
-
children: jsx(
|
|
247
|
-
children: props.title
|
|
262
|
+
children: jsx("div", {
|
|
263
|
+
css: /*#__PURE__*/css(_objectSpread({}, getTooltipStyles(state)), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["tooltip.tsx"],"names":[],"mappings":"AA4VmB","file":"tooltip.tsx","sourcesContent":["// inspired from https://github.com/mui-org/material-ui/blob/9ecc8db8abbfb829111d3b5c0678267827984024/packages/material-ui/src/Tooltip/Tooltip.js\nimport { Modifiers } from 'popper.js';\nimport {\n  ComponentType,\n  FocusEvent,\n  ChangeEvent,\n  LegacyRef,\n  CSSProperties,\n  ReactElement,\n  useRef,\n  useEffect,\n  useCallback,\n  cloneElement,\n  useState,\n} from 'react';\nimport { isValidElementType } from 'react-is';\nimport isNil from 'lodash/isNil';\nimport usePopper from 'use-popper';\nimport { css } from '@emotion/react';\nimport { useFieldId } from '@commercetools-uikit/hooks';\nimport { createSequentialId, warning } from '@commercetools-uikit/utils';\nimport {\n  Wrapper,\n  Body,\n  getBodyStyles,\n  getTooltipStyles,\n} from './tooltip.styles';\n\nconst sequentialId = createSequentialId('tooltip-');\n\nexport type TComponents = {\n  /**\n   * The component rendered as the tooltip body.\n   */\n  BodyComponent?: ComponentType;\n  /**\n   * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.\n   */\n  TooltipWrapperComponent?: ComponentType;\n  /**\n   * A custom component wrapper for the tooltip.\n   */\n  WrapperComponent?: ComponentType;\n};\n\nexport type TTooltipProps = {\n  children: ReactElement;\n\n  /**\n   * Delay (in milliseconds) between the start of the user interaction, and showing the tooltip.\n   */\n  showAfter?: number;\n  /**\n   * Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip.\n   */\n  closeAfter?: number;\n  /**\n   * Custom css-in-js object styles for the tooltip body.\n   */\n  styles?: Record<string, CSSProperties>;\n  /**\n   * Determines if the tooltip should not appear.\n   */\n  off: boolean;\n  /**\n   * An identifier for the tooltip, used for `aria-describedby`.\n   */\n  id?: string;\n  /**\n   * A callback function, called when the tooltip is closing.\n   */\n  onClose?: (e?: ChangeEvent | FocusEvent) => void;\n  /**\n   * A callback function, called when the tooltip is opening.\n   */\n  onOpen?: (e?: ChangeEvent | FocusEvent) => void;\n  isOpen?: boolean;\n  /**\n   * How the tooltip is positioned relative to the child element.\n   */\n  placement?:\n    | 'top'\n    | 'top-start'\n    | 'top-end'\n    | 'right'\n    | 'right-start'\n    | 'right-end'\n    | 'bottom'\n    | 'bottom-start'\n    | 'bottom-end'\n    | 'left'\n    | 'left-start'\n    | 'left-end';\n  /**\n   * The message to show in the tooltip.\n   */\n  title: string;\n  /**\n   * Provides a way to fine-tune an appearance of underlying Popper tooltip element. For more information, please check [Popper.js documentation](https://popper.js.org/popper-documentation.html#modifiers).\n   */\n  modifiers?: Modifiers;\n  /**\n   * Customize the appearance of certain elements of the tooltip.\n   */\n  components?: TComponents;\n  /**\n   * Horizontal size limit of the tooltip.\n   */\n  horizontalConstraint?:\n    | 1\n    | 2\n    | 3\n    | 4\n    | 5\n    | 6\n    | 7\n    | 8\n    | 9\n    | 10\n    | 11\n    | 12\n    | 13\n    | 14\n    | 15\n    | 16\n    | 'scale'\n    | 'auto';\n};\n\nexport type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';\n\nconst TooltipWrapper = (props: Pick<TTooltipProps, 'children'>) => (\n  <>{props.children}</>\n);\nTooltipWrapper.displayName = 'TooltipWrapperComponent';\n\nconst tooltipDefaultProps: Pick<\n  TTooltipProps,\n  'showAfter' | 'closeAfter' | 'horizontalConstraint' | 'off' | 'placement'\n> = {\n  showAfter: 300,\n  closeAfter: 200,\n  horizontalConstraint: 'scale',\n  off: false,\n  placement: 'top',\n};\n\nconst Tooltip = (props: TTooltipProps) => {\n  const enterTimer = useRef<ReturnType<typeof setTimeout>>();\n  const leaveTimer = useRef<ReturnType<typeof setTimeout>>();\n\n  if (props.components?.BodyComponent) {\n    warning(\n      isValidElementType(props.components.BodyComponent),\n      `ui-kit/Tooltip: the prop 'components.BodyComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.TooltipWrapperComponent) {\n    warning(\n      isValidElementType(props.components.TooltipWrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.`\n    );\n  }\n  if (props.components?.WrapperComponent) {\n    warning(\n      isValidElementType(props.components.WrapperComponent),\n      `ui-kit/Tooltip: the prop 'components.WrapperComponent' is not a valid React element.`\n    );\n  }\n\n  useEffect(() => {\n    return () => {\n      if (enterTimer.current) {\n        clearTimeout(enterTimer.current);\n      }\n      if (leaveTimer.current) {\n        clearTimeout(leaveTimer.current);\n      }\n    };\n  }, []);\n\n  const { reference, popper, popperInstance } = usePopper({\n    placement: props.placement,\n    modifiers: props.modifiers,\n  });\n  const [state, setState] = useState<TTooltipState>('closed');\n\n  const isControlled = !isNil(props.isOpen);\n  const tooltipIsOpen = isControlled\n    ? props.isOpen\n    : state === 'opened' || state === 'exiting';\n  const id = useFieldId(props.id, sequentialId);\n\n  const { onClose } = props;\n  const handleClose = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (!isControlled) {\n        setState('closed');\n      }\n      if (onClose) {\n        onClose(event);\n      }\n    },\n    [isControlled, onClose]\n  );\n\n  const { onFocus, onMouseOver } = props.children.props;\n  const { showAfter, onOpen } = props;\n  const handleEnter = useCallback(\n    (event?: ChangeEvent | FocusEvent) => {\n      if (event) {\n        if (event.type === 'mouseover' && onMouseOver) {\n          onMouseOver(event);\n        }\n\n        if (event.type === 'focus' && onFocus) {\n          onFocus(event);\n        }\n\n        if (state !== 'opened' && !isControlled) {\n          setState('entering');\n          enterTimer.current = setTimeout(() => {\n            setState('opened');\n\n            if (onOpen) {\n              onOpen(event);\n            }\n          }, showAfter);\n        }\n\n        event.preventDefault();\n        event.stopPropagation();\n      }\n    },\n    [onFocus, onOpen, onMouseOver, isControlled, state, showAfter]\n  );\n\n  const { onBlur, onMouseLeave } = props.children.props;\n  const { closeAfter } = props;\n\n  const handleLeave = useCallback(\n    (event) => {\n      clearTimeout(enterTimer.current);\n      clearTimeout(leaveTimer.current);\n\n      if (event.type === 'mouseleave' && onMouseLeave) {\n        onMouseLeave(event);\n      }\n\n      if (event.type === 'blur' && onBlur) {\n        onBlur(event);\n      }\n\n      if (closeAfter && state === 'opened') {\n        leaveTimer.current = setTimeout(() => {\n          const tooltipElement = popperInstance?.popper.querySelector(\n            '[data-testid=\"tooltip-message-wrapper\"]'\n          ) as HTMLElement;\n          tooltipElement.addEventListener('animationend', () => handleClose());\n\n          setState('exiting');\n        }, closeAfter);\n      } else {\n        handleClose(event);\n      }\n    },\n    [closeAfter, onBlur, onMouseLeave, handleClose, state, popperInstance]\n  );\n\n  useEffect(() => {\n    // if tooltip was open, and then component\n    // updated to be off, we should close the tooltip\n    if (state === 'opened' && props.off) {\n      if (closeAfter) {\n        leaveTimer.current = setTimeout(() => {\n          handleClose();\n        }, closeAfter);\n      } else {\n        handleClose();\n      }\n    }\n  }, [props.off, closeAfter, handleClose, state]);\n\n  const childrenProps = {\n    // don't pass event listeners to children\n    onFocus: null,\n    onMouseOver: null,\n    onMouseLeave: null,\n    onBlur: null,\n  };\n\n  const tooltipProps = !props.off\n    ? {\n        'aria-describedby': tooltipIsOpen ? id : null,\n        // for seo and accessibility, we add the tooltip's title\n        // as a native title when the title is hidden\n        title:\n          !tooltipIsOpen &&\n          state !== 'entering' &&\n          typeof props.title === 'string'\n            ? props.title\n            : null,\n      }\n    : {};\n\n  const eventListeners = !props.off\n    ? {\n        onMouseEnter: handleEnter,\n        onMouseLeave: handleLeave,\n        onFocus: handleEnter,\n        onBlur: handleLeave,\n      }\n    : {};\n\n  const WrapperComponent = props.components?.WrapperComponent || Wrapper;\n  const BodyComponent = props.components?.BodyComponent || Body;\n  const TooltipWrapperComponent =\n    props.components?.TooltipWrapperComponent || TooltipWrapper;\n\n  return (\n    <>\n      <WrapperComponent\n        {...eventListeners}\n        // @ts-expect-error: yes, ref can be undefined\n        ref={reference.ref}\n      >\n        {cloneElement(props.children, {\n          ...childrenProps,\n          ...tooltipProps,\n        })}\n      </WrapperComponent>\n      {tooltipIsOpen && (\n        <TooltipWrapperComponent>\n          <div\n            // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`\n            // propper.ref returns `RefObject`\n            ref={popper.ref as LegacyRef<HTMLDivElement>}\n            css={css({\n              ...popper.styles,\n              ...getBodyStyles({\n                constraint: props.horizontalConstraint,\n                placement: popper.placement,\n                customStyles: props.styles?.body,\n              }),\n            })}\n            data-placement={popper.placement}\n          >\n            <div\n              css={css({\n                ...getTooltipStyles(state),\n              })}\n              data-testid=\"tooltip-message-wrapper\"\n            >\n              <BodyComponent>{props.title}</BodyComponent>\n            </div>\n          </div>\n        </TooltipWrapperComponent>\n      )}\n    </>\n  );\n};\n\nTooltip.displayName = 'ToolTip';\nTooltip.defaultProps = tooltipDefaultProps;\n\nexport default Tooltip;\n"]} */"),
|
|
264
|
+
"data-testid": "tooltip-message-wrapper",
|
|
265
|
+
children: jsx(BodyComponent, {
|
|
266
|
+
children: props.title
|
|
267
|
+
})
|
|
248
268
|
})
|
|
249
269
|
})
|
|
250
270
|
})]
|
|
@@ -252,7 +272,8 @@ const Tooltip = props => {
|
|
|
252
272
|
};
|
|
253
273
|
Tooltip.propTypes = process.env.NODE_ENV !== "production" ? {
|
|
254
274
|
children: _pt.element.isRequired,
|
|
255
|
-
|
|
275
|
+
showAfter: _pt.number,
|
|
276
|
+
closeAfter: _pt.number,
|
|
256
277
|
styles: _pt.objectOf(_pt.any),
|
|
257
278
|
off: _pt.bool.isRequired,
|
|
258
279
|
id: _pt.string,
|
|
@@ -274,6 +295,6 @@ Tooltip.defaultProps = tooltipDefaultProps;
|
|
|
274
295
|
var Tooltip$1 = Tooltip;
|
|
275
296
|
|
|
276
297
|
// NOTE: This string will be replaced on build time with the package version.
|
|
277
|
-
var version = "16.
|
|
298
|
+
var version = "16.6.0";
|
|
278
299
|
|
|
279
300
|
export { Tooltip$1 as default, version };
|
|
@@ -7,7 +7,8 @@ export type TComponents = {
|
|
|
7
7
|
};
|
|
8
8
|
export type TTooltipProps = {
|
|
9
9
|
children: ReactElement;
|
|
10
|
-
|
|
10
|
+
showAfter?: number;
|
|
11
|
+
closeAfter?: number;
|
|
11
12
|
styles?: Record<string, CSSProperties>;
|
|
12
13
|
off: boolean;
|
|
13
14
|
id?: string;
|
|
@@ -20,9 +21,10 @@ export type TTooltipProps = {
|
|
|
20
21
|
components?: TComponents;
|
|
21
22
|
horizontalConstraint?: 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 'scale' | 'auto';
|
|
22
23
|
};
|
|
24
|
+
export type TTooltipState = 'closed' | 'entering' | 'opened' | 'exiting';
|
|
23
25
|
declare const Tooltip: {
|
|
24
26
|
(props: TTooltipProps): import("@emotion/react/jsx-runtime").JSX.Element;
|
|
25
27
|
displayName: string;
|
|
26
|
-
defaultProps: Pick<TTooltipProps, "off" | "horizontalConstraint" | "closeAfter" | "placement">;
|
|
28
|
+
defaultProps: Pick<TTooltipProps, "off" | "horizontalConstraint" | "showAfter" | "closeAfter" | "placement">;
|
|
27
29
|
};
|
|
28
30
|
export default Tooltip;
|
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { CSSProperties } from 'react';
|
|
2
|
-
import type { TTooltipProps } from './tooltip';
|
|
2
|
+
import type { TTooltipProps, TTooltipState } from './tooltip';
|
|
3
3
|
export declare const Body: import("@emotion/styled").StyledComponent<{
|
|
4
4
|
theme?: import("@emotion/react").Theme | undefined;
|
|
5
5
|
as?: import("react").ElementType<any> | undefined;
|
|
@@ -9,6 +9,11 @@ export declare const getBodyStyles: ({ constraint, placement, customStyles, }: {
|
|
|
9
9
|
placement: string;
|
|
10
10
|
customStyles?: CSSProperties | undefined;
|
|
11
11
|
}) => CSSProperties;
|
|
12
|
+
export declare const getTooltipStyles: (tooltipState: TTooltipState) => {
|
|
13
|
+
animation: string;
|
|
14
|
+
} | {
|
|
15
|
+
animation?: undefined;
|
|
16
|
+
};
|
|
12
17
|
export declare const Wrapper: import("@emotion/styled").StyledComponent<{
|
|
13
18
|
theme?: import("@emotion/react").Theme | undefined;
|
|
14
19
|
as?: import("react").ElementType<any> | undefined;
|
package/package.json
CHANGED
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@commercetools-uikit/tooltip",
|
|
3
3
|
"description": "Tooltips display informative text when users hover over or focus on an element.",
|
|
4
|
-
"version": "16.
|
|
4
|
+
"version": "16.6.0",
|
|
5
5
|
"bugs": "https://github.com/commercetools/ui-kit/issues",
|
|
6
6
|
"repository": {
|
|
7
7
|
"type": "git",
|
|
@@ -21,10 +21,10 @@
|
|
|
21
21
|
"dependencies": {
|
|
22
22
|
"@babel/runtime": "^7.20.13",
|
|
23
23
|
"@babel/runtime-corejs3": "^7.20.13",
|
|
24
|
-
"@commercetools-uikit/constraints": "16.
|
|
25
|
-
"@commercetools-uikit/design-system": "16.
|
|
26
|
-
"@commercetools-uikit/hooks": "16.
|
|
27
|
-
"@commercetools-uikit/utils": "16.
|
|
24
|
+
"@commercetools-uikit/constraints": "16.6.0",
|
|
25
|
+
"@commercetools-uikit/design-system": "16.6.0",
|
|
26
|
+
"@commercetools-uikit/hooks": "16.6.0",
|
|
27
|
+
"@commercetools-uikit/utils": "16.6.0",
|
|
28
28
|
"@emotion/react": "^11.10.5",
|
|
29
29
|
"@emotion/styled": "^11.10.5",
|
|
30
30
|
"lodash": "4.17.21",
|