@commercetools-uikit/tooltip 16.4.1 → 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 CHANGED
@@ -183,7 +183,8 @@ export {
183
183
  | Props | Type | Required | Default | Description |
184
184
  | ---------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | :------: | --------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
185
185
  | `children` | `ReactElement` | ✅ | | |
186
- | `closeAfter` | `number` | | `0` | Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip. |
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$1 = require('@emotion/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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCOEIiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG50eXBlIFREZXNpZ25Ub2tlbk5hbWUgPSBrZXlvZiB0eXBlb2YgZGVzaWduVG9rZW5zO1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfWA7XG4gICAgY2FzZSAndG9wJzpcbiAgICBjYXNlICdib3R0b20nOlxuICAgICAgcmV0dXJuIGAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9IDBgO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gJyc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBCb2R5ID0gc3R5bGVkLmRpdmBcbiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVG9vbHRpcH07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93Rm9yVG9vbHRpcH07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIG9wYWNpdHk6IDAuOTU7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JUb29sdGlwfTtcbmA7XG5cbi8vIGhlcmUgd2UgdXNlIG9iamVjdCBzdHlsZXMgc28gd2UgY2FuIHNwcmVhZCB0aGVzZVxuLy8gd2l0aCB0aGUgc3R5bGVzIHdlIGdldCBmcm9tIHJlYWN0LXBvcHBlciA6RFxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnRcbmV4cG9ydCBjb25zdCBnZXRCb2R5U3R5bGVzID0gKHtcbiAgY29uc3RyYWludCxcbiAgcGxhY2VtZW50LFxuICBjdXN0b21TdHlsZXMsXG59OiB7XG4gIGNvbnN0cmFpbnQ6IFRUb29sdGlwUHJvcHNbJ2hvcml6b250YWxDb25zdHJhaW50J107XG4gIHBsYWNlbWVudDogc3RyaW5nO1xuICBjdXN0b21TdHlsZXM/OiBDU1NQcm9wZXJ0aWVzO1xufSk6IENTU1Byb3BlcnRpZXMgPT4ge1xuICBjb25zdCBjb25zdHJhaW50VG9rZW5OYW1lID0gYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YDtcbiAgcmV0dXJuIHtcbiAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgbWFyZ2luOiBgJHtnZXRPZmZzZXRNYXJnaW4oeyBwbGFjZW1lbnQgfSl9ICFpbXBvcnRhbnRgLFxuICAgIG1heFdpZHRoOlxuICAgICAgY29uc3RyYWludFRva2VuTmFtZSBpbiBkZXNpZ25Ub2tlbnNcbiAgICAgICAgPyBkZXNpZ25Ub2tlbnNbY29uc3RyYWludFRva2VuTmFtZSBhcyBURGVzaWduVG9rZW5OYW1lXVxuICAgICAgICA6ICdhdXRvJyxcbiAgICAvLyBzbyBob3ZlcmluZyBvdmVyIHRoZSB0b29sdGlwIHdoZW4gdGhlIHRvb2x0aXAgb3ZlcmxhcHMgdGhlIGNvbXBvbmVudFxuICAgIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbiAgICB3aWR0aDogY29uc3RyYWludCA9PT0gJ2F1dG8nID8gJ2F1dG8nIDogdW5kZWZpbmVkLFxuICAgIHpJbmRleDogMTAwMCxcbiAgICAuLi5jdXN0b21TdHlsZXMsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgPiA6ZGlzYWJsZWQge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuIl19 */"));
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZEaUMiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG50eXBlIFREZXNpZ25Ub2tlbk5hbWUgPSBrZXlvZiB0eXBlb2YgZGVzaWduVG9rZW5zO1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfWA7XG4gICAgY2FzZSAndG9wJzpcbiAgICBjYXNlICdib3R0b20nOlxuICAgICAgcmV0dXJuIGAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9IDBgO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gJyc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBCb2R5ID0gc3R5bGVkLmRpdmBcbiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVG9vbHRpcH07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93Rm9yVG9vbHRpcH07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIG9wYWNpdHk6IDAuOTU7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JUb29sdGlwfTtcbmA7XG5cbi8vIGhlcmUgd2UgdXNlIG9iamVjdCBzdHlsZXMgc28gd2UgY2FuIHNwcmVhZCB0aGVzZVxuLy8gd2l0aCB0aGUgc3R5bGVzIHdlIGdldCBmcm9tIHJlYWN0LXBvcHBlciA6RFxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnRcbmV4cG9ydCBjb25zdCBnZXRCb2R5U3R5bGVzID0gKHtcbiAgY29uc3RyYWludCxcbiAgcGxhY2VtZW50LFxuICBjdXN0b21TdHlsZXMsXG59OiB7XG4gIGNvbnN0cmFpbnQ6IFRUb29sdGlwUHJvcHNbJ2hvcml6b250YWxDb25zdHJhaW50J107XG4gIHBsYWNlbWVudDogc3RyaW5nO1xuICBjdXN0b21TdHlsZXM/OiBDU1NQcm9wZXJ0aWVzO1xufSk6IENTU1Byb3BlcnRpZXMgPT4ge1xuICBjb25zdCBjb25zdHJhaW50VG9rZW5OYW1lID0gYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YDtcbiAgcmV0dXJuIHtcbiAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgbWFyZ2luOiBgJHtnZXRPZmZzZXRNYXJnaW4oeyBwbGFjZW1lbnQgfSl9ICFpbXBvcnRhbnRgLFxuICAgIG1heFdpZHRoOlxuICAgICAgY29uc3RyYWludFRva2VuTmFtZSBpbiBkZXNpZ25Ub2tlbnNcbiAgICAgICAgPyBkZXNpZ25Ub2tlbnNbY29uc3RyYWludFRva2VuTmFtZSBhcyBURGVzaWduVG9rZW5OYW1lXVxuICAgICAgICA6ICdhdXRvJyxcbiAgICAvLyBzbyBob3ZlcmluZyBvdmVyIHRoZSB0b29sdGlwIHdoZW4gdGhlIHRvb2x0aXAgb3ZlcmxhcHMgdGhlIGNvbXBvbmVudFxuICAgIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbiAgICB3aWR0aDogY29uc3RyYWludCA9PT0gJ2F1dG8nID8gJ2F1dG8nIDogdW5kZWZpbmVkLFxuICAgIHpJbmRleDogMTAwMCxcbiAgICAuLi5jdXN0b21TdHlsZXMsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgPiA6ZGlzYWJsZWQge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuIl19 */",
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
- closeAfter: 0,
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 leaveTimer = react.useRef();
119
- const childrenRef = react.useRef();
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
- const _useToggleState = hooks.useToggleState(false),
143
- _useToggleState2 = _slicedToArray(_useToggleState, 2),
144
- isOpen = _useToggleState2[0],
145
- toggle = _useToggleState2[1];
146
- const closeTooltip = react.useCallback(() => {
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 : 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
- closeTooltip();
176
+ setState('closed');
159
177
  }
160
178
  if (onClose) {
161
179
  onClose(event);
162
180
  }
163
- }, [isControlled, closeTooltip, onClose]);
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 onOpen = props.onOpen;
168
- const handleEnter = react.useCallback(event => {
169
- // Remove the title ahead of time.
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 (!isOpen && !isControlled) {
184
- openTooltip();
185
- }
186
- if (onOpen) {
187
- onOpen(event);
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, isOpen, openTooltip]);
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
- if (leaveTimer.current) {
199
- clearTimeout(leaveTimer.current);
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
- handleClose(event);
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 (isOpen && props.off) {
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, toggle, isOpen]);
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
- onMouseOver: handleEnter,
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$1.css(_objectSpread(_objectSpread({}, popper.styles), getBodyStyles({
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(BodyComponent, {
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
- closeAfter: _pt__default["default"].number.isRequired,
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.4.1";
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$1 = require('@emotion/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
- closeAfter: 0,
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 leaveTimer = react.useRef();
106
- const childrenRef = react.useRef();
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
- const _useToggleState = hooks.useToggleState(false),
124
- _useToggleState2 = _slicedToArray(_useToggleState, 2),
125
- isOpen = _useToggleState2[0],
126
- toggle = _useToggleState2[1];
127
- const closeTooltip = react.useCallback(() => {
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 : 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
- closeTooltip();
157
+ setState('closed');
140
158
  }
141
159
  if (onClose) {
142
160
  onClose(event);
143
161
  }
144
- }, [isControlled, closeTooltip, onClose]);
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 onOpen = props.onOpen;
149
- const handleEnter = react.useCallback(event => {
150
- // Remove the title ahead of time.
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 (!isOpen && !isControlled) {
165
- openTooltip();
166
- }
167
- if (onOpen) {
168
- onOpen(event);
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, isOpen, openTooltip]);
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
- if (leaveTimer.current) {
180
- clearTimeout(leaveTimer.current);
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
- handleClose(event);
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 (isOpen && props.off) {
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, toggle, isOpen]);
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
- onMouseOver: handleEnter,
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$1.css(_objectSpread(_objectSpread({}, popper.styles), getBodyStyles({
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(BodyComponent, {
248
- children: props.title
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.4.1";
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 { useToggleState, useFieldId } from '@commercetools-uikit/hooks';
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCOEIiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG50eXBlIFREZXNpZ25Ub2tlbk5hbWUgPSBrZXlvZiB0eXBlb2YgZGVzaWduVG9rZW5zO1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfWA7XG4gICAgY2FzZSAndG9wJzpcbiAgICBjYXNlICdib3R0b20nOlxuICAgICAgcmV0dXJuIGAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9IDBgO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gJyc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBCb2R5ID0gc3R5bGVkLmRpdmBcbiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVG9vbHRpcH07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93Rm9yVG9vbHRpcH07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIG9wYWNpdHk6IDAuOTU7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JUb29sdGlwfTtcbmA7XG5cbi8vIGhlcmUgd2UgdXNlIG9iamVjdCBzdHlsZXMgc28gd2UgY2FuIHNwcmVhZCB0aGVzZVxuLy8gd2l0aCB0aGUgc3R5bGVzIHdlIGdldCBmcm9tIHJlYWN0LXBvcHBlciA6RFxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnRcbmV4cG9ydCBjb25zdCBnZXRCb2R5U3R5bGVzID0gKHtcbiAgY29uc3RyYWludCxcbiAgcGxhY2VtZW50LFxuICBjdXN0b21TdHlsZXMsXG59OiB7XG4gIGNvbnN0cmFpbnQ6IFRUb29sdGlwUHJvcHNbJ2hvcml6b250YWxDb25zdHJhaW50J107XG4gIHBsYWNlbWVudDogc3RyaW5nO1xuICBjdXN0b21TdHlsZXM/OiBDU1NQcm9wZXJ0aWVzO1xufSk6IENTU1Byb3BlcnRpZXMgPT4ge1xuICBjb25zdCBjb25zdHJhaW50VG9rZW5OYW1lID0gYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YDtcbiAgcmV0dXJuIHtcbiAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgbWFyZ2luOiBgJHtnZXRPZmZzZXRNYXJnaW4oeyBwbGFjZW1lbnQgfSl9ICFpbXBvcnRhbnRgLFxuICAgIG1heFdpZHRoOlxuICAgICAgY29uc3RyYWludFRva2VuTmFtZSBpbiBkZXNpZ25Ub2tlbnNcbiAgICAgICAgPyBkZXNpZ25Ub2tlbnNbY29uc3RyYWludFRva2VuTmFtZSBhcyBURGVzaWduVG9rZW5OYW1lXVxuICAgICAgICA6ICdhdXRvJyxcbiAgICAvLyBzbyBob3ZlcmluZyBvdmVyIHRoZSB0b29sdGlwIHdoZW4gdGhlIHRvb2x0aXAgb3ZlcmxhcHMgdGhlIGNvbXBvbmVudFxuICAgIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbiAgICB3aWR0aDogY29uc3RyYWludCA9PT0gJ2F1dG8nID8gJ2F1dG8nIDogdW5kZWZpbmVkLFxuICAgIHpJbmRleDogMTAwMCxcbiAgICAuLi5jdXN0b21TdHlsZXMsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgPiA6ZGlzYWJsZWQge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuIl19 */"));
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZEaUMiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgZGVzaWduVG9rZW5zIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG50eXBlIFREZXNpZ25Ub2tlbk5hbWUgPSBrZXlvZiB0eXBlb2YgZGVzaWduVG9rZW5zO1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHtkZXNpZ25Ub2tlbnMuc3BhY2luZzEwfWA7XG4gICAgY2FzZSAndG9wJzpcbiAgICBjYXNlICdib3R0b20nOlxuICAgICAgcmV0dXJuIGAke2Rlc2lnblRva2Vucy5zcGFjaW5nMTB9IDBgO1xuICAgIGRlZmF1bHQ6XG4gICAgICByZXR1cm4gJyc7XG4gIH1cbn07XG5cbmV4cG9ydCBjb25zdCBCb2R5ID0gc3R5bGVkLmRpdmBcbiAgZm9udC1mYW1pbHk6IGluaGVyaXQ7XG4gIGJvcmRlci1yYWRpdXM6ICR7ZGVzaWduVG9rZW5zLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke2Rlc2lnblRva2Vucy5wYWRkaW5nRm9yVG9vbHRpcH07XG4gIGJvcmRlcjogbm9uZTtcbiAgYm94LXNoYWRvdzogJHtkZXNpZ25Ub2tlbnMuc2hhZG93Rm9yVG9vbHRpcH07XG4gIGZvbnQtc2l6ZTogJHtkZXNpZ25Ub2tlbnMuZm9udFNpemUyMH07XG4gIG9wYWNpdHk6IDAuOTU7XG4gIGNvbG9yOiAke2Rlc2lnblRva2Vucy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke2Rlc2lnblRva2Vucy5iYWNrZ3JvdW5kQ29sb3JGb3JUb29sdGlwfTtcbmA7XG5cbi8vIGhlcmUgd2UgdXNlIG9iamVjdCBzdHlsZXMgc28gd2UgY2FuIHNwcmVhZCB0aGVzZVxuLy8gd2l0aCB0aGUgc3R5bGVzIHdlIGdldCBmcm9tIHJlYWN0LXBvcHBlciA6RFxuLy8gZXNsaW50LWRpc2FibGUtbmV4dC1saW5lIGltcG9ydC9wcmVmZXItZGVmYXVsdC1leHBvcnRcbmV4cG9ydCBjb25zdCBnZXRCb2R5U3R5bGVzID0gKHtcbiAgY29uc3RyYWludCxcbiAgcGxhY2VtZW50LFxuICBjdXN0b21TdHlsZXMsXG59OiB7XG4gIGNvbnN0cmFpbnQ6IFRUb29sdGlwUHJvcHNbJ2hvcml6b250YWxDb25zdHJhaW50J107XG4gIHBsYWNlbWVudDogc3RyaW5nO1xuICBjdXN0b21TdHlsZXM/OiBDU1NQcm9wZXJ0aWVzO1xufSk6IENTU1Byb3BlcnRpZXMgPT4ge1xuICBjb25zdCBjb25zdHJhaW50VG9rZW5OYW1lID0gYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YDtcbiAgcmV0dXJuIHtcbiAgICBmb250RmFtaWx5OiAnaW5oZXJpdCcsXG4gICAgbWFyZ2luOiBgJHtnZXRPZmZzZXRNYXJnaW4oeyBwbGFjZW1lbnQgfSl9ICFpbXBvcnRhbnRgLFxuICAgIG1heFdpZHRoOlxuICAgICAgY29uc3RyYWludFRva2VuTmFtZSBpbiBkZXNpZ25Ub2tlbnNcbiAgICAgICAgPyBkZXNpZ25Ub2tlbnNbY29uc3RyYWludFRva2VuTmFtZSBhcyBURGVzaWduVG9rZW5OYW1lXVxuICAgICAgICA6ICdhdXRvJyxcbiAgICAvLyBzbyBob3ZlcmluZyBvdmVyIHRoZSB0b29sdGlwIHdoZW4gdGhlIHRvb2x0aXAgb3ZlcmxhcHMgdGhlIGNvbXBvbmVudFxuICAgIHBvaW50ZXJFdmVudHM6ICdub25lJyxcbiAgICB3aWR0aDogY29uc3RyYWludCA9PT0gJ2F1dG8nID8gJ2F1dG8nIDogdW5kZWZpbmVkLFxuICAgIHpJbmRleDogMTAwMCxcbiAgICAuLi5jdXN0b21TdHlsZXMsXG4gIH07XG59O1xuXG5leHBvcnQgY29uc3QgV3JhcHBlciA9IHN0eWxlZC5kaXZgXG4gIGRpc3BsYXk6IGlubGluZS1ibG9jaztcbiAgY3Vyc29yOiBub3QtYWxsb3dlZDtcbiAgPiA6ZGlzYWJsZWQge1xuICAgIHBvaW50ZXItZXZlbnRzOiBub25lO1xuICB9XG5gO1xuIl19 */",
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
- closeAfter: 0,
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
- const _useToggleState = useToggleState(false),
123
- _useToggleState2 = _slicedToArray(_useToggleState, 2),
124
- isOpen = _useToggleState2[0],
125
- toggle = _useToggleState2[1];
126
- const closeTooltip = useCallback(() => {
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 : 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
- closeTooltip();
156
+ setState('closed');
139
157
  }
140
158
  if (onClose) {
141
159
  onClose(event);
142
160
  }
143
- }, [isControlled, closeTooltip, onClose]);
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 onOpen = props.onOpen;
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 (!isOpen && !isControlled) {
164
- openTooltip();
165
- }
166
- if (onOpen) {
167
- onOpen(event);
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, isOpen, openTooltip]);
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
- if (leaveTimer.current) {
179
- clearTimeout(leaveTimer.current);
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
- handleClose(event);
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 (isOpen && props.off) {
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, toggle, isOpen]);
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
- onMouseOver: handleEnter,
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(BodyComponent, {
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
- closeAfter: _pt.number.isRequired,
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.4.1";
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
- closeAfter: number;
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.1",
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.4.1",
25
- "@commercetools-uikit/design-system": "16.4.1",
26
- "@commercetools-uikit/hooks": "16.4.1",
27
- "@commercetools-uikit/utils": "16.4.1",
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",