@commercetools-uikit/tooltip 0.0.0-canary-2021830134526

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/LICENSE ADDED
@@ -0,0 +1,21 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2019 commercetools GmbH
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy
6
+ of this software and associated documentation files (the "Software"), to deal
7
+ in the Software without restriction, including without limitation the rights
8
+ to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
9
+ copies of the Software, and to permit persons to whom the Software is
10
+ furnished to do so, subject to the following conditions:
11
+
12
+ The above copyright notice and this permission notice shall be included in all
13
+ copies or substantial portions of the Software.
14
+
15
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16
+ IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17
+ FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
18
+ AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19
+ LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
20
+ OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
21
+ SOFTWARE.
package/README.md ADDED
@@ -0,0 +1,230 @@
1
+ <!-- THIS IS AN AUTOGENERATED FILE. DO NOT EDIT THIS FILE DIRECTLY. -->
2
+ <!-- This file is created by the `yarn generate-readme` script. -->
3
+
4
+ # Tooltip
5
+
6
+ ## Description
7
+
8
+ Tooltips display informative text when users hover over or focus on an element.
9
+
10
+ ## Installation
11
+
12
+ ```
13
+ yarn add @commercetools-uikit/tooltip
14
+ ```
15
+
16
+ ```
17
+ npm --save install @commercetools-uikit/tooltip
18
+ ```
19
+
20
+ Additionally install the peer dependencies (if not present)
21
+
22
+ ```
23
+ yarn add react
24
+ ```
25
+
26
+ ```
27
+ npm --save install react
28
+ ```
29
+
30
+ ## Usage
31
+
32
+ ```jsx
33
+ import { forwardRef } from 'react';
34
+ import PropTypes from 'prop-types';
35
+ import ReactDOM from 'react-dom';
36
+ import styled from '@emotion/styled';
37
+ import Tooltip from '@commercetools-uikit/tooltip';
38
+
39
+ /* 1. Standard example */
40
+ const ExampleStandard = () => (
41
+ <Tooltip
42
+ placement="left"
43
+ title="If you buy a pizza, you will also get a free ice cream :)"
44
+ >
45
+ <button onClick={() => {}}>Submit</button>
46
+ </Tooltip>
47
+ );
48
+
49
+ /**
50
+ * 2. Working with disabled child elements
51
+ *
52
+ * When you use a tooltip with a disabled element, you should define the
53
+ * style `pointer-events: none` to the disabled element to stop it from capturing events.
54
+ * The Button components from UIKit already support this functionality.
55
+ */
56
+ const ExampleWithDisabledElements = () => (
57
+ <Tooltip
58
+ placement="left"
59
+ title="You do not have permission to delete the database"
60
+ >
61
+ <button disabled onClick={() => {}} style={{ pointerEvents: 'none' }}>
62
+ Delete production database
63
+ </button>
64
+ </Tooltip>
65
+ );
66
+
67
+ /**
68
+ * 3. Customizing the wrapper
69
+ *
70
+ * The tooltip applies event listeners (`onMouseOver`, `onMouseLeave`, `onFocus`,
71
+ * and `onBlur`) to a wrapping `div` component around the children element.
72
+ * By default, this wrapper is displayed with style `inline-block`.
73
+ * If you want to customize this behaviour, then you can pass in a custom element.
74
+ * Be sure to use `React.forwardRef`, as we need the to pass the ref to the wrapper.
75
+ */
76
+ const Wrapper = forwardRef((props, ref) => (
77
+ <div ref={ref} style={{ display: 'block' }} {...props}>
78
+ {props.children}
79
+ </div>
80
+ ));
81
+ Wrapper.propTypes = {
82
+ children: PropTypes.node.isRequired,
83
+ };
84
+ const FullWidthButton = styled.button`
85
+ display: block;
86
+ width: 100%;
87
+ `;
88
+ const ExampleWithCustomWrapper = () => (
89
+ <Tooltip title="Delete" components={{ WrapperComponent: Wrapper }}>
90
+ <FullWidthButton>Submit</FullWidthButton>
91
+ </Tooltip>
92
+ );
93
+
94
+ /**
95
+ * 4. Customizing the tooltip body
96
+ *
97
+ * You can customize the look and feel of the tooltip body by passing in a custom `BodyComponent`.
98
+ */
99
+ const Body = styled.div`
100
+ color: red;
101
+ `;
102
+ const ExampleWithCustomBody = () => (
103
+ <Tooltip title="Delete" components={{ BodyComponent: Body }}>
104
+ <button>Submit</button>
105
+ </Tooltip>
106
+ );
107
+
108
+ /**
109
+ * 5. Customizing where the portal is rendered
110
+ *
111
+ * When you are dealing with virtualized components, it can be useful to render
112
+ * the tooltip into another part of the document.
113
+ * You can define a `TooltipWrapperComponent` to do this.
114
+ */
115
+ const Portal = (props) => ReactDOM.createPortal(props.children, document.body);
116
+ const ExampleWithCustomPortal = () => (
117
+ <Tooltip title="Delete" components={{ TooltipWrapperComponent: Portal }}>
118
+ <button>Submit</button>
119
+ </Tooltip>
120
+ );
121
+
122
+ /**
123
+ * 6. Conditionally displaying tooltips
124
+ *
125
+ * There may be cases when you only want to enable the display of a tooltip under
126
+ * a certain condition. In these cases, you may want to use the `off` prop.
127
+ * In the following example, the tooltip text only appears on hover when the button is disabled.
128
+ */
129
+ const ExampleWithConditionals = (props) => (
130
+ <Tooltip
131
+ off={props.isDisabled}
132
+ title="You do not have permission to perform this action"
133
+ >
134
+ <button disabled={props.isDisabled}>Submit</button>
135
+ </Tooltip>
136
+ );
137
+ ExampleWithConditionals.propTypes = {
138
+ isDisabled: PropTypes.bool,
139
+ };
140
+
141
+ /**
142
+ * 7. Fine-tuning underlying Popper.js behavior
143
+ *
144
+ * This component uses [Popper.js](https://popper.js.org/) under the hood.
145
+ * Popper provides a way to adjust how tooltip element should behave, by providing
146
+ * a [set of `modifiers`](https://popper.js.org/popper-documentation.html#modifiers).
147
+ * For instance, forcing tooltip to stay in the original placement and not to try
148
+ * flipping when it's getting out of boundaries, can be implemented as following:
149
+ */
150
+ const ExampleWithCustomPopperBehavior = (props) => (
151
+ <Tooltip
152
+ placement="left"
153
+ title="I will always be on the left side"
154
+ modifiers={{
155
+ preventOverflow: {
156
+ enabled: false,
157
+ },
158
+ flip: {
159
+ enabled: false,
160
+ },
161
+ }}
162
+ >
163
+ <button disabled={props.isDisabled}>Submit</button>
164
+ </Tooltip>
165
+ );
166
+ ExampleWithCustomPopperBehavior.propTypes = {
167
+ isDisabled: PropTypes.bool,
168
+ };
169
+
170
+ export {
171
+ ExampleStandard,
172
+ ExampleWithDisabledElements,
173
+ ExampleWithCustomWrapper,
174
+ ExampleWithCustomBody,
175
+ ExampleWithCustomPortal,
176
+ ExampleWithConditionals,
177
+ ExampleWithCustomPopperBehavior,
178
+ };
179
+ ```
180
+
181
+ ## Properties
182
+
183
+ | Props | Type | Required | Default | Description |
184
+ | ---------------------- | --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- | :------: | --------- | -------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------- |
185
+ | `children` | `ReactElement` | ✅ | | |
186
+ | `closeAfter` | `number` | | `0` | Delay (in milliseconds) between the end of the user interaction, and the closing of the tooltip. |
187
+ | `styles` | `Record` | | | Custom css-in-js object styles for the tooltip body. |
188
+ | `off` | `boolean` | | `false` | Determines if the tooltip should not appear. |
189
+ | `id` | `string` | | | An identifier for the tooltip, used for `aria-describedby`. |
190
+ | `onClose` | `Function`<br/>[See signature.](#signature-onClose) | | | A callback function, called when the tooltip is closing. |
191
+ | `onOpen` | `Function`<br/>[See signature.](#signature-onOpen) | | | A callback function, called when the tooltip is opening. |
192
+ | `isOpen` | `boolean` | | | |
193
+ | `placement` | `union`<br/>Possible values:<br/>`, 'top', 'top-start', 'top-end', 'right', 'right-start', 'right-end', 'bottom', 'bottom-start', 'bottom-end', 'left', 'left-start', 'left-end'` | | `'top'` | How the tooltip is positioned relative to the child element. |
194
+ | `title` | `string` | ✅ | | The message to show in the tooltip. |
195
+ | `modifiers` | `Modifiers` | | | 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). |
196
+ | `components` | `Object`<br/>[See signature.](#signature-components) | | | Customize the appearance of certain elements of the tooltip. |
197
+ | `horizontalConstraint` | `union`<br/>Possible values:<br/>`, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'` | | `'scale'` | Horizontal size limit of the tooltip. |
198
+
199
+ ## Signatures
200
+
201
+ ### Signature `onClose`
202
+
203
+ ```ts
204
+ (e?: ChangeEvent | FocusEvent) => void
205
+ ```
206
+
207
+ ### Signature `onOpen`
208
+
209
+ ```ts
210
+ (e?: ChangeEvent | FocusEvent) => void
211
+ ```
212
+
213
+ ### Signature `components`
214
+
215
+ ```ts
216
+ {
217
+ /**
218
+ * The component rendered as the tooltip body.
219
+ */
220
+ BodyComponent?: ComponentType;
221
+ /**
222
+ * Where the tooltip should be rendered. This can be useful to render the tooltip into another part of the document, using React portal.
223
+ */
224
+ TooltipWrapperComponent?: ComponentType;
225
+ /**
226
+ * A custom component wrapper for the tooltip.
227
+ */
228
+ WrapperComponent?: ComponentType;
229
+ }
230
+ ```
@@ -0,0 +1,2 @@
1
+ export * from "./declarations/src/index";
2
+ export { default } from "./declarations/src/index";
@@ -0,0 +1,329 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var react$1 = require('@emotion/react');
6
+ var _defineProperty = require('@babel/runtime-corejs3/helpers/defineProperty');
7
+ var _slicedToArray = require('@babel/runtime-corejs3/helpers/slicedToArray');
8
+ var _pt = require('prop-types');
9
+ var _setTimeout = require('@babel/runtime-corejs3/core-js-stable/set-timeout');
10
+ var _Object$keys = require('@babel/runtime-corejs3/core-js-stable/object/keys');
11
+ var _Object$getOwnPropertySymbols = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-symbols');
12
+ var _filterInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/filter');
13
+ var _Object$getOwnPropertyDescriptor = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptor');
14
+ var _forEachInstanceProperty = require('@babel/runtime-corejs3/core-js-stable/instance/for-each');
15
+ var _Object$getOwnPropertyDescriptors = require('@babel/runtime-corejs3/core-js-stable/object/get-own-property-descriptors');
16
+ var _Object$defineProperties = require('@babel/runtime-corejs3/core-js-stable/object/define-properties');
17
+ var _Object$defineProperty = require('@babel/runtime-corejs3/core-js-stable/object/define-property');
18
+ var react = require('react');
19
+ var reactIs = require('react-is');
20
+ var isNil = require('lodash/isNil');
21
+ var usePopper = require('use-popper');
22
+ var hooks = require('@commercetools-uikit/hooks');
23
+ var utils = require('@commercetools-uikit/utils');
24
+ var _styled = require('@emotion/styled/base');
25
+ var designSystem = require('@commercetools-uikit/design-system');
26
+ var jsxRuntime = require('@emotion/react/jsx-runtime');
27
+
28
+ function _interopDefault (e) { return e && e.__esModule ? e : { 'default': e }; }
29
+
30
+ var _pt__default = /*#__PURE__*/_interopDefault(_pt);
31
+ var _setTimeout__default = /*#__PURE__*/_interopDefault(_setTimeout);
32
+ var _Object$keys__default = /*#__PURE__*/_interopDefault(_Object$keys);
33
+ var _Object$getOwnPropertySymbols__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertySymbols);
34
+ var _filterInstanceProperty__default = /*#__PURE__*/_interopDefault(_filterInstanceProperty);
35
+ var _Object$getOwnPropertyDescriptor__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptor);
36
+ var _forEachInstanceProperty__default = /*#__PURE__*/_interopDefault(_forEachInstanceProperty);
37
+ var _Object$getOwnPropertyDescriptors__default = /*#__PURE__*/_interopDefault(_Object$getOwnPropertyDescriptors);
38
+ var _Object$defineProperties__default = /*#__PURE__*/_interopDefault(_Object$defineProperties);
39
+ var _Object$defineProperty__default = /*#__PURE__*/_interopDefault(_Object$defineProperty);
40
+ var isNil__default = /*#__PURE__*/_interopDefault(isNil);
41
+ var usePopper__default = /*#__PURE__*/_interopDefault(usePopper);
42
+ var _styled__default = /*#__PURE__*/_interopDefault(_styled);
43
+
44
+ function ownKeys$1(object, enumerableOnly) { var keys = _Object$keys__default['default'](object); if (_Object$getOwnPropertySymbols__default['default']) { var symbols = _Object$getOwnPropertySymbols__default['default'](object); if (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
+
46
+ function _objectSpread$1(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty__default['default'](_context = ownKeys$1(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default['default']) { _Object$defineProperties__default['default'](target, _Object$getOwnPropertyDescriptors__default['default'](source)); } else { var _context2; _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
+
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
+
50
+ var getOffsetMargin = function getOffsetMargin(_ref) {
51
+ var placement = _ref.placement;
52
+ var position = placement && placement.split('-')[0] || '';
53
+
54
+ switch (position) {
55
+ case 'left':
56
+ case 'right':
57
+ return "0 ".concat(designSystem.customProperties.spacingXs);
58
+
59
+ case 'top':
60
+ case 'bottom':
61
+ return "".concat(designSystem.customProperties.spacingXs, " 0");
62
+
63
+ default:
64
+ return '';
65
+ }
66
+ };
67
+
68
+ var Body = _styled__default['default']("div", process.env.NODE_ENV === "production" ? {
69
+ target: "e14le4p1"
70
+ } : {
71
+ target: "e14le4p1",
72
+ label: "Body"
73
+ })("font-family:inherit;border-radius:", designSystem.customProperties.borderRadius6, ";padding:", designSystem.customProperties.spacingXs, " ", designSystem.customProperties.spacingS, ";border:'none';box-shadow:", designSystem.customProperties.shadow15, ";font-size:0.857rem;opacity:0.95;color:", designSystem.customProperties.colorSurface, ";background-color:", designSystem.customProperties.colorAccent, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1COEIiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHt2YXJzLnNwYWNpbmdYc31gO1xuICAgIGNhc2UgJ3RvcCc6XG4gICAgY2FzZSAnYm90dG9tJzpcbiAgICAgIHJldHVybiBgJHt2YXJzLnNwYWNpbmdYc30gMGA7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiAnJztcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IEJvZHkgPSBzdHlsZWQuZGl2YFxuICBmb250LWZhbWlseTogaW5oZXJpdDtcbiAgYm9yZGVyLXJhZGl1czogJHt2YXJzLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke3ZhcnMuc3BhY2luZ1hzfSAke3ZhcnMuc3BhY2luZ1N9O1xuICBib3JkZXI6ICdub25lJztcbiAgYm94LXNoYWRvdzogJHt2YXJzLnNoYWRvdzE1fTtcbiAgZm9udC1zaXplOiAwLjg1N3JlbTtcbiAgb3BhY2l0eTogMC45NTtcbiAgY29sb3I6ICR7dmFycy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3ZhcnMuY29sb3JBY2NlbnR9O1xuYDtcblxuLy8gaGVyZSB3ZSB1c2Ugb2JqZWN0IHN0eWxlcyBzbyB3ZSBjYW4gc3ByZWFkIHRoZXNlXG4vLyB3aXRoIHRoZSBzdHlsZXMgd2UgZ2V0IGZyb20gcmVhY3QtcG9wcGVyIDpEXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L3ByZWZlci1kZWZhdWx0LWV4cG9ydFxuZXhwb3J0IGNvbnN0IGdldEJvZHlTdHlsZXMgPSAoe1xuICBjb25zdHJhaW50LFxuICBwbGFjZW1lbnQsXG4gIGN1c3RvbVN0eWxlcyxcbn06IHtcbiAgY29uc3RyYWludDogVFRvb2x0aXBQcm9wc1snaG9yaXpvbnRhbENvbnN0cmFpbnQnXTtcbiAgcGxhY2VtZW50OiBzdHJpbmc7XG4gIGN1c3RvbVN0eWxlcz86IENTU1Byb3BlcnRpZXM7XG59KTogQ1NTUHJvcGVydGllcyA9PiB7XG4gIHJldHVybiB7XG4gICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgIG1hcmdpbjogYCR7Z2V0T2Zmc2V0TWFyZ2luKHsgcGxhY2VtZW50IH0pfSAhaW1wb3J0YW50YCxcbiAgICBtYXhXaWR0aDogKHZhcnMgYXMgUmVjb3JkPHN0cmluZywgc3RyaW5nPilbYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YF0sXG4gICAgLy8gc28gaG92ZXJpbmcgb3ZlciB0aGUgdG9vbHRpcCB3aGVuIHRoZSB0b29sdGlwIG92ZXJsYXBzIHRoZSBjb21wb25lbnRcbiAgICBwb2ludGVyRXZlbnRzOiAnbm9uZScsXG4gICAgd2lkdGg6IGNvbnN0cmFpbnQgPT09ICdhdXRvJyA/ICdhdXRvJyA6IHVuZGVmaW5lZCxcbiAgICB6SW5kZXg6IDEsXG4gICAgLi4uY3VzdG9tU3R5bGVzLFxuICB9O1xufTtcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gID4gOmRpc2FibGVkIHtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgfVxuYDtcbiJdfQ== */")); // here we use object styles so we can spread these
74
+ // with the styles we get from react-popper :D
75
+ // eslint-disable-next-line import/prefer-default-export
76
+
77
+ var getBodyStyles = function getBodyStyles(_ref2) {
78
+ var constraint = _ref2.constraint,
79
+ placement = _ref2.placement,
80
+ customStyles = _ref2.customStyles;
81
+ return _objectSpread$1({
82
+ fontFamily: 'inherit',
83
+ margin: "".concat(getOffsetMargin({
84
+ placement: placement
85
+ }), " !important"),
86
+ maxWidth: designSystem.customProperties["constraint".concat(constraint)],
87
+ // so hovering over the tooltip when the tooltip overlaps the component
88
+ pointerEvents: 'none',
89
+ width: constraint === 'auto' ? 'auto' : undefined,
90
+ zIndex: 1
91
+ }, customStyles);
92
+ };
93
+ var Wrapper = _styled__default['default']("div", process.env.NODE_ENV === "production" ? {
94
+ target: "e14le4p0"
95
+ } : {
96
+ target: "e14le4p0",
97
+ label: "Wrapper"
98
+ })(process.env.NODE_ENV === "production" ? {
99
+ name: "18fwu9s",
100
+ styles: "display:inline-block;cursor:not-allowed;>:disabled{pointer-events:none;}"
101
+ } : {
102
+ name: "18fwu9s",
103
+ styles: "display:inline-block;cursor:not-allowed;>:disabled{pointer-events:none;}",
104
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAuc3R5bGVzLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXVEaUMiLCJmaWxlIjoidG9vbHRpcC5zdHlsZXMudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDU1NQcm9wZXJ0aWVzIH0gZnJvbSAncmVhY3QnO1xuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnO1xuaW1wb3J0IHsgY3VzdG9tUHJvcGVydGllcyBhcyB2YXJzIH0gZnJvbSAnQGNvbW1lcmNldG9vbHMtdWlraXQvZGVzaWduLXN5c3RlbSc7XG5pbXBvcnQgdHlwZSB7IFRUb29sdGlwUHJvcHMgfSBmcm9tICcuL3Rvb2x0aXAnO1xuXG5jb25zdCBnZXRPZmZzZXRNYXJnaW4gPSAoeyBwbGFjZW1lbnQgfTogeyBwbGFjZW1lbnQ6IHN0cmluZyB9KSA9PiB7XG4gIGNvbnN0IHBvc2l0aW9uID0gKHBsYWNlbWVudCAmJiBwbGFjZW1lbnQuc3BsaXQoJy0nKVswXSkgfHwgJyc7XG4gIHN3aXRjaCAocG9zaXRpb24pIHtcbiAgICBjYXNlICdsZWZ0JzpcbiAgICBjYXNlICdyaWdodCc6XG4gICAgICByZXR1cm4gYDAgJHt2YXJzLnNwYWNpbmdYc31gO1xuICAgIGNhc2UgJ3RvcCc6XG4gICAgY2FzZSAnYm90dG9tJzpcbiAgICAgIHJldHVybiBgJHt2YXJzLnNwYWNpbmdYc30gMGA7XG4gICAgZGVmYXVsdDpcbiAgICAgIHJldHVybiAnJztcbiAgfVxufTtcblxuZXhwb3J0IGNvbnN0IEJvZHkgPSBzdHlsZWQuZGl2YFxuICBmb250LWZhbWlseTogaW5oZXJpdDtcbiAgYm9yZGVyLXJhZGl1czogJHt2YXJzLmJvcmRlclJhZGl1czZ9O1xuICBwYWRkaW5nOiAke3ZhcnMuc3BhY2luZ1hzfSAke3ZhcnMuc3BhY2luZ1N9O1xuICBib3JkZXI6ICdub25lJztcbiAgYm94LXNoYWRvdzogJHt2YXJzLnNoYWRvdzE1fTtcbiAgZm9udC1zaXplOiAwLjg1N3JlbTtcbiAgb3BhY2l0eTogMC45NTtcbiAgY29sb3I6ICR7dmFycy5jb2xvclN1cmZhY2V9O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAke3ZhcnMuY29sb3JBY2NlbnR9O1xuYDtcblxuLy8gaGVyZSB3ZSB1c2Ugb2JqZWN0IHN0eWxlcyBzbyB3ZSBjYW4gc3ByZWFkIHRoZXNlXG4vLyB3aXRoIHRoZSBzdHlsZXMgd2UgZ2V0IGZyb20gcmVhY3QtcG9wcGVyIDpEXG4vLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgaW1wb3J0L3ByZWZlci1kZWZhdWx0LWV4cG9ydFxuZXhwb3J0IGNvbnN0IGdldEJvZHlTdHlsZXMgPSAoe1xuICBjb25zdHJhaW50LFxuICBwbGFjZW1lbnQsXG4gIGN1c3RvbVN0eWxlcyxcbn06IHtcbiAgY29uc3RyYWludDogVFRvb2x0aXBQcm9wc1snaG9yaXpvbnRhbENvbnN0cmFpbnQnXTtcbiAgcGxhY2VtZW50OiBzdHJpbmc7XG4gIGN1c3RvbVN0eWxlcz86IENTU1Byb3BlcnRpZXM7XG59KTogQ1NTUHJvcGVydGllcyA9PiB7XG4gIHJldHVybiB7XG4gICAgZm9udEZhbWlseTogJ2luaGVyaXQnLFxuICAgIG1hcmdpbjogYCR7Z2V0T2Zmc2V0TWFyZ2luKHsgcGxhY2VtZW50IH0pfSAhaW1wb3J0YW50YCxcbiAgICBtYXhXaWR0aDogKHZhcnMgYXMgUmVjb3JkPHN0cmluZywgc3RyaW5nPilbYGNvbnN0cmFpbnQke2NvbnN0cmFpbnR9YF0sXG4gICAgLy8gc28gaG92ZXJpbmcgb3ZlciB0aGUgdG9vbHRpcCB3aGVuIHRoZSB0b29sdGlwIG92ZXJsYXBzIHRoZSBjb21wb25lbnRcbiAgICBwb2ludGVyRXZlbnRzOiAnbm9uZScsXG4gICAgd2lkdGg6IGNvbnN0cmFpbnQgPT09ICdhdXRvJyA/ICdhdXRvJyA6IHVuZGVmaW5lZCxcbiAgICB6SW5kZXg6IDEsXG4gICAgLi4uY3VzdG9tU3R5bGVzLFxuICB9O1xufTtcblxuZXhwb3J0IGNvbnN0IFdyYXBwZXIgPSBzdHlsZWQuZGl2YFxuICBkaXNwbGF5OiBpbmxpbmUtYmxvY2s7XG4gIGN1cnNvcjogbm90LWFsbG93ZWQ7XG4gID4gOmRpc2FibGVkIHtcbiAgICBwb2ludGVyLWV2ZW50czogbm9uZTtcbiAgfVxuYDtcbiJdfQ== */",
105
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__
106
+ });
107
+
108
+ function ownKeys(object, enumerableOnly) { var keys = _Object$keys__default['default'](object); if (_Object$getOwnPropertySymbols__default['default']) { var symbols = _Object$getOwnPropertySymbols__default['default'](object); if (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; }
109
+
110
+ function _objectSpread(target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i] != null ? arguments[i] : {}; if (i % 2) { var _context; _forEachInstanceProperty__default['default'](_context = ownKeys(Object(source), true)).call(_context, function (key) { _defineProperty(target, key, source[key]); }); } else if (_Object$getOwnPropertyDescriptors__default['default']) { _Object$defineProperties__default['default'](target, _Object$getOwnPropertyDescriptors__default['default'](source)); } else { var _context2; _forEachInstanceProperty__default['default'](_context2 = ownKeys(Object(source))).call(_context2, function (key) { _Object$defineProperty__default['default'](target, key, _Object$getOwnPropertyDescriptor__default['default'](source, key)); }); } } return target; }
111
+ var sequentialId = utils.createSequentialId('tooltip-');
112
+
113
+ var TooltipWrapper = function TooltipWrapper(props) {
114
+ return jsxRuntime.jsx(jsxRuntime.Fragment, {
115
+ children: props.children
116
+ });
117
+ };
118
+
119
+ TooltipWrapper.displayName = 'TooltipWrapperComponent';
120
+ var tooltipDefaultProps = {
121
+ closeAfter: 0,
122
+ horizontalConstraint: 'scale',
123
+ off: false,
124
+ placement: 'top'
125
+ };
126
+
127
+ var Tooltip = function Tooltip(props) {
128
+ var _props$components, _props$components2, _props$components3, _props$components4, _props$components5, _props$components6, _props$styles;
129
+
130
+ var leaveTimer = react.useRef();
131
+ var childrenRef = react.useRef();
132
+
133
+ if ((_props$components = props.components) !== null && _props$components !== void 0 && _props$components.BodyComponent) {
134
+ 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;
135
+ }
136
+
137
+ if ((_props$components2 = props.components) !== null && _props$components2 !== void 0 && _props$components2.TooltipWrapperComponent) {
138
+ process.env.NODE_ENV !== "production" ? utils.warning(reactIs.isValidElementType(props.components.TooltipWrapperComponent), "ui-kit/Tooltip: the prop 'components.TooltipWrapperComponent' is not a valid React element.") : void 0;
139
+ }
140
+
141
+ if ((_props$components3 = props.components) !== null && _props$components3 !== void 0 && _props$components3.WrapperComponent) {
142
+ 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;
143
+ }
144
+
145
+ react.useEffect(function () {
146
+ return function () {
147
+ if (leaveTimer.current) {
148
+ clearTimeout(leaveTimer.current);
149
+ }
150
+ };
151
+ }, []);
152
+
153
+ var _usePopper = usePopper__default['default']({
154
+ placement: props.placement,
155
+ modifiers: props.modifiers
156
+ }),
157
+ reference = _usePopper.reference,
158
+ popper = _usePopper.popper;
159
+
160
+ var _useToggleState = hooks.useToggleState(false),
161
+ _useToggleState2 = _slicedToArray(_useToggleState, 2),
162
+ isOpen = _useToggleState2[0],
163
+ toggle = _useToggleState2[1];
164
+
165
+ var closeTooltip = react.useCallback(function () {
166
+ toggle(false);
167
+ }, [toggle]);
168
+ var openTooltip = react.useCallback(function () {
169
+ toggle(true);
170
+ }, [toggle]);
171
+ var isControlled = !isNil__default['default'](props.isOpen);
172
+ var tooltipIsOpen = isControlled ? props.isOpen : isOpen;
173
+ var id = hooks.useFieldId(props.id, sequentialId);
174
+ var onClose = props.onClose;
175
+ var handleClose = react.useCallback(function (event) {
176
+ if (!isControlled) {
177
+ closeTooltip();
178
+ }
179
+
180
+ if (onClose) {
181
+ onClose(event);
182
+ }
183
+ }, [isControlled, closeTooltip, onClose]);
184
+ var _props$children$props = props.children.props,
185
+ onFocus = _props$children$props.onFocus,
186
+ onMouseOver = _props$children$props.onMouseOver;
187
+ var onOpen = props.onOpen;
188
+ var handleEnter = react.useCallback(function (event) {
189
+ // Remove the title ahead of time.
190
+ // We don't want to wait for the next render commit.
191
+ // We would risk displaying two tooltips at the same time (native + this one).
192
+ if (childrenRef && typeof childrenRef === 'function') {
193
+ // @ts-ignore
194
+ childrenRef.setAttribute('title', '');
195
+ }
196
+
197
+ if (event) {
198
+ if (event.type === 'mouseover' && onMouseOver) {
199
+ onMouseOver(event);
200
+ }
201
+
202
+ if (event.type === 'focus' && onFocus) {
203
+ onFocus(event);
204
+ }
205
+
206
+ if (!isOpen && !isControlled) {
207
+ openTooltip();
208
+ }
209
+
210
+ if (onOpen) {
211
+ onOpen(event);
212
+ }
213
+
214
+ event.preventDefault();
215
+ event.stopPropagation();
216
+ }
217
+ }, [onFocus, onOpen, onMouseOver, isControlled, isOpen, openTooltip]);
218
+ var _props$children$props2 = props.children.props,
219
+ onBlur = _props$children$props2.onBlur,
220
+ onMouseLeave = _props$children$props2.onMouseLeave;
221
+ var closeAfter = props.closeAfter;
222
+ var handleLeave = react.useCallback(function (event) {
223
+ if (leaveTimer.current) {
224
+ clearTimeout(leaveTimer.current);
225
+ }
226
+
227
+ if (event.type === 'mouseleave' && onMouseLeave) {
228
+ onMouseLeave(event);
229
+ }
230
+
231
+ if (event.type === 'blur' && onBlur) {
232
+ onBlur(event);
233
+ }
234
+
235
+ if (closeAfter) {
236
+ leaveTimer.current = _setTimeout__default['default'](function () {
237
+ handleClose(event);
238
+ }, closeAfter);
239
+ } else {
240
+ handleClose(event);
241
+ }
242
+ }, [closeAfter, onBlur, onMouseLeave, handleClose]);
243
+ react.useEffect(function () {
244
+ // if tooltip was open, and then component
245
+ // updated to be off, we should close the tooltip
246
+ if (isOpen && props.off) {
247
+ if (closeAfter) {
248
+ leaveTimer.current = _setTimeout__default['default'](function () {
249
+ handleClose();
250
+ }, closeAfter);
251
+ } else {
252
+ handleClose();
253
+ }
254
+ }
255
+ }, [props.off, closeAfter, handleClose, toggle, isOpen]);
256
+ var childrenProps = {
257
+ // don't pass event listeners to children
258
+ onFocus: null,
259
+ onMouseOver: null,
260
+ onMouseLeave: null,
261
+ onBlur: null
262
+ };
263
+ var tooltipProps = !props.off ? {
264
+ 'aria-describedby': tooltipIsOpen ? id : null,
265
+ // for seo and accessibility, we add the tooltip's title
266
+ // as a native title when the title is hidden
267
+ title: !tooltipIsOpen && typeof props.title === 'string' ? props.title : null
268
+ } : {};
269
+ var eventListeners = !props.off ? {
270
+ onMouseOver: handleEnter,
271
+ onMouseLeave: handleLeave,
272
+ onFocus: handleEnter,
273
+ onBlur: handleLeave
274
+ } : {};
275
+ var WrapperComponent = ((_props$components4 = props.components) === null || _props$components4 === void 0 ? void 0 : _props$components4.WrapperComponent) || Wrapper;
276
+ var BodyComponent = ((_props$components5 = props.components) === null || _props$components5 === void 0 ? void 0 : _props$components5.BodyComponent) || Body;
277
+ var TooltipWrapperComponent = ((_props$components6 = props.components) === null || _props$components6 === void 0 ? void 0 : _props$components6.TooltipWrapperComponent) || TooltipWrapper;
278
+ return jsxRuntime.jsxs(jsxRuntime.Fragment, {
279
+ children: [jsxRuntime.jsx(WrapperComponent, _objectSpread(_objectSpread({}, eventListeners), {}, {
280
+ // @ts-expect-error: yes, ref can be undefined
281
+ ref: reference.ref,
282
+ children: /*#__PURE__*/react.cloneElement(props.children, _objectSpread(_objectSpread({}, childrenProps), tooltipProps))
283
+ })), tooltipIsOpen && jsxRuntime.jsx(TooltipWrapperComponent, {
284
+ children: jsxRuntime.jsx("div", {
285
+ // ref accepts `LegacyRef`, which is a union of `RefObject` and `string`
286
+ // propper.ref returns `RefObject`
287
+ ref: popper.ref,
288
+ css: /*#__PURE__*/react$1.css(_objectSpread(_objectSpread({}, popper.styles), getBodyStyles({
289
+ constraint: props.horizontalConstraint,
290
+ placement: popper.placement,
291
+ customStyles: (_props$styles = props.styles) === null || _props$styles === void 0 ? void 0 : _props$styles.body
292
+ })), process.env.NODE_ENV === "production" ? "" : ";label:Tooltip;", process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbInRvb2x0aXAudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtVWSIsImZpbGUiOiJ0b29sdGlwLnRzeCIsInNvdXJjZXNDb250ZW50IjpbIi8vIGluc3BpcmVkIGZyb20gaHR0cHM6Ly9naXRodWIuY29tL211aS1vcmcvbWF0ZXJpYWwtdWkvYmxvYi85ZWNjOGRiOGFiYmZiODI5MTExZDNiNWMwNjc4MjY3ODI3OTg0MDI0L3BhY2thZ2VzL21hdGVyaWFsLXVpL3NyYy9Ub29sdGlwL1Rvb2x0aXAuanNcbmltcG9ydCB7IE1vZGlmaWVycyB9IGZyb20gJ3BvcHBlci5qcyc7XG5pbXBvcnQge1xuICBDb21wb25lbnRUeXBlLFxuICBGb2N1c0V2ZW50LFxuICBDaGFuZ2VFdmVudCxcbiAgTGVnYWN5UmVmLFxuICBDU1NQcm9wZXJ0aWVzLFxuICBSZWFjdEVsZW1lbnQsXG4gIHVzZVJlZixcbiAgdXNlRWZmZWN0LFxuICB1c2VDYWxsYmFjayxcbiAgY2xvbmVFbGVtZW50LFxufSBmcm9tICdyZWFjdCc7XG5pbXBvcnQgeyBpc1ZhbGlkRWxlbWVudFR5cGUgfSBmcm9tICdyZWFjdC1pcyc7XG5pbXBvcnQgaXNOaWwgZnJvbSAnbG9kYXNoL2lzTmlsJztcbmltcG9ydCB1c2VQb3BwZXIgZnJvbSAndXNlLXBvcHBlcic7XG5pbXBvcnQgeyB1c2VGaWVsZElkLCB1c2VUb2dnbGVTdGF0ZSB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L2hvb2tzJztcbmltcG9ydCB7IGNyZWF0ZVNlcXVlbnRpYWxJZCwgd2FybmluZyB9IGZyb20gJ0Bjb21tZXJjZXRvb2xzLXVpa2l0L3V0aWxzJztcbmltcG9ydCB7IFdyYXBwZXIsIEJvZHksIGdldEJvZHlTdHlsZXMgfSBmcm9tICcuL3Rvb2x0aXAuc3R5bGVzJztcblxuY29uc3Qgc2VxdWVudGlhbElkID0gY3JlYXRlU2VxdWVudGlhbElkKCd0b29sdGlwLScpO1xuXG50eXBlIFRDb21wb25lbnRzID0ge1xuICAvKipcbiAgICogVGhlIGNvbXBvbmVudCByZW5kZXJlZCBhcyB0aGUgdG9vbHRpcCBib2R5LlxuICAgKi9cbiAgQm9keUNvbXBvbmVudD86IENvbXBvbmVudFR5cGU7XG4gIC8qKlxuICAgKiBXaGVyZSB0aGUgdG9vbHRpcCBzaG91bGQgYmUgcmVuZGVyZWQuIFRoaXMgY2FuIGJlIHVzZWZ1bCB0byByZW5kZXIgdGhlIHRvb2x0aXAgaW50byBhbm90aGVyIHBhcnQgb2YgdGhlIGRvY3VtZW50LCB1c2luZyBSZWFjdCBwb3J0YWwuXG4gICAqL1xuICBUb29sdGlwV3JhcHBlckNvbXBvbmVudD86IENvbXBvbmVudFR5cGU7XG4gIC8qKlxuICAgKiBBIGN1c3RvbSBjb21wb25lbnQgd3JhcHBlciBmb3IgdGhlIHRvb2x0aXAuXG4gICAqL1xuICBXcmFwcGVyQ29tcG9uZW50PzogQ29tcG9uZW50VHlwZTtcbn07XG5cbmV4cG9ydCB0eXBlIFRUb29sdGlwUHJvcHMgPSB7XG4gIGNoaWxkcmVuOiBSZWFjdEVsZW1lbnQ7XG5cbiAgLyoqXG4gICAqIERlbGF5IChpbiBtaWxsaXNlY29uZHMpIGJldHdlZW4gdGhlIGVuZCBvZiB0aGUgdXNlciBpbnRlcmFjdGlvbiwgYW5kIHRoZSBjbG9zaW5nIG9mIHRoZSB0b29sdGlwLlxuICAgKi9cbiAgY2xvc2VBZnRlcjogbnVtYmVyO1xuICAvKipcbiAgICogQ3VzdG9tIGNzcy1pbi1qcyBvYmplY3Qgc3R5bGVzIGZvciB0aGUgdG9vbHRpcCBib2R5LlxuICAgKi9cbiAgc3R5bGVzPzogUmVjb3JkPHN0cmluZywgQ1NTUHJvcGVydGllcz47XG4gIC8qKlxuICAgKiBEZXRlcm1pbmVzIGlmIHRoZSB0b29sdGlwIHNob3VsZCBub3QgYXBwZWFyLlxuICAgKi9cbiAgb2ZmOiBib29sZWFuO1xuICAvKipcbiAgICogQW4gaWRlbnRpZmllciBmb3IgdGhlIHRvb2x0aXAsIHVzZWQgZm9yIGBhcmlhLWRlc2NyaWJlZGJ5YC5cbiAgICovXG4gIGlkPzogc3RyaW5nO1xuICAvKipcbiAgICogQSBjYWxsYmFjayBmdW5jdGlvbiwgY2FsbGVkIHdoZW4gdGhlIHRvb2x0aXAgaXMgY2xvc2luZy5cbiAgICovXG4gIG9uQ2xvc2U/OiAoZT86IENoYW5nZUV2ZW50IHwgRm9jdXNFdmVudCkgPT4gdm9pZDtcbiAgLyoqXG4gICAqIEEgY2FsbGJhY2sgZnVuY3Rpb24sIGNhbGxlZCB3aGVuIHRoZSB0b29sdGlwIGlzIG9wZW5pbmcuXG4gICAqL1xuICBvbk9wZW4/OiAoZT86IENoYW5nZUV2ZW50IHwgRm9jdXNFdmVudCkgPT4gdm9pZDtcbiAgaXNPcGVuPzogYm9vbGVhbjtcbiAgLyoqXG4gICAqIEhvdyB0aGUgdG9vbHRpcCBpcyBwb3NpdGlvbmVkIHJlbGF0aXZlIHRvIHRoZSBjaGlsZCBlbGVtZW50LlxuICAgKi9cbiAgcGxhY2VtZW50PzpcbiAgICB8ICd0b3AnXG4gICAgfCAndG9wLXN0YXJ0J1xuICAgIHwgJ3RvcC1lbmQnXG4gICAgfCAncmlnaHQnXG4gICAgfCAncmlnaHQtc3RhcnQnXG4gICAgfCAncmlnaHQtZW5kJ1xuICAgIHwgJ2JvdHRvbSdcbiAgICB8ICdib3R0b20tc3RhcnQnXG4gICAgfCAnYm90dG9tLWVuZCdcbiAgICB8ICdsZWZ0J1xuICAgIHwgJ2xlZnQtc3RhcnQnXG4gICAgfCAnbGVmdC1lbmQnO1xuICAvKipcbiAgICogVGhlIG1lc3NhZ2UgdG8gc2hvdyBpbiB0aGUgdG9vbHRpcC5cbiAgICovXG4gIHRpdGxlOiBzdHJpbmc7XG4gIC8qKlxuICAgKiBQcm92aWRlcyBhIHdheSB0byBmaW5lLXR1bmUgYW4gYXBwZWFyYW5jZSBvZiB1bmRlcmx5aW5nIFBvcHBlciB0b29sdGlwIGVsZW1lbnQuIEZvciBtb3JlIGluZm9ybWF0aW9uLCBwbGVhc2UgY2hlY2sgW1BvcHBlci5qcyBkb2N1bWVudGF0aW9uXShodHRwczovL3BvcHBlci5qcy5vcmcvcG9wcGVyLWRvY3VtZW50YXRpb24uaHRtbCNtb2RpZmllcnMpLlxuICAgKi9cbiAgbW9kaWZpZXJzPzogTW9kaWZpZXJzO1xuICAvKipcbiAgICogQ3VzdG9taXplIHRoZSBhcHBlYXJhbmNlIG9mIGNlcnRhaW4gZWxlbWVudHMgb2YgdGhlIHRvb2x0aXAuXG4gICAqL1xuICBjb21wb25lbnRzPzogVENvbXBvbmVudHM7XG4gIC8qKlxuICAgKiBIb3Jpem9udGFsIHNpemUgbGltaXQgb2YgdGhlIHRvb2x0aXAuXG4gICAqL1xuICBob3Jpem9udGFsQ29uc3RyYWludD86XG4gICAgfCAxXG4gICAgfCAyXG4gICAgfCAzXG4gICAgfCA0XG4gICAgfCA1XG4gICAgfCA2XG4gICAgfCA3XG4gICAgfCA4XG4gICAgfCA5XG4gICAgfCAxMFxuICAgIHwgMTFcbiAgICB8IDEyXG4gICAgfCAxM1xuICAgIHwgMTRcbiAgICB8IDE1XG4gICAgfCAxNlxuICAgIHwgJ3NjYWxlJ1xuICAgIHwgJ2F1dG8nO1xufTtcblxuY29uc3QgVG9vbHRpcFdyYXBwZXIgPSAocHJvcHM6IFBpY2s8VFRvb2x0aXBQcm9wcywgJ2NoaWxkcmVuJz4pID0+IChcbiAgPD57cHJvcHMuY2hpbGRyZW59PC8+XG4pO1xuVG9vbHRpcFdyYXBwZXIuZGlzcGxheU5hbWUgPSAnVG9vbHRpcFdyYXBwZXJDb21wb25lbnQnO1xuXG5jb25zdCB0b29sdGlwRGVmYXVsdFByb3BzOiBQaWNrPFxuICBUVG9vbHRpcFByb3BzLFxuICAnY2xvc2VBZnRlcicgfCAnaG9yaXpvbnRhbENvbnN0cmFpbnQnIHwgJ29mZicgfCAncGxhY2VtZW50J1xuPiA9IHtcbiAgY2xvc2VBZnRlcjogMCxcbiAgaG9yaXpvbnRhbENvbnN0cmFpbnQ6ICdzY2FsZScsXG4gIG9mZjogZmFsc2UsXG4gIHBsYWNlbWVudDogJ3RvcCcsXG59O1xuXG5jb25zdCBUb29sdGlwID0gKHByb3BzOiBUVG9vbHRpcFByb3BzKSA9PiB7XG4gIGNvbnN0IGxlYXZlVGltZXIgPSB1c2VSZWY8UmV0dXJuVHlwZTx0eXBlb2Ygc2V0VGltZW91dD4+KCk7XG4gIGNvbnN0IGNoaWxkcmVuUmVmID0gdXNlUmVmPFJldHVyblR5cGU8dHlwZW9mIHNldFRpbWVvdXQ+PigpO1xuICBpZiAocHJvcHMuY29tcG9uZW50cz8uQm9keUNvbXBvbmVudCkge1xuICAgIHdhcm5pbmcoXG4gICAgICBpc1ZhbGlkRWxlbWVudFR5cGUocHJvcHMuY29tcG9uZW50cy5Cb2R5Q29tcG9uZW50KSxcbiAgICAgIGB1aS1raXQvVG9vbHRpcDogdGhlIHByb3AgJ2NvbXBvbmVudHMuQm9keUNvbXBvbmVudCcgaXMgbm90IGEgdmFsaWQgUmVhY3QgZWxlbWVudC5gXG4gICAgKTtcbiAgfVxuICBpZiAocHJvcHMuY29tcG9uZW50cz8uVG9vbHRpcFdyYXBwZXJDb21wb25lbnQpIHtcbiAgICB3YXJuaW5nKFxuICAgICAgaXNWYWxpZEVsZW1lbnRUeXBlKHByb3BzLmNvbXBvbmVudHMuVG9vbHRpcFdyYXBwZXJDb21wb25lbnQpLFxuICAgICAgYHVpLWtpdC9Ub29sdGlwOiB0aGUgcHJvcCAnY29tcG9uZW50cy5Ub29sdGlwV3JhcHBlckNvbXBvbmVudCcgaXMgbm90IGEgdmFsaWQgUmVhY3QgZWxlbWVudC5gXG4gICAgKTtcbiAgfVxuICBpZiAocHJvcHMuY29tcG9uZW50cz8uV3JhcHBlckNvbXBvbmVudCkge1xuICAgIHdhcm5pbmcoXG4gICAgICBpc1ZhbGlkRWxlbWVudFR5cGUocHJvcHMuY29tcG9uZW50cy5XcmFwcGVyQ29tcG9uZW50KSxcbiAgICAgIGB1aS1raXQvVG9vbHRpcDogdGhlIHByb3AgJ2NvbXBvbmVudHMuV3JhcHBlckNvbXBvbmVudCcgaXMgbm90IGEgdmFsaWQgUmVhY3QgZWxlbWVudC5gXG4gICAgKTtcbiAgfVxuXG4gIHVzZUVmZmVjdCgoKSA9PiB7XG4gICAgcmV0dXJuICgpID0+IHtcbiAgICAgIGlmIChsZWF2ZVRpbWVyLmN1cnJlbnQpIHtcbiAgICAgICAgY2xlYXJUaW1lb3V0KGxlYXZlVGltZXIuY3VycmVudCk7XG4gICAgICB9XG4gICAgfTtcbiAgfSwgW10pO1xuXG4gIGNvbnN0IHsgcmVmZXJlbmNlLCBwb3BwZXIgfSA9IHVzZVBvcHBlcih7XG4gICAgcGxhY2VtZW50OiBwcm9wcy5wbGFjZW1lbnQsXG4gICAgbW9kaWZpZXJzOiBwcm9wcy5tb2RpZmllcnMsXG4gIH0pO1xuICBjb25zdCBbaXNPcGVuLCB0b2dnbGVdID0gdXNlVG9nZ2xlU3RhdGUoZmFsc2UpO1xuICBjb25zdCBjbG9zZVRvb2x0aXAgPSB1c2VDYWxsYmFjaygoKSA9PiB7XG4gICAgdG9nZ2xlKGZhbHNlKTtcbiAgfSwgW3RvZ2dsZV0pO1xuICBjb25zdCBvcGVuVG9vbHRpcCA9IHVzZUNhbGxiYWNrKCgpID0+IHtcbiAgICB0b2dnbGUodHJ1ZSk7XG4gIH0sIFt0b2dnbGVdKTtcblxuICBjb25zdCBpc0NvbnRyb2xsZWQgPSAhaXNOaWwocHJvcHMuaXNPcGVuKTtcbiAgY29uc3QgdG9vbHRpcElzT3BlbiA9IGlzQ29udHJvbGxlZCA/IHByb3BzLmlzT3BlbiA6IGlzT3BlbjtcbiAgY29uc3QgaWQgPSB1c2VGaWVsZElkKHByb3BzLmlkLCBzZXF1ZW50aWFsSWQpO1xuXG4gIGNvbnN0IHsgb25DbG9zZSB9ID0gcHJvcHM7XG4gIGNvbnN0IGhhbmRsZUNsb3NlID0gdXNlQ2FsbGJhY2soXG4gICAgKGV2ZW50PzogQ2hhbmdlRXZlbnQgfCBGb2N1c0V2ZW50KSA9PiB7XG4gICAgICBpZiAoIWlzQ29udHJvbGxlZCkge1xuICAgICAgICBjbG9zZVRvb2x0aXAoKTtcbiAgICAgIH1cbiAgICAgIGlmIChvbkNsb3NlKSB7XG4gICAgICAgIG9uQ2xvc2UoZXZlbnQpO1xuICAgICAgfVxuICAgIH0sXG4gICAgW2lzQ29udHJvbGxlZCwgY2xvc2VUb29sdGlwLCBvbkNsb3NlXVxuICApO1xuXG4gIGNvbnN0IHsgb25Gb2N1cywgb25Nb3VzZU92ZXIgfSA9IHByb3BzLmNoaWxkcmVuLnByb3BzO1xuICBjb25zdCB7IG9uT3BlbiB9ID0gcHJvcHM7XG4gIGNvbnN0IGhhbmRsZUVudGVyID0gdXNlQ2FsbGJhY2soXG4gICAgKGV2ZW50PzogQ2hhbmdlRXZlbnQgfCBGb2N1c0V2ZW50KSA9PiB7XG4gICAgICAvLyBSZW1vdmUgdGhlIHRpdGxlIGFoZWFkIG9mIHRpbWUuXG4gICAgICAvLyBXZSBkb24ndCB3YW50IHRvIHdhaXQgZm9yIHRoZSBuZXh0IHJlbmRlciBjb21taXQuXG4gICAgICAvLyBXZSB3b3VsZCByaXNrIGRpc3BsYXlpbmcgdHdvIHRvb2x0aXBzIGF0IHRoZSBzYW1lIHRpbWUgKG5hdGl2ZSArIHRoaXMgb25lKS5cbiAgICAgIGlmIChjaGlsZHJlblJlZiAmJiB0eXBlb2YgY2hpbGRyZW5SZWYgPT09ICdmdW5jdGlvbicpIHtcbiAgICAgICAgLy8gQHRzLWlnbm9yZVxuICAgICAgICBjaGlsZHJlblJlZi5zZXRBdHRyaWJ1dGUoJ3RpdGxlJywgJycpO1xuICAgICAgfVxuXG4gICAgICBpZiAoZXZlbnQpIHtcbiAgICAgICAgaWYgKGV2ZW50LnR5cGUgPT09ICdtb3VzZW92ZXInICYmIG9uTW91c2VPdmVyKSB7XG4gICAgICAgICAgb25Nb3VzZU92ZXIoZXZlbnQpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKGV2ZW50LnR5cGUgPT09ICdmb2N1cycgJiYgb25Gb2N1cykge1xuICAgICAgICAgIG9uRm9jdXMoZXZlbnQpO1xuICAgICAgICB9XG5cbiAgICAgICAgaWYgKCFpc09wZW4gJiYgIWlzQ29udHJvbGxlZCkge1xuICAgICAgICAgIG9wZW5Ub29sdGlwKCk7XG4gICAgICAgIH1cblxuICAgICAgICBpZiAob25PcGVuKSB7XG4gICAgICAgICAgb25PcGVuKGV2ZW50KTtcbiAgICAgICAgfVxuXG4gICAgICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XG4gICAgICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xuICAgICAgfVxuICAgIH0sXG4gICAgW29uRm9jdXMsIG9uT3Blbiwgb25Nb3VzZU92ZXIsIGlzQ29udHJvbGxlZCwgaXNPcGVuLCBvcGVuVG9vbHRpcF1cbiAgKTtcblxuICBjb25zdCB7IG9uQmx1ciwgb25Nb3VzZUxlYXZlIH0gPSBwcm9wcy5jaGlsZHJlbi5wcm9wcztcbiAgY29uc3QgeyBjbG9zZUFmdGVyIH0gPSBwcm9wcztcblxuICBjb25zdCBoYW5kbGVMZWF2ZSA9IHVzZUNhbGxiYWNrKFxuICAgIChldmVudCkgPT4ge1xuICAgICAgaWYgKGxlYXZlVGltZXIuY3VycmVudCkge1xuICAgICAgICBjbGVhclRpbWVvdXQobGVhdmVUaW1lci5jdXJyZW50KTtcbiAgICAgIH1cblxuICAgICAgaWYgKGV2ZW50LnR5cGUgPT09ICdtb3VzZWxlYXZlJyAmJiBvbk1vdXNlTGVhdmUpIHtcbiAgICAgICAgb25Nb3VzZUxlYXZlKGV2ZW50KTtcbiAgICAgIH1cblxuICAgICAgaWYgKGV2ZW50LnR5cGUgPT09ICdibHVyJyAmJiBvbkJsdXIpIHtcbiAgICAgICAgb25CbHVyKGV2ZW50KTtcbiAgICAgIH1cblxuICAgICAgaWYgKGNsb3NlQWZ0ZXIpIHtcbiAgICAgICAgbGVhdmVUaW1lci5jdXJyZW50ID0gc2V0VGltZW91dCgoKSA9PiB7XG4gICAgICAgICAgaGFuZGxlQ2xvc2UoZXZlbnQpO1xuICAgICAgICB9LCBjbG9zZUFmdGVyKTtcbiAgICAgIH0gZWxzZSB7XG4gICAgICAgIGhhbmRsZUNsb3NlKGV2ZW50KTtcbiAgICAgIH1cbiAgICB9LFxuICAgIFtjbG9zZUFmdGVyLCBvbkJsdXIsIG9uTW91c2VMZWF2ZSwgaGFuZGxlQ2xvc2VdXG4gICk7XG5cbiAgdXNlRWZmZWN0KCgpID0+IHtcbiAgICAvLyBpZiB0b29sdGlwIHdhcyBvcGVuLCBhbmQgdGhlbiBjb21wb25lbnRcbiAgICAvLyB1cGRhdGVkIHRvIGJlIG9mZiwgd2Ugc2hvdWxkIGNsb3NlIHRoZSB0b29sdGlwXG4gICAgaWYgKGlzT3BlbiAmJiBwcm9wcy5vZmYpIHtcbiAgICAgIGlmIChjbG9zZUFmdGVyKSB7XG4gICAgICAgIGxlYXZlVGltZXIuY3VycmVudCA9IHNldFRpbWVvdXQoKCkgPT4ge1xuICAgICAgICAgIGhhbmRsZUNsb3NlKCk7XG4gICAgICAgIH0sIGNsb3NlQWZ0ZXIpO1xuICAgICAgfSBlbHNlIHtcbiAgICAgICAgaGFuZGxlQ2xvc2UoKTtcbiAgICAgIH1cbiAgICB9XG4gIH0sIFtwcm9wcy5vZmYsIGNsb3NlQWZ0ZXIsIGhhbmRsZUNsb3NlLCB0b2dnbGUsIGlzT3Blbl0pO1xuXG4gIGNvbnN0IGNoaWxkcmVuUHJvcHMgPSB7XG4gICAgLy8gZG9uJ3QgcGFzcyBldmVudCBsaXN0ZW5lcnMgdG8gY2hpbGRyZW5cbiAgICBvbkZvY3VzOiBudWxsLFxuICAgIG9uTW91c2VPdmVyOiBudWxsLFxuICAgIG9uTW91c2VMZWF2ZTogbnVsbCxcbiAgICBvbkJsdXI6IG51bGwsXG4gIH07XG5cbiAgY29uc3QgdG9vbHRpcFByb3BzID0gIXByb3BzLm9mZlxuICAgID8ge1xuICAgICAgICAnYXJpYS1kZXNjcmliZWRieSc6IHRvb2x0aXBJc09wZW4gPyBpZCA6IG51bGwsXG4gICAgICAgIC8vIGZvciBzZW8gYW5kIGFjY2Vzc2liaWxpdHksIHdlIGFkZCB0aGUgdG9vbHRpcCdzIHRpdGxlXG4gICAgICAgIC8vIGFzIGEgbmF0aXZlIHRpdGxlIHdoZW4gdGhlIHRpdGxlIGlzIGhpZGRlblxuICAgICAgICB0aXRsZTpcbiAgICAgICAgICAhdG9vbHRpcElzT3BlbiAmJiB0eXBlb2YgcHJvcHMudGl0bGUgPT09ICdzdHJpbmcnXG4gICAgICAgICAgICA/IHByb3BzLnRpdGxlXG4gICAgICAgICAgICA6IG51bGwsXG4gICAgICB9XG4gICAgOiB7fTtcblxuICBjb25zdCBldmVudExpc3RlbmVycyA9ICFwcm9wcy5vZmZcbiAgICA/IHtcbiAgICAgICAgb25Nb3VzZU92ZXI6IGhhbmRsZUVudGVyLFxuICAgICAgICBvbk1vdXNlTGVhdmU6IGhhbmRsZUxlYXZlLFxuICAgICAgICBvbkZvY3VzOiBoYW5kbGVFbnRlcixcbiAgICAgICAgb25CbHVyOiBoYW5kbGVMZWF2ZSxcbiAgICAgIH1cbiAgICA6IHt9O1xuXG4gIGNvbnN0IFdyYXBwZXJDb21wb25lbnQgPSBwcm9wcy5jb21wb25lbnRzPy5XcmFwcGVyQ29tcG9uZW50IHx8IFdyYXBwZXI7XG4gIGNvbnN0IEJvZHlDb21wb25lbnQgPSBwcm9wcy5jb21wb25lbnRzPy5Cb2R5Q29tcG9uZW50IHx8IEJvZHk7XG4gIGNvbnN0IFRvb2x0aXBXcmFwcGVyQ29tcG9uZW50ID1cbiAgICBwcm9wcy5jb21wb25lbnRzPy5Ub29sdGlwV3JhcHBlckNvbXBvbmVudCB8fCBUb29sdGlwV3JhcHBlcjtcblxuICByZXR1cm4gKFxuICAgIDw+XG4gICAgICA8V3JhcHBlckNvbXBvbmVudFxuICAgICAgICB7Li4uZXZlbnRMaXN0ZW5lcnN9XG4gICAgICAgIC8vIEB0cy1leHBlY3QtZXJyb3I6IHllcywgcmVmIGNhbiBiZSB1bmRlZmluZWRcbiAgICAgICAgcmVmPXtyZWZlcmVuY2UucmVmfVxuICAgICAgPlxuICAgICAgICB7Y2xvbmVFbGVtZW50KHByb3BzLmNoaWxkcmVuLCB7XG4gICAgICAgICAgLi4uY2hpbGRyZW5Qcm9wcyxcbiAgICAgICAgICAuLi50b29sdGlwUHJvcHMsXG4gICAgICAgIH0pfVxuICAgICAgPC9XcmFwcGVyQ29tcG9uZW50PlxuICAgICAge3Rvb2x0aXBJc09wZW4gJiYgKFxuICAgICAgICA8VG9vbHRpcFdyYXBwZXJDb21wb25lbnQ+XG4gICAgICAgICAgPGRpdlxuICAgICAgICAgICAgLy8gcmVmIGFjY2VwdHMgYExlZ2FjeVJlZmAsIHdoaWNoIGlzIGEgdW5pb24gb2YgYFJlZk9iamVjdGAgYW5kIGBzdHJpbmdgXG4gICAgICAgICAgICAvLyBwcm9wcGVyLnJlZiByZXR1cm5zIGBSZWZPYmplY3RgXG4gICAgICAgICAgICByZWY9e3BvcHBlci5yZWYgYXMgTGVnYWN5UmVmPEhUTUxEaXZFbGVtZW50Pn1cbiAgICAgICAgICAgIGNzcz17e1xuICAgICAgICAgICAgICAuLi5wb3BwZXIuc3R5bGVzLFxuICAgICAgICAgICAgICAuLi5nZXRCb2R5U3R5bGVzKHtcbiAgICAgICAgICAgICAgICBjb25zdHJhaW50OiBwcm9wcy5ob3Jpem9udGFsQ29uc3RyYWludCxcbiAgICAgICAgICAgICAgICBwbGFjZW1lbnQ6IHBvcHBlci5wbGFjZW1lbnQsXG4gICAgICAgICAgICAgICAgY3VzdG9tU3R5bGVzOiBwcm9wcy5zdHlsZXM/LmJvZHksXG4gICAgICAgICAgICAgIH0pLFxuICAgICAgICAgICAgfX1cbiAgICAgICAgICAgIGRhdGEtcGxhY2VtZW50PXtwb3BwZXIucGxhY2VtZW50fVxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxCb2R5Q29tcG9uZW50Pntwcm9wcy50aXRsZX08L0JvZHlDb21wb25lbnQ+XG4gICAgICAgICAgPC9kaXY+XG4gICAgICAgIDwvVG9vbHRpcFdyYXBwZXJDb21wb25lbnQ+XG4gICAgICApfVxuICAgIDwvPlxuICApO1xufTtcblxuVG9vbHRpcC5kaXNwbGF5TmFtZSA9ICdUb29sVGlwJztcblRvb2x0aXAuZGVmYXVsdFByb3BzID0gdG9vbHRpcERlZmF1bHRQcm9wcztcblxuZXhwb3J0IGRlZmF1bHQgVG9vbHRpcDtcbiJdfQ== */"),
293
+ "data-placement": popper.placement,
294
+ children: jsxRuntime.jsx(BodyComponent, {
295
+ children: props.title
296
+ })
297
+ })
298
+ })]
299
+ });
300
+ };
301
+
302
+ Tooltip.propTypes = process.env.NODE_ENV !== "production" ? {
303
+ children: _pt__default['default'].element.isRequired,
304
+ closeAfter: _pt__default['default'].number.isRequired,
305
+ styles: _pt__default['default'].objectOf(_pt__default['default'].any),
306
+ off: _pt__default['default'].bool.isRequired,
307
+ id: _pt__default['default'].string,
308
+ onClose: _pt__default['default'].func,
309
+ onOpen: _pt__default['default'].func,
310
+ isOpen: _pt__default['default'].bool,
311
+ placement: _pt__default['default'].oneOf(['top', 'top-start', 'top-end', 'right', 'right-start', 'right-end', 'bottom', 'bottom-start', 'bottom-end', 'left', 'left-start', 'left-end']),
312
+ title: _pt__default['default'].string.isRequired,
313
+ modifiers: _pt__default['default'].any,
314
+ components: _pt__default['default'].shape({
315
+ BodyComponent: _pt__default['default'].elementType,
316
+ TooltipWrapperComponent: _pt__default['default'].elementType,
317
+ WrapperComponent: _pt__default['default'].elementType
318
+ }),
319
+ horizontalConstraint: _pt__default['default'].oneOf([1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 'scale', 'auto'])
320
+ } : {};
321
+ Tooltip.displayName = 'ToolTip';
322
+ Tooltip.defaultProps = tooltipDefaultProps;
323
+ var Tooltip$1 = Tooltip;
324
+
325
+ // NOTE: This string will be replaced in the `prepare` script by the `scripts/version.js` file.
326
+ var version = '0.0.0-canary-2021830134526';
327
+
328
+ exports['default'] = Tooltip$1;
329
+ exports.version = version;
@@ -0,0 +1,7 @@
1
+ 'use strict';
2
+
3
+ if (process.env.NODE_ENV === "production") {
4
+ module.exports = require("./commercetools-uikit-tooltip.cjs.prod.js");
5
+ } else {
6
+ module.exports = require("./commercetools-uikit-tooltip.cjs.dev.js");
7
+ }