@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 +21 -0
- package/README.md +230 -0
- package/dist/commercetools-uikit-tooltip.cjs.d.ts +2 -0
- package/dist/commercetools-uikit-tooltip.cjs.dev.js +329 -0
- package/dist/commercetools-uikit-tooltip.cjs.js +7 -0
- package/dist/commercetools-uikit-tooltip.cjs.prod.js +291 -0
- package/dist/commercetools-uikit-tooltip.esm.js +308 -0
- package/dist/declarations/src/export-types.d.ts +2 -0
- package/dist/declarations/src/index.d.ts +3 -0
- package/dist/declarations/src/tooltip.d.ts +28 -0
- package/dist/declarations/src/tooltip.styles.d.ts +15 -0
- package/dist/declarations/src/version.d.ts +2 -0
- package/package.json +52 -0
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,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;
|