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