@react-aria/utils 3.11.0 → 3.11.3

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 CHANGED
@@ -1,1090 +1,896 @@
1
- var {
2
- clamp,
3
- snapValueToStep
4
- } = require("@react-stately/utils");
5
-
6
- exports.snapValueToStep = snapValueToStep;
7
- exports.clamp = clamp;
8
-
9
- var _clsx = $parcel$interopDefault(require("clsx"));
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 $1Yh1N$react = require("react");
2
+ var $1Yh1N$reactariassr = require("@react-aria/ssr");
3
+ var $1Yh1N$clsx = require("clsx");
4
+ var $1Yh1N$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
- var {
22
- useCallback,
23
- useEffect,
24
- useRef,
25
- useState
26
- } = _react2;
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 $8c61827343eed941$exports = {};
31
29
 
32
- // During SSR, React emits a warning when calling useLayoutEffect.
33
- // Since neither useLayoutEffect nor useEffect run on the server,
34
- // we can suppress this by replace it with a noop on the server.
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($8c61827343eed941$exports, "useId", () => $8c61827343eed941$export$f680877a34711e37);
31
+ $parcel$export($8c61827343eed941$exports, "mergeIds", () => $8c61827343eed941$export$cd8c9cb68f842629);
32
+ $parcel$export($8c61827343eed941$exports, "useSlotId", () => $8c61827343eed941$export$b4cc09c592e8fdb8);
83
33
 
84
- exports.useId = useId;
34
+ var $78605a5d7424e31b$exports = {};
85
35
 
