@tamagui/floating 2.0.0-rc.3 → 2.0.0-rc.31
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.native.js +4 -0
- package/dist/cjs/Floating.native.js.map +1 -1
- package/dist/cjs/index.cjs +33 -2
- package/dist/cjs/index.native.js +33 -2
- package/dist/cjs/index.native.js.map +1 -1
- package/dist/cjs/interactions/PopupTriggerMap.cjs +40 -0
- package/dist/cjs/interactions/PopupTriggerMap.native.js +73 -0
- package/dist/cjs/interactions/PopupTriggerMap.native.js.map +1 -0
- package/dist/cjs/interactions/createFloatingEvents.cjs +41 -0
- package/dist/cjs/interactions/createFloatingEvents.native.js +47 -0
- package/dist/cjs/interactions/createFloatingEvents.native.js.map +1 -0
- package/dist/cjs/interactions/safePolygon.cjs +191 -0
- package/dist/cjs/interactions/safePolygon.native.js +205 -0
- package/dist/cjs/interactions/safePolygon.native.js.map +1 -0
- package/dist/cjs/interactions/types.cjs +16 -0
- package/dist/cjs/interactions/types.native.js +19 -0
- package/dist/cjs/interactions/types.native.js.map +1 -0
- package/dist/cjs/interactions/useClick.cjs +82 -0
- package/dist/cjs/interactions/useClick.native.js +90 -0
- package/dist/cjs/interactions/useClick.native.js.map +1 -0
- package/dist/cjs/interactions/useDelayGroup.cjs +96 -0
- package/dist/cjs/interactions/useDelayGroup.native.js +109 -0
- package/dist/cjs/interactions/useDelayGroup.native.js.map +1 -0
- package/dist/cjs/interactions/useFocus.cjs +101 -0
- package/dist/cjs/interactions/useFocus.native.js +113 -0
- package/dist/cjs/interactions/useFocus.native.js.map +1 -0
- package/dist/cjs/interactions/useHover.cjs +224 -0
- package/dist/cjs/interactions/useHover.native.js +248 -0
- package/dist/cjs/interactions/useHover.native.js.map +1 -0
- package/dist/cjs/interactions/useInnerOffset.cjs +104 -0
- package/dist/cjs/interactions/useInnerOffset.native.js +118 -0
- package/dist/cjs/interactions/useInnerOffset.native.js.map +1 -0
- package/dist/cjs/interactions/useInteractions.cjs +76 -0
- package/dist/cjs/interactions/useInteractions.native.js +164 -0
- package/dist/cjs/interactions/useInteractions.native.js.map +1 -0
- package/dist/cjs/interactions/useListNavigation.cjs +253 -0
- package/dist/cjs/interactions/useListNavigation.native.js +297 -0
- package/dist/cjs/interactions/useListNavigation.native.js.map +1 -0
- package/dist/cjs/interactions/useRole.cjs +112 -0
- package/dist/cjs/interactions/useRole.native.js +128 -0
- package/dist/cjs/interactions/useRole.native.js.map +1 -0
- package/dist/cjs/interactions/useTypeahead.cjs +93 -0
- package/dist/cjs/interactions/useTypeahead.native.js +114 -0
- package/dist/cjs/interactions/useTypeahead.native.js.map +1 -0
- package/dist/cjs/interactions/utils.cjs +178 -0
- package/dist/cjs/interactions/utils.native.js +188 -0
- package/dist/cjs/interactions/utils.native.js.map +1 -0
- package/dist/cjs/middleware/inner.cjs +106 -0
- package/dist/cjs/middleware/inner.native.js +120 -0
- package/dist/cjs/middleware/inner.native.js.map +1 -0
- package/dist/cjs/useFloating.cjs +21 -17
- package/dist/cjs/useFloating.native.js +2 -0
- package/dist/cjs/useFloating.native.js.map +1 -1
- package/dist/esm/Floating.native.js +4 -1
- 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 +17 -0
- package/dist/esm/interactions/PopupTriggerMap.mjs.map +1 -0
- package/dist/esm/interactions/PopupTriggerMap.native.js +47 -0
- package/dist/esm/interactions/PopupTriggerMap.native.js.map +1 -0
- package/dist/esm/interactions/createFloatingEvents.mjs +18 -0
- package/dist/esm/interactions/createFloatingEvents.mjs.map +1 -0
- package/dist/esm/interactions/createFloatingEvents.native.js +21 -0
- package/dist/esm/interactions/createFloatingEvents.native.js.map +1 -0
- package/dist/esm/interactions/safePolygon.mjs +168 -0
- package/dist/esm/interactions/safePolygon.mjs.map +1 -0
- package/dist/esm/interactions/safePolygon.native.js +179 -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 +59 -0
- package/dist/esm/interactions/useClick.mjs.map +1 -0
- package/dist/esm/interactions/useClick.native.js +64 -0
- package/dist/esm/interactions/useClick.native.js.map +1 -0
- package/dist/esm/interactions/useDelayGroup.mjs +60 -0
- package/dist/esm/interactions/useDelayGroup.mjs.map +1 -0
- package/dist/esm/interactions/useDelayGroup.native.js +70 -0
- package/dist/esm/interactions/useDelayGroup.native.js.map +1 -0
- package/dist/esm/interactions/useFocus.mjs +78 -0
- package/dist/esm/interactions/useFocus.mjs.map +1 -0
- package/dist/esm/interactions/useFocus.native.js +87 -0
- package/dist/esm/interactions/useFocus.native.js.map +1 -0
- package/dist/esm/interactions/useHover.mjs +189 -0
- package/dist/esm/interactions/useHover.mjs.map +1 -0
- package/dist/esm/interactions/useHover.native.js +210 -0
- package/dist/esm/interactions/useHover.native.js.map +1 -0
- package/dist/esm/interactions/useInnerOffset.mjs +70 -0
- package/dist/esm/interactions/useInnerOffset.mjs.map +1 -0
- package/dist/esm/interactions/useInnerOffset.native.js +81 -0
- package/dist/esm/interactions/useInnerOffset.native.js.map +1 -0
- package/dist/esm/interactions/useInteractions.mjs +53 -0
- package/dist/esm/interactions/useInteractions.mjs.map +1 -0
- package/dist/esm/interactions/useInteractions.native.js +138 -0
- package/dist/esm/interactions/useInteractions.native.js.map +1 -0
- package/dist/esm/interactions/useListNavigation.mjs +230 -0
- package/dist/esm/interactions/useListNavigation.mjs.map +1 -0
- package/dist/esm/interactions/useListNavigation.native.js +271 -0
- package/dist/esm/interactions/useListNavigation.native.js.map +1 -0
- package/dist/esm/interactions/useRole.mjs +78 -0
- package/dist/esm/interactions/useRole.mjs.map +1 -0
- package/dist/esm/interactions/useRole.native.js +91 -0
- package/dist/esm/interactions/useRole.native.js.map +1 -0
- package/dist/esm/interactions/useTypeahead.mjs +70 -0
- package/dist/esm/interactions/useTypeahead.mjs.map +1 -0
- package/dist/esm/interactions/useTypeahead.native.js +88 -0
- package/dist/esm/interactions/useTypeahead.native.js.map +1 -0
- package/dist/esm/interactions/utils.mjs +134 -0
- package/dist/esm/interactions/utils.mjs.map +1 -0
- package/dist/esm/interactions/utils.native.js +141 -0
- package/dist/esm/interactions/utils.native.js.map +1 -0
- package/dist/esm/middleware/inner.mjs +72 -0
- package/dist/esm/middleware/inner.mjs.map +1 -0
- package/dist/esm/middleware/inner.native.js +83 -0
- package/dist/esm/middleware/inner.native.js.map +1 -0
- package/dist/esm/useFloating.mjs +21 -17
- package/dist/esm/useFloating.mjs.map +1 -1
- package/dist/esm/useFloating.native.js +2 -0
- 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 +142 -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,120 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
var __create = Object.create;
|
|
4
|
+
var __defProp = Object.defineProperty;
|
|
5
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
6
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
7
|
+
var __getProtoOf = Object.getPrototypeOf,
|
|
8
|
+
__hasOwnProp = Object.prototype.hasOwnProperty;
|
|
9
|
+
var __export = (target, all) => {
|
|
10
|
+
for (var name in all) __defProp(target, name, {
|
|
11
|
+
get: all[name],
|
|
12
|
+
enumerable: !0
|
|
13
|
+
});
|
|
14
|
+
},
|
|
15
|
+
__copyProps = (to, from, except, desc) => {
|
|
16
|
+
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
|
|
17
|
+
get: () => from[key],
|
|
18
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
19
|
+
});
|
|
20
|
+
return to;
|
|
21
|
+
};
|
|
22
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
23
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
24
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
25
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
26
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
27
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
|
|
28
|
+
value: mod,
|
|
29
|
+
enumerable: !0
|
|
30
|
+
}) : target, mod)),
|
|
31
|
+
__toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
|
|
32
|
+
value: !0
|
|
33
|
+
}), mod);
|
|
34
|
+
var inner_exports = {};
|
|
35
|
+
__export(inner_exports, {
|
|
36
|
+
inner: () => inner
|
|
37
|
+
});
|
|
38
|
+
module.exports = __toCommonJS(inner_exports);
|
|
39
|
+
var ReactDOM = __toESM(require("react-dom"), 1),
|
|
40
|
+
import_react_dom = require("@floating-ui/react-dom");
|
|
41
|
+
function getArgsWithCustomFloatingHeight(state, height) {
|
|
42
|
+
return {
|
|
43
|
+
...state,
|
|
44
|
+
rects: {
|
|
45
|
+
...state.rects,
|
|
46
|
+
floating: {
|
|
47
|
+
...state.rects.floating,
|
|
48
|
+
height
|
|
49
|
+
}
|
|
50
|
+
}
|
|
51
|
+
};
|
|
52
|
+
}
|
|
53
|
+
var inner = function (props) {
|
|
54
|
+
return {
|
|
55
|
+
name: "inner",
|
|
56
|
+
options: props,
|
|
57
|
+
async fn(state) {
|
|
58
|
+
var _listRef_current,
|
|
59
|
+
{
|
|
60
|
+
listRef,
|
|
61
|
+
overflowRef,
|
|
62
|
+
onFallbackChange,
|
|
63
|
+
offset: innerOffset = 0,
|
|
64
|
+
index = 0,
|
|
65
|
+
minItemsVisible = 4,
|
|
66
|
+
referenceOverflowThreshold = 0,
|
|
67
|
+
scrollRef,
|
|
68
|
+
padding = 0
|
|
69
|
+
} = props,
|
|
70
|
+
{
|
|
71
|
+
rects,
|
|
72
|
+
platform,
|
|
73
|
+
elements: {
|
|
74
|
+
floating
|
|
75
|
+
}
|
|
76
|
+
} = state,
|
|
77
|
+
item = (_listRef_current = listRef.current) === null || _listRef_current === void 0 ? void 0 : _listRef_current[index ?? 0],
|
|
78
|
+
scrollEl = scrollRef?.current || floating,
|
|
79
|
+
clientTop = floating.clientTop || scrollEl.clientTop,
|
|
80
|
+
floatingIsBordered = floating.clientTop !== 0,
|
|
81
|
+
scrollElIsBordered = scrollEl.clientTop !== 0,
|
|
82
|
+
floatingIsScrollEl = floating === scrollEl;
|
|
83
|
+
if (!item || index == null) return onFallbackChange?.(!0), {};
|
|
84
|
+
var nextArgs = {
|
|
85
|
+
...state,
|
|
86
|
+
...(await (0, import_react_dom.offset)(-item.offsetTop - floating.clientTop - rects.reference.height / 2 - item.offsetHeight / 2 - innerOffset).fn(state))
|
|
87
|
+
},
|
|
88
|
+
detectOverflowOptions = {
|
|
89
|
+
padding
|
|
90
|
+
},
|
|
91
|
+
overflow = await platform.detectOverflow(getArgsWithCustomFloatingHeight(nextArgs, scrollEl.scrollHeight + clientTop + floating.clientTop), detectOverflowOptions),
|
|
92
|
+
refOverflow = await platform.detectOverflow(nextArgs, {
|
|
93
|
+
...detectOverflowOptions,
|
|
94
|
+
elementContext: "reference"
|
|
95
|
+
}),
|
|
96
|
+
diffY = Math.max(0, overflow.top),
|
|
97
|
+
nextY = nextArgs.y + diffY,
|
|
98
|
+
isScrollable = scrollEl.scrollHeight > scrollEl.clientHeight,
|
|
99
|
+
rounder = isScrollable ? function (v) {
|
|
100
|
+
return v;
|
|
101
|
+
} : Math.round,
|
|
102
|
+
maxHeight = rounder(Math.max(0, scrollEl.scrollHeight + (floatingIsBordered && floatingIsScrollEl || scrollElIsBordered ? clientTop * 2 : 0) - diffY - Math.max(0, overflow.bottom)));
|
|
103
|
+
if (scrollEl.style.maxHeight = `${maxHeight}px`, scrollEl.scrollTop = diffY, onFallbackChange) {
|
|
104
|
+
var _listRef_current1,
|
|
105
|
+
_listRef_current_length,
|
|
106
|
+
shouldFallback = scrollEl.offsetHeight < item.offsetHeight * Math.min(minItemsVisible, (_listRef_current_length = (_listRef_current1 = listRef.current) === null || _listRef_current1 === void 0 ? void 0 : _listRef_current1.length) !== null && _listRef_current_length !== void 0 ? _listRef_current_length : 0) - 1 || refOverflow.top >= -referenceOverflowThreshold || refOverflow.bottom >= -referenceOverflowThreshold;
|
|
107
|
+
ReactDOM.flushSync(function () {
|
|
108
|
+
return onFallbackChange(shouldFallback);
|
|
109
|
+
});
|
|
110
|
+
}
|
|
111
|
+
return overflowRef && (overflowRef.current = await platform.detectOverflow(getArgsWithCustomFloatingHeight({
|
|
112
|
+
...nextArgs,
|
|
113
|
+
y: nextY
|
|
114
|
+
}, scrollEl.offsetHeight + clientTop + floating.clientTop), detectOverflowOptions)), {
|
|
115
|
+
y: nextY
|
|
116
|
+
};
|
|
117
|
+
}
|
|
118
|
+
};
|
|
119
|
+
};
|
|
120
|
+
//# sourceMappingURL=inner.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["__toCommonJS","mod","__copyProps","__defProp","value","inner_exports","__export","inner","module","exports","ReactDOM","__toESM","require","import_react_dom","getArgsWithCustomFloatingHeight","state","height","rects","floating","props","name","options","fn","_listRef_current","listRef","overflowRef","onFallbackChange","offset","innerOffset","index","minItemsVisible","referenceOverflowThreshold","scrollRef","padding","platform","elements","item","current","scrollEl","clientTop","floatingIsBordered","scrollElIsBordered","floatingIsScrollEl","nextArgs","offsetTop","reference","offsetHeight","detectOverflowOptions","overflow","detectOverflow","scrollHeight","refOverflow","elementContext","diffY","Math","max","top","nextY","y","isScrollable","clientHeight","rounder","v","round","maxHeight","bottom","style","scrollTop","_listRef_current1","_listRef_current_length","shouldFallback","min","length","flushSync"],"sources":["../../../src/middleware/inner.ts"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|
package/dist/cjs/useFloating.cjs
CHANGED
|
@@ -38,20 +38,24 @@ module.exports = __toCommonJS(useFloating_exports);
|
|
|
38
38
|
var import_react = __toESM(require("react"), 1),
|
|
39
39
|
Floating = __toESM(require("./Floating.cjs"), 1);
|
|
40
40
|
const FloatingOverrideContext = import_react.default.createContext(null),
|
|
41
|
-
useFloating = props =>
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
41
|
+
useFloating = props => {
|
|
42
|
+
"use no memo";
|
|
43
|
+
|
|
44
|
+
return (import_react.default.useContext(FloatingOverrideContext) || Floating.useFloating)?.({
|
|
45
|
+
...props,
|
|
46
|
+
middleware: [
|
|
47
|
+
// @ts-ignore
|
|
48
|
+
...props.middleware, {
|
|
49
|
+
name: "rounded",
|
|
50
|
+
fn({
|
|
51
|
+
x,
|
|
52
|
+
y
|
|
53
|
+
}) {
|
|
54
|
+
return {
|
|
55
|
+
x: Math.round(x),
|
|
56
|
+
y: Math.round(y)
|
|
57
|
+
};
|
|
58
|
+
}
|
|
59
|
+
}]
|
|
60
|
+
});
|
|
61
|
+
};
|
|
@@ -41,6 +41,8 @@ var import_react = __toESM(require("react"), 1),
|
|
|
41
41
|
Floating = __toESM(require("./Floating.native.js"), 1),
|
|
42
42
|
FloatingOverrideContext = /* @__PURE__ */import_react.default.createContext(null),
|
|
43
43
|
useFloating = function (props) {
|
|
44
|
+
"use no memo";
|
|
45
|
+
|
|
44
46
|
var _this,
|
|
45
47
|
context = import_react.default.useContext(FloatingOverrideContext);
|
|
46
48
|
return (_this = context || Floating.useFloating) === null || _this === void 0 ? void 0 : _this({
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["__toCommonJS","mod","__copyProps","__defProp","value","useFloating_exports","__export","FloatingOverrideContext","useFloating","module","exports","import_react","__toESM","require","Floating","default","createContext","props","_this","context","useContext","middleware","name","fn","param","x","y","Math","round"],"sources":["../../src/useFloating.tsx"],"sourcesContent":[null],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAAA;EAAAA,YAAA,GAAAC,GAAA,IAAAC,WAAA,CAAAC,SAAA;IAAAC,KAAA;EAAA,IAAAH,GAAA;AAAA,IAAAI,mBAAA;AAAAC,QAAA,CAAAD,mBAAA;EAAAE,uBAAA,EAAAA,CAAA,KAAAA,uBAAA;EAAAC,WAAA,EAAAA,CAAA,KAAAA;AAAA;AAAAC,MAAA,CAAAC,OAAA,GAAAV,YAAkB,CAAAK,mBAElB;
|
|
1
|
+
{"version":3,"names":["__toCommonJS","mod","__copyProps","__defProp","value","useFloating_exports","__export","FloatingOverrideContext","useFloating","module","exports","import_react","__toESM","require","Floating","default","createContext","props","_this","context","useContext","middleware","name","fn","param","x","y","Math","round"],"sources":["../../src/useFloating.tsx"],"sourcesContent":[null],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAAA;EAAAA,YAAA,GAAAC,GAAA,IAAAC,WAAA,CAAAC,SAAA;IAAAC,KAAA;EAAA,IAAAH,GAAA;AAAA,IAAAI,mBAAA;AAAAC,QAAA,CAAAD,mBAAA;EAAAE,uBAAA,EAAAA,CAAA,KAAAA,uBAAA;EAAAC,WAAA,EAAAA,CAAA,KAAAA;AAAA;AAAAC,MAAA,CAAAC,OAAA,GAAAV,YAAkB,CAAAK,mBAElB;AA0BO,IAAAM,YAAM,GAAAC,OAAA,CAAAC,OAA0B;EAAAC,QAAM,GAAAF,OAAA,CAAAC,OAAA;EAAAN,uBAAA,kBAAAI,YAAA,CAAAI,OAAA,CAAAC,aAAA;EAAAR,WAAA,YAAAA,CAAAS,KAAA;IAC3C;;IACF,IAEaC,KAAA;MAAAC,OAAe,GAAAR,YAA+C,CAAAI,OAAA,CAAAK,UAAA,CAAAb,uBAAA;IACzE,QAAAW,KAAA,GAAAC,OAAA,IAAAL,QAAA,CAAAN,WAAA,cAAAU,KAAA,uBAAAA,KAAA;MAGA,GAAAD,KADgB;MAEdI,UAAG;MACH;MAAY,GAAAJ,KAAA,CAAAI,UAAA,EAEV;QACAC,IAAA;QACEC,GAAAC,KAAM;UACN,IAAK;YAAGC,CAAA;YAAEC;UAAG,IAAAF,KAAA;UACX,OAAO;YACLC,CAAA,EAAGE,IAAA,CAAKC,KAAA,CAAMH,CAAC;YACfC,CAAA,EAAGC,IAAA,CAAKC,KAAA,CAAMF,CAAC;UACjB;QACF;MACF;IAEJ,CAAC;EACH","ignoreList":[]}
|
|
@@ -1,5 +1,8 @@
|
|
|
1
1
|
export * from "@floating-ui/react-native";
|
|
2
2
|
var autoUpdate = function () {},
|
|
3
|
+
getOverflowAncestors = function () {
|
|
4
|
+
return [];
|
|
5
|
+
},
|
|
3
6
|
platform = null;
|
|
4
|
-
export { autoUpdate, platform };
|
|
7
|
+
export { autoUpdate, getOverflowAncestors, platform };
|
|
5
8
|
//# sourceMappingURL=Floating.native.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["autoUpdate","platform"],"sources":["../../src/Floating.native.tsx"],"sourcesContent":[null],"mappings":"
|
|
1
|
+
{"version":3,"names":["autoUpdate","getOverflowAncestors","platform"],"sources":["../../src/Floating.native.tsx"],"sourcesContent":[null],"mappings":"AAIA,cAAc;AAJP,IAAIA,UAAA,GAAa,SAAAA,CAAA,EAAW,CAAC;EACzBC,oBAAA,GAAuB,SAAAA,CAAA,EAAW;IACzC,OAAO,EAAC;EACZ;EAEWC,QAAA,GAAW","ignoreList":[]}
|
package/dist/esm/index.js
CHANGED
|
@@ -1,35 +1,18 @@
|
|
|
1
|
-
import {
|
|
2
|
-
|
|
3
|
-
|
|
4
|
-
|
|
5
|
-
|
|
6
|
-
|
|
7
|
-
|
|
8
|
-
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
} from "./
|
|
15
|
-
import {
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
} from "./useFloating";
|
|
19
|
-
export {
|
|
20
|
-
FloatingOverrideContext,
|
|
21
|
-
arrow,
|
|
22
|
-
autoPlacement,
|
|
23
|
-
autoUpdate,
|
|
24
|
-
detectOverflow,
|
|
25
|
-
flip,
|
|
26
|
-
hide,
|
|
27
|
-
inline,
|
|
28
|
-
limitShift,
|
|
29
|
-
offset,
|
|
30
|
-
platform,
|
|
31
|
-
shift,
|
|
32
|
-
size,
|
|
33
|
-
useFloating
|
|
34
|
-
};
|
|
1
|
+
import { arrow, autoPlacement, autoUpdate, detectOverflow, flip, getOverflowAncestors, hide, inline, limitShift, offset, platform, shift, size } from "./Floating.mjs";
|
|
2
|
+
import { useFloating, FloatingOverrideContext } from "./useFloating.mjs";
|
|
3
|
+
import { useFloating as useFloating2 } from "./Floating.mjs";
|
|
4
|
+
import { createFloatingEvents } from "./interactions/createFloatingEvents.mjs";
|
|
5
|
+
import { PopupTriggerMap } from "./interactions/PopupTriggerMap.mjs";
|
|
6
|
+
import { useInteractions } from "./interactions/useInteractions.mjs";
|
|
7
|
+
import { useHover } from "./interactions/useHover.mjs";
|
|
8
|
+
import { safePolygon } from "./interactions/safePolygon.mjs";
|
|
9
|
+
import { useFocus } from "./interactions/useFocus.mjs";
|
|
10
|
+
import { useRole } from "./interactions/useRole.mjs";
|
|
11
|
+
import { useClick } from "./interactions/useClick.mjs";
|
|
12
|
+
import { useListNavigation } from "./interactions/useListNavigation.mjs";
|
|
13
|
+
import { useTypeahead } from "./interactions/useTypeahead.mjs";
|
|
14
|
+
import { useInnerOffset } from "./interactions/useInnerOffset.mjs";
|
|
15
|
+
import { FloatingDelayGroup, useDelayGroup, useDelayGroupContext } from "./interactions/useDelayGroup.mjs";
|
|
16
|
+
import { inner } from "./middleware/inner.mjs";
|
|
17
|
+
export { FloatingDelayGroup, FloatingOverrideContext, PopupTriggerMap, arrow, autoPlacement, autoUpdate, createFloatingEvents, detectOverflow, flip, getOverflowAncestors, hide, inline, inner, limitShift, offset, platform, safePolygon, shift, size, useClick, useDelayGroup, useDelayGroupContext, useFloating, useFloating2 as useFloatingRaw, useFocus, useHover, useInnerOffset, useInteractions, useListNavigation, useRole, useTypeahead };
|
|
35
18
|
//# sourceMappingURL=index.js.map
|
package/dist/esm/index.js.map
CHANGED
|
@@ -1,6 +1 @@
|
|
|
1
|
-
{
|
|
2
|
-
"version": 3,
|
|
3
|
-
"sources": ["../../src/index.ts"],
|
|
4
|
-
"mappings": "AA6CA;AAAA,EACE;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,EACA;AAAA,OACK;AAEP;AAAA,EACE;AAAA,EACA;AAAA,OAIK;",
|
|
5
|
-
"names": []
|
|
6
|
-
}
|
|
1
|
+
{"version":3,"names":["arrow","autoPlacement","autoUpdate","detectOverflow","flip","getOverflowAncestors","hide","inline","limitShift","offset","platform","shift","size","useFloating","FloatingOverrideContext","useFloating2","createFloatingEvents","PopupTriggerMap","useInteractions","useHover","safePolygon","useFocus","useRole","useClick","useListNavigation","useTypeahead","useInnerOffset","FloatingDelayGroup","useDelayGroup","useDelayGroupContext","inner"],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AA6CA,SACEA,KAAA,EACAC,aAAA,EACAC,UAAA,EACAC,cAAA,EACAC,IAAA,EACAC,oBAAA,EACAC,IAAA,EACAC,MAAA,EACAC,UAAA,EACAC,MAAA,EACAC,QAAA,EACAC,KAAA,EACAC,IAAA,QACK;AAEP,SACEC,WAAA,EACAC,uBAAA,QAKK;AAIP,SAAwBD,WAAA,IAAfE,YAAA,QAAqC;AAG9C,SAASC,oBAAA,QAA4B;AAGrC,SAASC,eAAA,QAAuB;AAGhC,SAASC,eAAA,QAAuB;AAChC,SAASC,QAAA,QAAgB;AACzB,SAASC,WAAA,QAAmB;AAC5B,SAASC,QAAA,QAAgB;AACzB,SAASC,OAAA,QAAe;AACxB,SAASC,QAAA,QAAgB;AACzB,SAASC,iBAAA,QAAyB;AAClC,SAASC,YAAA,QAAoB;AAC7B,SAASC,cAAA,QAAsB;AAC/B,SACEC,kBAAA,EACAC,aAAA,EACAC,oBAAA,QACK;AAGP,SAASC,KAAA,QAAa","ignoreList":[]}
|
package/dist/esm/index.mjs
CHANGED
|
@@ -1,4 +1,18 @@
|
|
|
1
|
-
import { arrow, autoPlacement, autoUpdate, detectOverflow, flip, hide, inline, limitShift, offset, platform, shift, size } from "./Floating.mjs";
|
|
1
|
+
import { arrow, autoPlacement, autoUpdate, detectOverflow, flip, getOverflowAncestors, hide, inline, limitShift, offset, platform, shift, size } from "./Floating.mjs";
|
|
2
2
|
import { useFloating, FloatingOverrideContext } from "./useFloating.mjs";
|
|
3
|
-
|
|
3
|
+
import { useFloating as useFloating2 } from "./Floating.mjs";
|
|
4
|
+
import { createFloatingEvents } from "./interactions/createFloatingEvents.mjs";
|
|
5
|
+
import { PopupTriggerMap } from "./interactions/PopupTriggerMap.mjs";
|
|
6
|
+
import { useInteractions } from "./interactions/useInteractions.mjs";
|
|
7
|
+
import { useHover } from "./interactions/useHover.mjs";
|
|
8
|
+
import { safePolygon } from "./interactions/safePolygon.mjs";
|
|
9
|
+
import { useFocus } from "./interactions/useFocus.mjs";
|
|
10
|
+
import { useRole } from "./interactions/useRole.mjs";
|
|
11
|
+
import { useClick } from "./interactions/useClick.mjs";
|
|
12
|
+
import { useListNavigation } from "./interactions/useListNavigation.mjs";
|
|
13
|
+
import { useTypeahead } from "./interactions/useTypeahead.mjs";
|
|
14
|
+
import { useInnerOffset } from "./interactions/useInnerOffset.mjs";
|
|
15
|
+
import { FloatingDelayGroup, useDelayGroup, useDelayGroupContext } from "./interactions/useDelayGroup.mjs";
|
|
16
|
+
import { inner } from "./middleware/inner.mjs";
|
|
17
|
+
export { FloatingDelayGroup, FloatingOverrideContext, PopupTriggerMap, arrow, autoPlacement, autoUpdate, createFloatingEvents, detectOverflow, flip, getOverflowAncestors, hide, inline, inner, limitShift, offset, platform, safePolygon, shift, size, useClick, useDelayGroup, useDelayGroupContext, useFloating, useFloating2 as useFloatingRaw, useFocus, useHover, useInnerOffset, useInteractions, useListNavigation, useRole, useTypeahead };
|
|
4
18
|
//# sourceMappingURL=index.mjs.map
|
package/dist/esm/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["arrow","autoPlacement","autoUpdate","detectOverflow","flip","hide","inline","limitShift","offset","platform","shift","size","useFloating","FloatingOverrideContext"],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AA6CA,SACEA,KAAA,EACAC,aAAA,EACAC,UAAA,EACAC,cAAA,EACAC,IAAA,EACAC,IAAA,EACAC,MAAA,EACAC,UAAA,EACAC,MAAA,EACAC,QAAA,EACAC,KAAA,EACAC,IAAA,QACK;AAEP,SACEC,WAAA,EACAC,uBAAA,
|
|
1
|
+
{"version":3,"names":["arrow","autoPlacement","autoUpdate","detectOverflow","flip","getOverflowAncestors","hide","inline","limitShift","offset","platform","shift","size","useFloating","FloatingOverrideContext","useFloating2","createFloatingEvents","PopupTriggerMap","useInteractions","useHover","safePolygon","useFocus","useRole","useClick","useListNavigation","useTypeahead","useInnerOffset","FloatingDelayGroup","useDelayGroup","useDelayGroupContext","inner"],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AA6CA,SACEA,KAAA,EACAC,aAAA,EACAC,UAAA,EACAC,cAAA,EACAC,IAAA,EACAC,oBAAA,EACAC,IAAA,EACAC,MAAA,EACAC,UAAA,EACAC,MAAA,EACAC,QAAA,EACAC,KAAA,EACAC,IAAA,QACK;AAEP,SACEC,WAAA,EACAC,uBAAA,QAKK;AAIP,SAAwBD,WAAA,IAAfE,YAAA,QAAqC;AAG9C,SAASC,oBAAA,QAA4B;AAGrC,SAASC,eAAA,QAAuB;AAGhC,SAASC,eAAA,QAAuB;AAChC,SAASC,QAAA,QAAgB;AACzB,SAASC,WAAA,QAAmB;AAC5B,SAASC,QAAA,QAAgB;AACzB,SAASC,OAAA,QAAe;AACxB,SAASC,QAAA,QAAgB;AACzB,SAASC,iBAAA,QAAyB;AAClC,SAASC,YAAA,QAAoB;AAC7B,SAASC,cAAA,QAAsB;AAC/B,SACEC,kBAAA,EACAC,aAAA,EACAC,oBAAA,QACK;AAGP,SAASC,KAAA,QAAa","ignoreList":[]}
|
package/dist/esm/index.native.js
CHANGED
|
@@ -1,4 +1,18 @@
|
|
|
1
|
-
import { arrow, autoPlacement, autoUpdate, detectOverflow, flip, hide, inline, limitShift, offset, platform, shift, size } from "./Floating.native.js";
|
|
1
|
+
import { arrow, autoPlacement, autoUpdate, detectOverflow, flip, getOverflowAncestors, hide, inline, limitShift, offset, platform, shift, size } from "./Floating.native.js";
|
|
2
2
|
import { useFloating, FloatingOverrideContext } from "./useFloating.native.js";
|
|
3
|
-
|
|
3
|
+
import { useFloating as useFloating2 } from "./Floating.native.js";
|
|
4
|
+
import { createFloatingEvents } from "./interactions/createFloatingEvents.native.js";
|
|
5
|
+
import { PopupTriggerMap } from "./interactions/PopupTriggerMap.native.js";
|
|
6
|
+
import { useInteractions } from "./interactions/useInteractions.native.js";
|
|
7
|
+
import { useHover } from "./interactions/useHover.native.js";
|
|
8
|
+
import { safePolygon } from "./interactions/safePolygon.native.js";
|
|
9
|
+
import { useFocus } from "./interactions/useFocus.native.js";
|
|
10
|
+
import { useRole } from "./interactions/useRole.native.js";
|
|
11
|
+
import { useClick } from "./interactions/useClick.native.js";
|
|
12
|
+
import { useListNavigation } from "./interactions/useListNavigation.native.js";
|
|
13
|
+
import { useTypeahead } from "./interactions/useTypeahead.native.js";
|
|
14
|
+
import { useInnerOffset } from "./interactions/useInnerOffset.native.js";
|
|
15
|
+
import { FloatingDelayGroup, useDelayGroup, useDelayGroupContext } from "./interactions/useDelayGroup.native.js";
|
|
16
|
+
import { inner } from "./middleware/inner.native.js";
|
|
17
|
+
export { FloatingDelayGroup, FloatingOverrideContext, PopupTriggerMap, arrow, autoPlacement, autoUpdate, createFloatingEvents, detectOverflow, flip, getOverflowAncestors, hide, inline, inner, limitShift, offset, platform, safePolygon, shift, size, useClick, useDelayGroup, useDelayGroupContext, useFloating, useFloating2 as useFloatingRaw, useFocus, useHover, useInnerOffset, useInteractions, useListNavigation, useRole, useTypeahead };
|
|
4
18
|
//# sourceMappingURL=index.native.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"names":["arrow","autoPlacement","autoUpdate","detectOverflow","flip","hide","inline","limitShift","offset","platform","shift","size","useFloating","FloatingOverrideContext"],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AA6CA,SAAAA,KAAA,EAAAC,aAAA,EAAAC,UAAA,EAAAC,cAAA,EAAAC,IAAA,EAAAC,IAAA,EAAAC,MAAA,EAAAC,UAAA,EAAAC,MAAA,EAAAC,QAAA,EAAAC,KAAA,EAAAC,IAAA;AAAA,SACEC,WAAA,EAAAC,uBAAA;AAAA,
|
|
1
|
+
{"version":3,"names":["arrow","autoPlacement","autoUpdate","detectOverflow","flip","getOverflowAncestors","hide","inline","limitShift","offset","platform","shift","size","useFloating","FloatingOverrideContext","useFloating2","createFloatingEvents","PopupTriggerMap","useInteractions","useHover","safePolygon","useFocus","useRole","useClick","useListNavigation","useTypeahead","useInnerOffset","FloatingDelayGroup","useDelayGroup","useDelayGroupContext","inner"],"sources":["../../src/index.ts"],"sourcesContent":[null],"mappings":"AA6CA,SAAAA,KAAA,EAAAC,aAAA,EAAAC,UAAA,EAAAC,cAAA,EAAAC,IAAA,EAAAC,oBAAA,EAAAC,IAAA,EAAAC,MAAA,EAAAC,UAAA,EAAAC,MAAA,EAAAC,QAAA,EAAAC,KAAA,EAAAC,IAAA;AAAA,SACEC,WAAA,EAAAC,uBAAA;AAAA,SACAD,WAAA,IAAAE,YAAA;AAAA,SACAC,oBAAA;AAAA,SACAC,eAAA;AAAA,SACAC,eAAA;AAAA,SACAC,QAAA;AAAA,SACAC,WAAA;AAAA,SACAC,QAAA;AAAA,SACAC,OAAA;AAAA,SACAC,QAAA;AAAA,SACAC,iBAAA;AAAA,SACAC,YAAA;AAAA,SACAC,cAAA;AAAA,SACKC,kBAAA,EAAAC,aAAA,EAAAC,oBAAA;AAEP,SAAAC,KAAA;AAAA,SAEEH,kBAAA,EAAAb,uBAKK,EAIPG,eAAwB,EAGxBjB,KAAA,EAGAC,aAAS,EAGTC,UAAS,EACTc,oBAAS,EACTb,cAAS,EACTC,IAAA,EACAC,oBAAS,EACTC,IAAA,EACAC,MAAA,EACAuB,KAAA,EACAtB,UAAS,EACTC,MAAA,EACEC,QAAA,EACAU,WAAA,EACAT,KAAA,EAAAC,IAAA,EAIFW,QAAS,E","ignoreList":[]}
|
|
@@ -0,0 +1,17 @@
|
|
|
1
|
+
class PopupTriggerMap {
|
|
2
|
+
map = /* @__PURE__ */new Map();
|
|
3
|
+
elements = /* @__PURE__ */new Set();
|
|
4
|
+
add(id, element) {
|
|
5
|
+
const prev = this.map.get(id);
|
|
6
|
+
prev && this.elements.delete(prev), this.map.set(id, element), this.elements.add(element);
|
|
7
|
+
}
|
|
8
|
+
delete(id) {
|
|
9
|
+
const el = this.map.get(id);
|
|
10
|
+
el && (this.elements.delete(el), this.map.delete(id));
|
|
11
|
+
}
|
|
12
|
+
hasElement(element) {
|
|
13
|
+
return this.elements.has(element);
|
|
14
|
+
}
|
|
15
|
+
}
|
|
16
|
+
export { PopupTriggerMap };
|
|
17
|
+
//# sourceMappingURL=PopupTriggerMap.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["PopupTriggerMap","map","Map","elements","Set","add","id","element","prev","get","delete","set","el","hasElement","has"],"sources":["../../../src/interactions/PopupTriggerMap.ts"],"sourcesContent":[null],"mappings":"AAKO,MAAMA,eAAA,CAAgB;EACnBC,GAAA,GAAM,mBAAIC,GAAA,CAAqB;EAC/BC,QAAA,GAAW,mBAAIC,GAAA,CAAa;EAEpCC,IAAIC,EAAA,EAAYC,OAAA,EAAkB;IAChC,MAAMC,IAAA,GAAO,KAAKP,GAAA,CAAIQ,GAAA,CAAIH,EAAE;IACxBE,IAAA,IACF,KAAKL,QAAA,CAASO,MAAA,CAAOF,IAAI,GAE3B,KAAKP,GAAA,CAAIU,GAAA,CAAIL,EAAA,EAAIC,OAAO,GACxB,KAAKJ,QAAA,CAASE,GAAA,CAAIE,OAAO;EAC3B;EAEAG,OAAOJ,EAAA,EAAY;IACjB,MAAMM,EAAA,GAAK,KAAKX,GAAA,CAAIQ,GAAA,CAAIH,EAAE;IACtBM,EAAA,KACF,KAAKT,QAAA,CAASO,MAAA,CAAOE,EAAE,GACvB,KAAKX,GAAA,CAAIS,MAAA,CAAOJ,EAAE;EAEtB;EAEAO,WAAWN,OAAA,EAA2B;IACpC,OAAO,KAAKJ,QAAA,CAASW,GAAA,CAAIP,OAAO;EAClC;AACF","ignoreList":[]}
|
|
@@ -0,0 +1,47 @@
|
|
|
1
|
+
function _class_call_check(instance, Constructor) {
|
|
2
|
+
if (!(instance instanceof Constructor)) throw new TypeError("Cannot call a class as a function");
|
|
3
|
+
}
|
|
4
|
+
function _defineProperties(target, props) {
|
|
5
|
+
for (var i = 0; i < props.length; i++) {
|
|
6
|
+
var descriptor = props[i];
|
|
7
|
+
descriptor.enumerable = descriptor.enumerable || !1, descriptor.configurable = !0, "value" in descriptor && (descriptor.writable = !0), Object.defineProperty(target, descriptor.key, descriptor);
|
|
8
|
+
}
|
|
9
|
+
}
|
|
10
|
+
function _create_class(Constructor, protoProps, staticProps) {
|
|
11
|
+
return protoProps && _defineProperties(Constructor.prototype, protoProps), staticProps && _defineProperties(Constructor, staticProps), Constructor;
|
|
12
|
+
}
|
|
13
|
+
function _define_property(obj, key, value) {
|
|
14
|
+
return key in obj ? Object.defineProperty(obj, key, {
|
|
15
|
+
value,
|
|
16
|
+
enumerable: !0,
|
|
17
|
+
configurable: !0,
|
|
18
|
+
writable: !0
|
|
19
|
+
}) : obj[key] = value, obj;
|
|
20
|
+
}
|
|
21
|
+
var PopupTriggerMap = /* @__PURE__ */function () {
|
|
22
|
+
"use strict";
|
|
23
|
+
|
|
24
|
+
function PopupTriggerMap2() {
|
|
25
|
+
_class_call_check(this, PopupTriggerMap2), _define_property(this, "map", /* @__PURE__ */new Map()), _define_property(this, "elements", /* @__PURE__ */new Set());
|
|
26
|
+
}
|
|
27
|
+
return _create_class(PopupTriggerMap2, [{
|
|
28
|
+
key: "add",
|
|
29
|
+
value: function (id, element) {
|
|
30
|
+
var prev = this.map.get(id);
|
|
31
|
+
prev && this.elements.delete(prev), this.map.set(id, element), this.elements.add(element);
|
|
32
|
+
}
|
|
33
|
+
}, {
|
|
34
|
+
key: "delete",
|
|
35
|
+
value: function (id) {
|
|
36
|
+
var el = this.map.get(id);
|
|
37
|
+
el && (this.elements.delete(el), this.map.delete(id));
|
|
38
|
+
}
|
|
39
|
+
}, {
|
|
40
|
+
key: "hasElement",
|
|
41
|
+
value: function (element) {
|
|
42
|
+
return this.elements.has(element);
|
|
43
|
+
}
|
|
44
|
+
}]), PopupTriggerMap2;
|
|
45
|
+
}();
|
|
46
|
+
export { PopupTriggerMap };
|
|
47
|
+
//# sourceMappingURL=PopupTriggerMap.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["_class_call_check","instance","Constructor","TypeError","_defineProperties","target","props","i","length","descriptor","enumerable","configurable","writable","Object","defineProperty","key","_create_class","protoProps","staticProps","prototype","_define_property","obj","value"],"sources":["../../../src/interactions/PopupTriggerMap.ts"],"sourcesContent":[null],"mappings":"AAKO,SAAMA,iBAAgBA,CAAAC,QAAA,EAAAC,WAAA;EACnB,MAAMD,QAAA,YAAIC,WAAqB,GAC/B,UAAWC,SAAA,oCAAiB;AAAA;AAGlC,SAAAC,iBAAsBA,CAAAC,MAAM,EAAAC,KAAA;EAC5B,KAAI,IAAAC,CACF,MAAKA,CAAA,GAAAD,KAAS,CAAAE,MAAO,EAAAD,CAAI,IAE3B;IAEF,IAAAE,UAAA,GAAAH,KAAA,CAAAC,CAAA;IAEAE,UAAmB,CAAAC,UAAA,GAAAD,UAAA,CAAAC,UAAA,QAAAD,UAAA,CAAAE,YAAA,kBAAAF,UAAA,KAAAA,UAAA,CAAAG,QAAA,QAAAC,MAAA,CAAAC,cAAA,CAAAT,MAAA,EAAAI,UAAA,CAAAM,GAAA,EAAAN,UAAA;EACjB;AACA;AAEoB,SAEtBO,cAAAd,WAAA,EAAAe,UAAA,EAAAC,WAAA;EAEA,OAAAD,UAAW,IAA2Bb,iBAAA,CAAAF,WAAA,CAAAiB,SAAA,EAAAF,UAAA,GAAAC,WAAA,IAAAd,iBAAA,CAAAF,WAAA,EAAAgB,WAAA,GAAAhB,WAAA;AACpC;AAAgC,SAClCkB,iBAAAC,GAAA,EAAAN,GAAA,EAAAO,KAAA;EACF,OAAAP,GAAA,IAAAM,GAAA,GAAAR,MAAA,CAAAC,cAAA,CAAAO,GAAA,EAAAN,GAAA","ignoreList":[]}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
function createFloatingEvents() {
|
|
2
|
+
const listeners = /* @__PURE__ */new Map();
|
|
3
|
+
return {
|
|
4
|
+
emit(event, data) {
|
|
5
|
+
listeners.get(event)?.forEach(fn => fn(data));
|
|
6
|
+
},
|
|
7
|
+
on(event, handler) {
|
|
8
|
+
let set = listeners.get(event);
|
|
9
|
+
set || (set = /* @__PURE__ */new Set(), listeners.set(event, set)), set.add(handler);
|
|
10
|
+
},
|
|
11
|
+
off(event, handler) {
|
|
12
|
+
const set = listeners.get(event);
|
|
13
|
+
set && (set.delete(handler), set.size === 0 && listeners.delete(event));
|
|
14
|
+
}
|
|
15
|
+
};
|
|
16
|
+
}
|
|
17
|
+
export { createFloatingEvents };
|
|
18
|
+
//# sourceMappingURL=createFloatingEvents.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createFloatingEvents","listeners","Map","emit","event","data","get","forEach","fn","on","handler","set","Set","add","off","delete","size"],"sources":["../../../src/interactions/createFloatingEvents.ts"],"sourcesContent":[null],"mappings":"AAUO,SAASA,qBAAA,EAAuC;EACrD,MAAMC,SAAA,GAAY,mBAAIC,GAAA,CAAuC;EAE7D,OAAO;IACLC,KAAKC,KAAA,EAAOC,IAAA,EAAM;MAChBJ,SAAA,CAAUK,GAAA,CAAIF,KAAK,GAAGG,OAAA,CAASC,EAAA,IAAOA,EAAA,CAAGH,IAAI,CAAC;IAChD;IACAI,GAAGL,KAAA,EAAOM,OAAA,EAAS;MACjB,IAAIC,GAAA,GAAMV,SAAA,CAAUK,GAAA,CAAIF,KAAK;MACxBO,GAAA,KACHA,GAAA,GAAM,mBAAIC,GAAA,CAAI,GACdX,SAAA,CAAUU,GAAA,CAAIP,KAAA,EAAOO,GAAG,IAE1BA,GAAA,CAAIE,GAAA,CAAIH,OAAO;IACjB;IACAI,IAAIV,KAAA,EAAOM,OAAA,EAAS;MAClB,MAAMC,GAAA,GAAMV,SAAA,CAAUK,GAAA,CAAIF,KAAK;MAC3BO,GAAA,KACFA,GAAA,CAAII,MAAA,CAAOL,OAAO,GACdC,GAAA,CAAIK,IAAA,KAAS,KAAGf,SAAA,CAAUc,MAAA,CAAOX,KAAK;IAE9C;EACF;AACF","ignoreList":[]}
|
|
@@ -0,0 +1,21 @@
|
|
|
1
|
+
function createFloatingEvents() {
|
|
2
|
+
var listeners = /* @__PURE__ */new Map();
|
|
3
|
+
return {
|
|
4
|
+
emit(event, data) {
|
|
5
|
+
var _listeners_get;
|
|
6
|
+
(_listeners_get = listeners.get(event)) === null || _listeners_get === void 0 || _listeners_get.forEach(function (fn) {
|
|
7
|
+
return fn(data);
|
|
8
|
+
});
|
|
9
|
+
},
|
|
10
|
+
on(event, handler) {
|
|
11
|
+
var set = listeners.get(event);
|
|
12
|
+
set || (set = /* @__PURE__ */new Set(), listeners.set(event, set)), set.add(handler);
|
|
13
|
+
},
|
|
14
|
+
off(event, handler) {
|
|
15
|
+
var set = listeners.get(event);
|
|
16
|
+
set && (set.delete(handler), set.size === 0 && listeners.delete(event));
|
|
17
|
+
}
|
|
18
|
+
};
|
|
19
|
+
}
|
|
20
|
+
export { createFloatingEvents };
|
|
21
|
+
//# sourceMappingURL=createFloatingEvents.native.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["createFloatingEvents","listeners","Map","emit","event","data","_listeners_get","get","forEach","fn","on","handler","set","Set","add","off","delete","size"],"sources":["../../../src/interactions/createFloatingEvents.ts"],"sourcesContent":[null],"mappings":"AAUO,SAASA,qBAAA,EAAuC;EACrD,IAAAC,SAAM,kBAAY,IAAAC,GAAI;EAEtB,OAAO;IACLC,KAAKC,KAAA,EAAOC,IAAA,EAAM;MAChB,IAAAC,cAAc;MAChB,CAAAA,cAAA,GAAAL,SAAA,CAAAM,GAAA,CAAAH,KAAA,eAAAE,cAAA,eAAAA,cAAA,CAAAE,OAAA,WAAAC,EAAA;QACG,OAAOA,EAAA,CAAAJ,IAAA,CAAS;MACjB;IACA;IAKFK,GAAAN,KAAA,EAAAO,OAAA;MACA,IAAIC,GAAA,GAAOX,SAAS,CAAAM,GAAA,CAAAH,KAAA;MAClBQ,GAAA,KAAMA,GAAA,GAAM,eAAc,IAAKC,GAAA,IAAAZ,SAAA,CAAAW,GAAA,CAAAR,KAAA,EAAAQ,GAAA,IAAAA,GAAA,CAAAE,GAAA,CAAAH,OAAA;IAC/B;IAIFI,IAAAX,KAAA,EAAAO,OAAA;MACF,IAAAC,GAAA,GAAAX,SAAA,CAAAM,GAAA,CAAAH,KAAA;MACFQ,GAAA,KAAAA,GAAA,CAAAI,MAAA,CAAAL,OAAA,GAAAC,GAAA,CAAAK,IAAA,UAAAhB,SAAA,CAAAe,MAAA,CAAAZ,KAAA","ignoreList":[]}
|
|
@@ -0,0 +1,168 @@
|
|
|
1
|
+
import { clearTimeoutIfSet, contains, getTarget } from "./utils.mjs";
|
|
2
|
+
function isPointInPolygon(point, polygon) {
|
|
3
|
+
const [x, y] = point;
|
|
4
|
+
let isInside2 = !1;
|
|
5
|
+
const length = polygon.length;
|
|
6
|
+
for (let i = 0, j = length - 1; i < length; j = i++) {
|
|
7
|
+
const [xi, yi] = polygon[i] || [0, 0],
|
|
8
|
+
[xj, yj] = polygon[j] || [0, 0];
|
|
9
|
+
yi >= y != yj >= y && x <= (xj - xi) * (y - yi) / (yj - yi) + xi && (isInside2 = !isInside2);
|
|
10
|
+
}
|
|
11
|
+
return isInside2;
|
|
12
|
+
}
|
|
13
|
+
function isInside(point, rect) {
|
|
14
|
+
return point[0] >= rect.x && point[0] <= rect.x + rect.width && point[1] >= rect.y && point[1] <= rect.y + rect.height;
|
|
15
|
+
}
|
|
16
|
+
let debugSvg = null;
|
|
17
|
+
function debugDrawPolygon(polygon, trough, cursor, anchor) {
|
|
18
|
+
if (debugSvg || (debugSvg = document.createElementNS("http://www.w3.org/2000/svg", "svg"), debugSvg.id = "__safe-polygon-debug", Object.assign(debugSvg.style, {
|
|
19
|
+
position: "fixed",
|
|
20
|
+
inset: "0",
|
|
21
|
+
width: "100vw",
|
|
22
|
+
height: "100vh",
|
|
23
|
+
pointerEvents: "none",
|
|
24
|
+
zIndex: "999999"
|
|
25
|
+
}), document.body.appendChild(debugSvg)), debugSvg.innerHTML = "", trough.length) {
|
|
26
|
+
const troughEl = document.createElementNS("http://www.w3.org/2000/svg", "polygon");
|
|
27
|
+
troughEl.setAttribute("points", trough.map(p => p.join(",")).join(" ")), troughEl.setAttribute("fill", "rgba(0,100,255,0.15)"), troughEl.setAttribute("stroke", "rgba(0,100,255,0.6)"), troughEl.setAttribute("stroke-width", "1"), debugSvg.appendChild(troughEl);
|
|
28
|
+
}
|
|
29
|
+
if (polygon.length) {
|
|
30
|
+
const polyEl = document.createElementNS("http://www.w3.org/2000/svg", "polygon");
|
|
31
|
+
polyEl.setAttribute("points", polygon.map(p => p.join(",")).join(" ")), polyEl.setAttribute("fill", "rgba(255,50,50,0.2)"), polyEl.setAttribute("stroke", "rgba(255,50,50,0.8)"), polyEl.setAttribute("stroke-width", "1.5"), debugSvg.appendChild(polyEl);
|
|
32
|
+
}
|
|
33
|
+
const anchorCircle = document.createElementNS("http://www.w3.org/2000/svg", "circle");
|
|
34
|
+
anchorCircle.setAttribute("cx", String(anchor[0])), anchorCircle.setAttribute("cy", String(anchor[1])), anchorCircle.setAttribute("r", "5"), anchorCircle.setAttribute("fill", "lime"), anchorCircle.setAttribute("stroke", "darkgreen"), anchorCircle.setAttribute("stroke-width", "1.5"), debugSvg.appendChild(anchorCircle);
|
|
35
|
+
const cursorCircle = document.createElementNS("http://www.w3.org/2000/svg", "circle");
|
|
36
|
+
cursorCircle.setAttribute("cx", String(cursor[0])), cursorCircle.setAttribute("cy", String(cursor[1])), cursorCircle.setAttribute("r", "4"), cursorCircle.setAttribute("fill", "yellow"), cursorCircle.setAttribute("stroke", "orange"), cursorCircle.setAttribute("stroke-width", "1.5"), debugSvg.appendChild(cursorCircle);
|
|
37
|
+
}
|
|
38
|
+
function debugClear() {
|
|
39
|
+
debugSvg && (debugSvg.remove(), debugSvg = null);
|
|
40
|
+
}
|
|
41
|
+
function safePolygon(options = {}) {
|
|
42
|
+
const {
|
|
43
|
+
buffer = 0.5,
|
|
44
|
+
blockPointerEvents = !1,
|
|
45
|
+
requireIntent = !0,
|
|
46
|
+
__debug = !1
|
|
47
|
+
} = options,
|
|
48
|
+
timeoutRef = {
|
|
49
|
+
current: -1
|
|
50
|
+
};
|
|
51
|
+
let hasLanded = !1,
|
|
52
|
+
lastX = null,
|
|
53
|
+
lastY = null,
|
|
54
|
+
lastCursorTime = typeof performance < "u" ? performance.now() : 0;
|
|
55
|
+
function getCursorSpeed(x, y) {
|
|
56
|
+
const currentTime = performance.now(),
|
|
57
|
+
elapsedTime = currentTime - lastCursorTime;
|
|
58
|
+
if (lastX === null || lastY === null || elapsedTime === 0) return lastX = x, lastY = y, lastCursorTime = currentTime, null;
|
|
59
|
+
const deltaX = x - lastX,
|
|
60
|
+
deltaY = y - lastY,
|
|
61
|
+
speed = Math.sqrt(deltaX * deltaX + deltaY * deltaY) / elapsedTime;
|
|
62
|
+
return lastX = x, lastY = y, lastCursorTime = currentTime, speed;
|
|
63
|
+
}
|
|
64
|
+
const fn = ({
|
|
65
|
+
x,
|
|
66
|
+
y,
|
|
67
|
+
placement,
|
|
68
|
+
elements,
|
|
69
|
+
onClose
|
|
70
|
+
}) => (hasLanded = !1, lastX = null, lastY = null, function (event) {
|
|
71
|
+
function close() {
|
|
72
|
+
clearTimeoutIfSet(timeoutRef), onClose();
|
|
73
|
+
}
|
|
74
|
+
clearTimeoutIfSet(timeoutRef);
|
|
75
|
+
const domReference = elements.domReference ?? elements.reference;
|
|
76
|
+
if (!domReference || !elements.floating || placement == null || x == null || y == null) return;
|
|
77
|
+
const {
|
|
78
|
+
clientX,
|
|
79
|
+
clientY
|
|
80
|
+
} = event,
|
|
81
|
+
clientPoint = [clientX, clientY],
|
|
82
|
+
target = getTarget(event),
|
|
83
|
+
isLeave = event.type === "mouseleave",
|
|
84
|
+
isOverFloatingEl = contains(elements.floating, target),
|
|
85
|
+
isOverReferenceEl = contains(domReference, target),
|
|
86
|
+
refRect = domReference.getBoundingClientRect(),
|
|
87
|
+
rect = elements.floating.getBoundingClientRect(),
|
|
88
|
+
side = placement.split("-")[0],
|
|
89
|
+
cursorLeaveFromRight = x > rect.right - rect.width / 2,
|
|
90
|
+
cursorLeaveFromBottom = y > rect.bottom - rect.height / 2,
|
|
91
|
+
isOverReferenceRect = isInside(clientPoint, refRect),
|
|
92
|
+
isFloatingWider = rect.width > refRect.width,
|
|
93
|
+
isFloatingTaller = rect.height > refRect.height,
|
|
94
|
+
left = (isFloatingWider ? refRect : rect).left,
|
|
95
|
+
right = (isFloatingWider ? refRect : rect).right,
|
|
96
|
+
top = (isFloatingTaller ? refRect : rect).top,
|
|
97
|
+
bottom = (isFloatingTaller ? refRect : rect).bottom;
|
|
98
|
+
if (isOverFloatingEl && (hasLanded = !0, !isLeave)) return;
|
|
99
|
+
if (isOverReferenceEl && (hasLanded = !1), isOverReferenceEl && !isLeave) {
|
|
100
|
+
hasLanded = !0;
|
|
101
|
+
return;
|
|
102
|
+
}
|
|
103
|
+
if (!isOverReferenceEl && isOverReferenceRect && !isLeave || isLeave && event.relatedTarget && contains(elements.floating, event.relatedTarget)) return;
|
|
104
|
+
if (side === "top" && y >= refRect.bottom - 1 || side === "bottom" && y <= refRect.top + 1 || side === "left" && x >= refRect.right - 1 || side === "right" && x <= refRect.left + 1) return close();
|
|
105
|
+
let rectPoly = [];
|
|
106
|
+
switch (side) {
|
|
107
|
+
case "top":
|
|
108
|
+
rectPoly = [[left, refRect.top + 1], [left, rect.bottom - 1], [right, rect.bottom - 1], [right, refRect.top + 1]];
|
|
109
|
+
break;
|
|
110
|
+
case "bottom":
|
|
111
|
+
rectPoly = [[left, rect.top + 1], [left, refRect.bottom - 1], [right, refRect.bottom - 1], [right, rect.top + 1]];
|
|
112
|
+
break;
|
|
113
|
+
case "left":
|
|
114
|
+
rectPoly = [[rect.right - 1, bottom], [rect.right - 1, top], [refRect.left + 1, top], [refRect.left + 1, bottom]];
|
|
115
|
+
break;
|
|
116
|
+
case "right":
|
|
117
|
+
rectPoly = [[refRect.right - 1, bottom], [refRect.right - 1, top], [rect.left + 1, top], [rect.left + 1, bottom]];
|
|
118
|
+
break;
|
|
119
|
+
}
|
|
120
|
+
function getPolygon([x2, y2]) {
|
|
121
|
+
switch (side) {
|
|
122
|
+
case "top":
|
|
123
|
+
{
|
|
124
|
+
const cursorPointOne = [isFloatingWider ? x2 + buffer / 2 : cursorLeaveFromRight ? x2 + buffer * 4 : x2 - buffer * 4, y2 + buffer + 1],
|
|
125
|
+
cursorPointTwo = [isFloatingWider ? x2 - buffer / 2 : cursorLeaveFromRight ? x2 + buffer * 4 : x2 - buffer * 4, y2 + buffer + 1],
|
|
126
|
+
commonPoints = [[rect.left, cursorLeaveFromRight || isFloatingWider ? rect.bottom - buffer : rect.top], [rect.right, cursorLeaveFromRight ? isFloatingWider ? rect.bottom - buffer : rect.top : rect.bottom - buffer]];
|
|
127
|
+
return [cursorPointOne, cursorPointTwo, ...commonPoints];
|
|
128
|
+
}
|
|
129
|
+
case "bottom":
|
|
130
|
+
{
|
|
131
|
+
const cursorPointOne = [isFloatingWider ? x2 + buffer / 2 : cursorLeaveFromRight ? x2 + buffer * 4 : x2 - buffer * 4, y2 - buffer],
|
|
132
|
+
cursorPointTwo = [isFloatingWider ? x2 - buffer / 2 : cursorLeaveFromRight ? x2 + buffer * 4 : x2 - buffer * 4, y2 - buffer],
|
|
133
|
+
commonPoints = [[rect.left, cursorLeaveFromRight || isFloatingWider ? rect.top + buffer : rect.bottom], [rect.right, cursorLeaveFromRight ? isFloatingWider ? rect.top + buffer : rect.bottom : rect.top + buffer]];
|
|
134
|
+
return [cursorPointOne, cursorPointTwo, ...commonPoints];
|
|
135
|
+
}
|
|
136
|
+
case "left":
|
|
137
|
+
{
|
|
138
|
+
const cursorPointOne = [x2 + buffer + 1, isFloatingTaller ? y2 + buffer / 2 : cursorLeaveFromBottom ? y2 + buffer * 4 : y2 - buffer * 4],
|
|
139
|
+
cursorPointTwo = [x2 + buffer + 1, isFloatingTaller ? y2 - buffer / 2 : cursorLeaveFromBottom ? y2 + buffer * 4 : y2 - buffer * 4];
|
|
140
|
+
return [...[[cursorLeaveFromBottom || isFloatingTaller ? rect.right - buffer : rect.left, rect.top], [cursorLeaveFromBottom ? isFloatingTaller ? rect.right - buffer : rect.left : rect.right - buffer, rect.bottom]], cursorPointOne, cursorPointTwo];
|
|
141
|
+
}
|
|
142
|
+
case "right":
|
|
143
|
+
{
|
|
144
|
+
const cursorPointOne = [x2 - buffer, isFloatingTaller ? y2 + buffer / 2 : cursorLeaveFromBottom ? y2 + buffer * 4 : y2 - buffer * 4],
|
|
145
|
+
cursorPointTwo = [x2 - buffer, isFloatingTaller ? y2 - buffer / 2 : cursorLeaveFromBottom ? y2 + buffer * 4 : y2 - buffer * 4],
|
|
146
|
+
commonPoints = [[cursorLeaveFromBottom || isFloatingTaller ? rect.left + buffer : rect.right, rect.top], [cursorLeaveFromBottom ? isFloatingTaller ? rect.left + buffer : rect.right : rect.left + buffer, rect.bottom]];
|
|
147
|
+
return [cursorPointOne, cursorPointTwo, ...commonPoints];
|
|
148
|
+
}
|
|
149
|
+
}
|
|
150
|
+
}
|
|
151
|
+
const poly = getPolygon([x, y]);
|
|
152
|
+
if (__debug && debugDrawPolygon(poly, rectPoly, clientPoint, [x, y]), !isPointInPolygon([clientX, clientY], rectPoly)) {
|
|
153
|
+
if (hasLanded && !isOverReferenceRect) return __debug && debugClear(), close();
|
|
154
|
+
if (!isPointInPolygon([clientX, clientY], poly)) {
|
|
155
|
+
if (!isLeave && requireIntent) {
|
|
156
|
+
const cursorSpeed = getCursorSpeed(clientX, clientY);
|
|
157
|
+
if (cursorSpeed !== null && cursorSpeed < 0.1) return __debug && debugClear(), close();
|
|
158
|
+
}
|
|
159
|
+
__debug && debugClear(), close();
|
|
160
|
+
}
|
|
161
|
+
}
|
|
162
|
+
});
|
|
163
|
+
return fn.__options = {
|
|
164
|
+
blockPointerEvents
|
|
165
|
+
}, fn;
|
|
166
|
+
}
|
|
167
|
+
export { safePolygon };
|
|
168
|
+
//# sourceMappingURL=safePolygon.mjs.map
|