@react-aria/utils 3.11.0 → 3.11.1
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/dist/main.js +768 -966
- package/dist/main.js.map +1 -1
- package/dist/module.js +744 -877
- package/dist/module.js.map +1 -1
- package/dist/types.d.ts.map +1 -1
- package/package.json +5 -5
package/dist/main.js
CHANGED
|
@@ -1,1090 +1,892 @@
|
|
|
1
|
-
var
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
var _babelRuntimeHelpersExtends = $parcel$interopDefault(require("@babel/runtime/helpers/extends"));
|
|
12
|
-
|
|
13
|
-
var {
|
|
14
|
-
useSSRSafeId
|
|
15
|
-
} = require("@react-aria/ssr");
|
|
16
|
-
|
|
17
|
-
var _react2 = require("react");
|
|
18
|
-
|
|
19
|
-
var _react = $parcel$interopDefault(_react2);
|
|
1
|
+
var $gqa0x$react = require("react");
|
|
2
|
+
var $gqa0x$reactariassr = require("@react-aria/ssr");
|
|
3
|
+
var $gqa0x$clsx = require("clsx");
|
|
4
|
+
var $gqa0x$reactstatelyutils = require("@react-stately/utils");
|
|
5
|
+
|
|
6
|
+
function $parcel$exportWildcard(dest, source) {
|
|
7
|
+
Object.keys(source).forEach(function(key) {
|
|
8
|
+
if (key === 'default' || key === '__esModule' || dest.hasOwnProperty(key)) {
|
|
9
|
+
return;
|
|
10
|
+
}
|
|
20
11
|
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
}
|
|
12
|
+
Object.defineProperty(dest, key, {
|
|
13
|
+
enumerable: true,
|
|
14
|
+
get: function get() {
|
|
15
|
+
return source[key];
|
|
16
|
+
}
|
|
17
|
+
});
|
|
18
|
+
});
|
|
27
19
|
|
|
20
|
+
return dest;
|
|
21
|
+
}
|
|
22
|
+
function $parcel$export(e, n, v, s) {
|
|
23
|
+
Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true});
|
|
24
|
+
}
|
|
28
25
|
function $parcel$interopDefault(a) {
|
|
29
26
|
return a && a.__esModule ? a.default : a;
|
|
30
27
|
}
|
|
28
|
+
var $dd96e9bc07c5b25f$exports = {};
|
|
31
29
|
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
const useLayoutEffect = typeof window !== 'undefined' ? _react.useLayoutEffect : () => {};
|
|
36
|
-
exports.useLayoutEffect = useLayoutEffect;
|
|
37
|
-
let $f09fcd7f5f367fc80aacfeac62ed2$var$idsUpdaterMap = new Map();
|
|
38
|
-
/**
|
|
39
|
-
* If a default is not provided, generate an id.
|
|
40
|
-
* @param defaultId - Default component id.
|
|
41
|
-
*/
|
|
42
|
-
|
|
43
|
-
function useId(defaultId) {
|
|
44
|
-
let isRendering = useRef(true);
|
|
45
|
-
isRendering.current = true;
|
|
46
|
-
let [value, setValue] = useState(defaultId);
|
|
47
|
-
let nextId = useRef(null);
|
|
48
|
-
let res = useSSRSafeId(value); // don't memo this, we want it new each render so that the Effects always run
|
|
49
|
-
|
|
50
|
-
let updateValue = val => {
|
|
51
|
-
if (!isRendering.current) {
|
|
52
|
-
setValue(val);
|
|
53
|
-
} else {
|
|
54
|
-
nextId.current = val;
|
|
55
|
-
}
|
|
56
|
-
};
|
|
57
|
-
|
|
58
|
-
$f09fcd7f5f367fc80aacfeac62ed2$var$idsUpdaterMap.set(res, updateValue);
|
|
59
|
-
useLayoutEffect(() => {
|
|
60
|
-
isRendering.current = false;
|
|
61
|
-
}, [updateValue]);
|
|
62
|
-
useLayoutEffect(() => {
|
|
63
|
-
let r = res;
|
|
64
|
-
return () => {
|
|
65
|
-
$f09fcd7f5f367fc80aacfeac62ed2$var$idsUpdaterMap.delete(r);
|
|
66
|
-
};
|
|
67
|
-
}, [res]);
|
|
68
|
-
useEffect(() => {
|
|
69
|
-
let newId = nextId.current;
|
|
70
|
-
|
|
71
|
-
if (newId) {
|
|
72
|
-
setValue(newId);
|
|
73
|
-
nextId.current = null;
|
|
74
|
-
}
|
|
75
|
-
}, [setValue, updateValue]);
|
|
76
|
-
return res;
|
|
77
|
-
}
|
|
78
|
-
/**
|
|
79
|
-
* Merges two ids.
|
|
80
|
-
* Different ids will trigger a side-effect and re-render components hooked up with `useId`.
|
|
81
|
-
*/
|
|
82
|
-
|
|
30
|
+
$parcel$export($dd96e9bc07c5b25f$exports, "useId", () => $dd96e9bc07c5b25f$export$f680877a34711e37);
|
|
31
|
+
$parcel$export($dd96e9bc07c5b25f$exports, "mergeIds", () => $dd96e9bc07c5b25f$export$cd8c9cb68f842629);
|
|
32
|
+
$parcel$export($dd96e9bc07c5b25f$exports, "useSlotId", () => $dd96e9bc07c5b25f$export$b4cc09c592e8fdb8);
|
|
83
33
|
|
|
84
|
-
exports
|
|
34
|
+
var $565383b8cde869dd$exports = {};
|
|
85
35
|
|
|
86
|
-
|
|
87
|
-
if (idA === idB) {
|
|
88
|
-
return idA;
|
|
89
|
-
}
|
|
36
|
+
$parcel$export($565383b8cde869dd$exports, "useLayoutEffect", () => $565383b8cde869dd$export$e5c5a5f917a5871c);
|
|
90
37
|
|
|
91
|
-
|
|
38
|
+
const $565383b8cde869dd$export$e5c5a5f917a5871c = typeof window !== 'undefined' ? ($parcel$interopDefault($gqa0x$react)).useLayoutEffect : ()=>{
|
|
39
|
+
};
|
|
92
40
|
|
|
93
|
-
if (setIdA) {
|
|
94
|
-
setIdA(idB);
|
|
95
|
-
return idB;
|
|
96
|
-
}
|
|
97
41
|
|
|
98
|
-
let setIdB = $f09fcd7f5f367fc80aacfeac62ed2$var$idsUpdaterMap.get(idB);
|
|
99
42
|
|
|
100
|
-
if (setIdB) {
|
|
101
|
-
setIdB(idA);
|
|
102
|
-
return idA;
|
|
103
|
-
}
|
|
104
43
|
|
|
105
|
-
|
|
44
|
+
let $dd96e9bc07c5b25f$var$idsUpdaterMap = new Map();
|
|
45
|
+
function $dd96e9bc07c5b25f$export$f680877a34711e37(defaultId) {
|
|
46
|
+
let isRendering = $gqa0x$react.useRef(true);
|
|
47
|
+
isRendering.current = true;
|
|
48
|
+
let [value, setValue] = $gqa0x$react.useState(defaultId);
|
|
49
|
+
let nextId = $gqa0x$react.useRef(null);
|
|
50
|
+
let res = $gqa0x$reactariassr.useSSRSafeId(value);
|
|
51
|
+
// don't memo this, we want it new each render so that the Effects always run
|
|
52
|
+
let updateValue = (val)=>{
|
|
53
|
+
if (!isRendering.current) setValue(val);
|
|
54
|
+
else nextId.current = val;
|
|
55
|
+
};
|
|
56
|
+
$dd96e9bc07c5b25f$var$idsUpdaterMap.set(res, updateValue);
|
|
57
|
+
$565383b8cde869dd$export$e5c5a5f917a5871c(()=>{
|
|
58
|
+
isRendering.current = false;
|
|
59
|
+
}, [
|
|
60
|
+
updateValue
|
|
61
|
+
]);
|
|
62
|
+
$565383b8cde869dd$export$e5c5a5f917a5871c(()=>{
|
|
63
|
+
let r = res;
|
|
64
|
+
return ()=>{
|
|
65
|
+
$dd96e9bc07c5b25f$var$idsUpdaterMap.delete(r);
|
|
66
|
+
};
|
|
67
|
+
}, [
|
|
68
|
+
res
|
|
69
|
+
]);
|
|
70
|
+
$gqa0x$react.useEffect(()=>{
|
|
71
|
+
let newId = nextId.current;
|
|
72
|
+
if (newId) {
|
|
73
|
+
setValue(newId);
|
|
74
|
+
nextId.current = null;
|
|
75
|
+
}
|
|
76
|
+
}, [
|
|
77
|
+
setValue,
|
|
78
|
+
updateValue
|
|
79
|
+
]);
|
|
80
|
+
return res;
|
|
81
|
+
}
|
|
82
|
+
function $dd96e9bc07c5b25f$export$cd8c9cb68f842629(idA, idB) {
|
|
83
|
+
if (idA === idB) return idA;
|
|
84
|
+
let setIdA = $dd96e9bc07c5b25f$var$idsUpdaterMap.get(idA);
|
|
85
|
+
if (setIdA) {
|
|
86
|
+
setIdA(idB);
|
|
87
|
+
return idB;
|
|
88
|
+
}
|
|
89
|
+
let setIdB = $dd96e9bc07c5b25f$var$idsUpdaterMap.get(idB);
|
|
90
|
+
if (setIdB) {
|
|
91
|
+
setIdB(idA);
|
|
92
|
+
return idA;
|
|
93
|
+
}
|
|
94
|
+
return idB;
|
|
95
|
+
}
|
|
96
|
+
function $dd96e9bc07c5b25f$export$b4cc09c592e8fdb8(depArray = []) {
|
|
97
|
+
let id = $dd96e9bc07c5b25f$export$f680877a34711e37();
|
|
98
|
+
let [resolvedId, setResolvedId] = $789b9514fd01258b$export$14d238f342723f25(id);
|
|
99
|
+
let updateId = $gqa0x$react.useCallback(()=>{
|
|
100
|
+
setResolvedId(function*() {
|
|
101
|
+
yield id;
|
|
102
|
+
yield document.getElementById(id) ? id : null;
|
|
103
|
+
});
|
|
104
|
+
}, [
|
|
105
|
+
id,
|
|
106
|
+
setResolvedId
|
|
107
|
+
]);
|
|
108
|
+
$565383b8cde869dd$export$e5c5a5f917a5871c(updateId, [
|
|
109
|
+
id,
|
|
110
|
+
updateId,
|
|
111
|
+
...depArray
|
|
112
|
+
]);
|
|
113
|
+
return resolvedId;
|
|
114
|
+
}
|
|
115
|
+
|
|
116
|
+
|
|
117
|
+
var $5172289b7a1cda90$exports = {};
|
|
118
|
+
|
|
119
|
+
$parcel$export($5172289b7a1cda90$exports, "chain", () => $5172289b7a1cda90$export$e08e3b67e392101e);
|
|
120
|
+
function $5172289b7a1cda90$export$e08e3b67e392101e(...callbacks) {
|
|
121
|
+
return (...args)=>{
|
|
122
|
+
for (let callback of callbacks)if (typeof callback === 'function') callback(...args);
|
|
123
|
+
};
|
|
106
124
|
}
|
|
107
|
-
/**
|
|
108
|
-
* Used to generate an id, and after render, check if that id is rendered so we know
|
|
109
|
-
* if we can use it in places such as labelledby.
|
|
110
|
-
* @param depArray - When to recalculate if the id is in the DOM.
|
|
111
|
-
*/
|
|
112
|
-
|
|
113
125
|
|
|
114
|
-
exports.mergeIds = mergeIds;
|
|
115
126
|
|
|
116
|
-
|
|
117
|
-
if (depArray === void 0) {
|
|
118
|
-
depArray = [];
|
|
119
|
-
}
|
|
127
|
+
var $ee1eca53264e4e21$exports = {};
|
|
120
128
|
|
|
121
|
-
|
|
122
|
-
let [resolvedId, setResolvedId] = useValueEffect(id);
|
|
123
|
-
let updateId = useCallback(() => {
|
|
124
|
-
setResolvedId(function* () {
|
|
125
|
-
yield id;
|
|
126
|
-
yield document.getElementById(id) ? id : null;
|
|
127
|
-
});
|
|
128
|
-
}, [id, setResolvedId]);
|
|
129
|
-
useLayoutEffect(updateId, [id, updateId, ...depArray]);
|
|
130
|
-
return resolvedId;
|
|
131
|
-
}
|
|
129
|
+
$parcel$export($ee1eca53264e4e21$exports, "mergeProps", () => $ee1eca53264e4e21$export$9d1611c77c2fe928);
|
|
132
130
|
|
|
133
|
-
exports.useSlotId = useSlotId;
|
|
134
131
|
|
|
135
|
-
/*
|
|
136
|
-
* Copyright 2020 Adobe. All rights reserved.
|
|
137
|
-
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
|
|
138
|
-
* you may not use this file except in compliance with the License. You may obtain a copy
|
|
139
|
-
* of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
140
|
-
*
|
|
141
|
-
* Unless required by applicable law or agreed to in writing, software distributed under
|
|
142
|
-
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
|
|
143
|
-
* OF ANY KIND, either express or implied. See the License for the specific language
|
|
144
|
-
* governing permissions and limitations under the License.
|
|
145
|
-
*/
|
|
146
132
|
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
133
|
+
function $ee1eca53264e4e21$export$9d1611c77c2fe928(...args) {
|
|
134
|
+
// Start with a base clone of the first argument. This is a lot faster than starting
|
|
135
|
+
// with an empty object and adding properties as we go.
|
|
136
|
+
let result = {
|
|
137
|
+
...args[0]
|
|
138
|
+
};
|
|
139
|
+
for(let i = 1; i < args.length; i++){
|
|
140
|
+
let props = args[i];
|
|
141
|
+
for(let key in props){
|
|
142
|
+
let a = result[key];
|
|
143
|
+
let b = props[key];
|
|
144
|
+
// Chain events
|
|
145
|
+
if (typeof a === 'function' && typeof b === 'function' && // This is a lot faster than a regex.
|
|
146
|
+
key[0] === 'o' && key[1] === 'n' && key.charCodeAt(2) >= /* 'A' */ 65 && key.charCodeAt(2) <= /* 'Z' */ 90) result[key] = $5172289b7a1cda90$export$e08e3b67e392101e(a, b);
|
|
147
|
+
else if ((key === 'className' || key === 'UNSAFE_className') && typeof a === 'string' && typeof b === 'string') result[key] = ($parcel$interopDefault($gqa0x$clsx))(a, b);
|
|
148
|
+
else if (key === 'id' && a && b) result.id = $dd96e9bc07c5b25f$export$cd8c9cb68f842629(a, b);
|
|
149
|
+
else result[key] = b !== undefined ? b : a;
|
|
150
|
+
}
|
|
160
151
|
}
|
|
161
|
-
|
|
152
|
+
return result;
|
|
162
153
|
}
|
|
163
154
|
|
|
164
|
-
exports.chain = chain;
|
|
165
155
|
|
|
166
|
-
|
|
167
|
-
* Merges multiple props objects together. Event handlers are chained,
|
|
168
|
-
* classNames are combined, and ids are deduplicated - different ids
|
|
169
|
-
* will trigger a side-effect and re-render components hooked up with `useId`.
|
|
170
|
-
* For all other props, the last prop object overrides all previous ones.
|
|
171
|
-
* @param args - Multiple sets of props to merge together.
|
|
172
|
-
*/
|
|
173
|
-
function mergeProps() {
|
|
174
|
-
// Start with a base clone of the first argument. This is a lot faster than starting
|
|
175
|
-
// with an empty object and adding properties as we go.
|
|
176
|
-
let result = _babelRuntimeHelpersExtends({}, arguments.length <= 0 ? undefined : arguments[0]);
|
|
177
|
-
|
|
178
|
-
for (let i = 1; i < arguments.length; i++) {
|
|
179
|
-
let props = i < 0 || arguments.length <= i ? undefined : arguments[i];
|
|
180
|
-
|
|
181
|
-
for (let key in props) {
|
|
182
|
-
let a = result[key];
|
|
183
|
-
let b = props[key]; // Chain events
|
|
184
|
-
|
|
185
|
-
if (typeof a === 'function' && typeof b === 'function' && // This is a lot faster than a regex.
|
|
186
|
-
key[0] === 'o' && key[1] === 'n' && key.charCodeAt(2) >=
|
|
187
|
-
/* 'A' */
|
|
188
|
-
65 && key.charCodeAt(2) <=
|
|
189
|
-
/* 'Z' */
|
|
190
|
-
90) {
|
|
191
|
-
result[key] = chain(a, b); // Merge classnames, sometimes classNames are empty string which eval to false, so we just need to do a type check
|
|
192
|
-
} else if ((key === 'className' || key === 'UNSAFE_className') && typeof a === 'string' && typeof b === 'string') {
|
|
193
|
-
result[key] = _clsx(a, b);
|
|
194
|
-
} else if (key === 'id' && a && b) {
|
|
195
|
-
result.id = mergeIds(a, b); // Override others
|
|
196
|
-
} else {
|
|
197
|
-
result[key] = b !== undefined ? b : a;
|
|
198
|
-
}
|
|
199
|
-
}
|
|
200
|
-
}
|
|
156
|
+
var $2f71b7bbfef4ef86$exports = {};
|
|
201
157
|
|
|
202
|
-
|
|
158
|
+
$parcel$export($2f71b7bbfef4ef86$exports, "filterDOMProps", () => $2f71b7bbfef4ef86$export$457c3d6518dd4c6f);
|
|
159
|
+
const $2f71b7bbfef4ef86$var$DOMPropNames = new Set([
|
|
160
|
+
'id'
|
|
161
|
+
]);
|
|
162
|
+
const $2f71b7bbfef4ef86$var$labelablePropNames = new Set([
|
|
163
|
+
'aria-label',
|
|
164
|
+
'aria-labelledby',
|
|
165
|
+
'aria-describedby',
|
|
166
|
+
'aria-details'
|
|
167
|
+
]);
|
|
168
|
+
const $2f71b7bbfef4ef86$var$propRe = /^(data-.*)$/;
|
|
169
|
+
function $2f71b7bbfef4ef86$export$457c3d6518dd4c6f(props, opts = {
|
|
170
|
+
}) {
|
|
171
|
+
let { labelable: labelable , propNames: propNames } = opts;
|
|
172
|
+
let filteredProps = {
|
|
173
|
+
};
|
|
174
|
+
for(const prop in props)if (Object.prototype.hasOwnProperty.call(props, prop) && ($2f71b7bbfef4ef86$var$DOMPropNames.has(prop) || labelable && $2f71b7bbfef4ef86$var$labelablePropNames.has(prop) || propNames?.has(prop) || $2f71b7bbfef4ef86$var$propRe.test(prop))) filteredProps[prop] = props[prop];
|
|
175
|
+
return filteredProps;
|
|
203
176
|
}
|
|
204
177
|
|
|
205
|
-
exports.mergeProps = mergeProps;
|
|
206
|
-
const $a736ffc3e05a0bfc1508098ba395b41$var$DOMPropNames = new Set(['id']);
|
|
207
|
-
const $a736ffc3e05a0bfc1508098ba395b41$var$labelablePropNames = new Set(['aria-label', 'aria-labelledby', 'aria-describedby', 'aria-details']);
|
|
208
|
-
const $a736ffc3e05a0bfc1508098ba395b41$var$propRe = /^(data-.*)$/;
|
|
209
|
-
/**
|
|
210
|
-
* Filters out all props that aren't valid DOM props or defined via override prop obj.
|
|
211
|
-
* @param props - The component props to be filtered.
|
|
212
|
-
* @param opts - Props to override.
|
|
213
|
-
*/
|
|
214
|
-
|
|
215
|
-
function filterDOMProps(props, opts) {
|
|
216
|
-
if (opts === void 0) {
|
|
217
|
-
opts = {};
|
|
218
|
-
}
|
|
219
|
-
|
|
220
|
-
let {
|
|
221
|
-
labelable,
|
|
222
|
-
propNames
|
|
223
|
-
} = opts;
|
|
224
|
-
let filteredProps = {};
|
|
225
|
-
|
|
226
|
-
for (const prop in props) {
|
|
227
|
-
if (Object.prototype.hasOwnProperty.call(props, prop) && ($a736ffc3e05a0bfc1508098ba395b41$var$DOMPropNames.has(prop) || labelable && $a736ffc3e05a0bfc1508098ba395b41$var$labelablePropNames.has(prop) || propNames != null && propNames.has(prop) || $a736ffc3e05a0bfc1508098ba395b41$var$propRe.test(prop))) {
|
|
228
|
-
filteredProps[prop] = props[prop];
|
|
229
|
-
}
|
|
230
|
-
}
|
|
231
178
|
|
|
232
|
-
|
|
233
|
-
}
|
|
179
|
+
var $448ba02dcac1c856$exports = {};
|
|
234
180
|
|
|
235
|
-
exports
|
|
236
|
-
|
|
237
|
-
|
|
238
|
-
|
|
239
|
-
// See https://bugs.webkit.org/show_bug.cgi?id=178583
|
|
240
|
-
//
|
|
241
|
-
// Original licensing for the following methods can be found in the
|
|
242
|
-
// NOTICE file in the root directory of this source tree.
|
|
243
|
-
// See https://github.com/calvellido/focus-options-polyfill
|
|
244
|
-
function focusWithoutScrolling(element) {
|
|
245
|
-
if ($d2a175ba498dd7834499f256dfb330bc$var$supportsPreventScroll()) {
|
|
246
|
-
element.focus({
|
|
247
|
-
preventScroll: true
|
|
181
|
+
$parcel$export($448ba02dcac1c856$exports, "focusWithoutScrolling", () => $448ba02dcac1c856$export$de79e2c695e052f3);
|
|
182
|
+
function $448ba02dcac1c856$export$de79e2c695e052f3(element) {
|
|
183
|
+
if ($448ba02dcac1c856$var$supportsPreventScroll()) element.focus({
|
|
184
|
+
preventScroll: true
|
|
248
185
|
});
|
|
249
|
-
|
|
250
|
-
|
|
251
|
-
|
|
252
|
-
|
|
253
|
-
|
|
254
|
-
}
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
|
|
258
|
-
|
|
259
|
-
|
|
260
|
-
|
|
261
|
-
|
|
262
|
-
|
|
263
|
-
|
|
264
|
-
|
|
265
|
-
|
|
266
|
-
|
|
267
|
-
|
|
268
|
-
|
|
186
|
+
else {
|
|
187
|
+
let scrollableElements = $448ba02dcac1c856$var$getScrollableElements(element);
|
|
188
|
+
element.focus();
|
|
189
|
+
$448ba02dcac1c856$var$restoreScrollPosition(scrollableElements);
|
|
190
|
+
}
|
|
191
|
+
}
|
|
192
|
+
let $448ba02dcac1c856$var$supportsPreventScrollCached = null;
|
|
193
|
+
function $448ba02dcac1c856$var$supportsPreventScroll() {
|
|
194
|
+
if ($448ba02dcac1c856$var$supportsPreventScrollCached == null) {
|
|
195
|
+
$448ba02dcac1c856$var$supportsPreventScrollCached = false;
|
|
196
|
+
try {
|
|
197
|
+
var focusElem = document.createElement('div');
|
|
198
|
+
focusElem.focus({
|
|
199
|
+
get preventScroll () {
|
|
200
|
+
$448ba02dcac1c856$var$supportsPreventScrollCached = true;
|
|
201
|
+
return true;
|
|
202
|
+
}
|
|
203
|
+
});
|
|
204
|
+
} catch (e) {
|
|
205
|
+
// Ignore
|
|
269
206
|
}
|
|
270
|
-
|
|
271
|
-
});
|
|
272
|
-
} catch (e) {// Ignore
|
|
273
207
|
}
|
|
274
|
-
|
|
275
|
-
|
|
276
|
-
|
|
208
|
+
return $448ba02dcac1c856$var$supportsPreventScrollCached;
|
|
209
|
+
}
|
|
210
|
+
function $448ba02dcac1c856$var$getScrollableElements(element) {
|
|
211
|
+
var parent = element.parentNode;
|
|
212
|
+
var scrollableElements = [];
|
|
213
|
+
var rootScrollingElement = document.scrollingElement || document.documentElement;
|
|
214
|
+
while(parent instanceof HTMLElement && parent !== rootScrollingElement){
|
|
215
|
+
if (parent.offsetHeight < parent.scrollHeight || parent.offsetWidth < parent.scrollWidth) scrollableElements.push({
|
|
216
|
+
element: parent,
|
|
217
|
+
scrollTop: parent.scrollTop,
|
|
218
|
+
scrollLeft: parent.scrollLeft
|
|
219
|
+
});
|
|
220
|
+
parent = parent.parentNode;
|
|
221
|
+
}
|
|
222
|
+
if (rootScrollingElement instanceof HTMLElement) scrollableElements.push({
|
|
223
|
+
element: rootScrollingElement,
|
|
224
|
+
scrollTop: rootScrollingElement.scrollTop,
|
|
225
|
+
scrollLeft: rootScrollingElement.scrollLeft
|
|
226
|
+
});
|
|
227
|
+
return scrollableElements;
|
|
277
228
|
}
|
|
278
|
-
|
|
279
|
-
|
|
280
|
-
|
|
281
|
-
|
|
282
|
-
var rootScrollingElement = document.scrollingElement || document.documentElement;
|
|
283
|
-
|
|
284
|
-
while (parent instanceof HTMLElement && parent !== rootScrollingElement) {
|
|
285
|
-
if (parent.offsetHeight < parent.scrollHeight || parent.offsetWidth < parent.scrollWidth) {
|
|
286
|
-
scrollableElements.push({
|
|
287
|
-
element: parent,
|
|
288
|
-
scrollTop: parent.scrollTop,
|
|
289
|
-
scrollLeft: parent.scrollLeft
|
|
290
|
-
});
|
|
229
|
+
function $448ba02dcac1c856$var$restoreScrollPosition(scrollableElements) {
|
|
230
|
+
for (let { element: element , scrollTop: scrollTop , scrollLeft: scrollLeft } of scrollableElements){
|
|
231
|
+
element.scrollTop = scrollTop;
|
|
232
|
+
element.scrollLeft = scrollLeft;
|
|
291
233
|
}
|
|
234
|
+
}
|
|
292
235
|
|
|
293
|
-
parent = parent.parentNode;
|
|
294
|
-
}
|
|
295
236
|
|
|
296
|
-
|
|
297
|
-
scrollableElements.push({
|
|
298
|
-
element: rootScrollingElement,
|
|
299
|
-
scrollTop: rootScrollingElement.scrollTop,
|
|
300
|
-
scrollLeft: rootScrollingElement.scrollLeft
|
|
301
|
-
});
|
|
302
|
-
}
|
|
237
|
+
var $391ef47b89fbbdf8$exports = {};
|
|
303
238
|
|
|
304
|
-
|
|
239
|
+
$parcel$export($391ef47b89fbbdf8$exports, "getOffset", () => $391ef47b89fbbdf8$export$622cea445a1c5b7d);
|
|
240
|
+
function $391ef47b89fbbdf8$export$622cea445a1c5b7d(element, reverse, orientation = 'horizontal') {
|
|
241
|
+
let rect = element.getBoundingClientRect();
|
|
242
|
+
if (reverse) return orientation === 'horizontal' ? rect.right : rect.bottom;
|
|
243
|
+
return orientation === 'horizontal' ? rect.left : rect.top;
|
|
305
244
|
}
|
|
306
245
|
|
|
307
|
-
function $d2a175ba498dd7834499f256dfb330bc$var$restoreScrollPosition(scrollableElements) {
|
|
308
|
-
for (let {
|
|
309
|
-
element,
|
|
310
|
-
scrollTop,
|
|
311
|
-
scrollLeft
|
|
312
|
-
} of scrollableElements) {
|
|
313
|
-
element.scrollTop = scrollTop;
|
|
314
|
-
element.scrollLeft = scrollLeft;
|
|
315
|
-
}
|
|
316
|
-
}
|
|
317
246
|
|
|
318
|
-
|
|
319
|
-
if (orientation === void 0) {
|
|
320
|
-
orientation = 'horizontal';
|
|
321
|
-
}
|
|
247
|
+
var $c570a0a6fa1d588f$exports = {};
|
|
322
248
|
|
|
323
|
-
|
|
249
|
+
$parcel$export($c570a0a6fa1d588f$exports, "clamp", () => $gqa0x$reactstatelyutils.clamp);
|
|
250
|
+
$parcel$export($c570a0a6fa1d588f$exports, "snapValueToStep", () => $gqa0x$reactstatelyutils.snapValueToStep);
|
|
324
251
|
|
|
325
|
-
if (reverse) {
|
|
326
|
-
return orientation === 'horizontal' ? rect.right : rect.bottom;
|
|
327
|
-
}
|
|
328
252
|
|
|
329
|
-
return orientation === 'horizontal' ? rect.left : rect.top;
|
|
330
|
-
}
|
|
331
253
|
|
|
332
|
-
exports
|
|
254
|
+
var $4da380280744869b$exports = {};
|
|
255
|
+
|
|
256
|
+
$parcel$export($4da380280744869b$exports, "runAfterTransition", () => $4da380280744869b$export$24490316f764c430);
|
|
257
|
+
/*
|
|
258
|
+
* Copyright 2020 Adobe. All rights reserved.
|
|
259
|
+
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
|
|
260
|
+
* you may not use this file except in compliance with the License. You may obtain a copy
|
|
261
|
+
* of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
262
|
+
*
|
|
263
|
+
* Unless required by applicable law or agreed to in writing, software distributed under
|
|
264
|
+
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
|
|
265
|
+
* OF ANY KIND, either express or implied. See the License for the specific language
|
|
266
|
+
* governing permissions and limitations under the License.
|
|
267
|
+
*/ // We store a global list of elements that are currently transitioning,
|
|
333
268
|
// mapped to a set of CSS properties that are transitioning for that element.
|
|
334
269
|
// This is necessary rather than a simple count of transitions because of browser
|
|
335
270
|
// bugs, e.g. Chrome sometimes fires both transitionend and transitioncancel rather
|
|
336
271
|
// than one or the other. So we need to track what's actually transitioning so that
|
|
337
272
|
// we can ignore these duplicate events.
|
|
338
|
-
let $
|
|
339
|
-
|
|
340
|
-
let $
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
|
|
351
|
-
|
|
352
|
-
|
|
353
|
-
$a39a8553a97349a69bcc0255658c67ab$var$transitionsByElement.set(e.target, transitions); // The transitioncancel event must be registered on the element itself, rather than as a global
|
|
354
|
-
// event. This enables us to handle when the node is deleted from the document while it is transitioning.
|
|
355
|
-
// In that case, the cancel event would have nowhere to bubble to so we need to handle it directly.
|
|
356
|
-
|
|
357
|
-
e.target.addEventListener('transitioncancel', onTransitionEnd);
|
|
358
|
-
}
|
|
359
|
-
|
|
360
|
-
transitions.add(e.propertyName);
|
|
361
|
-
};
|
|
362
|
-
|
|
363
|
-
let onTransitionEnd = e => {
|
|
364
|
-
// Remove property from list of transitioning properties.
|
|
365
|
-
let properties = $a39a8553a97349a69bcc0255658c67ab$var$transitionsByElement.get(e.target);
|
|
366
|
-
|
|
367
|
-
if (!properties) {
|
|
368
|
-
return;
|
|
369
|
-
}
|
|
370
|
-
|
|
371
|
-
properties.delete(e.propertyName); // If empty, remove transitioncancel event, and remove the element from the list of transitioning elements.
|
|
372
|
-
|
|
373
|
-
if (properties.size === 0) {
|
|
374
|
-
e.target.removeEventListener('transitioncancel', onTransitionEnd);
|
|
375
|
-
$a39a8553a97349a69bcc0255658c67ab$var$transitionsByElement.delete(e.target);
|
|
376
|
-
} // If no transitioning elements, call all of the queued callbacks.
|
|
377
|
-
|
|
378
|
-
|
|
379
|
-
if ($a39a8553a97349a69bcc0255658c67ab$var$transitionsByElement.size === 0) {
|
|
380
|
-
for (let cb of $a39a8553a97349a69bcc0255658c67ab$var$transitionCallbacks) {
|
|
381
|
-
cb();
|
|
382
|
-
}
|
|
383
|
-
|
|
384
|
-
$a39a8553a97349a69bcc0255658c67ab$var$transitionCallbacks.clear();
|
|
385
|
-
}
|
|
386
|
-
};
|
|
387
|
-
|
|
388
|
-
document.body.addEventListener('transitionrun', onTransitionStart);
|
|
389
|
-
document.body.addEventListener('transitionend', onTransitionEnd);
|
|
390
|
-
}
|
|
391
|
-
|
|
392
|
-
if (typeof document !== 'undefined') {
|
|
393
|
-
if (document.readyState !== 'loading') {
|
|
394
|
-
$a39a8553a97349a69bcc0255658c67ab$var$setupGlobalEvents();
|
|
395
|
-
} else {
|
|
396
|
-
document.addEventListener('DOMContentLoaded', $a39a8553a97349a69bcc0255658c67ab$var$setupGlobalEvents);
|
|
397
|
-
}
|
|
398
|
-
}
|
|
399
|
-
|
|
400
|
-
function runAfterTransition(fn) {
|
|
401
|
-
// Wait one frame to see if an animation starts, e.g. a transition on mount.
|
|
402
|
-
requestAnimationFrame(() => {
|
|
403
|
-
// If no transitions are running, call the function immediately.
|
|
404
|
-
// Otherwise, add it to a list of callbacks to run at the end of the animation.
|
|
405
|
-
if ($a39a8553a97349a69bcc0255658c67ab$var$transitionsByElement.size === 0) {
|
|
406
|
-
fn();
|
|
407
|
-
} else {
|
|
408
|
-
$a39a8553a97349a69bcc0255658c67ab$var$transitionCallbacks.add(fn);
|
|
409
|
-
}
|
|
410
|
-
});
|
|
411
|
-
}
|
|
412
|
-
|
|
413
|
-
exports.runAfterTransition = runAfterTransition;
|
|
414
|
-
// Keep track of elements that we are currently handling dragging for via useDrag1D.
|
|
415
|
-
// If there's an ancestor and a descendant both using useDrag1D(), and the user starts
|
|
416
|
-
// dragging the descendant, we don't want useDrag1D events to fire for the ancestor.
|
|
417
|
-
const $f9e3d2838685addd749dc9b533488cd5$var$draggingElements = []; // created for splitview, this should be reusable for things like sliders/dials
|
|
418
|
-
// It also handles keyboard events on the target allowing for increment/decrement by a given stepsize as well as minifying/maximizing and toggling between minified and previous size
|
|
419
|
-
// It can also take a 'reverse' param to say if we should measure from the right/bottom instead of the top/left
|
|
420
|
-
// It can also handle either a vertical or horizontal movement, but not both at the same time
|
|
421
|
-
|
|
422
|
-
function useDrag1D(props) {
|
|
423
|
-
console.warn('useDrag1D is deprecated, please use `useMove` instead https://react-spectrum.adobe.com/react-aria/useMove.html');
|
|
424
|
-
let {
|
|
425
|
-
containerRef,
|
|
426
|
-
reverse,
|
|
427
|
-
orientation,
|
|
428
|
-
onHover,
|
|
429
|
-
onDrag,
|
|
430
|
-
onPositionChange,
|
|
431
|
-
onIncrement,
|
|
432
|
-
onDecrement,
|
|
433
|
-
onIncrementToMax,
|
|
434
|
-
onDecrementToMin,
|
|
435
|
-
onCollapseToggle
|
|
436
|
-
} = props;
|
|
437
|
-
|
|
438
|
-
let getPosition = e => orientation === 'horizontal' ? e.clientX : e.clientY;
|
|
439
|
-
|
|
440
|
-
let getNextOffset = e => {
|
|
441
|
-
let containerOffset = getOffset(containerRef.current, reverse, orientation);
|
|
442
|
-
let mouseOffset = getPosition(e);
|
|
443
|
-
let nextOffset = reverse ? containerOffset - mouseOffset : mouseOffset - containerOffset;
|
|
444
|
-
return nextOffset;
|
|
445
|
-
};
|
|
446
|
-
|
|
447
|
-
let dragging = useRef(false);
|
|
448
|
-
let prevPosition = useRef(0); // Keep track of the current handlers in a ref so that the events can access them.
|
|
449
|
-
|
|
450
|
-
let handlers = useRef({
|
|
451
|
-
onPositionChange,
|
|
452
|
-
onDrag
|
|
453
|
-
});
|
|
454
|
-
handlers.current.onDrag = onDrag;
|
|
455
|
-
handlers.current.onPositionChange = onPositionChange;
|
|
456
|
-
|
|
457
|
-
let onMouseDragged = e => {
|
|
458
|
-
e.preventDefault();
|
|
459
|
-
let nextOffset = getNextOffset(e);
|
|
460
|
-
|
|
461
|
-
if (!dragging.current) {
|
|
462
|
-
dragging.current = true;
|
|
463
|
-
|
|
464
|
-
if (handlers.current.onDrag) {
|
|
465
|
-
handlers.current.onDrag(true);
|
|
466
|
-
}
|
|
467
|
-
|
|
468
|
-
if (handlers.current.onPositionChange) {
|
|
469
|
-
handlers.current.onPositionChange(nextOffset);
|
|
470
|
-
}
|
|
471
|
-
}
|
|
472
|
-
|
|
473
|
-
if (prevPosition.current === nextOffset) {
|
|
474
|
-
return;
|
|
475
|
-
}
|
|
476
|
-
|
|
477
|
-
prevPosition.current = nextOffset;
|
|
478
|
-
|
|
479
|
-
if (onPositionChange) {
|
|
480
|
-
onPositionChange(nextOffset);
|
|
481
|
-
}
|
|
482
|
-
};
|
|
483
|
-
|
|
484
|
-
let onMouseUp = e => {
|
|
485
|
-
const target = e.target;
|
|
486
|
-
dragging.current = false;
|
|
487
|
-
let nextOffset = getNextOffset(e);
|
|
488
|
-
|
|
489
|
-
if (handlers.current.onDrag) {
|
|
490
|
-
handlers.current.onDrag(false);
|
|
491
|
-
}
|
|
492
|
-
|
|
493
|
-
if (handlers.current.onPositionChange) {
|
|
494
|
-
handlers.current.onPositionChange(nextOffset);
|
|
495
|
-
}
|
|
496
|
-
|
|
497
|
-
$f9e3d2838685addd749dc9b533488cd5$var$draggingElements.splice($f9e3d2838685addd749dc9b533488cd5$var$draggingElements.indexOf(target), 1);
|
|
498
|
-
window.removeEventListener('mouseup', onMouseUp, false);
|
|
499
|
-
window.removeEventListener('mousemove', onMouseDragged, false);
|
|
500
|
-
};
|
|
501
|
-
|
|
502
|
-
let onMouseDown = e => {
|
|
503
|
-
const target = e.currentTarget; // If we're already handling dragging on a descendant with useDrag1D, then
|
|
504
|
-
// we don't want to handle the drag motion on this target as well.
|
|
505
|
-
|
|
506
|
-
if ($f9e3d2838685addd749dc9b533488cd5$var$draggingElements.some(elt => target.contains(elt))) {
|
|
507
|
-
return;
|
|
508
|
-
}
|
|
509
|
-
|
|
510
|
-
$f9e3d2838685addd749dc9b533488cd5$var$draggingElements.push(target);
|
|
511
|
-
window.addEventListener('mousemove', onMouseDragged, false);
|
|
512
|
-
window.addEventListener('mouseup', onMouseUp, false);
|
|
513
|
-
};
|
|
514
|
-
|
|
515
|
-
let onMouseEnter = () => {
|
|
516
|
-
if (onHover) {
|
|
517
|
-
onHover(true);
|
|
518
|
-
}
|
|
519
|
-
};
|
|
520
|
-
|
|
521
|
-
let onMouseOut = () => {
|
|
522
|
-
if (onHover) {
|
|
523
|
-
onHover(false);
|
|
524
|
-
}
|
|
525
|
-
};
|
|
526
|
-
|
|
527
|
-
let onKeyDown = e => {
|
|
528
|
-
switch (e.key) {
|
|
529
|
-
case 'Left':
|
|
530
|
-
case 'ArrowLeft':
|
|
531
|
-
if (orientation === 'horizontal') {
|
|
532
|
-
e.preventDefault();
|
|
533
|
-
|
|
534
|
-
if (onDecrement && !reverse) {
|
|
535
|
-
onDecrement();
|
|
536
|
-
} else if (onIncrement && reverse) {
|
|
537
|
-
onIncrement();
|
|
538
|
-
}
|
|
273
|
+
let $4da380280744869b$var$transitionsByElement = new Map();
|
|
274
|
+
// A list of callbacks to call once there are no transitioning elements.
|
|
275
|
+
let $4da380280744869b$var$transitionCallbacks = new Set();
|
|
276
|
+
function $4da380280744869b$var$setupGlobalEvents() {
|
|
277
|
+
if (typeof window === 'undefined') return;
|
|
278
|
+
let onTransitionStart = (e)=>{
|
|
279
|
+
// Add the transitioning property to the list for this element.
|
|
280
|
+
let transitions = $4da380280744869b$var$transitionsByElement.get(e.target);
|
|
281
|
+
if (!transitions) {
|
|
282
|
+
transitions = new Set();
|
|
283
|
+
$4da380280744869b$var$transitionsByElement.set(e.target, transitions);
|
|
284
|
+
// The transitioncancel event must be registered on the element itself, rather than as a global
|
|
285
|
+
// event. This enables us to handle when the node is deleted from the document while it is transitioning.
|
|
286
|
+
// In that case, the cancel event would have nowhere to bubble to so we need to handle it directly.
|
|
287
|
+
e.target.addEventListener('transitioncancel', onTransitionEnd);
|
|
539
288
|
}
|
|
540
|
-
|
|
541
|
-
|
|
542
|
-
|
|
543
|
-
|
|
544
|
-
|
|
545
|
-
if (
|
|
546
|
-
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
onIncrement();
|
|
552
|
-
}
|
|
289
|
+
transitions.add(e.propertyName);
|
|
290
|
+
};
|
|
291
|
+
let onTransitionEnd = (e)=>{
|
|
292
|
+
// Remove property from list of transitioning properties.
|
|
293
|
+
let properties = $4da380280744869b$var$transitionsByElement.get(e.target);
|
|
294
|
+
if (!properties) return;
|
|
295
|
+
properties.delete(e.propertyName);
|
|
296
|
+
// If empty, remove transitioncancel event, and remove the element from the list of transitioning elements.
|
|
297
|
+
if (properties.size === 0) {
|
|
298
|
+
e.target.removeEventListener('transitioncancel', onTransitionEnd);
|
|
299
|
+
$4da380280744869b$var$transitionsByElement.delete(e.target);
|
|
553
300
|
}
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
case 'ArrowRight':
|
|
559
|
-
if (orientation === 'horizontal') {
|
|
560
|
-
e.preventDefault();
|
|
561
|
-
|
|
562
|
-
if (onIncrement && !reverse) {
|
|
563
|
-
onIncrement();
|
|
564
|
-
} else if (onDecrement && reverse) {
|
|
565
|
-
onDecrement();
|
|
566
|
-
}
|
|
301
|
+
// If no transitioning elements, call all of the queued callbacks.
|
|
302
|
+
if ($4da380280744869b$var$transitionsByElement.size === 0) {
|
|
303
|
+
for (let cb of $4da380280744869b$var$transitionCallbacks)cb();
|
|
304
|
+
$4da380280744869b$var$transitionCallbacks.clear();
|
|
567
305
|
}
|
|
306
|
+
};
|
|
307
|
+
document.body.addEventListener('transitionrun', onTransitionStart);
|
|
308
|
+
document.body.addEventListener('transitionend', onTransitionEnd);
|
|
309
|
+
}
|
|
310
|
+
if (typeof document !== 'undefined') {
|
|
311
|
+
if (document.readyState !== 'loading') $4da380280744869b$var$setupGlobalEvents();
|
|
312
|
+
else document.addEventListener('DOMContentLoaded', $4da380280744869b$var$setupGlobalEvents);
|
|
313
|
+
}
|
|
314
|
+
function $4da380280744869b$export$24490316f764c430(fn) {
|
|
315
|
+
// Wait one frame to see if an animation starts, e.g. a transition on mount.
|
|
316
|
+
requestAnimationFrame(()=>{
|
|
317
|
+
// If no transitions are running, call the function immediately.
|
|
318
|
+
// Otherwise, add it to a list of callbacks to run at the end of the animation.
|
|
319
|
+
if ($4da380280744869b$var$transitionsByElement.size === 0) fn();
|
|
320
|
+
else $4da380280744869b$var$transitionCallbacks.add(fn);
|
|
321
|
+
});
|
|
322
|
+
}
|
|
568
323
|
|
|
569
|
-
break;
|
|
570
324
|
|
|
571
|
-
|
|
572
|
-
case 'ArrowDown':
|
|
573
|
-
if (orientation === 'vertical') {
|
|
574
|
-
e.preventDefault();
|
|
325
|
+
var $ca85cc095ee7bdf9$exports = {};
|
|
575
326
|
|
|
576
|
-
|
|
577
|
-
onIncrement();
|
|
578
|
-
} else if (onDecrement && reverse) {
|
|
579
|
-
onDecrement();
|
|
580
|
-
}
|
|
581
|
-
}
|
|
327
|
+
$parcel$export($ca85cc095ee7bdf9$exports, "useDrag1D", () => $ca85cc095ee7bdf9$export$7bbed75feba39706);
|
|
582
328
|
|
|
583
|
-
break;
|
|
584
329
|
|
|
585
|
-
|
|
330
|
+
// Keep track of elements that we are currently handling dragging for via useDrag1D.
|
|
331
|
+
// If there's an ancestor and a descendant both using useDrag1D(), and the user starts
|
|
332
|
+
// dragging the descendant, we don't want useDrag1D events to fire for the ancestor.
|
|
333
|
+
const $ca85cc095ee7bdf9$var$draggingElements = [];
|
|
334
|
+
function $ca85cc095ee7bdf9$export$7bbed75feba39706(props) {
|
|
335
|
+
console.warn('useDrag1D is deprecated, please use `useMove` instead https://react-spectrum.adobe.com/react-aria/useMove.html');
|
|
336
|
+
let { containerRef: containerRef , reverse: reverse , orientation: orientation , onHover: onHover , onDrag: onDrag , onPositionChange: onPositionChange , onIncrement: onIncrement , onDecrement: onDecrement , onIncrementToMax: onIncrementToMax , onDecrementToMin: onDecrementToMin , onCollapseToggle: onCollapseToggle } = props;
|
|
337
|
+
let getPosition = (e)=>orientation === 'horizontal' ? e.clientX : e.clientY
|
|
338
|
+
;
|
|
339
|
+
let getNextOffset = (e)=>{
|
|
340
|
+
let containerOffset = $391ef47b89fbbdf8$export$622cea445a1c5b7d(containerRef.current, reverse, orientation);
|
|
341
|
+
let mouseOffset = getPosition(e);
|
|
342
|
+
let nextOffset = reverse ? containerOffset - mouseOffset : mouseOffset - containerOffset;
|
|
343
|
+
return nextOffset;
|
|
344
|
+
};
|
|
345
|
+
let dragging = $gqa0x$react.useRef(false);
|
|
346
|
+
let prevPosition = $gqa0x$react.useRef(0);
|
|
347
|
+
// Keep track of the current handlers in a ref so that the events can access them.
|
|
348
|
+
let handlers = $gqa0x$react.useRef({
|
|
349
|
+
onPositionChange: onPositionChange,
|
|
350
|
+
onDrag: onDrag
|
|
351
|
+
});
|
|
352
|
+
handlers.current.onDrag = onDrag;
|
|
353
|
+
handlers.current.onPositionChange = onPositionChange;
|
|
354
|
+
let onMouseDragged = (e)=>{
|
|
586
355
|
e.preventDefault();
|
|
587
|
-
|
|
588
|
-
if (
|
|
589
|
-
|
|
356
|
+
let nextOffset = getNextOffset(e);
|
|
357
|
+
if (!dragging.current) {
|
|
358
|
+
dragging.current = true;
|
|
359
|
+
if (handlers.current.onDrag) handlers.current.onDrag(true);
|
|
360
|
+
if (handlers.current.onPositionChange) handlers.current.onPositionChange(nextOffset);
|
|
590
361
|
}
|
|
591
|
-
|
|
592
|
-
|
|
593
|
-
|
|
594
|
-
|
|
595
|
-
|
|
596
|
-
|
|
597
|
-
|
|
598
|
-
|
|
362
|
+
if (prevPosition.current === nextOffset) return;
|
|
363
|
+
prevPosition.current = nextOffset;
|
|
364
|
+
if (onPositionChange) onPositionChange(nextOffset);
|
|
365
|
+
};
|
|
366
|
+
let onMouseUp = (e)=>{
|
|
367
|
+
const target = e.target;
|
|
368
|
+
dragging.current = false;
|
|
369
|
+
let nextOffset = getNextOffset(e);
|
|
370
|
+
if (handlers.current.onDrag) handlers.current.onDrag(false);
|
|
371
|
+
if (handlers.current.onPositionChange) handlers.current.onPositionChange(nextOffset);
|
|
372
|
+
$ca85cc095ee7bdf9$var$draggingElements.splice($ca85cc095ee7bdf9$var$draggingElements.indexOf(target), 1);
|
|
373
|
+
window.removeEventListener('mouseup', onMouseUp, false);
|
|
374
|
+
window.removeEventListener('mousemove', onMouseDragged, false);
|
|
375
|
+
};
|
|
376
|
+
let onMouseDown = (e)=>{
|
|
377
|
+
const target = e.currentTarget;
|
|
378
|
+
// If we're already handling dragging on a descendant with useDrag1D, then
|
|
379
|
+
// we don't want to handle the drag motion on this target as well.
|
|
380
|
+
if ($ca85cc095ee7bdf9$var$draggingElements.some((elt)=>target.contains(elt)
|
|
381
|
+
)) return;
|
|
382
|
+
$ca85cc095ee7bdf9$var$draggingElements.push(target);
|
|
383
|
+
window.addEventListener('mousemove', onMouseDragged, false);
|
|
384
|
+
window.addEventListener('mouseup', onMouseUp, false);
|
|
385
|
+
};
|
|
386
|
+
let onMouseEnter = ()=>{
|
|
387
|
+
if (onHover) onHover(true);
|
|
388
|
+
};
|
|
389
|
+
let onMouseOut = ()=>{
|
|
390
|
+
if (onHover) onHover(false);
|
|
391
|
+
};
|
|
392
|
+
let onKeyDown = (e)=>{
|
|
393
|
+
switch(e.key){
|
|
394
|
+
case 'Left':
|
|
395
|
+
case 'ArrowLeft':
|
|
396
|
+
if (orientation === 'horizontal') {
|
|
397
|
+
e.preventDefault();
|
|
398
|
+
if (onDecrement && !reverse) onDecrement();
|
|
399
|
+
else if (onIncrement && reverse) onIncrement();
|
|
400
|
+
}
|
|
401
|
+
break;
|
|
402
|
+
case 'Up':
|
|
403
|
+
case 'ArrowUp':
|
|
404
|
+
if (orientation === 'vertical') {
|
|
405
|
+
e.preventDefault();
|
|
406
|
+
if (onDecrement && !reverse) onDecrement();
|
|
407
|
+
else if (onIncrement && reverse) onIncrement();
|
|
408
|
+
}
|
|
409
|
+
break;
|
|
410
|
+
case 'Right':
|
|
411
|
+
case 'ArrowRight':
|
|
412
|
+
if (orientation === 'horizontal') {
|
|
413
|
+
e.preventDefault();
|
|
414
|
+
if (onIncrement && !reverse) onIncrement();
|
|
415
|
+
else if (onDecrement && reverse) onDecrement();
|
|
416
|
+
}
|
|
417
|
+
break;
|
|
418
|
+
case 'Down':
|
|
419
|
+
case 'ArrowDown':
|
|
420
|
+
if (orientation === 'vertical') {
|
|
421
|
+
e.preventDefault();
|
|
422
|
+
if (onIncrement && !reverse) onIncrement();
|
|
423
|
+
else if (onDecrement && reverse) onDecrement();
|
|
424
|
+
}
|
|
425
|
+
break;
|
|
426
|
+
case 'Home':
|
|
427
|
+
e.preventDefault();
|
|
428
|
+
if (onDecrementToMin) onDecrementToMin();
|
|
429
|
+
break;
|
|
430
|
+
case 'End':
|
|
431
|
+
e.preventDefault();
|
|
432
|
+
if (onIncrementToMax) onIncrementToMax();
|
|
433
|
+
break;
|
|
434
|
+
case 'Enter':
|
|
435
|
+
e.preventDefault();
|
|
436
|
+
if (onCollapseToggle) onCollapseToggle();
|
|
437
|
+
break;
|
|
599
438
|
}
|
|
439
|
+
};
|
|
440
|
+
return {
|
|
441
|
+
onMouseDown: onMouseDown,
|
|
442
|
+
onMouseEnter: onMouseEnter,
|
|
443
|
+
onMouseOut: onMouseOut,
|
|
444
|
+
onKeyDown: onKeyDown
|
|
445
|
+
};
|
|
446
|
+
}
|
|
600
447
|
|
|
601
|
-
break;
|
|
602
448
|
|
|
603
|
-
|
|
604
|
-
|
|
449
|
+
var $efa617098dfd7e72$exports = {};
|
|
450
|
+
|
|
451
|
+
$parcel$export($efa617098dfd7e72$exports, "useGlobalListeners", () => $efa617098dfd7e72$export$4eaf04e54aa8eed6);
|
|
452
|
+
|
|
453
|
+
function $efa617098dfd7e72$export$4eaf04e54aa8eed6() {
|
|
454
|
+
let globalListeners = $gqa0x$react.useRef(new Map());
|
|
455
|
+
let addGlobalListener = $gqa0x$react.useCallback((eventTarget, type, listener, options)=>{
|
|
456
|
+
// Make sure we remove the listener after it is called with the `once` option.
|
|
457
|
+
let fn = options?.once ? (...args)=>{
|
|
458
|
+
globalListeners.current.delete(listener);
|
|
459
|
+
listener(...args);
|
|
460
|
+
} : listener;
|
|
461
|
+
globalListeners.current.set(listener, {
|
|
462
|
+
type: type,
|
|
463
|
+
eventTarget: eventTarget,
|
|
464
|
+
fn: fn,
|
|
465
|
+
options: options
|
|
466
|
+
});
|
|
467
|
+
eventTarget.addEventListener(type, listener, options);
|
|
468
|
+
}, []);
|
|
469
|
+
let removeGlobalListener = $gqa0x$react.useCallback((eventTarget, type, listener, options)=>{
|
|
470
|
+
let fn = globalListeners.current.get(listener)?.fn || listener;
|
|
471
|
+
eventTarget.removeEventListener(type, fn, options);
|
|
472
|
+
globalListeners.current.delete(listener);
|
|
473
|
+
}, []);
|
|
474
|
+
let removeAllGlobalListeners = $gqa0x$react.useCallback(()=>{
|
|
475
|
+
globalListeners.current.forEach((value, key)=>{
|
|
476
|
+
removeGlobalListener(value.eventTarget, value.type, key, value.options);
|
|
477
|
+
});
|
|
478
|
+
}, [
|
|
479
|
+
removeGlobalListener
|
|
480
|
+
]);
|
|
481
|
+
// eslint-disable-next-line arrow-body-style
|
|
482
|
+
$gqa0x$react.useEffect(()=>{
|
|
483
|
+
return removeAllGlobalListeners;
|
|
484
|
+
}, [
|
|
485
|
+
removeAllGlobalListeners
|
|
486
|
+
]);
|
|
487
|
+
return {
|
|
488
|
+
addGlobalListener: addGlobalListener,
|
|
489
|
+
removeGlobalListener: removeGlobalListener,
|
|
490
|
+
removeAllGlobalListeners: removeAllGlobalListeners
|
|
491
|
+
};
|
|
492
|
+
}
|
|
605
493
|
|
|
606
|
-
if (onCollapseToggle) {
|
|
607
|
-
onCollapseToggle();
|
|
608
|
-
}
|
|
609
494
|
|
|
610
|
-
|
|
611
|
-
|
|
612
|
-
|
|
613
|
-
|
|
614
|
-
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
|
|
618
|
-
|
|
619
|
-
|
|
495
|
+
var $e0460f7e24b931b0$exports = {};
|
|
496
|
+
|
|
497
|
+
$parcel$export($e0460f7e24b931b0$exports, "useLabels", () => $e0460f7e24b931b0$export$d6875122194c7b44);
|
|
498
|
+
|
|
499
|
+
function $e0460f7e24b931b0$export$d6875122194c7b44(props, defaultLabel) {
|
|
500
|
+
let { id: id , 'aria-label': label , 'aria-labelledby': labelledBy } = props;
|
|
501
|
+
// If there is both an aria-label and aria-labelledby,
|
|
502
|
+
// combine them by pointing to the element itself.
|
|
503
|
+
id = $dd96e9bc07c5b25f$export$f680877a34711e37(id);
|
|
504
|
+
if (labelledBy && label) {
|
|
505
|
+
let ids = new Set([
|
|
506
|
+
...labelledBy.trim().split(/\s+/),
|
|
507
|
+
id
|
|
508
|
+
]);
|
|
509
|
+
labelledBy = [
|
|
510
|
+
...ids
|
|
511
|
+
].join(' ');
|
|
512
|
+
} else if (labelledBy) labelledBy = labelledBy.trim().split(/\s+/).join(' ');
|
|
513
|
+
// If no labels are provided, use the default
|
|
514
|
+
if (!label && !labelledBy && defaultLabel) label = defaultLabel;
|
|
515
|
+
return {
|
|
516
|
+
id: id,
|
|
517
|
+
'aria-label': label,
|
|
518
|
+
'aria-labelledby': labelledBy
|
|
519
|
+
};
|
|
620
520
|
}
|
|
621
521
|
|
|
622
|
-
exports.useDrag1D = useDrag1D;
|
|
623
|
-
|
|
624
|
-
function useGlobalListeners() {
|
|
625
|
-
let globalListeners = useRef(new Map());
|
|
626
|
-
let addGlobalListener = useCallback((eventTarget, type, listener, options) => {
|
|
627
|
-
// Make sure we remove the listener after it is called with the `once` option.
|
|
628
|
-
let fn = options != null && options.once ? function () {
|
|
629
|
-
globalListeners.current.delete(listener);
|
|
630
|
-
listener(...arguments);
|
|
631
|
-
} : listener;
|
|
632
|
-
globalListeners.current.set(listener, {
|
|
633
|
-
type,
|
|
634
|
-
eventTarget,
|
|
635
|
-
fn,
|
|
636
|
-
options
|
|
637
|
-
});
|
|
638
|
-
eventTarget.addEventListener(type, listener, options);
|
|
639
|
-
}, []);
|
|
640
|
-
let removeGlobalListener = useCallback((eventTarget, type, listener, options) => {
|
|
641
|
-
var _globalListeners$curr;
|
|
642
|
-
|
|
643
|
-
let fn = ((_globalListeners$curr = globalListeners.current.get(listener)) == null ? void 0 : _globalListeners$curr.fn) || listener;
|
|
644
|
-
eventTarget.removeEventListener(type, fn, options);
|
|
645
|
-
globalListeners.current.delete(listener);
|
|
646
|
-
}, []);
|
|
647
|
-
let removeAllGlobalListeners = useCallback(() => {
|
|
648
|
-
globalListeners.current.forEach((value, key) => {
|
|
649
|
-
removeGlobalListener(value.eventTarget, value.type, key, value.options);
|
|
650
|
-
});
|
|
651
|
-
}, [removeGlobalListener]); // eslint-disable-next-line arrow-body-style
|
|
652
|
-
|
|
653
|
-
useEffect(() => {
|
|
654
|
-
return removeAllGlobalListeners;
|
|
655
|
-
}, [removeAllGlobalListeners]);
|
|
656
|
-
return {
|
|
657
|
-
addGlobalListener,
|
|
658
|
-
removeGlobalListener,
|
|
659
|
-
removeAllGlobalListeners
|
|
660
|
-
};
|
|
661
|
-
}
|
|
662
522
|
|
|
663
|
-
exports
|
|
523
|
+
var $658832d06264448f$exports = {};
|
|
664
524
|
|
|
665
|
-
|
|
666
|
-
* Merges aria-label and aria-labelledby into aria-labelledby when both exist.
|
|
667
|
-
* @param props - Aria label props.
|
|
668
|
-
* @param defaultLabel - Default value for aria-label when not present.
|
|
669
|
-
*/
|
|
670
|
-
function useLabels(props, defaultLabel) {
|
|
671
|
-
let {
|
|
672
|
-
id,
|
|
673
|
-
'aria-label': label,
|
|
674
|
-
'aria-labelledby': labelledBy
|
|
675
|
-
} = props; // If there is both an aria-label and aria-labelledby,
|
|
676
|
-
// combine them by pointing to the element itself.
|
|
677
|
-
|
|
678
|
-
id = useId(id);
|
|
679
|
-
|
|
680
|
-
if (labelledBy && label) {
|
|
681
|
-
let ids = new Set([...labelledBy.trim().split(/\s+/), id]);
|
|
682
|
-
labelledBy = [...ids].join(' ');
|
|
683
|
-
} else if (labelledBy) {
|
|
684
|
-
labelledBy = labelledBy.trim().split(/\s+/).join(' ');
|
|
685
|
-
} // If no labels are provided, use the default
|
|
686
|
-
|
|
687
|
-
|
|
688
|
-
if (!label && !labelledBy && defaultLabel) {
|
|
689
|
-
label = defaultLabel;
|
|
690
|
-
}
|
|
691
|
-
|
|
692
|
-
return {
|
|
693
|
-
id,
|
|
694
|
-
'aria-label': label,
|
|
695
|
-
'aria-labelledby': labelledBy
|
|
696
|
-
};
|
|
697
|
-
}
|
|
525
|
+
$parcel$export($658832d06264448f$exports, "useObjectRef", () => $658832d06264448f$export$4338b53315abf666);
|
|
698
526
|
|
|
699
|
-
exports.useLabels = useLabels;
|
|
700
527
|
|
|
701
|
-
|
|
702
|
-
|
|
703
|
-
|
|
704
|
-
* React Aria Hooks.
|
|
705
|
-
*
|
|
706
|
-
* @param forwardedRef The original ref intended to be used.
|
|
707
|
-
* @returns An object ref that updates the given ref.
|
|
708
|
-
* @see https://reactjs.org/docs/forwarding-refs.html
|
|
709
|
-
*/
|
|
710
|
-
function useObjectRef(forwardedRef) {
|
|
711
|
-
const objRef = useRef();
|
|
712
|
-
/**
|
|
528
|
+
function $658832d06264448f$export$4338b53315abf666(forwardedRef) {
|
|
529
|
+
const objRef = $gqa0x$react.useRef();
|
|
530
|
+
/**
|
|
713
531
|
* We're using `useLayoutEffect` here instead of `useEffect` because we want
|
|
714
532
|
* to make sure that the `ref` value is up to date before other places in the
|
|
715
533
|
* the execution cycle try to read it.
|
|
716
|
-
*/
|
|
717
|
-
|
|
718
|
-
|
|
719
|
-
|
|
720
|
-
|
|
721
|
-
|
|
722
|
-
|
|
723
|
-
|
|
724
|
-
|
|
725
|
-
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
732
|
-
|
|
733
|
-
|
|
734
|
-
|
|
735
|
-
|
|
736
|
-
|
|
737
|
-
|
|
738
|
-
|
|
739
|
-
|
|
740
|
-
|
|
741
|
-
|
|
742
|
-
|
|
743
|
-
|
|
744
|
-
|
|
745
|
-
|
|
746
|
-
|
|
747
|
-
|
|
748
|
-
|
|
749
|
-
function $
|
|
750
|
-
|
|
534
|
+
*/ $565383b8cde869dd$export$e5c5a5f917a5871c(()=>{
|
|
535
|
+
if (!forwardedRef) return;
|
|
536
|
+
if (typeof forwardedRef === 'function') forwardedRef(objRef.current);
|
|
537
|
+
else forwardedRef.current = objRef.current;
|
|
538
|
+
}, [
|
|
539
|
+
forwardedRef
|
|
540
|
+
]);
|
|
541
|
+
return objRef;
|
|
542
|
+
}
|
|
543
|
+
|
|
544
|
+
|
|
545
|
+
var $5f37a52ce85585dd$exports = {};
|
|
546
|
+
|
|
547
|
+
$parcel$export($5f37a52ce85585dd$exports, "useUpdateEffect", () => $5f37a52ce85585dd$export$496315a1608d9602);
|
|
548
|
+
|
|
549
|
+
function $5f37a52ce85585dd$export$496315a1608d9602(effect, dependencies) {
|
|
550
|
+
const isInitialMount = $gqa0x$react.useRef(true);
|
|
551
|
+
$gqa0x$react.useEffect(()=>{
|
|
552
|
+
if (isInitialMount.current) isInitialMount.current = false;
|
|
553
|
+
else effect();
|
|
554
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
555
|
+
}, dependencies);
|
|
556
|
+
}
|
|
557
|
+
|
|
558
|
+
|
|
559
|
+
|
|
560
|
+
var $3599a41724a37362$exports = {};
|
|
561
|
+
|
|
562
|
+
$parcel$export($3599a41724a37362$exports, "useResizeObserver", () => $3599a41724a37362$export$683480f191c0e3ea);
|
|
563
|
+
|
|
564
|
+
function $3599a41724a37362$var$hasResizeObserver() {
|
|
565
|
+
return typeof window.ResizeObserver !== 'undefined';
|
|
566
|
+
}
|
|
567
|
+
function $3599a41724a37362$export$683480f191c0e3ea(options) {
|
|
568
|
+
const { ref: ref , onResize: onResize } = options;
|
|
569
|
+
$gqa0x$react.useEffect(()=>{
|
|
570
|
+
let element = ref?.current;
|
|
571
|
+
if (!element) return;
|
|
572
|
+
if (!$3599a41724a37362$var$hasResizeObserver()) {
|
|
573
|
+
window.addEventListener('resize', onResize, false);
|
|
574
|
+
return ()=>{
|
|
575
|
+
window.removeEventListener('resize', onResize, false);
|
|
576
|
+
};
|
|
577
|
+
} else {
|
|
578
|
+
const resizeObserverInstance = new window.ResizeObserver((entries)=>{
|
|
579
|
+
if (!entries.length) return;
|
|
580
|
+
onResize();
|
|
581
|
+
});
|
|
582
|
+
resizeObserverInstance.observe(element);
|
|
583
|
+
return ()=>{
|
|
584
|
+
if (element) resizeObserverInstance.unobserve(element);
|
|
585
|
+
};
|
|
586
|
+
}
|
|
587
|
+
}, [
|
|
588
|
+
onResize,
|
|
589
|
+
ref
|
|
590
|
+
]);
|
|
751
591
|
}
|
|
752
592
|
|
|
753
|
-
function useResizeObserver(options) {
|
|
754
|
-
const {
|
|
755
|
-
ref,
|
|
756
|
-
onResize
|
|
757
|
-
} = options;
|
|
758
|
-
useEffect(() => {
|
|
759
|
-
let element = ref == null ? void 0 : ref.current;
|
|
760
593
|
|
|
761
|
-
|
|
762
|
-
return;
|
|
763
|
-
}
|
|
594
|
+
var $c5073b0bf61d031a$exports = {};
|
|
764
595
|
|
|
765
|
-
|
|
766
|
-
window.addEventListener('resize', onResize, false);
|
|
767
|
-
return () => {
|
|
768
|
-
window.removeEventListener('resize', onResize, false);
|
|
769
|
-
};
|
|
770
|
-
} else {
|
|
771
|
-
const resizeObserverInstance = new window.ResizeObserver(entries => {
|
|
772
|
-
if (!entries.length) {
|
|
773
|
-
return;
|
|
774
|
-
}
|
|
596
|
+
$parcel$export($c5073b0bf61d031a$exports, "useSyncRef", () => $c5073b0bf61d031a$export$4debdb1a3f0fa79e);
|
|
775
597
|
|
|
776
|
-
|
|
777
|
-
|
|
778
|
-
|
|
779
|
-
|
|
780
|
-
|
|
781
|
-
|
|
598
|
+
function $c5073b0bf61d031a$export$4debdb1a3f0fa79e(context, ref) {
|
|
599
|
+
$565383b8cde869dd$export$e5c5a5f917a5871c(()=>{
|
|
600
|
+
if (context && context.ref && ref) {
|
|
601
|
+
context.ref.current = ref.current;
|
|
602
|
+
return ()=>{
|
|
603
|
+
context.ref.current = null;
|
|
604
|
+
};
|
|
782
605
|
}
|
|
783
|
-
|
|
784
|
-
|
|
785
|
-
|
|
786
|
-
|
|
787
|
-
|
|
788
|
-
exports.useResizeObserver = useResizeObserver;
|
|
789
|
-
|
|
790
|
-
// Syncs ref from context with ref passed to hook
|
|
791
|
-
function useSyncRef(context, ref) {
|
|
792
|
-
useLayoutEffect(() => {
|
|
793
|
-
if (context && context.ref && ref) {
|
|
794
|
-
context.ref.current = ref.current;
|
|
795
|
-
return () => {
|
|
796
|
-
context.ref.current = null;
|
|
797
|
-
};
|
|
798
|
-
}
|
|
799
|
-
}, [context, ref]);
|
|
606
|
+
}, [
|
|
607
|
+
context,
|
|
608
|
+
ref
|
|
609
|
+
]);
|
|
800
610
|
}
|
|
801
611
|
|
|
802
|
-
exports.useSyncRef = useSyncRef;
|
|
803
612
|
|
|
804
|
-
|
|
805
|
-
while (node && !$e9be933e81f272fbb0513fcc706c7$var$isScrollable(node)) {
|
|
806
|
-
node = node.parentElement;
|
|
807
|
-
}
|
|
613
|
+
var $56cba3ac4ebbec36$exports = {};
|
|
808
614
|
|
|
809
|
-
|
|
615
|
+
$parcel$export($56cba3ac4ebbec36$exports, "getScrollParent", () => $56cba3ac4ebbec36$export$cfa2225e87938781);
|
|
616
|
+
function $56cba3ac4ebbec36$export$cfa2225e87938781(node) {
|
|
617
|
+
while(node && !$56cba3ac4ebbec36$var$isScrollable(node))node = node.parentElement;
|
|
618
|
+
return node || document.scrollingElement || document.documentElement;
|
|
810
619
|
}
|
|
811
|
-
|
|
812
|
-
|
|
813
|
-
|
|
814
|
-
function $e9be933e81f272fbb0513fcc706c7$var$isScrollable(node) {
|
|
815
|
-
let style = window.getComputedStyle(node);
|
|
816
|
-
return /(auto|scroll)/.test(style.overflow + style.overflowX + style.overflowY);
|
|
620
|
+
function $56cba3ac4ebbec36$var$isScrollable(node) {
|
|
621
|
+
let style = window.getComputedStyle(node);
|
|
622
|
+
return /(auto|scroll)/.test(style.overflow + style.overflowX + style.overflowY);
|
|
817
623
|
}
|
|
818
624
|
|
|
819
|
-
// @ts-ignore
|
|
820
|
-
let $f1a92c0e19f2e1ad09851454bf93009$var$visualViewport = typeof window !== 'undefined' && window.visualViewport;
|
|
821
|
-
|
|
822
|
-
function useViewportSize() {
|
|
823
|
-
let [size, setSize] = useState(() => $f1a92c0e19f2e1ad09851454bf93009$var$getViewportSize());
|
|
824
|
-
useEffect(() => {
|
|
825
|
-
// Use visualViewport api to track available height even on iOS virtual keyboard opening
|
|
826
|
-
let onResize = () => {
|
|
827
|
-
setSize(size => {
|
|
828
|
-
let newSize = $f1a92c0e19f2e1ad09851454bf93009$var$getViewportSize();
|
|
829
|
-
|
|
830
|
-
if (newSize.width === size.width && newSize.height === size.height) {
|
|
831
|
-
return size;
|
|
832
|
-
}
|
|
833
625
|
|
|
834
|
-
|
|
835
|
-
});
|
|
836
|
-
};
|
|
626
|
+
var $eda1f9b13ac03ccc$exports = {};
|
|
837
627
|
|
|
838
|
-
|
|
839
|
-
window.addEventListener('resize', onResize);
|
|
840
|
-
} else {
|
|
841
|
-
$f1a92c0e19f2e1ad09851454bf93009$var$visualViewport.addEventListener('resize', onResize);
|
|
842
|
-
}
|
|
628
|
+
$parcel$export($eda1f9b13ac03ccc$exports, "useViewportSize", () => $eda1f9b13ac03ccc$export$d699905dd57c73ca);
|
|
843
629
|
|
|
844
|
-
|
|
845
|
-
|
|
846
|
-
|
|
847
|
-
|
|
848
|
-
|
|
849
|
-
|
|
630
|
+
// @ts-ignore
|
|
631
|
+
let $eda1f9b13ac03ccc$var$visualViewport = typeof window !== 'undefined' && window.visualViewport;
|
|
632
|
+
function $eda1f9b13ac03ccc$export$d699905dd57c73ca() {
|
|
633
|
+
let [size1, setSize] = $gqa0x$react.useState(()=>$eda1f9b13ac03ccc$var$getViewportSize()
|
|
634
|
+
);
|
|
635
|
+
$gqa0x$react.useEffect(()=>{
|
|
636
|
+
// Use visualViewport api to track available height even on iOS virtual keyboard opening
|
|
637
|
+
let onResize = ()=>{
|
|
638
|
+
setSize((size)=>{
|
|
639
|
+
let newSize = $eda1f9b13ac03ccc$var$getViewportSize();
|
|
640
|
+
if (newSize.width === size.width && newSize.height === size.height) return size;
|
|
641
|
+
return newSize;
|
|
642
|
+
});
|
|
643
|
+
};
|
|
644
|
+
if (!$eda1f9b13ac03ccc$var$visualViewport) window.addEventListener('resize', onResize);
|
|
645
|
+
else $eda1f9b13ac03ccc$var$visualViewport.addEventListener('resize', onResize);
|
|
646
|
+
return ()=>{
|
|
647
|
+
if (!$eda1f9b13ac03ccc$var$visualViewport) window.removeEventListener('resize', onResize);
|
|
648
|
+
else $eda1f9b13ac03ccc$var$visualViewport.removeEventListener('resize', onResize);
|
|
649
|
+
};
|
|
650
|
+
}, []);
|
|
651
|
+
return size1;
|
|
652
|
+
}
|
|
653
|
+
function $eda1f9b13ac03ccc$var$getViewportSize() {
|
|
654
|
+
return {
|
|
655
|
+
width: $eda1f9b13ac03ccc$var$visualViewport?.width || window.innerWidth,
|
|
656
|
+
height: $eda1f9b13ac03ccc$var$visualViewport?.height || window.innerHeight
|
|
850
657
|
};
|
|
851
|
-
}, []);
|
|
852
|
-
return size;
|
|
853
658
|
}
|
|
854
659
|
|
|
855
|
-
exports.useViewportSize = useViewportSize;
|
|
856
|
-
|
|
857
|
-
function $f1a92c0e19f2e1ad09851454bf93009$var$getViewportSize() {
|
|
858
|
-
return {
|
|
859
|
-
width: ($f1a92c0e19f2e1ad09851454bf93009$var$visualViewport == null ? void 0 : $f1a92c0e19f2e1ad09851454bf93009$var$visualViewport.width) || window.innerWidth,
|
|
860
|
-
height: ($f1a92c0e19f2e1ad09851454bf93009$var$visualViewport == null ? void 0 : $f1a92c0e19f2e1ad09851454bf93009$var$visualViewport.height) || window.innerHeight
|
|
861
|
-
};
|
|
862
|
-
}
|
|
863
660
|
|
|
864
|
-
|
|
865
|
-
|
|
866
|
-
|
|
867
|
-
|
|
868
|
-
|
|
869
|
-
|
|
870
|
-
|
|
871
|
-
|
|
872
|
-
|
|
873
|
-
|
|
874
|
-
|
|
875
|
-
|
|
876
|
-
|
|
877
|
-
|
|
878
|
-
|
|
879
|
-
|
|
880
|
-
|
|
881
|
-
|
|
882
|
-
|
|
883
|
-
|
|
884
|
-
|
|
885
|
-
|
|
886
|
-
|
|
887
|
-
|
|
888
|
-
|
|
889
|
-
|
|
890
|
-
|
|
891
|
-
|
|
892
|
-
|
|
893
|
-
|
|
894
|
-
|
|
895
|
-
|
|
896
|
-
|
|
897
|
-
|
|
898
|
-
|
|
661
|
+
var $fc64a6f8ffc8f0f9$exports = {};
|
|
662
|
+
|
|
663
|
+
$parcel$export($fc64a6f8ffc8f0f9$exports, "useDescription", () => $fc64a6f8ffc8f0f9$export$f8aeda7b10753fa1);
|
|
664
|
+
|
|
665
|
+
|
|
666
|
+
let $fc64a6f8ffc8f0f9$var$descriptionId = 0;
|
|
667
|
+
const $fc64a6f8ffc8f0f9$var$descriptionNodes = new Map();
|
|
668
|
+
function $fc64a6f8ffc8f0f9$export$f8aeda7b10753fa1(description) {
|
|
669
|
+
let [id1, setId] = $gqa0x$react.useState(null);
|
|
670
|
+
$565383b8cde869dd$export$e5c5a5f917a5871c(()=>{
|
|
671
|
+
if (!description) return;
|
|
672
|
+
let desc = $fc64a6f8ffc8f0f9$var$descriptionNodes.get(description);
|
|
673
|
+
if (!desc) {
|
|
674
|
+
let id = `react-aria-description-${$fc64a6f8ffc8f0f9$var$descriptionId++}`;
|
|
675
|
+
setId(id);
|
|
676
|
+
let node = document.createElement('div');
|
|
677
|
+
node.id = id;
|
|
678
|
+
node.style.display = 'none';
|
|
679
|
+
node.textContent = description;
|
|
680
|
+
document.body.appendChild(node);
|
|
681
|
+
desc = {
|
|
682
|
+
refCount: 0,
|
|
683
|
+
element: node
|
|
684
|
+
};
|
|
685
|
+
$fc64a6f8ffc8f0f9$var$descriptionNodes.set(description, desc);
|
|
686
|
+
} else setId(desc.element.id);
|
|
687
|
+
desc.refCount++;
|
|
688
|
+
return ()=>{
|
|
689
|
+
if (--desc.refCount === 0) {
|
|
690
|
+
desc.element.remove();
|
|
691
|
+
$fc64a6f8ffc8f0f9$var$descriptionNodes.delete(description);
|
|
692
|
+
}
|
|
693
|
+
};
|
|
694
|
+
}, [
|
|
695
|
+
description
|
|
696
|
+
]);
|
|
697
|
+
return {
|
|
698
|
+
'aria-describedby': description ? id1 : undefined
|
|
899
699
|
};
|
|
900
|
-
}, [description]);
|
|
901
|
-
return {
|
|
902
|
-
'aria-describedby': description ? id : undefined
|
|
903
|
-
};
|
|
904
700
|
}
|
|
905
701
|
|
|
906
|
-
exports.useDescription = useDescription;
|
|
907
702
|
|
|
908
|
-
|
|
909
|
-
return typeof window !== 'undefined' && window.navigator != null ? re.test(window.navigator.userAgent) : false;
|
|
910
|
-
}
|
|
703
|
+
var $8dce0acd60edf5c8$exports = {};
|
|
911
704
|
|
|
912
|
-
|
|
913
|
-
|
|
705
|
+
$parcel$export($8dce0acd60edf5c8$exports, "isMac", () => $8dce0acd60edf5c8$export$9ac100e40613ea10);
|
|
706
|
+
$parcel$export($8dce0acd60edf5c8$exports, "isIPhone", () => $8dce0acd60edf5c8$export$186c6964ca17d99);
|
|
707
|
+
$parcel$export($8dce0acd60edf5c8$exports, "isIPad", () => $8dce0acd60edf5c8$export$7bef049ce92e4224);
|
|
708
|
+
$parcel$export($8dce0acd60edf5c8$exports, "isIOS", () => $8dce0acd60edf5c8$export$fedb369cb70207f1);
|
|
709
|
+
$parcel$export($8dce0acd60edf5c8$exports, "isAppleDevice", () => $8dce0acd60edf5c8$export$e1865c3bedcd822b);
|
|
710
|
+
$parcel$export($8dce0acd60edf5c8$exports, "isWebKit", () => $8dce0acd60edf5c8$export$78551043582a6a98);
|
|
711
|
+
$parcel$export($8dce0acd60edf5c8$exports, "isChrome", () => $8dce0acd60edf5c8$export$6446a186d09e379e);
|
|
712
|
+
$parcel$export($8dce0acd60edf5c8$exports, "isAndroid", () => $8dce0acd60edf5c8$export$a11b0059900ceec8);
|
|
713
|
+
/*
|
|
714
|
+
* Copyright 2020 Adobe. All rights reserved.
|
|
715
|
+
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
|
|
716
|
+
* you may not use this file except in compliance with the License. You may obtain a copy
|
|
717
|
+
* of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
718
|
+
*
|
|
719
|
+
* Unless required by applicable law or agreed to in writing, software distributed under
|
|
720
|
+
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
|
|
721
|
+
* OF ANY KIND, either express or implied. See the License for the specific language
|
|
722
|
+
* governing permissions and limitations under the License.
|
|
723
|
+
*/ function $8dce0acd60edf5c8$var$testUserAgent(re) {
|
|
724
|
+
return typeof window !== 'undefined' && window.navigator != null ? re.test(window.navigator.userAgent) : false;
|
|
914
725
|
}
|
|
915
|
-
|
|
916
|
-
|
|
917
|
-
return $ffc9ede5fda79bf280c1bec834e32f$var$testPlatform(/^Mac/);
|
|
726
|
+
function $8dce0acd60edf5c8$var$testPlatform(re) {
|
|
727
|
+
return typeof window !== 'undefined' && window.navigator != null ? re.test(window.navigator.platform) : false;
|
|
918
728
|
}
|
|
919
|
-
|
|
920
|
-
|
|
921
|
-
|
|
922
|
-
function isIPhone() {
|
|
923
|
-
return $ffc9ede5fda79bf280c1bec834e32f$var$testPlatform(/^iPhone/);
|
|
729
|
+
function $8dce0acd60edf5c8$export$9ac100e40613ea10() {
|
|
730
|
+
return $8dce0acd60edf5c8$var$testPlatform(/^Mac/);
|
|
924
731
|
}
|
|
925
|
-
|
|
926
|
-
|
|
927
|
-
|
|
928
|
-
function isIPad() {
|
|
929
|
-
return $ffc9ede5fda79bf280c1bec834e32f$var$testPlatform(/^iPad/) || // iPadOS 13 lies and says it's a Mac, but we can distinguish by detecting touch support.
|
|
930
|
-
isMac() && navigator.maxTouchPoints > 1;
|
|
732
|
+
function $8dce0acd60edf5c8$export$186c6964ca17d99() {
|
|
733
|
+
return $8dce0acd60edf5c8$var$testPlatform(/^iPhone/);
|
|
931
734
|
}
|
|
932
|
-
|
|
933
|
-
|
|
934
|
-
|
|
935
|
-
function isIOS() {
|
|
936
|
-
return isIPhone() || isIPad();
|
|
735
|
+
function $8dce0acd60edf5c8$export$7bef049ce92e4224() {
|
|
736
|
+
return $8dce0acd60edf5c8$var$testPlatform(/^iPad/) || $8dce0acd60edf5c8$export$9ac100e40613ea10() && navigator.maxTouchPoints > 1;
|
|
937
737
|
}
|
|
938
|
-
|
|
939
|
-
|
|
940
|
-
|
|
941
|
-
function isAppleDevice() {
|
|
942
|
-
return isMac() || isIOS();
|
|
738
|
+
function $8dce0acd60edf5c8$export$fedb369cb70207f1() {
|
|
739
|
+
return $8dce0acd60edf5c8$export$186c6964ca17d99() || $8dce0acd60edf5c8$export$7bef049ce92e4224();
|
|
943
740
|
}
|
|
944
|
-
|
|
945
|
-
|
|
946
|
-
|
|
947
|
-
function isWebKit() {
|
|
948
|
-
return $ffc9ede5fda79bf280c1bec834e32f$var$testUserAgent(/AppleWebKit/) && !isChrome();
|
|
741
|
+
function $8dce0acd60edf5c8$export$e1865c3bedcd822b() {
|
|
742
|
+
return $8dce0acd60edf5c8$export$9ac100e40613ea10() || $8dce0acd60edf5c8$export$fedb369cb70207f1();
|
|
949
743
|
}
|
|
950
|
-
|
|
951
|
-
|
|
952
|
-
|
|
953
|
-
function isChrome() {
|
|
954
|
-
return $ffc9ede5fda79bf280c1bec834e32f$var$testUserAgent(/Chrome/);
|
|
744
|
+
function $8dce0acd60edf5c8$export$78551043582a6a98() {
|
|
745
|
+
return $8dce0acd60edf5c8$var$testUserAgent(/AppleWebKit/) && !$8dce0acd60edf5c8$export$6446a186d09e379e();
|
|
955
746
|
}
|
|
956
|
-
|
|
957
|
-
|
|
958
|
-
|
|
959
|
-
function
|
|
960
|
-
|
|
747
|
+
function $8dce0acd60edf5c8$export$6446a186d09e379e() {
|
|
748
|
+
return $8dce0acd60edf5c8$var$testUserAgent(/Chrome/);
|
|
749
|
+
}
|
|
750
|
+
function $8dce0acd60edf5c8$export$a11b0059900ceec8() {
|
|
751
|
+
return $8dce0acd60edf5c8$var$testUserAgent(/Android/);
|
|
961
752
|
}
|
|
962
753
|
|
|
963
|
-
exports.isAndroid = isAndroid;
|
|
964
|
-
|
|
965
|
-
function useEvent(ref, event, handler, options) {
|
|
966
|
-
let handlerRef = useRef(handler);
|
|
967
|
-
handlerRef.current = handler;
|
|
968
|
-
let isDisabled = handler == null;
|
|
969
|
-
useEffect(() => {
|
|
970
|
-
if (isDisabled) {
|
|
971
|
-
return;
|
|
972
|
-
}
|
|
973
754
|
|
|
974
|
-
|
|
755
|
+
var $bc4cfb54fe7e6088$exports = {};
|
|
975
756
|
|
|
976
|
-
|
|
757
|
+
$parcel$export($bc4cfb54fe7e6088$exports, "useEvent", () => $bc4cfb54fe7e6088$export$90fc3a17d93f704c);
|
|
977
758
|
|
|
978
|
-
|
|
979
|
-
|
|
980
|
-
|
|
981
|
-
|
|
982
|
-
|
|
759
|
+
function $bc4cfb54fe7e6088$export$90fc3a17d93f704c(ref, event, handler1, options) {
|
|
760
|
+
let handlerRef = $gqa0x$react.useRef(handler1);
|
|
761
|
+
handlerRef.current = handler1;
|
|
762
|
+
let isDisabled = handler1 == null;
|
|
763
|
+
$gqa0x$react.useEffect(()=>{
|
|
764
|
+
if (isDisabled) return;
|
|
765
|
+
let element = ref.current;
|
|
766
|
+
let handler = (e)=>handlerRef.current.call(this, e)
|
|
767
|
+
;
|
|
768
|
+
element.addEventListener(event, handler, options);
|
|
769
|
+
return ()=>{
|
|
770
|
+
element.removeEventListener(event, handler, options);
|
|
771
|
+
};
|
|
772
|
+
}, [
|
|
773
|
+
ref,
|
|
774
|
+
event,
|
|
775
|
+
options,
|
|
776
|
+
isDisabled
|
|
777
|
+
]);
|
|
983
778
|
}
|
|
984
779
|
|
|
985
|
-
exports.useEvent = useEvent;
|
|
986
780
|
|
|
987
|
-
|
|
988
|
-
// that can yield multiple values. Each yielded value updates the state and waits for the next
|
|
989
|
-
// layout effect, then continues the generator. This allows sequential updates to state to be
|
|
990
|
-
// written linearly.
|
|
991
|
-
function useValueEffect(defaultValue) {
|
|
992
|
-
let [value, setValue] = useState(defaultValue);
|
|
993
|
-
let valueRef = useRef(value);
|
|
994
|
-
let effect = useRef(null);
|
|
995
|
-
valueRef.current = value; // Store the function in a ref so we can always access the current version
|
|
996
|
-
// which has the proper `value` in scope.
|
|
781
|
+
var $789b9514fd01258b$exports = {};
|
|
997
782
|
|
|
998
|
-
|
|
783
|
+
$parcel$export($789b9514fd01258b$exports, "useValueEffect", () => $789b9514fd01258b$export$14d238f342723f25);
|
|
999
784
|
|
|
1000
|
-
nextRef.current = () => {
|
|
1001
|
-
// Run the generator to the next yield.
|
|
1002
|
-
let newValue = effect.current.next(); // If the generator is done, reset the effect.
|
|
1003
785
|
|
|
1004
|
-
|
|
1005
|
-
|
|
1006
|
-
|
|
1007
|
-
|
|
1008
|
-
|
|
1009
|
-
//
|
|
1010
|
-
|
|
1011
|
-
|
|
1012
|
-
|
|
1013
|
-
|
|
1014
|
-
|
|
1015
|
-
|
|
1016
|
-
|
|
1017
|
-
|
|
1018
|
-
|
|
1019
|
-
|
|
1020
|
-
|
|
1021
|
-
|
|
1022
|
-
|
|
1023
|
-
|
|
1024
|
-
|
|
1025
|
-
|
|
1026
|
-
|
|
1027
|
-
|
|
1028
|
-
|
|
1029
|
-
|
|
1030
|
-
|
|
1031
|
-
|
|
1032
|
-
|
|
1033
|
-
|
|
1034
|
-
|
|
1035
|
-
|
|
1036
|
-
|
|
1037
|
-
|
|
1038
|
-
|
|
1039
|
-
|
|
1040
|
-
|
|
1041
|
-
|
|
1042
|
-
|
|
1043
|
-
|
|
1044
|
-
|
|
1045
|
-
|
|
1046
|
-
|
|
1047
|
-
|
|
1048
|
-
|
|
1049
|
-
|
|
1050
|
-
|
|
1051
|
-
|
|
1052
|
-
|
|
1053
|
-
y
|
|
1054
|
-
|
|
1055
|
-
|
|
1056
|
-
|
|
1057
|
-
|
|
786
|
+
function $789b9514fd01258b$export$14d238f342723f25(defaultValue) {
|
|
787
|
+
let [value, setValue] = $gqa0x$react.useState(defaultValue);
|
|
788
|
+
let valueRef = $gqa0x$react.useRef(value);
|
|
789
|
+
let effect = $gqa0x$react.useRef(null);
|
|
790
|
+
valueRef.current = value;
|
|
791
|
+
// Store the function in a ref so we can always access the current version
|
|
792
|
+
// which has the proper `value` in scope.
|
|
793
|
+
let nextRef = $gqa0x$react.useRef(null);
|
|
794
|
+
nextRef.current = ()=>{
|
|
795
|
+
// Run the generator to the next yield.
|
|
796
|
+
let newValue = effect.current.next();
|
|
797
|
+
// If the generator is done, reset the effect.
|
|
798
|
+
if (newValue.done) {
|
|
799
|
+
effect.current = null;
|
|
800
|
+
return;
|
|
801
|
+
}
|
|
802
|
+
// If the value is the same as the current value,
|
|
803
|
+
// then continue to the next yield. Otherwise,
|
|
804
|
+
// set the value in state and wait for the next layout effect.
|
|
805
|
+
if (value === newValue.value) nextRef.current();
|
|
806
|
+
else setValue(newValue.value);
|
|
807
|
+
};
|
|
808
|
+
$565383b8cde869dd$export$e5c5a5f917a5871c(()=>{
|
|
809
|
+
// If there is an effect currently running, continue to the next yield.
|
|
810
|
+
if (effect.current) nextRef.current();
|
|
811
|
+
});
|
|
812
|
+
let queue = $gqa0x$react.useCallback((fn)=>{
|
|
813
|
+
effect.current = fn(valueRef.current);
|
|
814
|
+
nextRef.current();
|
|
815
|
+
}, [
|
|
816
|
+
effect,
|
|
817
|
+
nextRef
|
|
818
|
+
]);
|
|
819
|
+
return [
|
|
820
|
+
value,
|
|
821
|
+
queue
|
|
822
|
+
];
|
|
823
|
+
}
|
|
824
|
+
|
|
825
|
+
|
|
826
|
+
var $c5c390447fdbf212$exports = {};
|
|
827
|
+
|
|
828
|
+
$parcel$export($c5c390447fdbf212$exports, "scrollIntoView", () => $c5c390447fdbf212$export$53a0910f038337bd);
|
|
829
|
+
function $c5c390447fdbf212$export$53a0910f038337bd(scrollView, element) {
|
|
830
|
+
let offsetX = $c5c390447fdbf212$var$relativeOffset(scrollView, element, 'left');
|
|
831
|
+
let offsetY = $c5c390447fdbf212$var$relativeOffset(scrollView, element, 'top');
|
|
832
|
+
let width = element.offsetWidth;
|
|
833
|
+
let height = element.offsetHeight;
|
|
834
|
+
let x = scrollView.scrollLeft;
|
|
835
|
+
let y = scrollView.scrollTop;
|
|
836
|
+
let maxX = x + scrollView.offsetWidth;
|
|
837
|
+
let maxY = y + scrollView.offsetHeight;
|
|
838
|
+
if (offsetX <= x) x = offsetX;
|
|
839
|
+
else if (offsetX + width > maxX) x += offsetX + width - maxX;
|
|
840
|
+
if (offsetY <= y) y = offsetY;
|
|
841
|
+
else if (offsetY + height > maxY) y += offsetY + height - maxY;
|
|
842
|
+
scrollView.scrollLeft = x;
|
|
843
|
+
scrollView.scrollTop = y;
|
|
1058
844
|
}
|
|
1059
845
|
/**
|
|
1060
846
|
* Computes the offset left or top from child to ancestor by accumulating
|
|
1061
847
|
* offsetLeft or offsetTop through intervening offsetParents.
|
|
1062
|
-
*/
|
|
1063
|
-
|
|
1064
|
-
|
|
1065
|
-
|
|
1066
|
-
|
|
1067
|
-
|
|
1068
|
-
|
|
1069
|
-
|
|
1070
|
-
|
|
1071
|
-
|
|
1072
|
-
|
|
1073
|
-
|
|
1074
|
-
|
|
1075
|
-
|
|
1076
|
-
|
|
1077
|
-
|
|
1078
|
-
|
|
1079
|
-
|
|
1080
|
-
|
|
1081
|
-
|
|
1082
|
-
|
|
1083
|
-
|
|
848
|
+
*/ function $c5c390447fdbf212$var$relativeOffset(ancestor, child, axis) {
|
|
849
|
+
const prop = axis === 'left' ? 'offsetLeft' : 'offsetTop';
|
|
850
|
+
let sum = 0;
|
|
851
|
+
while(child.offsetParent){
|
|
852
|
+
sum += child[prop];
|
|
853
|
+
if (child.offsetParent === ancestor) break;
|
|
854
|
+
else if (child.offsetParent.contains(ancestor)) {
|
|
855
|
+
// If the ancestor is not `position:relative`, then we stop at
|
|
856
|
+
// _its_ offset parent, and we subtract off _its_ offset, so that
|
|
857
|
+
// we end up with the proper offset from child to ancestor.
|
|
858
|
+
sum -= ancestor[prop];
|
|
859
|
+
break;
|
|
860
|
+
}
|
|
861
|
+
child = child.offsetParent;
|
|
862
|
+
}
|
|
863
|
+
return sum;
|
|
864
|
+
}
|
|
865
|
+
|
|
866
|
+
|
|
867
|
+
$parcel$exportWildcard(module.exports, $dd96e9bc07c5b25f$exports);
|
|
868
|
+
$parcel$exportWildcard(module.exports, $5172289b7a1cda90$exports);
|
|
869
|
+
$parcel$exportWildcard(module.exports, $ee1eca53264e4e21$exports);
|
|
870
|
+
$parcel$exportWildcard(module.exports, $2f71b7bbfef4ef86$exports);
|
|
871
|
+
$parcel$exportWildcard(module.exports, $448ba02dcac1c856$exports);
|
|
872
|
+
$parcel$exportWildcard(module.exports, $391ef47b89fbbdf8$exports);
|
|
873
|
+
$parcel$exportWildcard(module.exports, $c570a0a6fa1d588f$exports);
|
|
874
|
+
$parcel$exportWildcard(module.exports, $4da380280744869b$exports);
|
|
875
|
+
$parcel$exportWildcard(module.exports, $ca85cc095ee7bdf9$exports);
|
|
876
|
+
$parcel$exportWildcard(module.exports, $efa617098dfd7e72$exports);
|
|
877
|
+
$parcel$exportWildcard(module.exports, $e0460f7e24b931b0$exports);
|
|
878
|
+
$parcel$exportWildcard(module.exports, $658832d06264448f$exports);
|
|
879
|
+
$parcel$exportWildcard(module.exports, $5f37a52ce85585dd$exports);
|
|
880
|
+
$parcel$exportWildcard(module.exports, $565383b8cde869dd$exports);
|
|
881
|
+
$parcel$exportWildcard(module.exports, $3599a41724a37362$exports);
|
|
882
|
+
$parcel$exportWildcard(module.exports, $c5073b0bf61d031a$exports);
|
|
883
|
+
$parcel$exportWildcard(module.exports, $56cba3ac4ebbec36$exports);
|
|
884
|
+
$parcel$exportWildcard(module.exports, $eda1f9b13ac03ccc$exports);
|
|
885
|
+
$parcel$exportWildcard(module.exports, $fc64a6f8ffc8f0f9$exports);
|
|
886
|
+
$parcel$exportWildcard(module.exports, $8dce0acd60edf5c8$exports);
|
|
887
|
+
$parcel$exportWildcard(module.exports, $bc4cfb54fe7e6088$exports);
|
|
888
|
+
$parcel$exportWildcard(module.exports, $789b9514fd01258b$exports);
|
|
889
|
+
$parcel$exportWildcard(module.exports, $c5c390447fdbf212$exports);
|
|
1084
890
|
|
|
1085
|
-
child = child.offsetParent;
|
|
1086
|
-
}
|
|
1087
891
|
|
|
1088
|
-
return sum;
|
|
1089
|
-
}
|
|
1090
892
|
//# sourceMappingURL=main.js.map
|