@tamagui/floating 2.0.0-rc.4 → 2.0.0-rc.40
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/cjs/Floating.cjs +7 -5
- package/dist/cjs/Floating.native.js +19 -13
- package/dist/cjs/Floating.native.js.map +1 -1
- package/dist/cjs/index.cjs +46 -13
- package/dist/cjs/index.native.js +46 -13
- package/dist/cjs/index.native.js.map +1 -1
- package/dist/cjs/interactions/PopupTriggerMap.cjs +49 -0
- package/dist/cjs/interactions/PopupTriggerMap.native.js +97 -0
- package/dist/cjs/interactions/PopupTriggerMap.native.js.map +1 -0
- package/dist/cjs/interactions/createFloatingEvents.cjs +50 -0
- package/dist/cjs/interactions/createFloatingEvents.native.js +56 -0
- package/dist/cjs/interactions/createFloatingEvents.native.js.map +1 -0
- package/dist/cjs/interactions/safePolygon.cjs +273 -0
- package/dist/cjs/interactions/safePolygon.native.js +284 -0
- package/dist/cjs/interactions/safePolygon.native.js.map +1 -0
- package/dist/cjs/interactions/types.cjs +18 -0
- package/dist/cjs/interactions/types.native.js +21 -0
- package/dist/cjs/interactions/types.native.js.map +1 -0
- package/dist/cjs/interactions/useClick.cjs +124 -0
- package/dist/cjs/interactions/useClick.native.js +132 -0
- package/dist/cjs/interactions/useClick.native.js.map +1 -0
- package/dist/cjs/interactions/useDelayGroup.cjs +115 -0
- package/dist/cjs/interactions/useDelayGroup.native.js +125 -0
- package/dist/cjs/interactions/useDelayGroup.native.js.map +1 -0
- package/dist/cjs/interactions/useFocus.cjs +130 -0
- package/dist/cjs/interactions/useFocus.native.js +139 -0
- package/dist/cjs/interactions/useFocus.native.js.map +1 -0
- package/dist/cjs/interactions/useHover.cjs +357 -0
- package/dist/cjs/interactions/useHover.native.js +373 -0
- package/dist/cjs/interactions/useHover.native.js.map +1 -0
- package/dist/cjs/interactions/useInnerOffset.cjs +128 -0
- package/dist/cjs/interactions/useInnerOffset.native.js +141 -0
- package/dist/cjs/interactions/useInnerOffset.native.js.map +1 -0
- package/dist/cjs/interactions/useInteractions.cjs +105 -0
- package/dist/cjs/interactions/useInteractions.native.js +216 -0
- package/dist/cjs/interactions/useInteractions.native.js.map +1 -0
- package/dist/cjs/interactions/useListNavigation.cjs +418 -0
- package/dist/cjs/interactions/useListNavigation.native.js +433 -0
- package/dist/cjs/interactions/useListNavigation.native.js.map +1 -0
- package/dist/cjs/interactions/useRole.cjs +122 -0
- package/dist/cjs/interactions/useRole.native.js +136 -0
- package/dist/cjs/interactions/useRole.native.js.map +1 -0
- package/dist/cjs/interactions/useTypeahead.cjs +143 -0
- package/dist/cjs/interactions/useTypeahead.native.js +159 -0
- package/dist/cjs/interactions/useTypeahead.native.js.map +1 -0
- package/dist/cjs/interactions/utils.cjs +208 -0
- package/dist/cjs/interactions/utils.native.js +227 -0
- package/dist/cjs/interactions/utils.native.js.map +1 -0
- package/dist/cjs/middleware/inner.cjs +118 -0
- package/dist/cjs/middleware/inner.native.js +130 -0
- package/dist/cjs/middleware/inner.native.js.map +1 -0
- package/dist/cjs/useFloating.cjs +35 -28
- package/dist/cjs/useFloating.native.js +51 -47
- package/dist/cjs/useFloating.native.js.map +1 -1
- package/dist/esm/Floating.native.js +6 -3
- package/dist/esm/Floating.native.js.map +1 -1
- package/dist/esm/index.js +17 -34
- package/dist/esm/index.js.map +1 -6
- package/dist/esm/index.mjs +16 -2
- package/dist/esm/index.mjs.map +1 -1
- package/dist/esm/index.native.js +16 -2
- package/dist/esm/index.native.js.map +1 -1
- package/dist/esm/interactions/PopupTriggerMap.mjs +24 -0
- package/dist/esm/interactions/PopupTriggerMap.mjs.map +1 -0
- package/dist/esm/interactions/PopupTriggerMap.native.js +69 -0
- package/dist/esm/interactions/PopupTriggerMap.native.js.map +1 -0
- package/dist/esm/interactions/createFloatingEvents.mjs +25 -0
- package/dist/esm/interactions/createFloatingEvents.mjs.map +1 -0
- package/dist/esm/interactions/createFloatingEvents.native.js +28 -0
- package/dist/esm/interactions/createFloatingEvents.native.js.map +1 -0
- package/dist/esm/interactions/safePolygon.mjs +248 -0
- package/dist/esm/interactions/safePolygon.mjs.map +1 -0
- package/dist/esm/interactions/safePolygon.native.js +256 -0
- package/dist/esm/interactions/safePolygon.native.js.map +1 -0
- package/dist/esm/interactions/types.mjs +2 -0
- package/dist/esm/interactions/types.mjs.map +1 -0
- package/dist/esm/interactions/types.native.js +2 -0
- package/dist/esm/interactions/types.native.js.map +1 -0
- package/dist/esm/interactions/useClick.mjs +99 -0
- package/dist/esm/interactions/useClick.mjs.map +1 -0
- package/dist/esm/interactions/useClick.native.js +104 -0
- package/dist/esm/interactions/useClick.native.js.map +1 -0
- package/dist/esm/interactions/useDelayGroup.mjs +77 -0
- package/dist/esm/interactions/useDelayGroup.mjs.map +1 -0
- package/dist/esm/interactions/useDelayGroup.native.js +84 -0
- package/dist/esm/interactions/useDelayGroup.native.js.map +1 -0
- package/dist/esm/interactions/useFocus.mjs +105 -0
- package/dist/esm/interactions/useFocus.mjs.map +1 -0
- package/dist/esm/interactions/useFocus.native.js +111 -0
- package/dist/esm/interactions/useFocus.native.js.map +1 -0
- package/dist/esm/interactions/useHover.mjs +320 -0
- package/dist/esm/interactions/useHover.mjs.map +1 -0
- package/dist/esm/interactions/useHover.native.js +333 -0
- package/dist/esm/interactions/useHover.native.js.map +1 -0
- package/dist/esm/interactions/useInnerOffset.mjs +92 -0
- package/dist/esm/interactions/useInnerOffset.mjs.map +1 -0
- package/dist/esm/interactions/useInnerOffset.native.js +102 -0
- package/dist/esm/interactions/useInnerOffset.native.js.map +1 -0
- package/dist/esm/interactions/useInteractions.mjs +80 -0
- package/dist/esm/interactions/useInteractions.mjs.map +1 -0
- package/dist/esm/interactions/useInteractions.native.js +188 -0
- package/dist/esm/interactions/useInteractions.native.js.map +1 -0
- package/dist/esm/interactions/useListNavigation.mjs +393 -0
- package/dist/esm/interactions/useListNavigation.mjs.map +1 -0
- package/dist/esm/interactions/useListNavigation.native.js +405 -0
- package/dist/esm/interactions/useListNavigation.native.js.map +1 -0
- package/dist/esm/interactions/useRole.mjs +86 -0
- package/dist/esm/interactions/useRole.mjs.map +1 -0
- package/dist/esm/interactions/useRole.native.js +97 -0
- package/dist/esm/interactions/useRole.native.js.map +1 -0
- package/dist/esm/interactions/useTypeahead.mjs +118 -0
- package/dist/esm/interactions/useTypeahead.mjs.map +1 -0
- package/dist/esm/interactions/useTypeahead.native.js +131 -0
- package/dist/esm/interactions/useTypeahead.native.js.map +1 -0
- package/dist/esm/interactions/utils.mjs +162 -0
- package/dist/esm/interactions/utils.mjs.map +1 -0
- package/dist/esm/interactions/utils.native.js +178 -0
- package/dist/esm/interactions/utils.native.js.map +1 -0
- package/dist/esm/middleware/inner.mjs +82 -0
- package/dist/esm/middleware/inner.mjs.map +1 -0
- package/dist/esm/middleware/inner.native.js +91 -0
- package/dist/esm/middleware/inner.native.js.map +1 -0
- package/dist/esm/useFloating.mjs +8 -3
- package/dist/esm/useFloating.mjs.map +1 -1
- package/dist/esm/useFloating.native.js +25 -23
- package/dist/esm/useFloating.native.js.map +1 -1
- package/package.json +8 -10
- package/src/Floating.native.tsx +1 -0
- package/src/index.ts +49 -0
- package/src/interactions/PopupTriggerMap.ts +30 -0
- package/src/interactions/createFloatingEvents.ts +34 -0
- package/src/interactions/safePolygon.ts +500 -0
- package/src/interactions/types.ts +165 -0
- package/src/interactions/useClick.ts +148 -0
- package/src/interactions/useDelayGroup.ts +114 -0
- package/src/interactions/useFocus.ts +164 -0
- package/src/interactions/useHover.ts +453 -0
- package/src/interactions/useInnerOffset.ts +116 -0
- package/src/interactions/useInteractions.ts +101 -0
- package/src/interactions/useListNavigation.ts +578 -0
- package/src/interactions/useRole.ts +103 -0
- package/src/interactions/useTypeahead.ts +173 -0
- package/src/interactions/utils.ts +234 -0
- package/src/middleware/inner.ts +141 -0
- package/src/useFloating.tsx +13 -1
- package/types/Floating.native.d.ts +1 -0
- package/types/Floating.native.d.ts.map +1 -1
- package/types/index.d.ts +17 -2
- package/types/index.d.ts.map +1 -1
- package/types/interactions/PopupTriggerMap.d.ts +8 -0
- package/types/interactions/PopupTriggerMap.d.ts.map +1 -0
- package/types/interactions/createFloatingEvents.d.ts +7 -0
- package/types/interactions/createFloatingEvents.d.ts.map +1 -0
- package/types/interactions/safePolygon.d.ts +4 -0
- package/types/interactions/safePolygon.d.ts.map +1 -0
- package/types/interactions/types.d.ts +123 -0
- package/types/interactions/types.d.ts.map +1 -0
- package/types/interactions/useClick.d.ts +3 -0
- package/types/interactions/useClick.d.ts.map +1 -0
- package/types/interactions/useDelayGroup.d.ts +23 -0
- package/types/interactions/useDelayGroup.d.ts.map +1 -0
- package/types/interactions/useFocus.d.ts +3 -0
- package/types/interactions/useFocus.d.ts.map +1 -0
- package/types/interactions/useHover.d.ts +6 -0
- package/types/interactions/useHover.d.ts.map +1 -0
- package/types/interactions/useInnerOffset.d.ts +3 -0
- package/types/interactions/useInnerOffset.d.ts.map +1 -0
- package/types/interactions/useInteractions.d.ts +8 -0
- package/types/interactions/useInteractions.d.ts.map +1 -0
- package/types/interactions/useListNavigation.d.ts +3 -0
- package/types/interactions/useListNavigation.d.ts.map +1 -0
- package/types/interactions/useRole.d.ts +3 -0
- package/types/interactions/useRole.d.ts.map +1 -0
- package/types/interactions/useTypeahead.d.ts +3 -0
- package/types/interactions/useTypeahead.d.ts.map +1 -0
- package/types/interactions/utils.d.ts +46 -0
- package/types/interactions/utils.d.ts.map +1 -0
- package/types/middleware/inner.d.ts +14 -0
- package/types/middleware/inner.d.ts.map +1 -0
- package/types/useFloating.d.ts +7 -1
- package/types/useFloating.d.ts.map +1 -1
- package/dist/cjs/Floating.js +0 -15
- package/dist/cjs/Floating.js.map +0 -6
- package/dist/cjs/index.js +0 -34
- package/dist/cjs/index.js.map +0 -6
- package/dist/cjs/useFloating.js +0 -46
- package/dist/cjs/useFloating.js.map +0 -6
- package/dist/esm/Floating.js +0 -2
- package/dist/esm/Floating.js.map +0 -6
- package/dist/esm/useFloating.js +0 -23
- package/dist/esm/useFloating.js.map +0 -6
|
@@ -0,0 +1,405 @@
|
|
|
1
|
+
import { useLayoutEffect, useMemo, useRef, useState } from "react";
|
|
2
|
+
import { useEvent } from "@tamagui/use-event";
|
|
3
|
+
import { activeElement, enqueueFocus, findNonDisabledListIndex, getMinListIndex, getMaxListIndex, isHTMLElement, isIndexOutOfListBounds, isTypeableCombobox, isVirtualClick, isVirtualPointerEvent, stopEvent } from "./utils.native.js";
|
|
4
|
+
var ARROW_UP = "ArrowUp";
|
|
5
|
+
var ARROW_DOWN = "ArrowDown";
|
|
6
|
+
var ARROW_LEFT = "ArrowLeft";
|
|
7
|
+
var ARROW_RIGHT = "ArrowRight";
|
|
8
|
+
function doSwitch(orientation, vertical, horizontal) {
|
|
9
|
+
switch (orientation) {
|
|
10
|
+
case "vertical":
|
|
11
|
+
return vertical;
|
|
12
|
+
case "horizontal":
|
|
13
|
+
return horizontal;
|
|
14
|
+
default:
|
|
15
|
+
return vertical || horizontal;
|
|
16
|
+
}
|
|
17
|
+
}
|
|
18
|
+
function isMainOrientationKey(key, orientation) {
|
|
19
|
+
var vertical = key === ARROW_UP || key === ARROW_DOWN;
|
|
20
|
+
var horizontal = key === ARROW_LEFT || key === ARROW_RIGHT;
|
|
21
|
+
return doSwitch(orientation, vertical, horizontal);
|
|
22
|
+
}
|
|
23
|
+
function isMainOrientationToEndKey(key, orientation, rtl) {
|
|
24
|
+
var vertical = key === ARROW_DOWN;
|
|
25
|
+
var horizontal = rtl ? key === ARROW_LEFT : key === ARROW_RIGHT;
|
|
26
|
+
return doSwitch(orientation, vertical, horizontal) || key === "Enter" || key === " " || key === "";
|
|
27
|
+
}
|
|
28
|
+
function isCrossOrientationOpenKey(key, orientation, rtl) {
|
|
29
|
+
var vertical = rtl ? key === ARROW_LEFT : key === ARROW_RIGHT;
|
|
30
|
+
var horizontal = key === ARROW_DOWN;
|
|
31
|
+
return doSwitch(orientation, vertical, horizontal);
|
|
32
|
+
}
|
|
33
|
+
function isCrossOrientationCloseKey(key, orientation, rtl) {
|
|
34
|
+
var vertical = rtl ? key === ARROW_RIGHT : key === ARROW_LEFT;
|
|
35
|
+
var horizontal = key === ARROW_UP;
|
|
36
|
+
return doSwitch(orientation, vertical, horizontal);
|
|
37
|
+
}
|
|
38
|
+
function useListNavigation(context, props) {
|
|
39
|
+
var {
|
|
40
|
+
open,
|
|
41
|
+
onOpenChange,
|
|
42
|
+
elements
|
|
43
|
+
} = context;
|
|
44
|
+
var {
|
|
45
|
+
listRef,
|
|
46
|
+
activeIndex,
|
|
47
|
+
onNavigate: unstable_onNavigate = function () {},
|
|
48
|
+
enabled = true,
|
|
49
|
+
selectedIndex = null,
|
|
50
|
+
allowEscape = false,
|
|
51
|
+
loop = false,
|
|
52
|
+
nested = false,
|
|
53
|
+
rtl = false,
|
|
54
|
+
virtual = false,
|
|
55
|
+
focusItemOnOpen = "auto",
|
|
56
|
+
focusItemOnHover = true,
|
|
57
|
+
openOnArrowKeyDown = true,
|
|
58
|
+
disabledIndices = void 0,
|
|
59
|
+
orientation = "vertical",
|
|
60
|
+
scrollItemIntoView = true
|
|
61
|
+
} = props;
|
|
62
|
+
var typeableComboboxReference = isTypeableCombobox(elements.domReference);
|
|
63
|
+
var focusItemOnOpenRef = useRef(focusItemOnOpen);
|
|
64
|
+
var indexRef = useRef(selectedIndex !== null && selectedIndex !== void 0 ? selectedIndex : -1);
|
|
65
|
+
var keyRef = useRef(null);
|
|
66
|
+
var isPointerModalityRef = useRef(true);
|
|
67
|
+
var previousMountedRef = useRef(!!elements.floating);
|
|
68
|
+
var previousOpenRef = useRef(open);
|
|
69
|
+
var forceSyncFocusRef = useRef(false);
|
|
70
|
+
var forceScrollIntoViewRef = useRef(false);
|
|
71
|
+
var disabledIndicesRef = useRef(disabledIndices);
|
|
72
|
+
disabledIndicesRef.current = disabledIndices;
|
|
73
|
+
var latestOpenRef = useRef(open);
|
|
74
|
+
latestOpenRef.current = open;
|
|
75
|
+
var scrollItemIntoViewRef = useRef(scrollItemIntoView);
|
|
76
|
+
scrollItemIntoViewRef.current = scrollItemIntoView;
|
|
77
|
+
var selectedIndexRef = useRef(selectedIndex);
|
|
78
|
+
selectedIndexRef.current = selectedIndex;
|
|
79
|
+
var stableOnNavigate = useEvent(unstable_onNavigate);
|
|
80
|
+
var [activeId, setActiveId] = useState();
|
|
81
|
+
var onNavigate = useEvent(function () {
|
|
82
|
+
stableOnNavigate(indexRef.current === -1 ? null : indexRef.current);
|
|
83
|
+
});
|
|
84
|
+
var previousOnNavigateRef = useRef(onNavigate);
|
|
85
|
+
var focusItem = useEvent(function () {
|
|
86
|
+
function runFocus(item2) {
|
|
87
|
+
if (virtual) {
|
|
88
|
+
setActiveId(item2.id);
|
|
89
|
+
} else {
|
|
90
|
+
enqueueFocus(item2, {
|
|
91
|
+
sync: forceSyncFocusRef.current,
|
|
92
|
+
preventScroll: true
|
|
93
|
+
});
|
|
94
|
+
}
|
|
95
|
+
}
|
|
96
|
+
var initialItem = listRef.current[indexRef.current];
|
|
97
|
+
var forceScrollIntoView = forceScrollIntoViewRef.current;
|
|
98
|
+
if (initialItem) {
|
|
99
|
+
runFocus(initialItem);
|
|
100
|
+
}
|
|
101
|
+
var scheduler = forceSyncFocusRef.current ? function (v) {
|
|
102
|
+
return v();
|
|
103
|
+
} : requestAnimationFrame;
|
|
104
|
+
scheduler(function () {
|
|
105
|
+
var waitedItem = listRef.current[indexRef.current] || initialItem;
|
|
106
|
+
if (!waitedItem) return;
|
|
107
|
+
if (!initialItem) {
|
|
108
|
+
runFocus(waitedItem);
|
|
109
|
+
}
|
|
110
|
+
var scrollIntoViewOptions = scrollItemIntoViewRef.current;
|
|
111
|
+
var shouldScrollIntoView = scrollIntoViewOptions && waitedItem && (forceScrollIntoView || !isPointerModalityRef.current);
|
|
112
|
+
if (shouldScrollIntoView) {
|
|
113
|
+
var _waitedItem_scrollIntoView;
|
|
114
|
+
(_waitedItem_scrollIntoView = waitedItem.scrollIntoView) === null || _waitedItem_scrollIntoView === void 0 ? void 0 : _waitedItem_scrollIntoView.call(waitedItem, typeof scrollIntoViewOptions === "boolean" ? {
|
|
115
|
+
block: "nearest",
|
|
116
|
+
inline: "nearest"
|
|
117
|
+
} : scrollIntoViewOptions);
|
|
118
|
+
}
|
|
119
|
+
});
|
|
120
|
+
});
|
|
121
|
+
useLayoutEffect(function () {
|
|
122
|
+
if (!enabled) return;
|
|
123
|
+
if (open && elements.floating) {
|
|
124
|
+
if (focusItemOnOpenRef.current && selectedIndex != null) {
|
|
125
|
+
forceScrollIntoViewRef.current = true;
|
|
126
|
+
indexRef.current = selectedIndex;
|
|
127
|
+
onNavigate();
|
|
128
|
+
}
|
|
129
|
+
} else if (previousMountedRef.current) {
|
|
130
|
+
indexRef.current = -1;
|
|
131
|
+
previousOnNavigateRef.current();
|
|
132
|
+
}
|
|
133
|
+
}, [enabled, open, elements.floating, selectedIndex, onNavigate]);
|
|
134
|
+
useLayoutEffect(function () {
|
|
135
|
+
if (!enabled) return;
|
|
136
|
+
if (!open) return;
|
|
137
|
+
if (!elements.floating) return;
|
|
138
|
+
if (activeIndex == null) {
|
|
139
|
+
forceSyncFocusRef.current = false;
|
|
140
|
+
if (selectedIndexRef.current != null) {
|
|
141
|
+
return;
|
|
142
|
+
}
|
|
143
|
+
if (previousMountedRef.current) {
|
|
144
|
+
indexRef.current = -1;
|
|
145
|
+
focusItem();
|
|
146
|
+
}
|
|
147
|
+
if ((!previousOpenRef.current || !previousMountedRef.current) && focusItemOnOpenRef.current && (keyRef.current != null || focusItemOnOpenRef.current === true && keyRef.current == null)) {
|
|
148
|
+
var runs = 0;
|
|
149
|
+
var waitForListPopulated = function () {
|
|
150
|
+
if (listRef.current[0] == null) {
|
|
151
|
+
if (runs < 2) {
|
|
152
|
+
var scheduler = runs ? requestAnimationFrame : queueMicrotask;
|
|
153
|
+
scheduler(waitForListPopulated);
|
|
154
|
+
}
|
|
155
|
+
runs++;
|
|
156
|
+
} else {
|
|
157
|
+
indexRef.current = keyRef.current == null || isMainOrientationToEndKey(keyRef.current, orientation, rtl) || nested ? getMinListIndex(listRef, disabledIndicesRef.current) : getMaxListIndex(listRef, disabledIndicesRef.current);
|
|
158
|
+
keyRef.current = null;
|
|
159
|
+
onNavigate();
|
|
160
|
+
}
|
|
161
|
+
};
|
|
162
|
+
waitForListPopulated();
|
|
163
|
+
}
|
|
164
|
+
} else if (!isIndexOutOfListBounds(listRef, activeIndex)) {
|
|
165
|
+
indexRef.current = activeIndex;
|
|
166
|
+
focusItem();
|
|
167
|
+
forceScrollIntoViewRef.current = false;
|
|
168
|
+
}
|
|
169
|
+
}, [enabled, open, elements.floating, activeIndex, selectedIndexRef, nested, listRef, orientation, rtl, onNavigate, focusItem, disabledIndicesRef]);
|
|
170
|
+
useLayoutEffect(function () {
|
|
171
|
+
previousOnNavigateRef.current = onNavigate;
|
|
172
|
+
previousOpenRef.current = open;
|
|
173
|
+
previousMountedRef.current = !!elements.floating;
|
|
174
|
+
});
|
|
175
|
+
useLayoutEffect(function () {
|
|
176
|
+
if (!open) {
|
|
177
|
+
keyRef.current = null;
|
|
178
|
+
focusItemOnOpenRef.current = focusItemOnOpen;
|
|
179
|
+
}
|
|
180
|
+
}, [open, focusItemOnOpen]);
|
|
181
|
+
var hasActiveIndex = activeIndex != null;
|
|
182
|
+
var commonOnKeyDown = useEvent(function (event) {
|
|
183
|
+
isPointerModalityRef.current = false;
|
|
184
|
+
forceSyncFocusRef.current = true;
|
|
185
|
+
if (event.which === 229) {
|
|
186
|
+
return;
|
|
187
|
+
}
|
|
188
|
+
if (!latestOpenRef.current && event.currentTarget === elements.floating) {
|
|
189
|
+
return;
|
|
190
|
+
}
|
|
191
|
+
if (nested && isCrossOrientationCloseKey(event.key, orientation, rtl)) {
|
|
192
|
+
stopEvent(event);
|
|
193
|
+
onOpenChange(false, event.nativeEvent, "list-navigation");
|
|
194
|
+
if (isHTMLElement(elements.domReference)) {
|
|
195
|
+
elements.domReference.focus();
|
|
196
|
+
}
|
|
197
|
+
return;
|
|
198
|
+
}
|
|
199
|
+
var currentIndex = indexRef.current;
|
|
200
|
+
var minIndex = getMinListIndex(listRef, disabledIndices);
|
|
201
|
+
var maxIndex = getMaxListIndex(listRef, disabledIndices);
|
|
202
|
+
if (!typeableComboboxReference) {
|
|
203
|
+
if (event.key === "Home") {
|
|
204
|
+
stopEvent(event);
|
|
205
|
+
indexRef.current = minIndex;
|
|
206
|
+
onNavigate();
|
|
207
|
+
}
|
|
208
|
+
if (event.key === "End") {
|
|
209
|
+
stopEvent(event);
|
|
210
|
+
indexRef.current = maxIndex;
|
|
211
|
+
onNavigate();
|
|
212
|
+
}
|
|
213
|
+
}
|
|
214
|
+
if (isMainOrientationKey(event.key, orientation)) {
|
|
215
|
+
stopEvent(event);
|
|
216
|
+
if (open && !virtual && activeElement(event.currentTarget.ownerDocument) === event.currentTarget) {
|
|
217
|
+
indexRef.current = isMainOrientationToEndKey(event.key, orientation, rtl) ? minIndex : maxIndex;
|
|
218
|
+
onNavigate();
|
|
219
|
+
return;
|
|
220
|
+
}
|
|
221
|
+
if (isMainOrientationToEndKey(event.key, orientation, rtl)) {
|
|
222
|
+
if (loop) {
|
|
223
|
+
indexRef.current = currentIndex >= maxIndex ? allowEscape && currentIndex !== listRef.current.length ? -1 : minIndex : findNonDisabledListIndex(listRef, {
|
|
224
|
+
startingIndex: currentIndex,
|
|
225
|
+
disabledIndices
|
|
226
|
+
});
|
|
227
|
+
} else {
|
|
228
|
+
indexRef.current = Math.min(maxIndex, findNonDisabledListIndex(listRef, {
|
|
229
|
+
startingIndex: currentIndex,
|
|
230
|
+
disabledIndices
|
|
231
|
+
}));
|
|
232
|
+
}
|
|
233
|
+
} else {
|
|
234
|
+
if (loop) {
|
|
235
|
+
indexRef.current = currentIndex <= minIndex ? allowEscape && currentIndex !== -1 ? listRef.current.length : maxIndex : findNonDisabledListIndex(listRef, {
|
|
236
|
+
startingIndex: currentIndex,
|
|
237
|
+
decrement: true,
|
|
238
|
+
disabledIndices
|
|
239
|
+
});
|
|
240
|
+
} else {
|
|
241
|
+
indexRef.current = Math.max(minIndex, findNonDisabledListIndex(listRef, {
|
|
242
|
+
startingIndex: currentIndex,
|
|
243
|
+
decrement: true,
|
|
244
|
+
disabledIndices
|
|
245
|
+
}));
|
|
246
|
+
}
|
|
247
|
+
}
|
|
248
|
+
if (isIndexOutOfListBounds(listRef, indexRef.current)) {
|
|
249
|
+
indexRef.current = -1;
|
|
250
|
+
}
|
|
251
|
+
onNavigate();
|
|
252
|
+
}
|
|
253
|
+
});
|
|
254
|
+
var ariaActiveDescendantProp = useMemo(function () {
|
|
255
|
+
return virtual && open && hasActiveIndex && {
|
|
256
|
+
"aria-activedescendant": activeId
|
|
257
|
+
};
|
|
258
|
+
}, [virtual, open, hasActiveIndex, activeId]);
|
|
259
|
+
var floating = useMemo(function () {
|
|
260
|
+
return {
|
|
261
|
+
"aria-orientation": orientation === "both" ? void 0 : orientation,
|
|
262
|
+
...(!typeableComboboxReference ? ariaActiveDescendantProp : {}),
|
|
263
|
+
onKeyDown: commonOnKeyDown,
|
|
264
|
+
onPointerMove() {
|
|
265
|
+
isPointerModalityRef.current = true;
|
|
266
|
+
}
|
|
267
|
+
};
|
|
268
|
+
}, [ariaActiveDescendantProp, commonOnKeyDown, orientation, typeableComboboxReference]);
|
|
269
|
+
var reference = useMemo(function () {
|
|
270
|
+
function checkVirtualMouse(event) {
|
|
271
|
+
if (focusItemOnOpen === "auto" && isVirtualClick(event.nativeEvent)) {
|
|
272
|
+
focusItemOnOpenRef.current = true;
|
|
273
|
+
}
|
|
274
|
+
}
|
|
275
|
+
function checkVirtualPointer(event) {
|
|
276
|
+
focusItemOnOpenRef.current = focusItemOnOpen;
|
|
277
|
+
if (focusItemOnOpen === "auto" && isVirtualPointerEvent(event.nativeEvent)) {
|
|
278
|
+
focusItemOnOpenRef.current = true;
|
|
279
|
+
}
|
|
280
|
+
}
|
|
281
|
+
return {
|
|
282
|
+
...ariaActiveDescendantProp,
|
|
283
|
+
onKeyDown(event) {
|
|
284
|
+
isPointerModalityRef.current = false;
|
|
285
|
+
var isArrowKey = event.key.startsWith("Arrow");
|
|
286
|
+
var isCrossOpenKey = isCrossOrientationOpenKey(event.key, orientation, rtl);
|
|
287
|
+
var isMainKey = isMainOrientationKey(event.key, orientation);
|
|
288
|
+
var isNavigationKey = (nested ? isCrossOpenKey : isMainKey) || event.key === "Enter" || event.key.trim() === "";
|
|
289
|
+
if (virtual && open) {
|
|
290
|
+
return commonOnKeyDown(event);
|
|
291
|
+
}
|
|
292
|
+
if (!open && !openOnArrowKeyDown && isArrowKey) {
|
|
293
|
+
return;
|
|
294
|
+
}
|
|
295
|
+
if (isNavigationKey) {
|
|
296
|
+
keyRef.current = event.key;
|
|
297
|
+
}
|
|
298
|
+
if (nested) {
|
|
299
|
+
if (isCrossOpenKey) {
|
|
300
|
+
stopEvent(event);
|
|
301
|
+
if (open) {
|
|
302
|
+
indexRef.current = getMinListIndex(listRef, disabledIndicesRef.current);
|
|
303
|
+
onNavigate();
|
|
304
|
+
} else {
|
|
305
|
+
onOpenChange(true, event.nativeEvent, "list-navigation");
|
|
306
|
+
}
|
|
307
|
+
}
|
|
308
|
+
return;
|
|
309
|
+
}
|
|
310
|
+
if (isMainKey) {
|
|
311
|
+
if (selectedIndex != null) {
|
|
312
|
+
indexRef.current = selectedIndex;
|
|
313
|
+
}
|
|
314
|
+
stopEvent(event);
|
|
315
|
+
if (!open && openOnArrowKeyDown) {
|
|
316
|
+
onOpenChange(true, event.nativeEvent, "list-navigation");
|
|
317
|
+
} else {
|
|
318
|
+
commonOnKeyDown(event);
|
|
319
|
+
}
|
|
320
|
+
if (open) {
|
|
321
|
+
onNavigate();
|
|
322
|
+
}
|
|
323
|
+
}
|
|
324
|
+
},
|
|
325
|
+
onFocus() {
|
|
326
|
+
if (open && !virtual) {
|
|
327
|
+
indexRef.current = -1;
|
|
328
|
+
onNavigate();
|
|
329
|
+
}
|
|
330
|
+
},
|
|
331
|
+
onPointerDown: checkVirtualPointer,
|
|
332
|
+
onPointerEnter: checkVirtualPointer,
|
|
333
|
+
onMouseDown: checkVirtualMouse,
|
|
334
|
+
onClick: checkVirtualMouse
|
|
335
|
+
};
|
|
336
|
+
}, [ariaActiveDescendantProp, commonOnKeyDown, disabledIndicesRef, focusItemOnOpen, listRef, nested, onNavigate, onOpenChange, open, openOnArrowKeyDown, orientation, rtl, selectedIndex, virtual]);
|
|
337
|
+
var item = useMemo(function () {
|
|
338
|
+
function syncCurrentTarget(currentTarget) {
|
|
339
|
+
if (!latestOpenRef.current) return;
|
|
340
|
+
var index = listRef.current.indexOf(currentTarget);
|
|
341
|
+
if (index !== -1 && indexRef.current !== index) {
|
|
342
|
+
indexRef.current = index;
|
|
343
|
+
onNavigate();
|
|
344
|
+
}
|
|
345
|
+
}
|
|
346
|
+
var itemProps = {
|
|
347
|
+
onFocus(param) {
|
|
348
|
+
var {
|
|
349
|
+
currentTarget
|
|
350
|
+
} = param;
|
|
351
|
+
forceSyncFocusRef.current = true;
|
|
352
|
+
syncCurrentTarget(currentTarget);
|
|
353
|
+
},
|
|
354
|
+
onClick: function (param) {
|
|
355
|
+
var {
|
|
356
|
+
currentTarget
|
|
357
|
+
} = param;
|
|
358
|
+
return currentTarget.focus({
|
|
359
|
+
preventScroll: true
|
|
360
|
+
});
|
|
361
|
+
},
|
|
362
|
+
// safari
|
|
363
|
+
onMouseMove(param) {
|
|
364
|
+
var {
|
|
365
|
+
currentTarget
|
|
366
|
+
} = param;
|
|
367
|
+
forceSyncFocusRef.current = true;
|
|
368
|
+
forceScrollIntoViewRef.current = false;
|
|
369
|
+
if (focusItemOnHover) {
|
|
370
|
+
syncCurrentTarget(currentTarget);
|
|
371
|
+
}
|
|
372
|
+
},
|
|
373
|
+
onPointerLeave(param) {
|
|
374
|
+
var {
|
|
375
|
+
pointerType
|
|
376
|
+
} = param;
|
|
377
|
+
if (!isPointerModalityRef.current || pointerType === "touch") {
|
|
378
|
+
return;
|
|
379
|
+
}
|
|
380
|
+
forceSyncFocusRef.current = true;
|
|
381
|
+
if (!focusItemOnHover) {
|
|
382
|
+
return;
|
|
383
|
+
}
|
|
384
|
+
indexRef.current = -1;
|
|
385
|
+
onNavigate();
|
|
386
|
+
if (!virtual) {
|
|
387
|
+
var _elements_floating;
|
|
388
|
+
(_elements_floating = elements.floating) === null || _elements_floating === void 0 ? void 0 : _elements_floating.focus({
|
|
389
|
+
preventScroll: true
|
|
390
|
+
});
|
|
391
|
+
}
|
|
392
|
+
}
|
|
393
|
+
};
|
|
394
|
+
return itemProps;
|
|
395
|
+
}, [latestOpenRef, focusItemOnHover, listRef, onNavigate, virtual, elements.floating]);
|
|
396
|
+
return useMemo(function () {
|
|
397
|
+
return enabled ? {
|
|
398
|
+
reference,
|
|
399
|
+
floating,
|
|
400
|
+
item
|
|
401
|
+
} : {};
|
|
402
|
+
}, [enabled, reference, floating, item]);
|
|
403
|
+
}
|
|
404
|
+
export { useListNavigation };
|
|
405
|
+
//# sourceMappingURL=useListNavigation.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["useLayoutEffect","useMemo","useRef","useState","useEvent","activeElement","enqueueFocus","findNonDisabledListIndex","getMinListIndex","getMaxListIndex","isHTMLElement","isIndexOutOfListBounds","isTypeableCombobox","isVirtualClick","isVirtualPointerEvent","stopEvent","ARROW_UP","ARROW_DOWN","ARROW_LEFT","ARROW_RIGHT","doSwitch","orientation","vertical","horizontal","isMainOrientationKey","key","isMainOrientationToEndKey","rtl","isCrossOrientationOpenKey","isCrossOrientationCloseKey","useListNavigation","context","props","open","onOpenChange","elements","listRef","activeIndex","onNavigate","unstable_onNavigate","enabled","selectedIndex","allowEscape","loop","nested","virtual","focusItemOnOpen","focusItemOnHover","openOnArrowKeyDown","disabledIndices","scrollItemIntoView","typeableComboboxReference","domReference","focusItemOnOpenRef","indexRef","keyRef","isPointerModalityRef","previousMountedRef","floating","previousOpenRef","forceSyncFocusRef","forceScrollIntoViewRef","disabledIndicesRef","current","latestOpenRef","scrollItemIntoViewRef","selectedIndexRef","stableOnNavigate","activeId","setActiveId","previousOnNavigateRef","focusItem","runFocus","item2","id","sync","preventScroll","initialItem","forceScrollIntoView","scheduler","v","requestAnimationFrame","waitedItem","scrollIntoViewOptions","shouldScrollIntoView","_waitedItem_scrollIntoView","scrollIntoView","call","block","inline","runs","waitForListPopulated","queueMicrotask","hasActiveIndex","commonOnKeyDown","event","which","currentTarget","nativeEvent","focus","currentIndex","minIndex","maxIndex","ownerDocument","length","startingIndex","Math","min","decrement","max","ariaActiveDescendantProp","onKeyDown","onPointerMove","reference","checkVirtualMouse","checkVirtualPointer","isArrowKey","startsWith","isCrossOpenKey","isMainKey","isNavigationKey","trim","onFocus","onPointerDown","onPointerEnter","onMouseDown","onClick","item","syncCurrentTarget","index","indexOf","itemProps","param","onMouseMove","onPointerLeave","pointerType","_elements_floating"],"sources":["../../../src/interactions/useListNavigation.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,86 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
const componentRoleToAriaRoleMap = /* @__PURE__ */new Map([["select", "listbox"], ["combobox", "listbox"], ["label", false]]);
|
|
3
|
+
let idCounter = 0;
|
|
4
|
+
function useRole(context, props = {}) {
|
|
5
|
+
const {
|
|
6
|
+
open,
|
|
7
|
+
elements
|
|
8
|
+
} = context;
|
|
9
|
+
const {
|
|
10
|
+
enabled = true,
|
|
11
|
+
role = "dialog"
|
|
12
|
+
} = props;
|
|
13
|
+
const defaultReferenceId = React.useId();
|
|
14
|
+
const referenceId = elements.domReference?.id || defaultReferenceId;
|
|
15
|
+
const defaultFloatingId = React.useMemo(() => `floating-${idCounter++}`, []);
|
|
16
|
+
const floatingId = React.useMemo(() => elements.floating?.id || defaultFloatingId, [elements.floating, defaultFloatingId]);
|
|
17
|
+
const ariaRole = componentRoleToAriaRoleMap.get(role) ?? role;
|
|
18
|
+
const reference = React.useMemo(() => {
|
|
19
|
+
if (ariaRole === "tooltip" || role === "label") {
|
|
20
|
+
return {
|
|
21
|
+
[`aria-${role === "label" ? "labelledby" : "describedby"}`]: open ? floatingId : void 0
|
|
22
|
+
};
|
|
23
|
+
}
|
|
24
|
+
return {
|
|
25
|
+
"aria-expanded": open ? "true" : "false",
|
|
26
|
+
"aria-haspopup": ariaRole === "alertdialog" ? "dialog" : ariaRole,
|
|
27
|
+
"aria-controls": open ? floatingId : void 0,
|
|
28
|
+
...(ariaRole === "listbox" && {
|
|
29
|
+
role: "combobox"
|
|
30
|
+
}),
|
|
31
|
+
...(ariaRole === "menu" && {
|
|
32
|
+
id: referenceId
|
|
33
|
+
}),
|
|
34
|
+
...(role === "select" && {
|
|
35
|
+
"aria-autocomplete": "none"
|
|
36
|
+
}),
|
|
37
|
+
...(role === "combobox" && {
|
|
38
|
+
"aria-autocomplete": "list"
|
|
39
|
+
})
|
|
40
|
+
};
|
|
41
|
+
}, [ariaRole, floatingId, open, referenceId, role]);
|
|
42
|
+
const floating = React.useMemo(() => {
|
|
43
|
+
const floatingProps = {
|
|
44
|
+
id: floatingId,
|
|
45
|
+
...(ariaRole && {
|
|
46
|
+
role: ariaRole
|
|
47
|
+
})
|
|
48
|
+
};
|
|
49
|
+
if (ariaRole === "tooltip" || role === "label") {
|
|
50
|
+
return floatingProps;
|
|
51
|
+
}
|
|
52
|
+
return {
|
|
53
|
+
...floatingProps,
|
|
54
|
+
...(ariaRole === "menu" && {
|
|
55
|
+
"aria-labelledby": referenceId
|
|
56
|
+
})
|
|
57
|
+
};
|
|
58
|
+
}, [ariaRole, floatingId, referenceId, role]);
|
|
59
|
+
const item = React.useCallback(({
|
|
60
|
+
active,
|
|
61
|
+
selected
|
|
62
|
+
}) => {
|
|
63
|
+
const commonProps = {
|
|
64
|
+
role: "option",
|
|
65
|
+
...(active && {
|
|
66
|
+
id: `${floatingId}-fui-option`
|
|
67
|
+
})
|
|
68
|
+
};
|
|
69
|
+
switch (role) {
|
|
70
|
+
case "select":
|
|
71
|
+
case "combobox":
|
|
72
|
+
return {
|
|
73
|
+
...commonProps,
|
|
74
|
+
"aria-selected": selected
|
|
75
|
+
};
|
|
76
|
+
}
|
|
77
|
+
return {};
|
|
78
|
+
}, [floatingId, role]);
|
|
79
|
+
return React.useMemo(() => enabled ? {
|
|
80
|
+
reference,
|
|
81
|
+
floating,
|
|
82
|
+
item
|
|
83
|
+
} : {}, [enabled, reference, floating, item]);
|
|
84
|
+
}
|
|
85
|
+
export { useRole };
|
|
86
|
+
//# sourceMappingURL=useRole.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","componentRoleToAriaRoleMap","Map","idCounter","useRole","context","props","open","elements","enabled","role","defaultReferenceId","useId","referenceId","domReference","id","defaultFloatingId","useMemo","floatingId","floating","ariaRole","get","reference","floatingProps","item","useCallback","active","selected","commonProps"],"sources":["../../../src/interactions/useRole.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
|
@@ -0,0 +1,97 @@
|
|
|
1
|
+
import * as React from "react";
|
|
2
|
+
var componentRoleToAriaRoleMap = /* @__PURE__ */new Map([["select", "listbox"], ["combobox", "listbox"], ["label", false]]);
|
|
3
|
+
var idCounter = 0;
|
|
4
|
+
function useRole(context) {
|
|
5
|
+
var props = arguments.length > 1 && arguments[1] !== void 0 ? arguments[1] : {};
|
|
6
|
+
var _elements_domReference;
|
|
7
|
+
var {
|
|
8
|
+
open,
|
|
9
|
+
elements
|
|
10
|
+
} = context;
|
|
11
|
+
var {
|
|
12
|
+
enabled = true,
|
|
13
|
+
role = "dialog"
|
|
14
|
+
} = props;
|
|
15
|
+
var defaultReferenceId = React.useId();
|
|
16
|
+
var referenceId = ((_elements_domReference = elements.domReference) === null || _elements_domReference === void 0 ? void 0 : _elements_domReference.id) || defaultReferenceId;
|
|
17
|
+
var defaultFloatingId = React.useMemo(function () {
|
|
18
|
+
return `floating-${idCounter++}`;
|
|
19
|
+
}, []);
|
|
20
|
+
var floatingId = React.useMemo(function () {
|
|
21
|
+
var _elements_floating;
|
|
22
|
+
return ((_elements_floating = elements.floating) === null || _elements_floating === void 0 ? void 0 : _elements_floating.id) || defaultFloatingId;
|
|
23
|
+
}, [elements.floating, defaultFloatingId]);
|
|
24
|
+
var _componentRoleToAriaRoleMap_get;
|
|
25
|
+
var ariaRole = (_componentRoleToAriaRoleMap_get = componentRoleToAriaRoleMap.get(role)) !== null && _componentRoleToAriaRoleMap_get !== void 0 ? _componentRoleToAriaRoleMap_get : role;
|
|
26
|
+
var reference = React.useMemo(function () {
|
|
27
|
+
if (ariaRole === "tooltip" || role === "label") {
|
|
28
|
+
return {
|
|
29
|
+
[`aria-${role === "label" ? "labelledby" : "describedby"}`]: open ? floatingId : void 0
|
|
30
|
+
};
|
|
31
|
+
}
|
|
32
|
+
return {
|
|
33
|
+
"aria-expanded": open ? "true" : "false",
|
|
34
|
+
"aria-haspopup": ariaRole === "alertdialog" ? "dialog" : ariaRole,
|
|
35
|
+
"aria-controls": open ? floatingId : void 0,
|
|
36
|
+
...(ariaRole === "listbox" && {
|
|
37
|
+
role: "combobox"
|
|
38
|
+
}),
|
|
39
|
+
...(ariaRole === "menu" && {
|
|
40
|
+
id: referenceId
|
|
41
|
+
}),
|
|
42
|
+
...(role === "select" && {
|
|
43
|
+
"aria-autocomplete": "none"
|
|
44
|
+
}),
|
|
45
|
+
...(role === "combobox" && {
|
|
46
|
+
"aria-autocomplete": "list"
|
|
47
|
+
})
|
|
48
|
+
};
|
|
49
|
+
}, [ariaRole, floatingId, open, referenceId, role]);
|
|
50
|
+
var floating = React.useMemo(function () {
|
|
51
|
+
var floatingProps = {
|
|
52
|
+
id: floatingId,
|
|
53
|
+
...(ariaRole && {
|
|
54
|
+
role: ariaRole
|
|
55
|
+
})
|
|
56
|
+
};
|
|
57
|
+
if (ariaRole === "tooltip" || role === "label") {
|
|
58
|
+
return floatingProps;
|
|
59
|
+
}
|
|
60
|
+
return {
|
|
61
|
+
...floatingProps,
|
|
62
|
+
...(ariaRole === "menu" && {
|
|
63
|
+
"aria-labelledby": referenceId
|
|
64
|
+
})
|
|
65
|
+
};
|
|
66
|
+
}, [ariaRole, floatingId, referenceId, role]);
|
|
67
|
+
var item = React.useCallback(function (param) {
|
|
68
|
+
var {
|
|
69
|
+
active,
|
|
70
|
+
selected
|
|
71
|
+
} = param;
|
|
72
|
+
var commonProps = {
|
|
73
|
+
role: "option",
|
|
74
|
+
...(active && {
|
|
75
|
+
id: `${floatingId}-fui-option`
|
|
76
|
+
})
|
|
77
|
+
};
|
|
78
|
+
switch (role) {
|
|
79
|
+
case "select":
|
|
80
|
+
case "combobox":
|
|
81
|
+
return {
|
|
82
|
+
...commonProps,
|
|
83
|
+
"aria-selected": selected
|
|
84
|
+
};
|
|
85
|
+
}
|
|
86
|
+
return {};
|
|
87
|
+
}, [floatingId, role]);
|
|
88
|
+
return React.useMemo(function () {
|
|
89
|
+
return enabled ? {
|
|
90
|
+
reference,
|
|
91
|
+
floating,
|
|
92
|
+
item
|
|
93
|
+
} : {};
|
|
94
|
+
}, [enabled, reference, floating, item]);
|
|
95
|
+
}
|
|
96
|
+
export { useRole };
|
|
97
|
+
//# sourceMappingURL=useRole.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["React","componentRoleToAriaRoleMap","Map","idCounter","useRole","context","props","arguments","length","_elements_domReference","open","elements","enabled","role","defaultReferenceId","useId","referenceId","domReference","id","defaultFloatingId","useMemo","floatingId","_elements_floating","floating","_componentRoleToAriaRoleMap_get","ariaRole","get","reference","floatingProps"],"sources":["../../../src/interactions/useRole.ts"],"sourcesContent":[null],"mappings":"AAAA,YAAYA,KAAA,MAAW;AAMvB,IAAAC,0BAAM,kBAA6B,IAAAC,GAAI,EACrC,CACC,UACA,SAAS,CACX,EAED,CAGO,UAAS,EAId,SAAQ,CACR,EAEA,CACA,OAAM,EAEN,KAAM,CACN,CAAyB;AACQ,IAC/BC,SAAC,GAAS;AAA2B,SACvCC,QAAAC,OAAA;EAEA,IAAAC,KAAM,GAAAC,SAAY,CAAAC,MAAA,QAAAD,SAA2B,GAAI,KAAI,KAAK,IAAAA,SAAA;EAU1D,IAAAE,sBAAmD;EACjD;IAAIC,IAAA;IAAAC;EAAa,IAAAN,OAAa;EAC5B;IAAAO,OAAO;IAAAC,IAAA;EAAA,IAAAP,KAAA;EAAA,IAAAQ,kBACI,GAASd,KAAA,CAAAe,KAAU;EAExB,IACNC,WAAA,KAAAP,sBAAA,GAAAE,QAAA,CAAAM,YAAA,cAAAR,sBAAA,uBAAAA,sBAAA,CAAAS,EAAA,KAAAJ,kBAAA;EAAA,IACFK,iBAAA,GAAAnB,KAAA,CAAAoB,OAAA;IAEA,OAAO,YAAAjB,SAAA;EAAA,KACL;EAAiC,IACjCkB,UAAA,GAAArB,KAAiB,CAAAoB,OAAA,aAAa;IAA2B,IACzDE,kBAAiB;IAAoB,OACjC,EAAAA,kBAAa,GAAAX,QAAe,CAAMY,QAAA,MAAW,QAAAD,kBAAA,uBAAAA,kBAAA,CAAAJ,EAAA,KAAAC,iBAAA;EAAA,IACJR,QACzC,CAAAY,QAAS,EAA0CJ,iBAC1C,CAA4C,CAC3D;EACF,IAAIK,+BAA4B;EAEhC,IAAAC,QAAM,IAAAD,+BAAyD,GAAAvB,0BAAA,CAAAyB,GAAA,CAAAb,IAAA,eAAAW,+BAAA,cAAAA,+BAAA,GAAAX,IAAA;EAC7D,IAAAc,SAAM,GAAA3B,KAAA,CAAAoB,OAAgB;IAAA,IACpBK,QAAI,kBAAAZ,IAAA;MACJ,OAAI;QACN,SAAAA,IAAA,gDAAAH,IAAA,GAAAW,UAAA;MAEA;IACE;IACF;MAEA,eAAO,EAAAX,IAAA;MACL,eAAG,EAAAe,QAAA,gCAAAA,QAAA;MACH,eAAI,EAAaf,IAAA,GAAAW,UAAY;MAC/B,IAAAI,QAAA;QACEZ,IAAA;MAEJ;MACG,IAAEY,QAAQ,WAAS,IAAgD;QAClEP,EAAA,EAAMF;MAAc;MACZ,IACNH,IAAI,aAAY,IAAO;QACzB;MAEA;MAAc,IACZA,IAAK;QACL,mBAAK;MACH;IAAO;EACF,IACcY,QACnB,EAAAJ,UACJ,EAEAX,IAAA,EACFM,WAAA,EACAH,IAAC,CACH;EAEA,IAAAU,QAAO,GAAMvB,KAAA,CAAAoB,OAAA;IACX,IAAAQ,aAAiB,GAAE;MAClBV,EAAA,EAAAG,UAAS;MACZ,IAAAI,QAAA;QACFZ,IAAA,EAAAY","ignoreList":[]}
|