86
- function mergeIds(idA, idB) {
87
- if (idA === idB) {
88
- return idA;
89
- }
36
+ $parcel$export($78605a5d7424e31b$exports, "useLayoutEffect", () => $78605a5d7424e31b$export$e5c5a5f917a5871c);
90
37
 
91
- let setIdA = $f09fcd7f5f367fc80aacfeac62ed2$var$idsUpdaterMap.get(idA);
38
+ const $78605a5d7424e31b$export$e5c5a5f917a5871c = typeof window !== 'undefined' ? ($parcel$interopDefault($1Yh1N$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
- return idB;
44
+ let $8c61827343eed941$var$idsUpdaterMap = new Map();
45
+ function $8c61827343eed941$export$f680877a34711e37(defaultId) {
46
+ let isRendering = $1Yh1N$react.useRef(true);
47
+ isRendering.current = true;
48
+ let [value, setValue] = $1Yh1N$react.useState(defaultId);
49
+ let nextId = $1Yh1N$react.useRef(null);
50
+ let res = $1Yh1N$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
+ $8c61827343eed941$var$idsUpdaterMap.set(res, updateValue);
57
+ $78605a5d7424e31b$export$e5c5a5f917a5871c(()=>{
58
+ isRendering.current = false;
59
+ }, [
60
+ updateValue
61
+ ]);
62
+ $78605a5d7424e31b$export$e5c5a5f917a5871c(()=>{
63
+ let r = res;
64
+ return ()=>{
65
+ $8c61827343eed941$var$idsUpdaterMap.delete(r);
66
+ };
67
+ }, [
68
+ res
69
+ ]);
70
+ $1Yh1N$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 $8c61827343eed941$export$cd8c9cb68f842629(idA, idB) {
83
+ if (idA === idB) return idA;
84
+ let setIdA = $8c61827343eed941$var$idsUpdaterMap.get(idA);
85
+ if (setIdA) {
86
+ setIdA(idB);
87
+ return idB;
88
+ }
89
+ let setIdB = $8c61827343eed941$var$idsUpdaterMap.get(idB);
90
+ if (setIdB) {
91
+ setIdB(idA);
92
+ return idA;
93
+ }
94
+ return idB;
95
+ }
96
+ function $8c61827343eed941$export$b4cc09c592e8fdb8(depArray = []) {
97
+ let id = $8c61827343eed941$export$f680877a34711e37();
98
+ let [resolvedId, setResolvedId] = $19a2307bfabafaf1$export$14d238f342723f25(id);
99
+ let updateId = $1Yh1N$react.useCallback(()=>{
100
+ setResolvedId(function*() {
101
+ yield id;
102
+ yield document.getElementById(id) ? id : null;
103
+ });
104
+ }, [
105
+ id,
106
+ setResolvedId
107
+ ]);
108
+ $78605a5d7424e31b$export$e5c5a5f917a5871c(updateId, [
109
+ id,
110
+ updateId,
111
+ ...depArray
112
+ ]);
113
+ return resolvedId;
114
+ }
115
+
116
+
117
+ var $1e2191638e54f613$exports = {};
118
+
119
+ $parcel$export($1e2191638e54f613$exports, "chain", () => $1e2191638e54f613$export$e08e3b67e392101e);
120
+ function $1e2191638e54f613$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
- function useSlotId(depArray) {
117
- if (depArray === void 0) {
118
- depArray = [];
119
- }
127
+ var $f847cd1382ea7cd4$exports = {};
120
128
 
121
- let id = useId();
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($f847cd1382ea7cd4$exports, "mergeProps", () => $f847cd1382ea7cd4$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
- * Calls all functions in the order they were chained with the same arguments.
149
- */
150
- function chain() {
151
- for (var _len = arguments.length, callbacks = new Array(_len), _key = 0; _key < _len; _key++) {
152
- callbacks[_key] = arguments[_key];
153
- }
154
-
155
- return function () {
156
- for (let callback of callbacks) {
157
- if (typeof callback === 'function') {
158
- callback(...arguments);
159
- }
133
+ function $f847cd1382ea7cd4$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] = $1e2191638e54f613$export$e08e3b67e392101e(a, b);
147
+ else if ((key === 'className' || key === 'UNSAFE_className') && typeof a === 'string' && typeof b === 'string') result[key] = ($parcel$interopDefault($1Yh1N$clsx))(a, b);
148
+ else if (key === 'id' && a && b) result.id = $8c61827343eed941$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 $8d15d0e1797d4238$exports = {};
201
157
 
202
- return result;
158
+ $parcel$export($8d15d0e1797d4238$exports, "filterDOMProps", () => $8d15d0e1797d4238$export$457c3d6518dd4c6f);
159
+ const $8d15d0e1797d4238$var$DOMPropNames = new Set([
160
+ 'id'
161
+ ]);
162
+ const $8d15d0e1797d4238$var$labelablePropNames = new Set([
163
+ 'aria-label',
164
+ 'aria-labelledby',
165
+ 'aria-describedby',
166
+ 'aria-details'
167
+ ]);
168
+ const $8d15d0e1797d4238$var$propRe = /^(data-.*)$/;
169
+ function $8d15d0e1797d4238$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) && ($8d15d0e1797d4238$var$DOMPropNames.has(prop) || labelable && $8d15d0e1797d4238$var$labelablePropNames.has(prop) || (propNames === null || propNames === void 0 ? void 0 : propNames.has(prop)) || $8d15d0e1797d4238$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
- return filteredProps;
233
- }
179
+ var $1117b6c0d4c4c164$exports = {};
234
180
 
235
- exports.filterDOMProps = filterDOMProps;
236
-
237
- // Currently necessary for Safari and old Edge:
238
- // https://caniuse.com/#feat=mdn-api_htmlelement_focus_preventscroll_option
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($1117b6c0d4c4c164$exports, "focusWithoutScrolling", () => $1117b6c0d4c4c164$export$de79e2c695e052f3);
182
+ function $1117b6c0d4c4c164$export$de79e2c695e052f3(element) {
183
+ if ($1117b6c0d4c4c164$var$supportsPreventScroll()) element.focus({
184
+ preventScroll: true
248
185
  });
249
- } else {
250
- let scrollableElements = $d2a175ba498dd7834499f256dfb330bc$var$getScrollableElements(element);
251
- element.focus();
252
- $d2a175ba498dd7834499f256dfb330bc$var$restoreScrollPosition(scrollableElements);
253
- }
254
- }
255
-
256
- exports.focusWithoutScrolling = focusWithoutScrolling;
257
- let $d2a175ba498dd7834499f256dfb330bc$var$supportsPreventScrollCached = null;
258
-
259
- function $d2a175ba498dd7834499f256dfb330bc$var$supportsPreventScroll() {
260
- if ($d2a175ba498dd7834499f256dfb330bc$var$supportsPreventScrollCached == null) {
261
- $d2a175ba498dd7834499f256dfb330bc$var$supportsPreventScrollCached = false;
262
-
263
- try {
264
- var focusElem = document.createElement('div');
265
- focusElem.focus({
266
- get preventScroll() {
267
- $d2a175ba498dd7834499f256dfb330bc$var$supportsPreventScrollCached = true;
268
- return true;
186
+ else {
187
+ let scrollableElements = $1117b6c0d4c4c164$var$getScrollableElements(element);
188
+ element.focus();
189
+ $1117b6c0d4c4c164$var$restoreScrollPosition(scrollableElements);
190
+ }
191
+ }
192
+ let $1117b6c0d4c4c164$var$supportsPreventScrollCached = null;
193
+ function $1117b6c0d4c4c164$var$supportsPreventScroll() {
194
+ if ($1117b6c0d4c4c164$var$supportsPreventScrollCached == null) {
195
+ $1117b6c0d4c4c164$var$supportsPreventScrollCached = false;
196
+ try {
197
+ var focusElem = document.createElement('div');
198
+ focusElem.focus({
199
+ get preventScroll () {
200
+ $1117b6c0d4c4c164$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
- return $d2a175ba498dd7834499f256dfb330bc$var$supportsPreventScrollCached;
208
+ return $1117b6c0d4c4c164$var$supportsPreventScrollCached;
209
+ }
210
+ function $1117b6c0d4c4c164$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
- function $d2a175ba498dd7834499f256dfb330bc$var$getScrollableElements(element) {
280
- var parent = element.parentNode;
281
- var scrollableElements = [];
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 $1117b6c0d4c4c164$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
- if (rootScrollingElement instanceof HTMLElement) {
297
- scrollableElements.push({
298
- element: rootScrollingElement,
299
- scrollTop: rootScrollingElement.scrollTop,
300
- scrollLeft: rootScrollingElement.scrollLeft
301
- });
302
- }
237
+ var $16ec41ef3e36c19c$exports = {};
303
238
 
304
- return scrollableElements;
239
+ $parcel$export($16ec41ef3e36c19c$exports, "getOffset", () => $16ec41ef3e36c19c$export$622cea445a1c5b7d);
240
+ function $16ec41ef3e36c19c$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
- function getOffset(element, reverse, orientation) {
319
- if (orientation === void 0) {
320
- orientation = 'horizontal';
321
- }
247
+ var $eb1d06911309900e$exports = {};
322
248
 
323
- let rect = element.getBoundingClientRect();
249
+ $parcel$export($eb1d06911309900e$exports, "clamp", () => $1Yh1N$reactstatelyutils.clamp);
250
+ $parcel$export($eb1d06911309900e$exports, "snapValueToStep", () => $1Yh1N$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.getOffset = getOffset;
254
+ var $e8117ebcab55be6a$exports = {};
255
+
256
+ $parcel$export($e8117ebcab55be6a$exports, "runAfterTransition", () => $e8117ebcab55be6a$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 $a39a8553a97349a69bcc0255658c67ab$var$transitionsByElement = new Map(); // A list of callbacks to call once there are no transitioning elements.
339
-
340
- let $a39a8553a97349a69bcc0255658c67ab$var$transitionCallbacks = new Set();
341
-
342
- function $a39a8553a97349a69bcc0255658c67ab$var$setupGlobalEvents() {
343
- if (typeof window === 'undefined') {
344
- return;
345
- }
346
-
347
- let onTransitionStart = e => {
348
- // Add the transitioning property to the list for this element.
349
- let transitions = $a39a8553a97349a69bcc0255658c67ab$var$transitionsByElement.get(e.target);
350
-
351
- if (!transitions) {
352
- transitions = new Set();
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 $e8117ebcab55be6a$var$transitionsByElement = new Map();
274
+ // A list of callbacks to call once there are no transitioning elements.
275
+ let $e8117ebcab55be6a$var$transitionCallbacks = new Set();
276
+ function $e8117ebcab55be6a$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 = $e8117ebcab55be6a$var$transitionsByElement.get(e.target);
281
+ if (!transitions) {
282
+ transitions = new Set();
283
+ $e8117ebcab55be6a$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
- break;
542
-
543
- case 'Up':
544
- case 'ArrowUp':
545
- if (orientation === 'vertical') {
546
- e.preventDefault();
547
-
548
- if (onDecrement && !reverse) {
549
- onDecrement();
550
- } else if (onIncrement && reverse) {
551
- onIncrement();
552
- }
289
+ transitions.add(e.propertyName);
290
+ };
291
+ let onTransitionEnd = (e)=>{
292
+ // Remove property from list of transitioning properties.
293
+ let properties = $e8117ebcab55be6a$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
+ $e8117ebcab55be6a$var$transitionsByElement.delete(e.target);
553
300
  }
554
-
555
- break;
556
-
557
- case 'Right':
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 ($e8117ebcab55be6a$var$transitionsByElement.size === 0) {
303
+ for (let cb of $e8117ebcab55be6a$var$transitionCallbacks)cb();
304
+ $e8117ebcab55be6a$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') $e8117ebcab55be6a$var$setupGlobalEvents();
312
+ else document.addEventListener('DOMContentLoaded', $e8117ebcab55be6a$var$setupGlobalEvents);
313
+ }
314
+ function $e8117ebcab55be6a$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 ($e8117ebcab55be6a$var$transitionsByElement.size === 0) fn();
320
+ else $e8117ebcab55be6a$var$transitionCallbacks.add(fn);
321
+ });
322
+ }
568
323
 
569
- break;
570
324
 
571
- case 'Down':
572
- case 'ArrowDown':
573
- if (orientation === 'vertical') {
574
- e.preventDefault();
325
+ var $28ed3fb20343b78b$exports = {};
575
326
 
576
- if (onIncrement && !reverse) {
577
- onIncrement();
578
- } else if (onDecrement && reverse) {
579
- onDecrement();
580
- }
581
- }
327
+ $parcel$export($28ed3fb20343b78b$exports, "useDrag1D", () => $28ed3fb20343b78b$export$7bbed75feba39706);
582
328
 
583
- break;
584
329
 
585
- case 'Home':
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 $28ed3fb20343b78b$var$draggingElements = [];
334
+ function $28ed3fb20343b78b$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 = $16ec41ef3e36c19c$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 = $1Yh1N$react.useRef(false);
346
+ let prevPosition = $1Yh1N$react.useRef(0);
347
+ // Keep track of the current handlers in a ref so that the events can access them.
348
+ let handlers = $1Yh1N$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 (onDecrementToMin) {
589
- onDecrementToMin();
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
- break;
593
-
594
- case 'End':
595
- e.preventDefault();
596
-
597
- if (onIncrementToMax) {
598
- onIncrementToMax();
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
+ $28ed3fb20343b78b$var$draggingElements.splice($28ed3fb20343b78b$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 ($28ed3fb20343b78b$var$draggingElements.some((elt)=>target.contains(elt)
381
+ )) return;
382
+ $28ed3fb20343b78b$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
- case 'Enter':
604
- e.preventDefault();
449
+ var $4571ff54ac709100$exports = {};
450
+
451
+ $parcel$export($4571ff54ac709100$exports, "useGlobalListeners", () => $4571ff54ac709100$export$4eaf04e54aa8eed6);
452
+
453
+ function $4571ff54ac709100$export$4eaf04e54aa8eed6() {
454
+ let globalListeners = $1Yh1N$react.useRef(new Map());
455
+ let addGlobalListener = $1Yh1N$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 === null || options === void 0 ? void 0 : 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 = $1Yh1N$react.useCallback((eventTarget, type, listener, options)=>{
470
+ var ref;
471
+ let fn = ((ref = globalListeners.current.get(listener)) === null || ref === void 0 ? void 0 : ref.fn) || listener;
472
+ eventTarget.removeEventListener(type, fn, options);
473
+ globalListeners.current.delete(listener);
474
+ }, []);
475
+ let removeAllGlobalListeners = $1Yh1N$react.useCallback(()=>{
476
+ globalListeners.current.forEach((value, key)=>{
477
+ removeGlobalListener(value.eventTarget, value.type, key, value.options);
478
+ });
479
+ }, [
480
+ removeGlobalListener
481
+ ]);
482
+ // eslint-disable-next-line arrow-body-style
483
+ $1Yh1N$react.useEffect(()=>{
484
+ return removeAllGlobalListeners;
485
+ }, [
486
+ removeAllGlobalListeners
487
+ ]);
488
+ return {
489
+ addGlobalListener: addGlobalListener,
490
+ removeGlobalListener: removeGlobalListener,
491
+ removeAllGlobalListeners: removeAllGlobalListeners
492
+ };
493
+ }
605
494
 
606
- if (onCollapseToggle) {
607
- onCollapseToggle();
608
- }
609
495
 
610
- break;
611
- }
612
- };
613
-
614
- return {
615
- onMouseDown,
616
- onMouseEnter,
617
- onMouseOut,
618
- onKeyDown
619
- };
496
+ var $6ec78bde395c477d$exports = {};
497
+
498
+ $parcel$export($6ec78bde395c477d$exports, "useLabels", () => $6ec78bde395c477d$export$d6875122194c7b44);
499
+
500
+ function $6ec78bde395c477d$export$d6875122194c7b44(props, defaultLabel) {
501
+ let { id: id , 'aria-label': label , 'aria-labelledby': labelledBy } = props;
502
+ // If there is both an aria-label and aria-labelledby,
503
+ // combine them by pointing to the element itself.
504
+ id = $8c61827343eed941$export$f680877a34711e37(id);
505
+ if (labelledBy && label) {
506
+ let ids = new Set([
507
+ ...labelledBy.trim().split(/\s+/),
508
+ id
509
+ ]);
510
+ labelledBy = [
511
+ ...ids
512
+ ].join(' ');
513
+ } else if (labelledBy) labelledBy = labelledBy.trim().split(/\s+/).join(' ');
514
+ // If no labels are provided, use the default
515
+ if (!label && !labelledBy && defaultLabel) label = defaultLabel;
516
+ return {
517
+ id: id,
518
+ 'aria-label': label,
519
+ 'aria-labelledby': labelledBy
520
+ };
620
521
  }
621
522
 
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
523
 
663
- exports.useGlobalListeners = useGlobalListeners;
524
+ var $475b35fe72ba49b3$exports = {};
664
525
 
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
- }
526
+ $parcel$export($475b35fe72ba49b3$exports, "useObjectRef", () => $475b35fe72ba49b3$export$4338b53315abf666);
698
527
 
699
- exports.useLabels = useLabels;
700
528
 
701
- /**
702
- * Offers an object ref for a given callback ref or an object ref. Especially
703
- * helfpul when passing forwarded refs (created using `React.forwardRef`) to
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
- /**
529
+ function $475b35fe72ba49b3$export$4338b53315abf666(forwardedRef) {
530
+ const objRef = $1Yh1N$react.useRef();
531
+ /**
713
532
  * We're using `useLayoutEffect` here instead of `useEffect` because we want
714
533
  * to make sure that the `ref` value is up to date before other places in the
715
534
  * the execution cycle try to read it.
716
- */
717
-
718
- useLayoutEffect(() => {
719
- if (!forwardedRef) {
720
- return;
721
- }
722
-
723
- if (typeof forwardedRef === 'function') {
724
- forwardedRef(objRef.current);
725
- } else {
726
- forwardedRef.current = objRef.current;
727
- }
728
- }, [forwardedRef]);
729
- return objRef;
730
- }
731
-
732
- exports.useObjectRef = useObjectRef;
733
-
734
- // Like useEffect, but only called for updates after the initial render.
735
- function useUpdateEffect(effect, dependencies) {
736
- const isInitialMount = useRef(true);
737
- useEffect(() => {
738
- if (isInitialMount.current) {
739
- isInitialMount.current = false;
740
- } else {
741
- effect();
742
- } // eslint-disable-next-line react-hooks/exhaustive-deps
743
-
744
- }, dependencies);
745
- }
746
-
747
- exports.useUpdateEffect = useUpdateEffect;
748
-
749
- function $f58f1969071f2661185e38312efabfc$var$hasResizeObserver() {
750
- return typeof window.ResizeObserver !== 'undefined';
535
+ */ $78605a5d7424e31b$export$e5c5a5f917a5871c(()=>{
536
+ if (!forwardedRef) return;
537
+ if (typeof forwardedRef === 'function') forwardedRef(objRef.current);
538
+ else forwardedRef.current = objRef.current;
539
+ }, [
540
+ forwardedRef
541
+ ]);
542
+ return objRef;
543
+ }
544
+
545
+
546
+ var $29293a6f5c75b37e$exports = {};
547
+
548
+ $parcel$export($29293a6f5c75b37e$exports, "useUpdateEffect", () => $29293a6f5c75b37e$export$496315a1608d9602);
549
+
550
+ function $29293a6f5c75b37e$export$496315a1608d9602(effect, dependencies) {
551
+ const isInitialMount = $1Yh1N$react.useRef(true);
552
+ $1Yh1N$react.useEffect(()=>{
553
+ if (isInitialMount.current) isInitialMount.current = false;
554
+ else effect();
555
+ // eslint-disable-next-line react-hooks/exhaustive-deps
556
+ }, dependencies);
557
+ }
558
+
559
+
560
+
561
+ var $37733e1652f47193$exports = {};
562
+
563
+ $parcel$export($37733e1652f47193$exports, "useResizeObserver", () => $37733e1652f47193$export$683480f191c0e3ea);
564
+
565
+ function $37733e1652f47193$var$hasResizeObserver() {
566
+ return typeof window.ResizeObserver !== 'undefined';
567
+ }
568
+ function $37733e1652f47193$export$683480f191c0e3ea(options) {
569
+ const { ref: ref , onResize: onResize } = options;
570
+ $1Yh1N$react.useEffect(()=>{
571
+ let element = ref === null || ref === void 0 ? void 0 : ref.current;
572
+ if (!element) return;
573
+ if (!$37733e1652f47193$var$hasResizeObserver()) {
574
+ window.addEventListener('resize', onResize, false);
575
+ return ()=>{
576
+ window.removeEventListener('resize', onResize, false);
577
+ };
578
+ } else {
579
+ const resizeObserverInstance = new window.ResizeObserver((entries)=>{
580
+ if (!entries.length) return;
581
+ onResize();
582
+ });
583
+ resizeObserverInstance.observe(element);
584
+ return ()=>{
585
+ if (element) resizeObserverInstance.unobserve(element);
586
+ };
587
+ }
588
+ }, [
589
+ onResize,
590
+ ref
591
+ ]);
751
592
  }
752
593
 
753
- function useResizeObserver(options) {
754
- const {
755
- ref,
756
- onResize
757
- } = options;
758
- useEffect(() => {
759
- let element = ref == null ? void 0 : ref.current;
760
594
 
761
- if (!element) {
762
- return;
763
- }
595
+ var $6fc733991a9f977c$exports = {};
764
596
 
765
- if (!$f58f1969071f2661185e38312efabfc$var$hasResizeObserver()) {
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
- }
597
+ $parcel$export($6fc733991a9f977c$exports, "useSyncRef", () => $6fc733991a9f977c$export$4debdb1a3f0fa79e);
775
598
 
776
- onResize();
777
- });
778
- resizeObserverInstance.observe(element);
779
- return () => {
780
- if (element) {
781
- resizeObserverInstance.unobserve(element);
599
+ function $6fc733991a9f977c$export$4debdb1a3f0fa79e(context, ref) {
600
+ $78605a5d7424e31b$export$e5c5a5f917a5871c(()=>{
601
+ if (context && context.ref && ref) {
602
+ context.ref.current = ref.current;
603
+ return ()=>{
604
+ context.ref.current = null;
605
+ };
782
606
  }
783
- };
784
- }
785
- }, [onResize, ref]);
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]);
607
+ }, [
608
+ context,
609
+ ref
610
+ ]);
800
611
  }
801
612
 
802
- exports.useSyncRef = useSyncRef;
803
613
 
804
- function getScrollParent(node) {
805
- while (node && !$e9be933e81f272fbb0513fcc706c7$var$isScrollable(node)) {
806
- node = node.parentElement;
807
- }
614
+ var $d796e7157ac96470$exports = {};
808
615
 
809
- return node || document.scrollingElement || document.documentElement;
616
+ $parcel$export($d796e7157ac96470$exports, "getScrollParent", () => $d796e7157ac96470$export$cfa2225e87938781);
617
+ function $d796e7157ac96470$export$cfa2225e87938781(node) {
618
+ while(node && !$d796e7157ac96470$var$isScrollable(node))node = node.parentElement;
619
+ return node || document.scrollingElement || document.documentElement;
810
620
  }
811
-
812
- exports.getScrollParent = getScrollParent;
813
-
814
- function $e9be933e81f272fbb0513fcc706c7$var$isScrollable(node) {
815
- let style = window.getComputedStyle(node);
816
- return /(auto|scroll)/.test(style.overflow + style.overflowX + style.overflowY);
621
+ function $d796e7157ac96470$var$isScrollable(node) {
622
+ let style = window.getComputedStyle(node);
623
+ return /(auto|scroll)/.test(style.overflow + style.overflowX + style.overflowY);
817
624
  }
818
625
 
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
626
 
834
- return newSize;
835
- });
836
- };
627
+ var $8b24bab62f5c65ad$exports = {};
837
628
 
838
- if (!$f1a92c0e19f2e1ad09851454bf93009$var$visualViewport) {
839
- window.addEventListener('resize', onResize);
840
- } else {
841
- $f1a92c0e19f2e1ad09851454bf93009$var$visualViewport.addEventListener('resize', onResize);
842
- }
629
+ $parcel$export($8b24bab62f5c65ad$exports, "useViewportSize", () => $8b24bab62f5c65ad$export$d699905dd57c73ca);
843
630
 
844
- return () => {
845
- if (!$f1a92c0e19f2e1ad09851454bf93009$var$visualViewport) {
846
- window.removeEventListener('resize', onResize);
847
- } else {
848
- $f1a92c0e19f2e1ad09851454bf93009$var$visualViewport.removeEventListener('resize', onResize);
849
- }
631
+ // @ts-ignore
632
+ let $8b24bab62f5c65ad$var$visualViewport = typeof window !== 'undefined' && window.visualViewport;
633
+ function $8b24bab62f5c65ad$export$d699905dd57c73ca() {
634
+ let [size1, setSize] = $1Yh1N$react.useState(()=>$8b24bab62f5c65ad$var$getViewportSize()
635
+ );
636
+ $1Yh1N$react.useEffect(()=>{
637
+ // Use visualViewport api to track available height even on iOS virtual keyboard opening
638
+ let onResize = ()=>{
639
+ setSize((size)=>{
640
+ let newSize = $8b24bab62f5c65ad$var$getViewportSize();
641
+ if (newSize.width === size.width && newSize.height === size.height) return size;
642
+ return newSize;
643
+ });
644
+ };
645
+ if (!$8b24bab62f5c65ad$var$visualViewport) window.addEventListener('resize', onResize);
646
+ else $8b24bab62f5c65ad$var$visualViewport.addEventListener('resize', onResize);
647
+ return ()=>{
648
+ if (!$8b24bab62f5c65ad$var$visualViewport) window.removeEventListener('resize', onResize);
649
+ else $8b24bab62f5c65ad$var$visualViewport.removeEventListener('resize', onResize);
650
+ };
651
+ }, []);
652
+ return size1;
653
+ }
654
+ function $8b24bab62f5c65ad$var$getViewportSize() {
655
+ return {
656
+ width: ($8b24bab62f5c65ad$var$visualViewport === null || $8b24bab62f5c65ad$var$visualViewport === void 0 ? void 0 : $8b24bab62f5c65ad$var$visualViewport.width) || window.innerWidth,
657
+ height: ($8b24bab62f5c65ad$var$visualViewport === null || $8b24bab62f5c65ad$var$visualViewport === void 0 ? void 0 : $8b24bab62f5c65ad$var$visualViewport.height) || window.innerHeight
850
658
  };
851
- }, []);
852
- return size;
853
659
  }
854
660
 
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
661
 
864
- let $bd5928122fc632cc7302c36df9f$var$descriptionId = 0;
865
- const $bd5928122fc632cc7302c36df9f$var$descriptionNodes = new Map();
866
-
867
- function useDescription(description) {
868
- let [id, setId] = useState(null);
869
- useLayoutEffect(() => {
870
- if (!description) {
871
- return;
872
- }
873
-
874
- let desc = $bd5928122fc632cc7302c36df9f$var$descriptionNodes.get(description);
875
-
876
- if (!desc) {
877
- let id = "react-aria-description-" + $bd5928122fc632cc7302c36df9f$var$descriptionId++;
878
- setId(id);
879
- let node = document.createElement('div');
880
- node.id = id;
881
- node.style.display = 'none';
882
- node.textContent = description;
883
- document.body.appendChild(node);
884
- desc = {
885
- refCount: 0,
886
- element: node
887
- };
888
- $bd5928122fc632cc7302c36df9f$var$descriptionNodes.set(description, desc);
889
- } else {
890
- setId(desc.element.id);
891
- }
892
-
893
- desc.refCount++;
894
- return () => {
895
- if (--desc.refCount === 0) {
896
- desc.element.remove();
897
- $bd5928122fc632cc7302c36df9f$var$descriptionNodes.delete(description);
898
- }
662
+ var $34da4502ea8120db$exports = {};
663
+
664
+ $parcel$export($34da4502ea8120db$exports, "useDescription", () => $34da4502ea8120db$export$f8aeda7b10753fa1);
665
+
666
+
667
+ let $34da4502ea8120db$var$descriptionId = 0;
668
+ const $34da4502ea8120db$var$descriptionNodes = new Map();
669
+ function $34da4502ea8120db$export$f8aeda7b10753fa1(description) {
670
+ let [id1, setId] = $1Yh1N$react.useState(null);
671
+ $78605a5d7424e31b$export$e5c5a5f917a5871c(()=>{
672
+ if (!description) return;
673
+ let desc = $34da4502ea8120db$var$descriptionNodes.get(description);
674
+ if (!desc) {
675
+ let id = `react-aria-description-${$34da4502ea8120db$var$descriptionId++}`;
676
+ setId(id);
677
+ let node = document.createElement('div');
678
+ node.id = id;
679
+ node.style.display = 'none';
680
+ node.textContent = description;
681
+ document.body.appendChild(node);
682
+ desc = {
683
+ refCount: 0,
684
+ element: node
685
+ };
686
+ $34da4502ea8120db$var$descriptionNodes.set(description, desc);
687
+ } else setId(desc.element.id);
688
+ desc.refCount++;
689
+ return ()=>{
690
+ if (--desc.refCount === 0) {
691
+ desc.element.remove();
692
+ $34da4502ea8120db$var$descriptionNodes.delete(description);
693
+ }
694
+ };
695
+ }, [
696
+ description
697
+ ]);
698
+ return {
699
+ 'aria-describedby': description ? id1 : undefined
899
700
  };
900
- }, [description]);
901
- return {
902
- 'aria-describedby': description ? id : undefined
903
- };
904
701
  }
905
702
 
906
- exports.useDescription = useDescription;
907
703
 
908
- function $ffc9ede5fda79bf280c1bec834e32f$var$testUserAgent(re) {
909
- return typeof window !== 'undefined' && window.navigator != null ? re.test(window.navigator.userAgent) : false;
910
- }
704
+ var $9e20cff0af27e8cc$exports = {};
911
705
 
912
- function $ffc9ede5fda79bf280c1bec834e32f$var$testPlatform(re) {
913
- return typeof window !== 'undefined' && window.navigator != null ? re.test(window.navigator.platform) : false;
706
+ $parcel$export($9e20cff0af27e8cc$exports, "isMac", () => $9e20cff0af27e8cc$export$9ac100e40613ea10);
707
+ $parcel$export($9e20cff0af27e8cc$exports, "isIPhone", () => $9e20cff0af27e8cc$export$186c6964ca17d99);
708
+ $parcel$export($9e20cff0af27e8cc$exports, "isIPad", () => $9e20cff0af27e8cc$export$7bef049ce92e4224);
709
+ $parcel$export($9e20cff0af27e8cc$exports, "isIOS", () => $9e20cff0af27e8cc$export$fedb369cb70207f1);
710
+ $parcel$export($9e20cff0af27e8cc$exports, "isAppleDevice", () => $9e20cff0af27e8cc$export$e1865c3bedcd822b);
711
+ $parcel$export($9e20cff0af27e8cc$exports, "isWebKit", () => $9e20cff0af27e8cc$export$78551043582a6a98);
712
+ $parcel$export($9e20cff0af27e8cc$exports, "isChrome", () => $9e20cff0af27e8cc$export$6446a186d09e379e);
713
+ $parcel$export($9e20cff0af27e8cc$exports, "isAndroid", () => $9e20cff0af27e8cc$export$a11b0059900ceec8);
714
+ /*
715
+ * Copyright 2020 Adobe. All rights reserved.
716
+ * This file is licensed to you under the Apache License, Version 2.0 (the "License");
717
+ * you may not use this file except in compliance with the License. You may obtain a copy
718
+ * of the License at http://www.apache.org/licenses/LICENSE-2.0
719
+ *
720
+ * Unless required by applicable law or agreed to in writing, software distributed under
721
+ * the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
722
+ * OF ANY KIND, either express or implied. See the License for the specific language
723
+ * governing permissions and limitations under the License.
724
+ */ function $9e20cff0af27e8cc$var$testUserAgent(re) {
725
+ var ref;
726
+ if (typeof window === 'undefined' || window.navigator == null) return false;
727
+ return ((ref = window.navigator['userAgentData']) === null || ref === void 0 ? void 0 : ref.brands.some((brand)=>re.test(brand.brand)
728
+ )) || re.test(window.navigator.userAgent);
914
729
  }
915
-
916
- function isMac() {
917
- return $ffc9ede5fda79bf280c1bec834e32f$var$testPlatform(/^Mac/);
730
+ function $9e20cff0af27e8cc$var$testPlatform(re) {
731
+ return typeof window !== 'undefined' && window.navigator != null ? re.test((window.navigator['userAgentData'] || window.navigator).platform) : false;
918
732
  }
919
-
920
- exports.isMac = isMac;
921
-
922
- function isIPhone() {
923
- return $ffc9ede5fda79bf280c1bec834e32f$var$testPlatform(/^iPhone/);
733
+ function $9e20cff0af27e8cc$export$9ac100e40613ea10() {
734
+ return $9e20cff0af27e8cc$var$testPlatform(/^Mac/i);
924
735
  }
925
-
926
- exports.isIPhone = isIPhone;
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;
736
+ function $9e20cff0af27e8cc$export$186c6964ca17d99() {
737
+ return $9e20cff0af27e8cc$var$testPlatform(/^iPhone/i);
931
738
  }
932
-
933
- exports.isIPad = isIPad;
934
-
935
- function isIOS() {
936
- return isIPhone() || isIPad();
739
+ function $9e20cff0af27e8cc$export$7bef049ce92e4224() {
740
+ return $9e20cff0af27e8cc$var$testPlatform(/^iPad/i) || $9e20cff0af27e8cc$export$9ac100e40613ea10() && navigator.maxTouchPoints > 1;
937
741
  }
938
-
939
- exports.isIOS = isIOS;
940
-
941
- function isAppleDevice() {
942
- return isMac() || isIOS();
742
+ function $9e20cff0af27e8cc$export$fedb369cb70207f1() {
743
+ return $9e20cff0af27e8cc$export$186c6964ca17d99() || $9e20cff0af27e8cc$export$7bef049ce92e4224();
943
744
  }
944
-
945
- exports.isAppleDevice = isAppleDevice;
946
-
947
- function isWebKit() {
948
- return $ffc9ede5fda79bf280c1bec834e32f$var$testUserAgent(/AppleWebKit/) && !isChrome();
745
+ function $9e20cff0af27e8cc$export$e1865c3bedcd822b() {
746
+ return $9e20cff0af27e8cc$export$9ac100e40613ea10() || $9e20cff0af27e8cc$export$fedb369cb70207f1();
949
747
  }
950
-
951
- exports.isWebKit = isWebKit;
952
-
953
- function isChrome() {
954
- return $ffc9ede5fda79bf280c1bec834e32f$var$testUserAgent(/Chrome/);
748
+ function $9e20cff0af27e8cc$export$78551043582a6a98() {
749
+ return $9e20cff0af27e8cc$var$testUserAgent(/AppleWebKit/i) && !$9e20cff0af27e8cc$export$6446a186d09e379e();
955
750
  }
956
-
957
- exports.isChrome = isChrome;
958
-
959
- function isAndroid() {
960
- return $ffc9ede5fda79bf280c1bec834e32f$var$testUserAgent(/Android/);
751
+ function $9e20cff0af27e8cc$export$6446a186d09e379e() {
752
+ return $9e20cff0af27e8cc$var$testUserAgent(/Chrome/i);
753
+ }
754
+ function $9e20cff0af27e8cc$export$a11b0059900ceec8() {
755
+ return $9e20cff0af27e8cc$var$testUserAgent(/Android/i);
961
756
  }
962
757
 
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
758
 
974
- let element = ref.current;
759
+ var $2a8c0bb1629926c8$exports = {};
975
760
 
976
- let handler = e => handlerRef.current.call(this, e);
761
+ $parcel$export($2a8c0bb1629926c8$exports, "useEvent", () => $2a8c0bb1629926c8$export$90fc3a17d93f704c);
977
762
 
978
- element.addEventListener(event, handler, options);
979
- return () => {
980
- element.removeEventListener(event, handler, options);
981
- };
982
- }, [ref, event, options, isDisabled]);
763
+ function $2a8c0bb1629926c8$export$90fc3a17d93f704c(ref, event, handler1, options) {
764
+ let handlerRef = $1Yh1N$react.useRef(handler1);
765
+ handlerRef.current = handler1;
766
+ let isDisabled = handler1 == null;
767
+ $1Yh1N$react.useEffect(()=>{
768
+ if (isDisabled) return;
769
+ let element = ref.current;
770
+ let handler = (e)=>handlerRef.current.call(this, e)
771
+ ;
772
+ element.addEventListener(event, handler, options);
773
+ return ()=>{
774
+ element.removeEventListener(event, handler, options);
775
+ };
776
+ }, [
777
+ ref,
778
+ event,
779
+ options,
780
+ isDisabled
781
+ ]);
983
782
  }
984
783
 
985
- exports.useEvent = useEvent;
986
784
 
987
- // This hook works like `useState`, but when setting the value, you pass a generator function
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.
785
+ var $19a2307bfabafaf1$exports = {};
997
786
 
998
- let nextRef = useRef(null);
787
+ $parcel$export($19a2307bfabafaf1$exports, "useValueEffect", () => $19a2307bfabafaf1$export$14d238f342723f25);
999
788
 
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
789
 
1004
- if (newValue.done) {
1005
- effect.current = null;
1006
- return;
1007
- } // If the value is the same as the current value,
1008
- // then continue to the next yield. Otherwise,
1009
- // set the value in state and wait for the next layout effect.
1010
-
1011
-
1012
- if (value === newValue.value) {
1013
- nextRef.current();
1014
- } else {
1015
- setValue(newValue.value);
1016
- }
1017
- };
1018
-
1019
- useLayoutEffect(() => {
1020
- // If there is an effect currently running, continue to the next yield.
1021
- if (effect.current) {
1022
- nextRef.current();
1023
- }
1024
- });
1025
- let queue = useCallback(fn => {
1026
- effect.current = fn(valueRef.current);
1027
- nextRef.current();
1028
- }, [effect, nextRef]);
1029
- return [value, queue];
1030
- }
1031
-
1032
- exports.useValueEffect = useValueEffect;
1033
-
1034
- function scrollIntoView(scrollView, element) {
1035
- let offsetX = $cbd55f9ce27bf074ec65b15e6f24531$var$relativeOffset(scrollView, element, 'left');
1036
- let offsetY = $cbd55f9ce27bf074ec65b15e6f24531$var$relativeOffset(scrollView, element, 'top');
1037
- let width = element.offsetWidth;
1038
- let height = element.offsetHeight;
1039
- let x = scrollView.scrollLeft;
1040
- let y = scrollView.scrollTop;
1041
- let maxX = x + scrollView.offsetWidth;
1042
- let maxY = y + scrollView.offsetHeight;
1043
-
1044
- if (offsetX <= x) {
1045
- x = offsetX;
1046
- } else if (offsetX + width > maxX) {
1047
- x += offsetX + width - maxX;
1048
- }
1049
-
1050
- if (offsetY <= y) {
1051
- y = offsetY;
1052
- } else if (offsetY + height > maxY) {
1053
- y += offsetY + height - maxY;
1054
- }
1055
-
1056
- scrollView.scrollLeft = x;
1057
- scrollView.scrollTop = y;
790
+ function $19a2307bfabafaf1$export$14d238f342723f25(defaultValue) {
791
+ let [value, setValue] = $1Yh1N$react.useState(defaultValue);
792
+ let valueRef = $1Yh1N$react.useRef(value);
793
+ let effect = $1Yh1N$react.useRef(null);
794
+ valueRef.current = value;
795
+ // Store the function in a ref so we can always access the current version
796
+ // which has the proper `value` in scope.
797
+ let nextRef = $1Yh1N$react.useRef(null);
798
+ nextRef.current = ()=>{
799
+ // Run the generator to the next yield.
800
+ let newValue = effect.current.next();
801
+ // If the generator is done, reset the effect.
802
+ if (newValue.done) {
803
+ effect.current = null;
804
+ return;
805
+ }
806
+ // If the value is the same as the current value,
807
+ // then continue to the next yield. Otherwise,
808
+ // set the value in state and wait for the next layout effect.
809
+ if (value === newValue.value) nextRef.current();
810
+ else setValue(newValue.value);
811
+ };
812
+ $78605a5d7424e31b$export$e5c5a5f917a5871c(()=>{
813
+ // If there is an effect currently running, continue to the next yield.
814
+ if (effect.current) nextRef.current();
815
+ });
816
+ let queue = $1Yh1N$react.useCallback((fn)=>{
817
+ effect.current = fn(valueRef.current);
818
+ nextRef.current();
819
+ }, [
820
+ effect,
821
+ nextRef
822
+ ]);
823
+ return [
824
+ value,
825
+ queue
826
+ ];
827
+ }
828
+
829
+
830
+ var $449412113267a1fe$exports = {};
831
+
832
+ $parcel$export($449412113267a1fe$exports, "scrollIntoView", () => $449412113267a1fe$export$53a0910f038337bd);
833
+ function $449412113267a1fe$export$53a0910f038337bd(scrollView, element) {
834
+ let offsetX = $449412113267a1fe$var$relativeOffset(scrollView, element, 'left');
835
+ let offsetY = $449412113267a1fe$var$relativeOffset(scrollView, element, 'top');
836
+ let width = element.offsetWidth;
837
+ let height = element.offsetHeight;
838
+ let x = scrollView.scrollLeft;
839
+ let y = scrollView.scrollTop;
840
+ let maxX = x + scrollView.offsetWidth;
841
+ let maxY = y + scrollView.offsetHeight;
842
+ if (offsetX <= x) x = offsetX;
843
+ else if (offsetX + width > maxX) x += offsetX + width - maxX;
844
+ if (offsetY <= y) y = offsetY;
845
+ else if (offsetY + height > maxY) y += offsetY + height - maxY;
846
+ scrollView.scrollLeft = x;
847
+ scrollView.scrollTop = y;
1058
848
  }
1059
849
  /**
1060
850
  * Computes the offset left or top from child to ancestor by accumulating
1061
851
  * offsetLeft or offsetTop through intervening offsetParents.
1062
- */
1063
-
1064
-
1065
- exports.scrollIntoView = scrollIntoView;
1066
-
1067
- function $cbd55f9ce27bf074ec65b15e6f24531$var$relativeOffset(ancestor, child, axis) {
1068
- const prop = axis === 'left' ? 'offsetLeft' : 'offsetTop';
1069
- let sum = 0;
1070
-
1071
- while (child.offsetParent) {
1072
- sum += child[prop];
1073
-
1074
- if (child.offsetParent === ancestor) {
1075
- // Stop once we have found the ancestor we are interested in.
1076
- break;
1077
- } else if (child.offsetParent.contains(ancestor)) {
1078
- // If the ancestor is not `position:relative`, then we stop at
1079
- // _its_ offset parent, and we subtract off _its_ offset, so that
1080
- // we end up with the proper offset from child to ancestor.
1081
- sum -= ancestor[prop];
1082
- break;
1083
- }
852
+ */ function $449412113267a1fe$var$relativeOffset(ancestor, child, axis) {
853
+ const prop = axis === 'left' ? 'offsetLeft' : 'offsetTop';
854
+ let sum = 0;
855
+ while(child.offsetParent){
856
+ sum += child[prop];
857
+ if (child.offsetParent === ancestor) break;
858
+ else if (child.offsetParent.contains(ancestor)) {
859
+ // If the ancestor is not `position:relative`, then we stop at
860
+ // _its_ offset parent, and we subtract off _its_ offset, so that
861
+ // we end up with the proper offset from child to ancestor.
862
+ sum -= ancestor[prop];
863
+ break;
864
+ }
865
+ child = child.offsetParent;
866
+ }
867
+ return sum;
868
+ }
869
+
870
+
871
+ $parcel$exportWildcard(module.exports, $8c61827343eed941$exports);
872
+ $parcel$exportWildcard(module.exports, $1e2191638e54f613$exports);
873
+ $parcel$exportWildcard(module.exports, $f847cd1382ea7cd4$exports);
874
+ $parcel$exportWildcard(module.exports, $8d15d0e1797d4238$exports);
875
+ $parcel$exportWildcard(module.exports, $1117b6c0d4c4c164$exports);
876
+ $parcel$exportWildcard(module.exports, $16ec41ef3e36c19c$exports);
877
+ $parcel$exportWildcard(module.exports, $eb1d06911309900e$exports);
878
+ $parcel$exportWildcard(module.exports, $e8117ebcab55be6a$exports);
879
+ $parcel$exportWildcard(module.exports, $28ed3fb20343b78b$exports);
880
+ $parcel$exportWildcard(module.exports, $4571ff54ac709100$exports);
881
+ $parcel$exportWildcard(module.exports, $6ec78bde395c477d$exports);
882
+ $parcel$exportWildcard(module.exports, $475b35fe72ba49b3$exports);
883
+ $parcel$exportWildcard(module.exports, $29293a6f5c75b37e$exports);
884
+ $parcel$exportWildcard(module.exports, $78605a5d7424e31b$exports);
885
+ $parcel$exportWildcard(module.exports, $37733e1652f47193$exports);
886
+ $parcel$exportWildcard(module.exports, $6fc733991a9f977c$exports);
887
+ $parcel$exportWildcard(module.exports, $d796e7157ac96470$exports);
888
+ $parcel$exportWildcard(module.exports, $8b24bab62f5c65ad$exports);
889
+ $parcel$exportWildcard(module.exports, $34da4502ea8120db$exports);
890
+ $parcel$exportWildcard(module.exports, $9e20cff0af27e8cc$exports);
891
+ $parcel$exportWildcard(module.exports, $2a8c0bb1629926c8$exports);
892
+ $parcel$exportWildcard(module.exports, $19a2307bfabafaf1$exports);
893
+ $parcel$exportWildcard(module.exports, $449412113267a1fe$exports);
1084
894
 
1085
- child = child.offsetParent;
1086
- }
1087
895
 
1088
- return sum;
1089
- }
1090
896
  //# sourceMappingURL=main.js.map