@react-aria/utils 3.9.0 → 3.11.2
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 +769 -814
- package/dist/main.js.map +1 -1
- package/dist/module.js +751 -738
- package/dist/module.js.map +1 -1
- package/dist/types.d.ts +21 -2
- package/dist/types.d.ts.map +1 -1
- package/package.json +5 -5
- package/src/index.ts +3 -0
- package/src/scrollIntoView.ts +65 -0
- package/src/useDescription.ts +2 -1
- package/src/useGlobalListeners.ts +8 -2
- package/src/useId.ts +14 -11
- package/src/useObjectRef.ts +46 -0
- package/src/useValueEffect.ts +65 -0
package/dist/module.js
CHANGED
|
@@ -1,839 +1,852 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
import
|
|
4
|
-
import
|
|
5
|
-
import { useSSRSafeId } from "@react-aria/ssr";
|
|
6
|
-
import _react, { useEffect, useRef, useState, useCallback, useLayoutEffect as _useLayoutEffect } 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 $5yePs$react, {useRef as $5yePs$useRef, useState as $5yePs$useState, useEffect as $5yePs$useEffect, useCallback as $5yePs$useCallback} from "react";
|
|
2
|
+
import {useSSRSafeId as $5yePs$useSSRSafeId} from "@react-aria/ssr";
|
|
3
|
+
import $5yePs$clsx from "clsx";
|
|
4
|
+
import {clamp as $691ac3ad1af88e64$re_export$clamp, snapValueToStep as $691ac3ad1af88e64$re_export$snapValueToStep} from "@react-stately/utils";
|
|
44
5
|
|
|
45
|
-
|
|
46
|
-
|
|
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 $5b01a7ee7dba2d86$exports = {};
|
|
56
10
|
|
|
57
|
-
export
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
}
|
|
11
|
+
$parcel$export($5b01a7ee7dba2d86$exports, "useId", () => $5b01a7ee7dba2d86$export$f680877a34711e37);
|
|
12
|
+
$parcel$export($5b01a7ee7dba2d86$exports, "mergeIds", () => $5b01a7ee7dba2d86$export$cd8c9cb68f842629);
|
|
13
|
+
$parcel$export($5b01a7ee7dba2d86$exports, "useSlotId", () => $5b01a7ee7dba2d86$export$b4cc09c592e8fdb8);
|
|
61
14
|
|
|
62
|
-
|
|
15
|
+
var $5ac25c9c8ba077b3$exports = {};
|
|
63
16
|
|
|
64
|
-
|
|
65
|
-
setIdA(idB);
|
|
66
|
-
return idB;
|
|
67
|
-
}
|
|
17
|
+
$parcel$export($5ac25c9c8ba077b3$exports, "useLayoutEffect", () => $5ac25c9c8ba077b3$export$e5c5a5f917a5871c);
|
|
68
18
|
|
|
69
|
-
|
|
19
|
+
const $5ac25c9c8ba077b3$export$e5c5a5f917a5871c = typeof window !== 'undefined' ? $5yePs$react.useLayoutEffect : ()=>{
|
|
20
|
+
};
|
|
70
21
|
|
|
71
|
-
if (setIdB) {
|
|
72
|
-
setIdB(idA);
|
|
73
|
-
return idA;
|
|
74
|
-
}
|
|
75
22
|
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
80
|
-
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
|
|
86
|
-
|
|
87
|
-
|
|
88
|
-
|
|
89
|
-
|
|
90
|
-
|
|
91
|
-
|
|
92
|
-
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
let $5b01a7ee7dba2d86$var$idsUpdaterMap = new Map();
|
|
26
|
+
function $5b01a7ee7dba2d86$export$f680877a34711e37(defaultId) {
|
|
27
|
+
let isRendering = $5yePs$useRef(true);
|
|
28
|
+
isRendering.current = true;
|
|
29
|
+
let [value, setValue] = $5yePs$useState(defaultId);
|
|
30
|
+
let nextId = $5yePs$useRef(null);
|
|
31
|
+
let res = $5yePs$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
|
+
$5b01a7ee7dba2d86$var$idsUpdaterMap.set(res, updateValue);
|
|
38
|
+
$5ac25c9c8ba077b3$export$e5c5a5f917a5871c(()=>{
|
|
39
|
+
isRendering.current = false;
|
|
40
|
+
}, [
|
|
41
|
+
updateValue
|
|
42
|
+
]);
|
|
43
|
+
$5ac25c9c8ba077b3$export$e5c5a5f917a5871c(()=>{
|
|
44
|
+
let r = res;
|
|
45
|
+
return ()=>{
|
|
46
|
+
$5b01a7ee7dba2d86$var$idsUpdaterMap.delete(r);
|
|
47
|
+
};
|
|
48
|
+
}, [
|
|
49
|
+
res
|
|
50
|
+
]);
|
|
51
|
+
$5yePs$useEffect(()=>{
|
|
52
|
+
let newId = nextId.current;
|
|
53
|
+
if (newId) {
|
|
54
|
+
setValue(newId);
|
|
55
|
+
nextId.current = null;
|
|
56
|
+
}
|
|
57
|
+
}, [
|
|
58
|
+
setValue,
|
|
59
|
+
updateValue
|
|
60
|
+
]);
|
|
61
|
+
return res;
|
|
62
|
+
}
|
|
63
|
+
function $5b01a7ee7dba2d86$export$cd8c9cb68f842629(idA, idB) {
|
|
64
|
+
if (idA === idB) return idA;
|
|
65
|
+
let setIdA = $5b01a7ee7dba2d86$var$idsUpdaterMap.get(idA);
|
|
66
|
+
if (setIdA) {
|
|
67
|
+
setIdA(idB);
|
|
68
|
+
return idB;
|
|
93
69
|
}
|
|
94
|
-
|
|
95
|
-
|
|
70
|
+
let setIdB = $5b01a7ee7dba2d86$var$idsUpdaterMap.get(idB);
|
|
71
|
+
if (setIdB) {
|
|
72
|
+
setIdB(idA);
|
|
73
|
+
return idA;
|
|
74
|
+
}
|
|
75
|
+
return idB;
|
|
76
|
+
}
|
|
77
|
+
function $5b01a7ee7dba2d86$export$b4cc09c592e8fdb8(depArray = []) {
|
|
78
|
+
let id = $5b01a7ee7dba2d86$export$f680877a34711e37();
|
|
79
|
+
let [resolvedId, setResolvedId] = $71eec9ddbfb7f6c6$export$14d238f342723f25(id);
|
|
80
|
+
let updateId = $5yePs$useCallback(()=>{
|
|
81
|
+
setResolvedId(function*() {
|
|
82
|
+
yield id;
|
|
83
|
+
yield document.getElementById(id) ? id : null;
|
|
84
|
+
});
|
|
85
|
+
}, [
|
|
86
|
+
id,
|
|
87
|
+
setResolvedId
|
|
88
|
+
]);
|
|
89
|
+
$5ac25c9c8ba077b3$export$e5c5a5f917a5871c(updateId, [
|
|
90
|
+
id,
|
|
91
|
+
updateId,
|
|
92
|
+
...depArray
|
|
93
|
+
]);
|
|
94
|
+
return resolvedId;
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
|
|
98
|
+
var $2a5eca539fe56811$exports = {};
|
|
99
|
+
|
|
100
|
+
$parcel$export($2a5eca539fe56811$exports, "chain", () => $2a5eca539fe56811$export$e08e3b67e392101e);
|
|
101
|
+
function $2a5eca539fe56811$export$e08e3b67e392101e(...callbacks) {
|
|
102
|
+
return (...args)=>{
|
|
103
|
+
for (let callback of callbacks)if (typeof callback === 'function') callback(...args);
|
|
104
|
+
};
|
|
96
105
|
}
|
|
97
106
|
|
|
98
|
-
/*
|
|
99
|
-
* Copyright 2020 Adobe. All rights reserved.
|
|
100
|
-
* This file is licensed to you under the Apache License, Version 2.0 (the "License");
|
|
101
|
-
* you may not use this file except in compliance with the License. You may obtain a copy
|
|
102
|
-
* of the License at http://www.apache.org/licenses/LICENSE-2.0
|
|
103
|
-
*
|
|
104
|
-
* Unless required by applicable law or agreed to in writing, software distributed under
|
|
105
|
-
* the License is distributed on an "AS IS" BASIS, WITHOUT WARRANTIES OR REPRESENTATIONS
|
|
106
|
-
* OF ANY KIND, either express or implied. See the License for the specific language
|
|
107
|
-
* governing permissions and limitations under the License.
|
|
108
|
-
*/
|
|
109
107
|
|
|
110
|
-
|
|
111
|
-
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
|
|
116
|
-
|
|
117
|
-
|
|
118
|
-
|
|
119
|
-
|
|
120
|
-
|
|
121
|
-
|
|
122
|
-
|
|
108
|
+
var $c42fb2a2f22e1846$exports = {};
|
|
109
|
+
|
|
110
|
+
$parcel$export($c42fb2a2f22e1846$exports, "mergeProps", () => $c42fb2a2f22e1846$export$9d1611c77c2fe928);
|
|
111
|
+
|
|
112
|
+
|
|
113
|
+
|
|
114
|
+
function $c42fb2a2f22e1846$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] = $2a5eca539fe56811$export$e08e3b67e392101e(a, b);
|
|
128
|
+
else if ((key === 'className' || key === 'UNSAFE_className') && typeof a === 'string' && typeof b === 'string') result[key] = $5yePs$clsx(a, b);
|
|
129
|
+
else if (key === 'id' && a && b) result.id = $5b01a7ee7dba2d86$export$cd8c9cb68f842629(a, b);
|
|
130
|
+
else result[key] = b !== undefined ? b : a;
|
|
131
|
+
}
|
|
123
132
|
}
|
|
124
|
-
|
|
133
|
+
return result;
|
|
134
|
+
}
|
|
135
|
+
|
|
136
|
+
|
|
137
|
+
var $f3859cd41d3e5b7d$exports = {};
|
|
138
|
+
|
|
139
|
+
$parcel$export($f3859cd41d3e5b7d$exports, "filterDOMProps", () => $f3859cd41d3e5b7d$export$457c3d6518dd4c6f);
|
|
140
|
+
const $f3859cd41d3e5b7d$var$DOMPropNames = new Set([
|
|
141
|
+
'id'
|
|
142
|
+
]);
|
|
143
|
+
const $f3859cd41d3e5b7d$var$labelablePropNames = new Set([
|
|
144
|
+
'aria-label',
|
|
145
|
+
'aria-labelledby',
|
|
146
|
+
'aria-describedby',
|
|
147
|
+
'aria-details'
|
|
148
|
+
]);
|
|
149
|
+
const $f3859cd41d3e5b7d$var$propRe = /^(data-.*)$/;
|
|
150
|
+
function $f3859cd41d3e5b7d$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) && ($f3859cd41d3e5b7d$var$DOMPropNames.has(prop) || labelable && $f3859cd41d3e5b7d$var$labelablePropNames.has(prop) || (propNames === null || propNames === void 0 ? void 0 : propNames.has(prop)) || $f3859cd41d3e5b7d$var$propRe.test(prop))) filteredProps[prop] = props[prop];
|
|
156
|
+
return filteredProps;
|
|
125
157
|
}
|
|
126
158
|
|
|
127
|
-
|
|
128
|
-
|
|
129
|
-
|
|
130
|
-
|
|
131
|
-
|
|
132
|
-
|
|
133
|
-
|
|
134
|
-
|
|
135
|
-
|
|
136
|
-
|
|
137
|
-
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
152
|
-
|
|
153
|
-
|
|
154
|
-
|
|
155
|
-
|
|
156
|
-
result.id = mergeIds(a, b); // Override others
|
|
157
|
-
} else {
|
|
158
|
-
result[key] = b !== undefined ? b : a;
|
|
159
|
-
}
|
|
159
|
+
|
|
160
|
+
var $1b46e2787874cd75$exports = {};
|
|
161
|
+
|
|
162
|
+
$parcel$export($1b46e2787874cd75$exports, "focusWithoutScrolling", () => $1b46e2787874cd75$export$de79e2c695e052f3);
|
|
163
|
+
function $1b46e2787874cd75$export$de79e2c695e052f3(element) {
|
|
164
|
+
if ($1b46e2787874cd75$var$supportsPreventScroll()) element.focus({
|
|
165
|
+
preventScroll: true
|
|
166
|
+
});
|
|
167
|
+
else {
|
|
168
|
+
let scrollableElements = $1b46e2787874cd75$var$getScrollableElements(element);
|
|
169
|
+
element.focus();
|
|
170
|
+
$1b46e2787874cd75$var$restoreScrollPosition(scrollableElements);
|
|
171
|
+
}
|
|
172
|
+
}
|
|
173
|
+
let $1b46e2787874cd75$var$supportsPreventScrollCached = null;
|
|
174
|
+
function $1b46e2787874cd75$var$supportsPreventScroll() {
|
|
175
|
+
if ($1b46e2787874cd75$var$supportsPreventScrollCached == null) {
|
|
176
|
+
$1b46e2787874cd75$var$supportsPreventScrollCached = false;
|
|
177
|
+
try {
|
|
178
|
+
var focusElem = document.createElement('div');
|
|
179
|
+
focusElem.focus({
|
|
180
|
+
get preventScroll () {
|
|
181
|
+
$1b46e2787874cd75$var$supportsPreventScrollCached = true;
|
|
182
|
+
return true;
|
|
183
|
+
}
|
|
184
|
+
});
|
|
185
|
+
} catch (e) {
|
|
186
|
+
// Ignore
|
|
187
|
+
}
|
|
160
188
|
}
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
174
|
-
labelable,
|
|
175
|
-
propNames
|
|
176
|
-
} = opts;
|
|
177
|
-
let filteredProps = {};
|
|
178
|
-
|
|
179
|
-
for (const prop in props) {
|
|
180
|
-
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))) {
|
|
181
|
-
filteredProps[prop] = props[prop];
|
|
189
|
+
return $1b46e2787874cd75$var$supportsPreventScrollCached;
|
|
190
|
+
}
|
|
191
|
+
function $1b46e2787874cd75$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;
|
|
182
202
|
}
|
|
183
|
-
|
|
184
|
-
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
// Currently necessary for Safari and old Edge:
|
|
188
|
-
// https://caniuse.com/#feat=mdn-api_htmlelement_focus_preventscroll_option
|
|
189
|
-
// See https://bugs.webkit.org/show_bug.cgi?id=178583
|
|
190
|
-
//
|
|
191
|
-
// Original licensing for the following methods can be found in the
|
|
192
|
-
// NOTICE file in the root directory of this source tree.
|
|
193
|
-
// See https://github.com/calvellido/focus-options-polyfill
|
|
194
|
-
export function focusWithoutScrolling(element) {
|
|
195
|
-
if ($bc7c9c3af78f5218ff72cecce15730$var$supportsPreventScroll()) {
|
|
196
|
-
element.focus({
|
|
197
|
-
preventScroll: true
|
|
203
|
+
if (rootScrollingElement instanceof HTMLElement) scrollableElements.push({
|
|
204
|
+
element: rootScrollingElement,
|
|
205
|
+
scrollTop: rootScrollingElement.scrollTop,
|
|
206
|
+
scrollLeft: rootScrollingElement.scrollLeft
|
|
198
207
|
});
|
|
199
|
-
|
|
200
|
-
|
|
201
|
-
|
|
202
|
-
|
|
203
|
-
|
|
204
|
-
|
|
205
|
-
let $bc7c9c3af78f5218ff72cecce15730$var$supportsPreventScrollCached = null;
|
|
206
|
-
|
|
207
|
-
function $bc7c9c3af78f5218ff72cecce15730$var$supportsPreventScroll() {
|
|
208
|
-
if ($bc7c9c3af78f5218ff72cecce15730$var$supportsPreventScrollCached == null) {
|
|
209
|
-
$bc7c9c3af78f5218ff72cecce15730$var$supportsPreventScrollCached = false;
|
|
210
|
-
|
|
211
|
-
try {
|
|
212
|
-
var focusElem = document.createElement('div');
|
|
213
|
-
focusElem.focus({
|
|
214
|
-
get preventScroll() {
|
|
215
|
-
$bc7c9c3af78f5218ff72cecce15730$var$supportsPreventScrollCached = true;
|
|
216
|
-
return true;
|
|
217
|
-
}
|
|
218
|
-
|
|
219
|
-
});
|
|
220
|
-
} catch (e) {// Ignore
|
|
208
|
+
return scrollableElements;
|
|
209
|
+
}
|
|
210
|
+
function $1b46e2787874cd75$var$restoreScrollPosition(scrollableElements) {
|
|
211
|
+
for (let { element: element , scrollTop: scrollTop , scrollLeft: scrollLeft } of scrollableElements){
|
|
212
|
+
element.scrollTop = scrollTop;
|
|
213
|
+
element.scrollLeft = scrollLeft;
|
|
221
214
|
}
|
|
222
|
-
}
|
|
223
|
-
|
|
224
|
-
return $bc7c9c3af78f5218ff72cecce15730$var$supportsPreventScrollCached;
|
|
225
215
|
}
|
|
226
216
|
|
|
227
|
-
function $bc7c9c3af78f5218ff72cecce15730$var$getScrollableElements(element) {
|
|
228
|
-
var parent = element.parentNode;
|
|
229
|
-
var scrollableElements = [];
|
|
230
|
-
var rootScrollingElement = document.scrollingElement || document.documentElement;
|
|
231
217
|
|
|
232
|
-
|
|
233
|
-
if (parent.offsetHeight < parent.scrollHeight || parent.offsetWidth < parent.scrollWidth) {
|
|
234
|
-
scrollableElements.push({
|
|
235
|
-
element: parent,
|
|
236
|
-
scrollTop: parent.scrollTop,
|
|
237
|
-
scrollLeft: parent.scrollLeft
|
|
238
|
-
});
|
|
239
|
-
}
|
|
218
|
+
var $fbd35a31e994df41$exports = {};
|
|
240
219
|
|
|
241
|
-
|
|
242
|
-
|
|
220
|
+
$parcel$export($fbd35a31e994df41$exports, "getOffset", () => $fbd35a31e994df41$export$622cea445a1c5b7d);
|
|
221
|
+
function $fbd35a31e994df41$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
|
+
}
|
|
243
226
|
|
|
244
|
-
if (rootScrollingElement instanceof HTMLElement) {
|
|
245
|
-
scrollableElements.push({
|
|
246
|
-
element: rootScrollingElement,
|
|
247
|
-
scrollTop: rootScrollingElement.scrollTop,
|
|
248
|
-
scrollLeft: rootScrollingElement.scrollLeft
|
|
249
|
-
});
|
|
250
|
-
}
|
|
251
227
|
|
|
252
|
-
|
|
253
|
-
}
|
|
228
|
+
var $691ac3ad1af88e64$exports = {};
|
|
254
229
|
|
|
255
|
-
|
|
256
|
-
|
|
257
|
-
element,
|
|
258
|
-
scrollTop,
|
|
259
|
-
scrollLeft
|
|
260
|
-
} of scrollableElements) {
|
|
261
|
-
element.scrollTop = scrollTop;
|
|
262
|
-
element.scrollLeft = scrollLeft;
|
|
263
|
-
}
|
|
264
|
-
}
|
|
230
|
+
$parcel$export($691ac3ad1af88e64$exports, "clamp", () => $691ac3ad1af88e64$re_export$clamp);
|
|
231
|
+
$parcel$export($691ac3ad1af88e64$exports, "snapValueToStep", () => $691ac3ad1af88e64$re_export$snapValueToStep);
|
|
265
232
|
|
|
266
|
-
export function getOffset(element, reverse, orientation) {
|
|
267
|
-
if (orientation === void 0) {
|
|
268
|
-
orientation = 'horizontal';
|
|
269
|
-
}
|
|
270
233
|
|
|
271
|
-
let rect = element.getBoundingClientRect();
|
|
272
234
|
|
|
273
|
-
|
|
274
|
-
return orientation === 'horizontal' ? rect.right : rect.bottom;
|
|
275
|
-
}
|
|
235
|
+
var $51de12ccb2f75a87$exports = {};
|
|
276
236
|
|
|
277
|
-
|
|
278
|
-
|
|
237
|
+
$parcel$export($51de12ccb2f75a87$exports, "runAfterTransition", () => $51de12ccb2f75a87$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,
|
|
279
249
|
// mapped to a set of CSS properties that are transitioning for that element.
|
|
280
250
|
// This is necessary rather than a simple count of transitions because of browser
|
|
281
251
|
// bugs, e.g. Chrome sometimes fires both transitionend and transitioncancel rather
|
|
282
252
|
// than one or the other. So we need to track what's actually transitioning so that
|
|
283
253
|
// we can ignore these duplicate events.
|
|
284
|
-
let $
|
|
285
|
-
|
|
286
|
-
let $
|
|
287
|
-
|
|
288
|
-
|
|
289
|
-
|
|
290
|
-
|
|
291
|
-
|
|
292
|
-
|
|
293
|
-
|
|
294
|
-
|
|
295
|
-
|
|
296
|
-
|
|
297
|
-
|
|
298
|
-
|
|
299
|
-
|
|
300
|
-
|
|
301
|
-
|
|
302
|
-
|
|
303
|
-
|
|
304
|
-
|
|
305
|
-
|
|
306
|
-
|
|
307
|
-
|
|
308
|
-
|
|
309
|
-
|
|
310
|
-
|
|
311
|
-
|
|
312
|
-
|
|
313
|
-
|
|
314
|
-
|
|
315
|
-
|
|
316
|
-
|
|
317
|
-
|
|
318
|
-
|
|
319
|
-
|
|
320
|
-
e.target.removeEventListener('transitioncancel', onTransitionEnd);
|
|
321
|
-
$b3e8d5c5f32fa26afa6df1b81f09b6b8$var$transitionsByElement.delete(e.target);
|
|
322
|
-
} // If no transitioning elements, call all of the queued callbacks.
|
|
323
|
-
|
|
324
|
-
|
|
325
|
-
if ($b3e8d5c5f32fa26afa6df1b81f09b6b8$var$transitionsByElement.size === 0) {
|
|
326
|
-
for (let cb of $b3e8d5c5f32fa26afa6df1b81f09b6b8$var$transitionCallbacks) {
|
|
327
|
-
cb();
|
|
328
|
-
}
|
|
329
|
-
|
|
330
|
-
$b3e8d5c5f32fa26afa6df1b81f09b6b8$var$transitionCallbacks.clear();
|
|
331
|
-
}
|
|
332
|
-
};
|
|
333
|
-
|
|
334
|
-
document.body.addEventListener('transitionrun', onTransitionStart);
|
|
335
|
-
document.body.addEventListener('transitionend', onTransitionEnd);
|
|
254
|
+
let $51de12ccb2f75a87$var$transitionsByElement = new Map();
|
|
255
|
+
// A list of callbacks to call once there are no transitioning elements.
|
|
256
|
+
let $51de12ccb2f75a87$var$transitionCallbacks = new Set();
|
|
257
|
+
function $51de12ccb2f75a87$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 = $51de12ccb2f75a87$var$transitionsByElement.get(e.target);
|
|
262
|
+
if (!transitions) {
|
|
263
|
+
transitions = new Set();
|
|
264
|
+
$51de12ccb2f75a87$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);
|
|
269
|
+
}
|
|
270
|
+
transitions.add(e.propertyName);
|
|
271
|
+
};
|
|
272
|
+
let onTransitionEnd = (e)=>{
|
|
273
|
+
// Remove property from list of transitioning properties.
|
|
274
|
+
let properties = $51de12ccb2f75a87$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
|
+
$51de12ccb2f75a87$var$transitionsByElement.delete(e.target);
|
|
281
|
+
}
|
|
282
|
+
// If no transitioning elements, call all of the queued callbacks.
|
|
283
|
+
if ($51de12ccb2f75a87$var$transitionsByElement.size === 0) {
|
|
284
|
+
for (let cb of $51de12ccb2f75a87$var$transitionCallbacks)cb();
|
|
285
|
+
$51de12ccb2f75a87$var$transitionCallbacks.clear();
|
|
286
|
+
}
|
|
287
|
+
};
|
|
288
|
+
document.body.addEventListener('transitionrun', onTransitionStart);
|
|
289
|
+
document.body.addEventListener('transitionend', onTransitionEnd);
|
|
336
290
|
}
|
|
337
|
-
|
|
338
291
|
if (typeof document !== 'undefined') {
|
|
339
|
-
|
|
340
|
-
$
|
|
341
|
-
|
|
342
|
-
|
|
343
|
-
|
|
344
|
-
|
|
345
|
-
|
|
346
|
-
|
|
347
|
-
|
|
348
|
-
|
|
349
|
-
|
|
350
|
-
// Otherwise, add it to a list of callbacks to run at the end of the animation.
|
|
351
|
-
if ($b3e8d5c5f32fa26afa6df1b81f09b6b8$var$transitionsByElement.size === 0) {
|
|
352
|
-
fn();
|
|
353
|
-
} else {
|
|
354
|
-
$b3e8d5c5f32fa26afa6df1b81f09b6b8$var$transitionCallbacks.add(fn);
|
|
355
|
-
}
|
|
356
|
-
});
|
|
292
|
+
if (document.readyState !== 'loading') $51de12ccb2f75a87$var$setupGlobalEvents();
|
|
293
|
+
else document.addEventListener('DOMContentLoaded', $51de12ccb2f75a87$var$setupGlobalEvents);
|
|
294
|
+
}
|
|
295
|
+
function $51de12ccb2f75a87$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 ($51de12ccb2f75a87$var$transitionsByElement.size === 0) fn();
|
|
301
|
+
else $51de12ccb2f75a87$var$transitionCallbacks.add(fn);
|
|
302
|
+
});
|
|
357
303
|
}
|
|
358
|
-
// Keep track of elements that we are currently handling dragging for via useDrag1D.
|
|
359
|
-
// If there's an ancestor and a descendant both using useDrag1D(), and the user starts
|
|
360
|
-
// dragging the descendant, we don't want useDrag1D events to fire for the ancestor.
|
|
361
|
-
const $be9622dfd8e876c0943b0b4e429554f3$var$draggingElements = []; // created for splitview, this should be reusable for things like sliders/dials
|
|
362
|
-
// 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
|
|
363
|
-
// It can also take a 'reverse' param to say if we should measure from the right/bottom instead of the top/left
|
|
364
|
-
// It can also handle either a vertical or horizontal movement, but not both at the same time
|
|
365
|
-
|
|
366
|
-
export function useDrag1D(props) {
|
|
367
|
-
console.warn('useDrag1D is deprecated, please use `useMove` instead https://react-spectrum.adobe.com/react-aria/useMove.html');
|
|
368
|
-
let {
|
|
369
|
-
containerRef,
|
|
370
|
-
reverse,
|
|
371
|
-
orientation,
|
|
372
|
-
onHover,
|
|
373
|
-
onDrag,
|
|
374
|
-
onPositionChange,
|
|
375
|
-
onIncrement,
|
|
376
|
-
onDecrement,
|
|
377
|
-
onIncrementToMax,
|
|
378
|
-
onDecrementToMin,
|
|
379
|
-
onCollapseToggle
|
|
380
|
-
} = props;
|
|
381
|
-
|
|
382
|
-
let getPosition = e => orientation === 'horizontal' ? e.clientX : e.clientY;
|
|
383
|
-
|
|
384
|
-
let getNextOffset = e => {
|
|
385
|
-
let containerOffset = getOffset(containerRef.current, reverse, orientation);
|
|
386
|
-
let mouseOffset = getPosition(e);
|
|
387
|
-
let nextOffset = reverse ? containerOffset - mouseOffset : mouseOffset - containerOffset;
|
|
388
|
-
return nextOffset;
|
|
389
|
-
};
|
|
390
|
-
|
|
391
|
-
let dragging = useRef(false);
|
|
392
|
-
let prevPosition = useRef(0); // Keep track of the current handlers in a ref so that the events can access them.
|
|
393
|
-
|
|
394
|
-
let handlers = useRef({
|
|
395
|
-
onPositionChange,
|
|
396
|
-
onDrag
|
|
397
|
-
});
|
|
398
|
-
handlers.current.onDrag = onDrag;
|
|
399
|
-
handlers.current.onPositionChange = onPositionChange;
|
|
400
|
-
|
|
401
|
-
let onMouseDragged = e => {
|
|
402
|
-
e.preventDefault();
|
|
403
|
-
let nextOffset = getNextOffset(e);
|
|
404
|
-
|
|
405
|
-
if (!dragging.current) {
|
|
406
|
-
dragging.current = true;
|
|
407
|
-
|
|
408
|
-
if (handlers.current.onDrag) {
|
|
409
|
-
handlers.current.onDrag(true);
|
|
410
|
-
}
|
|
411
|
-
|
|
412
|
-
if (handlers.current.onPositionChange) {
|
|
413
|
-
handlers.current.onPositionChange(nextOffset);
|
|
414
|
-
}
|
|
415
|
-
}
|
|
416
304
|
|
|
417
|
-
if (prevPosition.current === nextOffset) {
|
|
418
|
-
return;
|
|
419
|
-
}
|
|
420
305
|
|
|
421
|
-
|
|
306
|
+
var $b8aeddd69b238bce$exports = {};
|
|
422
307
|
|
|
423
|
-
|
|
424
|
-
onPositionChange(nextOffset);
|
|
425
|
-
}
|
|
426
|
-
};
|
|
308
|
+
$parcel$export($b8aeddd69b238bce$exports, "useDrag1D", () => $b8aeddd69b238bce$export$7bbed75feba39706);
|
|
427
309
|
|
|
428
|
-
let onMouseUp = e => {
|
|
429
|
-
const target = e.target;
|
|
430
|
-
dragging.current = false;
|
|
431
|
-
let nextOffset = getNextOffset(e);
|
|
432
|
-
|
|
433
|
-
if (handlers.current.onDrag) {
|
|
434
|
-
handlers.current.onDrag(false);
|
|
435
|
-
}
|
|
436
310
|
|
|
437
|
-
|
|
438
|
-
|
|
439
|
-
|
|
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 $b8aeddd69b238bce$var$draggingElements = [];
|
|
315
|
+
function $b8aeddd69b238bce$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 = $fbd35a31e994df41$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 = $5yePs$useRef(false);
|
|
327
|
+
let prevPosition = $5yePs$useRef(0);
|
|
328
|
+
// Keep track of the current handlers in a ref so that the events can access them.
|
|
329
|
+
let handlers = $5yePs$useRef({
|
|
330
|
+
onPositionChange: onPositionChange,
|
|
331
|
+
onDrag: onDrag
|
|
332
|
+
});
|
|
333
|
+
handlers.current.onDrag = onDrag;
|
|
334
|
+
handlers.current.onPositionChange = onPositionChange;
|
|
335
|
+
let onMouseDragged = (e)=>{
|
|
336
|
+
e.preventDefault();
|
|
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);
|
|
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
|
+
$b8aeddd69b238bce$var$draggingElements.splice($b8aeddd69b238bce$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 ($b8aeddd69b238bce$var$draggingElements.some((elt)=>target.contains(elt)
|
|
362
|
+
)) return;
|
|
363
|
+
$b8aeddd69b238bce$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
|
+
}
|
|
440
428
|
|
|
441
|
-
$be9622dfd8e876c0943b0b4e429554f3$var$draggingElements.splice($be9622dfd8e876c0943b0b4e429554f3$var$draggingElements.indexOf(target), 1);
|
|
442
|
-
window.removeEventListener('mouseup', onMouseUp, false);
|
|
443
|
-
window.removeEventListener('mousemove', onMouseDragged, false);
|
|
444
|
-
};
|
|
445
429
|
|
|
446
|
-
|
|
447
|
-
|
|
448
|
-
|
|
430
|
+
var $ce924e419b398d4c$exports = {};
|
|
431
|
+
|
|
432
|
+
$parcel$export($ce924e419b398d4c$exports, "useGlobalListeners", () => $ce924e419b398d4c$export$4eaf04e54aa8eed6);
|
|
433
|
+
|
|
434
|
+
function $ce924e419b398d4c$export$4eaf04e54aa8eed6() {
|
|
435
|
+
let globalListeners = $5yePs$useRef(new Map());
|
|
436
|
+
let addGlobalListener = $5yePs$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 = $5yePs$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 = $5yePs$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
|
+
$5yePs$useEffect(()=>{
|
|
465
|
+
return removeAllGlobalListeners;
|
|
466
|
+
}, [
|
|
467
|
+
removeAllGlobalListeners
|
|
468
|
+
]);
|
|
469
|
+
return {
|
|
470
|
+
addGlobalListener: addGlobalListener,
|
|
471
|
+
removeGlobalListener: removeGlobalListener,
|
|
472
|
+
removeAllGlobalListeners: removeAllGlobalListeners
|
|
473
|
+
};
|
|
474
|
+
}
|
|
449
475
|
|
|
450
|
-
if ($be9622dfd8e876c0943b0b4e429554f3$var$draggingElements.some(elt => target.contains(elt))) {
|
|
451
|
-
return;
|
|
452
|
-
}
|
|
453
476
|
|
|
454
|
-
|
|
455
|
-
|
|
456
|
-
|
|
457
|
-
|
|
477
|
+
var $71a2c5844f2b60a4$exports = {};
|
|
478
|
+
|
|
479
|
+
$parcel$export($71a2c5844f2b60a4$exports, "useLabels", () => $71a2c5844f2b60a4$export$d6875122194c7b44);
|
|
480
|
+
|
|
481
|
+
function $71a2c5844f2b60a4$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 = $5b01a7ee7dba2d86$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
|
+
}
|
|
458
503
|
|
|
459
|
-
let onMouseEnter = () => {
|
|
460
|
-
if (onHover) {
|
|
461
|
-
onHover(true);
|
|
462
|
-
}
|
|
463
|
-
};
|
|
464
504
|
|
|
465
|
-
|
|
466
|
-
if (onHover) {
|
|
467
|
-
onHover(false);
|
|
468
|
-
}
|
|
469
|
-
};
|
|
470
|
-
|
|
471
|
-
let onKeyDown = e => {
|
|
472
|
-
switch (e.key) {
|
|
473
|
-
case 'Left':
|
|
474
|
-
case 'ArrowLeft':
|
|
475
|
-
if (orientation === 'horizontal') {
|
|
476
|
-
e.preventDefault();
|
|
477
|
-
|
|
478
|
-
if (onDecrement && !reverse) {
|
|
479
|
-
onDecrement();
|
|
480
|
-
} else if (onIncrement && reverse) {
|
|
481
|
-
onIncrement();
|
|
482
|
-
}
|
|
483
|
-
}
|
|
505
|
+
var $a235e7a487a1e81a$exports = {};
|
|
484
506
|
|
|
485
|
-
|
|
507
|
+
$parcel$export($a235e7a487a1e81a$exports, "useObjectRef", () => $a235e7a487a1e81a$export$4338b53315abf666);
|
|
486
508
|
|
|
487
|
-
case 'Up':
|
|
488
|
-
case 'ArrowUp':
|
|
489
|
-
if (orientation === 'vertical') {
|
|
490
|
-
e.preventDefault();
|
|
491
509
|
|
|
492
|
-
|
|
493
|
-
|
|
494
|
-
|
|
495
|
-
|
|
496
|
-
|
|
497
|
-
|
|
510
|
+
function $a235e7a487a1e81a$export$4338b53315abf666(forwardedRef) {
|
|
511
|
+
const objRef = $5yePs$useRef();
|
|
512
|
+
/**
|
|
513
|
+
* We're using `useLayoutEffect` here instead of `useEffect` because we want
|
|
514
|
+
* to make sure that the `ref` value is up to date before other places in the
|
|
515
|
+
* the execution cycle try to read it.
|
|
516
|
+
*/ $5ac25c9c8ba077b3$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
|
+
}
|
|
498
525
|
|
|
499
|
-
break;
|
|
500
526
|
|
|
501
|
-
|
|
502
|
-
case 'ArrowRight':
|
|
503
|
-
if (orientation === 'horizontal') {
|
|
504
|
-
e.preventDefault();
|
|
527
|
+
var $2a91c3126c559388$exports = {};
|
|
505
528
|
|
|
506
|
-
|
|
507
|
-
onIncrement();
|
|
508
|
-
} else if (onDecrement && reverse) {
|
|
509
|
-
onDecrement();
|
|
510
|
-
}
|
|
511
|
-
}
|
|
529
|
+
$parcel$export($2a91c3126c559388$exports, "useUpdateEffect", () => $2a91c3126c559388$export$496315a1608d9602);
|
|
512
530
|
|
|
513
|
-
|
|
531
|
+
function $2a91c3126c559388$export$496315a1608d9602(effect, dependencies) {
|
|
532
|
+
const isInitialMount = $5yePs$useRef(true);
|
|
533
|
+
$5yePs$useEffect(()=>{
|
|
534
|
+
if (isInitialMount.current) isInitialMount.current = false;
|
|
535
|
+
else effect();
|
|
536
|
+
// eslint-disable-next-line react-hooks/exhaustive-deps
|
|
537
|
+
}, dependencies);
|
|
538
|
+
}
|
|
514
539
|
|
|
515
|
-
case 'Down':
|
|
516
|
-
case 'ArrowDown':
|
|
517
|
-
if (orientation === 'vertical') {
|
|
518
|
-
e.preventDefault();
|
|
519
540
|
|
|
520
|
-
if (onIncrement && !reverse) {
|
|
521
|
-
onIncrement();
|
|
522
|
-
} else if (onDecrement && reverse) {
|
|
523
|
-
onDecrement();
|
|
524
|
-
}
|
|
525
|
-
}
|
|
526
541
|
|
|
527
|
-
|
|
542
|
+
var $3e864361342e1b32$exports = {};
|
|
528
543
|
|
|
529
|
-
|
|
530
|
-
e.preventDefault();
|
|
544
|
+
$parcel$export($3e864361342e1b32$exports, "useResizeObserver", () => $3e864361342e1b32$export$683480f191c0e3ea);
|
|
531
545
|
|
|
532
|
-
|
|
533
|
-
|
|
546
|
+
function $3e864361342e1b32$var$hasResizeObserver() {
|
|
547
|
+
return typeof window.ResizeObserver !== 'undefined';
|
|
548
|
+
}
|
|
549
|
+
function $3e864361342e1b32$export$683480f191c0e3ea(options) {
|
|
550
|
+
const { ref: ref , onResize: onResize } = options;
|
|
551
|
+
$5yePs$useEffect(()=>{
|
|
552
|
+
let element = ref === null || ref === void 0 ? void 0 : ref.current;
|
|
553
|
+
if (!element) return;
|
|
554
|
+
if (!$3e864361342e1b32$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
|
+
};
|
|
534
568
|
}
|
|
569
|
+
}, [
|
|
570
|
+
onResize,
|
|
571
|
+
ref
|
|
572
|
+
]);
|
|
573
|
+
}
|
|
535
574
|
|
|
536
|
-
break;
|
|
537
|
-
|
|
538
|
-
case 'End':
|
|
539
|
-
e.preventDefault();
|
|
540
575
|
|
|
541
|
-
|
|
542
|
-
onIncrementToMax();
|
|
543
|
-
}
|
|
576
|
+
var $0b7d7b0ae05ba812$exports = {};
|
|
544
577
|
|
|
545
|
-
|
|
578
|
+
$parcel$export($0b7d7b0ae05ba812$exports, "useSyncRef", () => $0b7d7b0ae05ba812$export$4debdb1a3f0fa79e);
|
|
546
579
|
|
|
547
|
-
|
|
548
|
-
|
|
549
|
-
|
|
550
|
-
|
|
551
|
-
|
|
580
|
+
function $0b7d7b0ae05ba812$export$4debdb1a3f0fa79e(context, ref) {
|
|
581
|
+
$5ac25c9c8ba077b3$export$e5c5a5f917a5871c(()=>{
|
|
582
|
+
if (context && context.ref && ref) {
|
|
583
|
+
context.ref.current = ref.current;
|
|
584
|
+
return ()=>{
|
|
585
|
+
context.ref.current = null;
|
|
586
|
+
};
|
|
552
587
|
}
|
|
553
|
-
|
|
554
|
-
|
|
555
|
-
|
|
556
|
-
|
|
557
|
-
|
|
558
|
-
return {
|
|
559
|
-
onMouseDown,
|
|
560
|
-
onMouseEnter,
|
|
561
|
-
onMouseOut,
|
|
562
|
-
onKeyDown
|
|
563
|
-
};
|
|
564
|
-
}
|
|
565
|
-
export function useGlobalListeners() {
|
|
566
|
-
let globalListeners = useRef(new Map());
|
|
567
|
-
let addGlobalListener = useCallback((eventTarget, type, listener, options) => {
|
|
568
|
-
globalListeners.current.set(listener, {
|
|
569
|
-
type,
|
|
570
|
-
eventTarget,
|
|
571
|
-
options
|
|
572
|
-
});
|
|
573
|
-
eventTarget.addEventListener(type, listener, options);
|
|
574
|
-
}, []);
|
|
575
|
-
let removeGlobalListener = useCallback((eventTarget, type, listener, options) => {
|
|
576
|
-
eventTarget.removeEventListener(type, listener, options);
|
|
577
|
-
globalListeners.current.delete(listener);
|
|
578
|
-
}, []);
|
|
579
|
-
let removeAllGlobalListeners = useCallback(() => {
|
|
580
|
-
globalListeners.current.forEach((value, key) => {
|
|
581
|
-
removeGlobalListener(value.eventTarget, value.type, key, value.options);
|
|
582
|
-
});
|
|
583
|
-
}, [removeGlobalListener]);
|
|
584
|
-
useEffect(() => {
|
|
585
|
-
return removeAllGlobalListeners;
|
|
586
|
-
}, [removeAllGlobalListeners]);
|
|
587
|
-
return {
|
|
588
|
-
addGlobalListener,
|
|
589
|
-
removeGlobalListener,
|
|
590
|
-
removeAllGlobalListeners
|
|
591
|
-
};
|
|
588
|
+
}, [
|
|
589
|
+
context,
|
|
590
|
+
ref
|
|
591
|
+
]);
|
|
592
592
|
}
|
|
593
593
|
|
|
594
|
-
/**
|
|
595
|
-
* Merges aria-label and aria-labelledby into aria-labelledby when both exist.
|
|
596
|
-
* @param props - Aria label props.
|
|
597
|
-
* @param defaultLabel - Default value for aria-label when not present.
|
|
598
|
-
*/
|
|
599
|
-
export function useLabels(props, defaultLabel) {
|
|
600
|
-
let {
|
|
601
|
-
id,
|
|
602
|
-
'aria-label': label,
|
|
603
|
-
'aria-labelledby': labelledBy
|
|
604
|
-
} = props; // If there is both an aria-label and aria-labelledby,
|
|
605
|
-
// combine them by pointing to the element itself.
|
|
606
|
-
|
|
607
|
-
id = useId(id);
|
|
608
|
-
|
|
609
|
-
if (labelledBy && label) {
|
|
610
|
-
let ids = new Set([...labelledBy.trim().split(/\s+/), id]);
|
|
611
|
-
labelledBy = [...ids].join(' ');
|
|
612
|
-
} else if (labelledBy) {
|
|
613
|
-
labelledBy = labelledBy.trim().split(/\s+/).join(' ');
|
|
614
|
-
} // If no labels are provided, use the default
|
|
615
|
-
|
|
616
|
-
|
|
617
|
-
if (!label && !labelledBy && defaultLabel) {
|
|
618
|
-
label = defaultLabel;
|
|
619
|
-
}
|
|
620
|
-
|
|
621
|
-
return {
|
|
622
|
-
id,
|
|
623
|
-
'aria-label': label,
|
|
624
|
-
'aria-labelledby': labelledBy
|
|
625
|
-
};
|
|
626
|
-
}
|
|
627
|
-
// Like useEffect, but only called for updates after the initial render.
|
|
628
|
-
export function useUpdateEffect(effect, dependencies) {
|
|
629
|
-
const isInitialMount = useRef(true);
|
|
630
|
-
useEffect(() => {
|
|
631
|
-
if (isInitialMount.current) {
|
|
632
|
-
isInitialMount.current = false;
|
|
633
|
-
} else {
|
|
634
|
-
effect();
|
|
635
|
-
} // eslint-disable-next-line react-hooks/exhaustive-deps
|
|
636
|
-
|
|
637
|
-
}, dependencies);
|
|
638
|
-
}
|
|
639
|
-
|
|
640
|
-
function $d642970c01dc21e3fe2261c17768$var$hasResizeObserver() {
|
|
641
|
-
return typeof window.ResizeObserver !== 'undefined';
|
|
642
|
-
}
|
|
643
|
-
|
|
644
|
-
export function useResizeObserver(options) {
|
|
645
|
-
const {
|
|
646
|
-
ref,
|
|
647
|
-
onResize
|
|
648
|
-
} = options;
|
|
649
|
-
useEffect(() => {
|
|
650
|
-
let element = ref == null ? void 0 : ref.current;
|
|
651
|
-
|
|
652
|
-
if (!element) {
|
|
653
|
-
return;
|
|
654
|
-
}
|
|
655
594
|
|
|
656
|
-
|
|
657
|
-
window.addEventListener('resize', onResize, false);
|
|
658
|
-
return () => {
|
|
659
|
-
window.removeEventListener('resize', onResize, false);
|
|
660
|
-
};
|
|
661
|
-
} else {
|
|
662
|
-
const resizeObserverInstance = new window.ResizeObserver(entries => {
|
|
663
|
-
if (!entries.length) {
|
|
664
|
-
return;
|
|
665
|
-
}
|
|
595
|
+
var $0ac9283dcb18fed4$exports = {};
|
|
666
596
|
|
|
667
|
-
|
|
668
|
-
|
|
669
|
-
|
|
670
|
-
|
|
671
|
-
if (element) {
|
|
672
|
-
resizeObserverInstance.unobserve(element);
|
|
673
|
-
}
|
|
674
|
-
};
|
|
675
|
-
}
|
|
676
|
-
}, [onResize, ref]);
|
|
677
|
-
}
|
|
678
|
-
// Syncs ref from context with ref passed to hook
|
|
679
|
-
export function useSyncRef(context, ref) {
|
|
680
|
-
useLayoutEffect(() => {
|
|
681
|
-
if (context && context.ref && ref) {
|
|
682
|
-
context.ref.current = ref.current;
|
|
683
|
-
return () => {
|
|
684
|
-
context.ref.current = null;
|
|
685
|
-
};
|
|
686
|
-
}
|
|
687
|
-
}, [context, ref]);
|
|
688
|
-
}
|
|
689
|
-
export function getScrollParent(node) {
|
|
690
|
-
while (node && !$a164c39662575b65a0b01a73e313e5$var$isScrollable(node)) {
|
|
691
|
-
node = node.parentElement;
|
|
692
|
-
}
|
|
693
|
-
|
|
694
|
-
return node || document.scrollingElement || document.documentElement;
|
|
597
|
+
$parcel$export($0ac9283dcb18fed4$exports, "getScrollParent", () => $0ac9283dcb18fed4$export$cfa2225e87938781);
|
|
598
|
+
function $0ac9283dcb18fed4$export$cfa2225e87938781(node) {
|
|
599
|
+
while(node && !$0ac9283dcb18fed4$var$isScrollable(node))node = node.parentElement;
|
|
600
|
+
return node || document.scrollingElement || document.documentElement;
|
|
695
601
|
}
|
|
696
|
-
|
|
697
|
-
|
|
698
|
-
|
|
699
|
-
return /(auto|scroll)/.test(style.overflow + style.overflowX + style.overflowY);
|
|
602
|
+
function $0ac9283dcb18fed4$var$isScrollable(node) {
|
|
603
|
+
let style = window.getComputedStyle(node);
|
|
604
|
+
return /(auto|scroll)/.test(style.overflow + style.overflowX + style.overflowY);
|
|
700
605
|
}
|
|
701
606
|
|
|
702
|
-
// @ts-ignore
|
|
703
|
-
let $d662329747d896105af008c761523$var$visualViewport = typeof window !== 'undefined' && window.visualViewport;
|
|
704
|
-
export function useViewportSize() {
|
|
705
|
-
let [size, setSize] = useState(() => $d662329747d896105af008c761523$var$getViewportSize());
|
|
706
|
-
useEffect(() => {
|
|
707
|
-
// Use visualViewport api to track available height even on iOS virtual keyboard opening
|
|
708
|
-
let onResize = () => {
|
|
709
|
-
setSize(size => {
|
|
710
|
-
let newSize = $d662329747d896105af008c761523$var$getViewportSize();
|
|
711
|
-
|
|
712
|
-
if (newSize.width === size.width && newSize.height === size.height) {
|
|
713
|
-
return size;
|
|
714
|
-
}
|
|
715
607
|
|
|
716
|
-
|
|
717
|
-
});
|
|
718
|
-
};
|
|
608
|
+
var $9ab7274bc657ab6d$exports = {};
|
|
719
609
|
|
|
720
|
-
|
|
721
|
-
window.addEventListener('resize', onResize);
|
|
722
|
-
} else {
|
|
723
|
-
$d662329747d896105af008c761523$var$visualViewport.addEventListener('resize', onResize);
|
|
724
|
-
}
|
|
610
|
+
$parcel$export($9ab7274bc657ab6d$exports, "useViewportSize", () => $9ab7274bc657ab6d$export$d699905dd57c73ca);
|
|
725
611
|
|
|
726
|
-
|
|
727
|
-
|
|
728
|
-
|
|
729
|
-
|
|
730
|
-
|
|
731
|
-
|
|
612
|
+
// @ts-ignore
|
|
613
|
+
let $9ab7274bc657ab6d$var$visualViewport = typeof window !== 'undefined' && window.visualViewport;
|
|
614
|
+
function $9ab7274bc657ab6d$export$d699905dd57c73ca() {
|
|
615
|
+
let [size1, setSize] = $5yePs$useState(()=>$9ab7274bc657ab6d$var$getViewportSize()
|
|
616
|
+
);
|
|
617
|
+
$5yePs$useEffect(()=>{
|
|
618
|
+
// Use visualViewport api to track available height even on iOS virtual keyboard opening
|
|
619
|
+
let onResize = ()=>{
|
|
620
|
+
setSize((size)=>{
|
|
621
|
+
let newSize = $9ab7274bc657ab6d$var$getViewportSize();
|
|
622
|
+
if (newSize.width === size.width && newSize.height === size.height) return size;
|
|
623
|
+
return newSize;
|
|
624
|
+
});
|
|
625
|
+
};
|
|
626
|
+
if (!$9ab7274bc657ab6d$var$visualViewport) window.addEventListener('resize', onResize);
|
|
627
|
+
else $9ab7274bc657ab6d$var$visualViewport.addEventListener('resize', onResize);
|
|
628
|
+
return ()=>{
|
|
629
|
+
if (!$9ab7274bc657ab6d$var$visualViewport) window.removeEventListener('resize', onResize);
|
|
630
|
+
else $9ab7274bc657ab6d$var$visualViewport.removeEventListener('resize', onResize);
|
|
631
|
+
};
|
|
632
|
+
}, []);
|
|
633
|
+
return size1;
|
|
634
|
+
}
|
|
635
|
+
function $9ab7274bc657ab6d$var$getViewportSize() {
|
|
636
|
+
return {
|
|
637
|
+
width: ($9ab7274bc657ab6d$var$visualViewport === null || $9ab7274bc657ab6d$var$visualViewport === void 0 ? void 0 : $9ab7274bc657ab6d$var$visualViewport.width) || window.innerWidth,
|
|
638
|
+
height: ($9ab7274bc657ab6d$var$visualViewport === null || $9ab7274bc657ab6d$var$visualViewport === void 0 ? void 0 : $9ab7274bc657ab6d$var$visualViewport.height) || window.innerHeight
|
|
732
639
|
};
|
|
733
|
-
}, []);
|
|
734
|
-
return size;
|
|
735
640
|
}
|
|
736
641
|
|
|
737
|
-
function $d662329747d896105af008c761523$var$getViewportSize() {
|
|
738
|
-
return {
|
|
739
|
-
width: ($d662329747d896105af008c761523$var$visualViewport == null ? void 0 : $d662329747d896105af008c761523$var$visualViewport.width) || window.innerWidth,
|
|
740
|
-
height: ($d662329747d896105af008c761523$var$visualViewport == null ? void 0 : $d662329747d896105af008c761523$var$visualViewport.height) || window.innerHeight
|
|
741
|
-
};
|
|
742
|
-
}
|
|
743
|
-
|
|
744
|
-
let $c8aa524f123a75a64d51e06d16b9568$var$descriptionId = 0;
|
|
745
|
-
const $c8aa524f123a75a64d51e06d16b9568$var$descriptionNodes = new Map();
|
|
746
|
-
export function useDescription(description) {
|
|
747
|
-
let [id, setId] = useState(null);
|
|
748
642
|
|
|
749
|
-
|
|
750
|
-
|
|
751
|
-
|
|
752
|
-
|
|
643
|
+
var $eea11ba5aff18b32$exports = {};
|
|
644
|
+
|
|
645
|
+
$parcel$export($eea11ba5aff18b32$exports, "useDescription", () => $eea11ba5aff18b32$export$f8aeda7b10753fa1);
|
|
646
|
+
|
|
647
|
+
|
|
648
|
+
let $eea11ba5aff18b32$var$descriptionId = 0;
|
|
649
|
+
const $eea11ba5aff18b32$var$descriptionNodes = new Map();
|
|
650
|
+
function $eea11ba5aff18b32$export$f8aeda7b10753fa1(description) {
|
|
651
|
+
let [id1, setId] = $5yePs$useState(null);
|
|
652
|
+
$5ac25c9c8ba077b3$export$e5c5a5f917a5871c(()=>{
|
|
653
|
+
if (!description) return;
|
|
654
|
+
let desc = $eea11ba5aff18b32$var$descriptionNodes.get(description);
|
|
655
|
+
if (!desc) {
|
|
656
|
+
let id = `react-aria-description-${$eea11ba5aff18b32$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
|
+
$eea11ba5aff18b32$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
|
+
$eea11ba5aff18b32$var$descriptionNodes.delete(description);
|
|
674
|
+
}
|
|
675
|
+
};
|
|
676
|
+
}, [
|
|
677
|
+
description
|
|
678
|
+
]);
|
|
679
|
+
return {
|
|
680
|
+
'aria-describedby': description ? id1 : undefined
|
|
681
|
+
};
|
|
682
|
+
}
|
|
753
683
|
|
|
754
|
-
let desc = $c8aa524f123a75a64d51e06d16b9568$var$descriptionNodes.get(description);
|
|
755
|
-
|
|
756
|
-
if (!desc) {
|
|
757
|
-
let id = "react-aria-description-" + $c8aa524f123a75a64d51e06d16b9568$var$descriptionId++;
|
|
758
|
-
setId(id);
|
|
759
|
-
let node = document.createElement('div');
|
|
760
|
-
node.id = id;
|
|
761
|
-
node.style.display = 'none';
|
|
762
|
-
node.textContent = description;
|
|
763
|
-
document.body.appendChild(node);
|
|
764
|
-
desc = {
|
|
765
|
-
refCount: 0,
|
|
766
|
-
element: node
|
|
767
|
-
};
|
|
768
|
-
$c8aa524f123a75a64d51e06d16b9568$var$descriptionNodes.set(description, desc);
|
|
769
|
-
} else {
|
|
770
|
-
setId(desc.element.id);
|
|
771
|
-
}
|
|
772
684
|
|
|
773
|
-
|
|
774
|
-
return () => {
|
|
775
|
-
if (--desc.refCount === 0) {
|
|
776
|
-
desc.element.remove();
|
|
777
|
-
$c8aa524f123a75a64d51e06d16b9568$var$descriptionNodes.delete(description);
|
|
778
|
-
}
|
|
779
|
-
};
|
|
780
|
-
}, [description]);
|
|
685
|
+
var $59df4c60f0011bf4$exports = {};
|
|
781
686
|
|
|
782
|
-
|
|
783
|
-
|
|
784
|
-
|
|
687
|
+
$parcel$export($59df4c60f0011bf4$exports, "isMac", () => $59df4c60f0011bf4$export$9ac100e40613ea10);
|
|
688
|
+
$parcel$export($59df4c60f0011bf4$exports, "isIPhone", () => $59df4c60f0011bf4$export$186c6964ca17d99);
|
|
689
|
+
$parcel$export($59df4c60f0011bf4$exports, "isIPad", () => $59df4c60f0011bf4$export$7bef049ce92e4224);
|
|
690
|
+
$parcel$export($59df4c60f0011bf4$exports, "isIOS", () => $59df4c60f0011bf4$export$fedb369cb70207f1);
|
|
691
|
+
$parcel$export($59df4c60f0011bf4$exports, "isAppleDevice", () => $59df4c60f0011bf4$export$e1865c3bedcd822b);
|
|
692
|
+
$parcel$export($59df4c60f0011bf4$exports, "isWebKit", () => $59df4c60f0011bf4$export$78551043582a6a98);
|
|
693
|
+
$parcel$export($59df4c60f0011bf4$exports, "isChrome", () => $59df4c60f0011bf4$export$6446a186d09e379e);
|
|
694
|
+
$parcel$export($59df4c60f0011bf4$exports, "isAndroid", () => $59df4c60f0011bf4$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 $59df4c60f0011bf4$var$testUserAgent(re) {
|
|
706
|
+
return typeof window !== 'undefined' && window.navigator != null ? re.test(window.navigator.userAgent) : false;
|
|
785
707
|
}
|
|
786
|
-
|
|
787
|
-
|
|
788
|
-
return typeof window !== 'undefined' && window.navigator != null ? re.test(window.navigator.userAgent) : false;
|
|
708
|
+
function $59df4c60f0011bf4$var$testPlatform(re) {
|
|
709
|
+
return typeof window !== 'undefined' && window.navigator != null ? re.test(window.navigator.platform) : false;
|
|
789
710
|
}
|
|
790
|
-
|
|
791
|
-
|
|
792
|
-
return typeof window !== 'undefined' && window.navigator != null ? re.test(window.navigator.platform) : false;
|
|
711
|
+
function $59df4c60f0011bf4$export$9ac100e40613ea10() {
|
|
712
|
+
return $59df4c60f0011bf4$var$testPlatform(/^Mac/);
|
|
793
713
|
}
|
|
794
|
-
|
|
795
|
-
|
|
796
|
-
return $b0986c1243f71db8e992f67117a1ed9$var$testPlatform(/^Mac/);
|
|
714
|
+
function $59df4c60f0011bf4$export$186c6964ca17d99() {
|
|
715
|
+
return $59df4c60f0011bf4$var$testPlatform(/^iPhone/);
|
|
797
716
|
}
|
|
798
|
-
|
|
799
|
-
|
|
717
|
+
function $59df4c60f0011bf4$export$7bef049ce92e4224() {
|
|
718
|
+
return $59df4c60f0011bf4$var$testPlatform(/^iPad/) || $59df4c60f0011bf4$export$9ac100e40613ea10() && navigator.maxTouchPoints > 1;
|
|
800
719
|
}
|
|
801
|
-
|
|
802
|
-
|
|
803
|
-
isMac() && navigator.maxTouchPoints > 1;
|
|
720
|
+
function $59df4c60f0011bf4$export$fedb369cb70207f1() {
|
|
721
|
+
return $59df4c60f0011bf4$export$186c6964ca17d99() || $59df4c60f0011bf4$export$7bef049ce92e4224();
|
|
804
722
|
}
|
|
805
|
-
|
|
806
|
-
|
|
723
|
+
function $59df4c60f0011bf4$export$e1865c3bedcd822b() {
|
|
724
|
+
return $59df4c60f0011bf4$export$9ac100e40613ea10() || $59df4c60f0011bf4$export$fedb369cb70207f1();
|
|
807
725
|
}
|
|
808
|
-
|
|
809
|
-
|
|
726
|
+
function $59df4c60f0011bf4$export$78551043582a6a98() {
|
|
727
|
+
return $59df4c60f0011bf4$var$testUserAgent(/AppleWebKit/) && !$59df4c60f0011bf4$export$6446a186d09e379e();
|
|
810
728
|
}
|
|
811
|
-
|
|
812
|
-
|
|
729
|
+
function $59df4c60f0011bf4$export$6446a186d09e379e() {
|
|
730
|
+
return $59df4c60f0011bf4$var$testUserAgent(/Chrome/);
|
|
813
731
|
}
|
|
814
|
-
|
|
815
|
-
|
|
732
|
+
function $59df4c60f0011bf4$export$a11b0059900ceec8() {
|
|
733
|
+
return $59df4c60f0011bf4$var$testUserAgent(/Android/);
|
|
816
734
|
}
|
|
817
|
-
|
|
818
|
-
|
|
735
|
+
|
|
736
|
+
|
|
737
|
+
var $a3dca252611ad6b3$exports = {};
|
|
738
|
+
|
|
739
|
+
$parcel$export($a3dca252611ad6b3$exports, "useEvent", () => $a3dca252611ad6b3$export$90fc3a17d93f704c);
|
|
740
|
+
|
|
741
|
+
function $a3dca252611ad6b3$export$90fc3a17d93f704c(ref, event, handler1, options) {
|
|
742
|
+
let handlerRef = $5yePs$useRef(handler1);
|
|
743
|
+
handlerRef.current = handler1;
|
|
744
|
+
let isDisabled = handler1 == null;
|
|
745
|
+
$5yePs$useEffect(()=>{
|
|
746
|
+
if (isDisabled) return;
|
|
747
|
+
let element = ref.current;
|
|
748
|
+
let handler = (e)=>handlerRef.current.call(this, e)
|
|
749
|
+
;
|
|
750
|
+
element.addEventListener(event, handler, options);
|
|
751
|
+
return ()=>{
|
|
752
|
+
element.removeEventListener(event, handler, options);
|
|
753
|
+
};
|
|
754
|
+
}, [
|
|
755
|
+
ref,
|
|
756
|
+
event,
|
|
757
|
+
options,
|
|
758
|
+
isDisabled
|
|
759
|
+
]);
|
|
819
760
|
}
|
|
820
|
-
export function useEvent(ref, event, handler, options) {
|
|
821
|
-
let handlerRef = useRef(handler);
|
|
822
|
-
handlerRef.current = handler;
|
|
823
|
-
let isDisabled = handler == null;
|
|
824
|
-
useEffect(() => {
|
|
825
|
-
if (isDisabled) {
|
|
826
|
-
return;
|
|
827
|
-
}
|
|
828
761
|
|
|
829
|
-
let element = ref.current;
|
|
830
762
|
|
|
831
|
-
|
|
763
|
+
var $71eec9ddbfb7f6c6$exports = {};
|
|
764
|
+
|
|
765
|
+
$parcel$export($71eec9ddbfb7f6c6$exports, "useValueEffect", () => $71eec9ddbfb7f6c6$export$14d238f342723f25);
|
|
832
766
|
|
|
833
|
-
|
|
834
|
-
|
|
835
|
-
|
|
767
|
+
|
|
768
|
+
function $71eec9ddbfb7f6c6$export$14d238f342723f25(defaultValue) {
|
|
769
|
+
let [value, setValue] = $5yePs$useState(defaultValue);
|
|
770
|
+
let valueRef = $5yePs$useRef(value);
|
|
771
|
+
let effect = $5yePs$useRef(null);
|
|
772
|
+
valueRef.current = value;
|
|
773
|
+
// Store the function in a ref so we can always access the current version
|
|
774
|
+
// which has the proper `value` in scope.
|
|
775
|
+
let nextRef = $5yePs$useRef(null);
|
|
776
|
+
nextRef.current = ()=>{
|
|
777
|
+
// Run the generator to the next yield.
|
|
778
|
+
let newValue = effect.current.next();
|
|
779
|
+
// If the generator is done, reset the effect.
|
|
780
|
+
if (newValue.done) {
|
|
781
|
+
effect.current = null;
|
|
782
|
+
return;
|
|
783
|
+
}
|
|
784
|
+
// If the value is the same as the current value,
|
|
785
|
+
// then continue to the next yield. Otherwise,
|
|
786
|
+
// set the value in state and wait for the next layout effect.
|
|
787
|
+
if (value === newValue.value) nextRef.current();
|
|
788
|
+
else setValue(newValue.value);
|
|
836
789
|
};
|
|
837
|
-
|
|
790
|
+
$5ac25c9c8ba077b3$export$e5c5a5f917a5871c(()=>{
|
|
791
|
+
// If there is an effect currently running, continue to the next yield.
|
|
792
|
+
if (effect.current) nextRef.current();
|
|
793
|
+
});
|
|
794
|
+
let queue = $5yePs$useCallback((fn)=>{
|
|
795
|
+
effect.current = fn(valueRef.current);
|
|
796
|
+
nextRef.current();
|
|
797
|
+
}, [
|
|
798
|
+
effect,
|
|
799
|
+
nextRef
|
|
800
|
+
]);
|
|
801
|
+
return [
|
|
802
|
+
value,
|
|
803
|
+
queue
|
|
804
|
+
];
|
|
805
|
+
}
|
|
806
|
+
|
|
807
|
+
|
|
808
|
+
var $f2c8e5a8b491ced1$exports = {};
|
|
809
|
+
|
|
810
|
+
$parcel$export($f2c8e5a8b491ced1$exports, "scrollIntoView", () => $f2c8e5a8b491ced1$export$53a0910f038337bd);
|
|
811
|
+
function $f2c8e5a8b491ced1$export$53a0910f038337bd(scrollView, element) {
|
|
812
|
+
let offsetX = $f2c8e5a8b491ced1$var$relativeOffset(scrollView, element, 'left');
|
|
813
|
+
let offsetY = $f2c8e5a8b491ced1$var$relativeOffset(scrollView, element, 'top');
|
|
814
|
+
let width = element.offsetWidth;
|
|
815
|
+
let height = element.offsetHeight;
|
|
816
|
+
let x = scrollView.scrollLeft;
|
|
817
|
+
let y = scrollView.scrollTop;
|
|
818
|
+
let maxX = x + scrollView.offsetWidth;
|
|
819
|
+
let maxY = y + scrollView.offsetHeight;
|
|
820
|
+
if (offsetX <= x) x = offsetX;
|
|
821
|
+
else if (offsetX + width > maxX) x += offsetX + width - maxX;
|
|
822
|
+
if (offsetY <= y) y = offsetY;
|
|
823
|
+
else if (offsetY + height > maxY) y += offsetY + height - maxY;
|
|
824
|
+
scrollView.scrollLeft = x;
|
|
825
|
+
scrollView.scrollTop = y;
|
|
838
826
|
}
|
|
827
|
+
/**
|
|
828
|
+
* Computes the offset left or top from child to ancestor by accumulating
|
|
829
|
+
* offsetLeft or offsetTop through intervening offsetParents.
|
|
830
|
+
*/ function $f2c8e5a8b491ced1$var$relativeOffset(ancestor, child, axis) {
|
|
831
|
+
const prop = axis === 'left' ? 'offsetLeft' : 'offsetTop';
|
|
832
|
+
let sum = 0;
|
|
833
|
+
while(child.offsetParent){
|
|
834
|
+
sum += child[prop];
|
|
835
|
+
if (child.offsetParent === ancestor) break;
|
|
836
|
+
else if (child.offsetParent.contains(ancestor)) {
|
|
837
|
+
// If the ancestor is not `position:relative`, then we stop at
|
|
838
|
+
// _its_ offset parent, and we subtract off _its_ offset, so that
|
|
839
|
+
// we end up with the proper offset from child to ancestor.
|
|
840
|
+
sum -= ancestor[prop];
|
|
841
|
+
break;
|
|
842
|
+
}
|
|
843
|
+
child = child.offsetParent;
|
|
844
|
+
}
|
|
845
|
+
return sum;
|
|
846
|
+
}
|
|
847
|
+
|
|
848
|
+
|
|
849
|
+
|
|
850
|
+
|
|
851
|
+
export {$5b01a7ee7dba2d86$export$f680877a34711e37 as useId, $5b01a7ee7dba2d86$export$cd8c9cb68f842629 as mergeIds, $5b01a7ee7dba2d86$export$b4cc09c592e8fdb8 as useSlotId, $2a5eca539fe56811$export$e08e3b67e392101e as chain, $c42fb2a2f22e1846$export$9d1611c77c2fe928 as mergeProps, $f3859cd41d3e5b7d$export$457c3d6518dd4c6f as filterDOMProps, $1b46e2787874cd75$export$de79e2c695e052f3 as focusWithoutScrolling, $fbd35a31e994df41$export$622cea445a1c5b7d as getOffset, $691ac3ad1af88e64$re_export$clamp as clamp, $691ac3ad1af88e64$re_export$snapValueToStep as snapValueToStep, $51de12ccb2f75a87$export$24490316f764c430 as runAfterTransition, $b8aeddd69b238bce$export$7bbed75feba39706 as useDrag1D, $ce924e419b398d4c$export$4eaf04e54aa8eed6 as useGlobalListeners, $71a2c5844f2b60a4$export$d6875122194c7b44 as useLabels, $a235e7a487a1e81a$export$4338b53315abf666 as useObjectRef, $2a91c3126c559388$export$496315a1608d9602 as useUpdateEffect, $5ac25c9c8ba077b3$export$e5c5a5f917a5871c as useLayoutEffect, $3e864361342e1b32$export$683480f191c0e3ea as useResizeObserver, $0b7d7b0ae05ba812$export$4debdb1a3f0fa79e as useSyncRef, $0ac9283dcb18fed4$export$cfa2225e87938781 as getScrollParent, $9ab7274bc657ab6d$export$d699905dd57c73ca as useViewportSize, $eea11ba5aff18b32$export$f8aeda7b10753fa1 as useDescription, $59df4c60f0011bf4$export$9ac100e40613ea10 as isMac, $59df4c60f0011bf4$export$186c6964ca17d99 as isIPhone, $59df4c60f0011bf4$export$7bef049ce92e4224 as isIPad, $59df4c60f0011bf4$export$fedb369cb70207f1 as isIOS, $59df4c60f0011bf4$export$e1865c3bedcd822b as isAppleDevice, $59df4c60f0011bf4$export$78551043582a6a98 as isWebKit, $59df4c60f0011bf4$export$6446a186d09e379e as isChrome, $59df4c60f0011bf4$export$a11b0059900ceec8 as isAndroid, $a3dca252611ad6b3$export$90fc3a17d93f704c as useEvent, $71eec9ddbfb7f6c6$export$14d238f342723f25 as useValueEffect, $f2c8e5a8b491ced1$export$53a0910f038337bd as scrollIntoView};
|
|
839
852
|
//# sourceMappingURL=module.js.map
|