@tamagui/v2-toast 2.0.0-1769464493958
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/Toast.cjs +170 -0
- package/dist/cjs/Toast.js +119 -0
- package/dist/cjs/Toast.js.map +6 -0
- package/dist/cjs/Toast.native.js +174 -0
- package/dist/cjs/Toast.native.js.map +1 -0
- package/dist/cjs/ToastAnnounce.cjs +97 -0
- package/dist/cjs/ToastAnnounce.js +72 -0
- package/dist/cjs/ToastAnnounce.js.map +6 -0
- package/dist/cjs/ToastAnnounce.native.js +105 -0
- package/dist/cjs/ToastAnnounce.native.js.map +1 -0
- package/dist/cjs/ToastImperative.cjs +100 -0
- package/dist/cjs/ToastImperative.js +71 -0
- package/dist/cjs/ToastImperative.js.map +6 -0
- package/dist/cjs/ToastImperative.native.js +122 -0
- package/dist/cjs/ToastImperative.native.js.map +1 -0
- package/dist/cjs/ToastImpl.cjs +292 -0
- package/dist/cjs/ToastImpl.js +227 -0
- package/dist/cjs/ToastImpl.js.map +6 -0
- package/dist/cjs/ToastImpl.native.js +327 -0
- package/dist/cjs/ToastImpl.native.js.map +1 -0
- package/dist/cjs/ToastItem.cjs +466 -0
- package/dist/cjs/ToastItem.js +356 -0
- package/dist/cjs/ToastItem.js.map +6 -0
- package/dist/cjs/ToastItem.native.js +547 -0
- package/dist/cjs/ToastItem.native.js.map +1 -0
- package/dist/cjs/ToastPortal.cjs +44 -0
- package/dist/cjs/ToastPortal.js +26 -0
- package/dist/cjs/ToastPortal.js.map +6 -0
- package/dist/cjs/ToastPortal.native.js +47 -0
- package/dist/cjs/ToastPortal.native.js.map +1 -0
- package/dist/cjs/ToastProvider.cjs +146 -0
- package/dist/cjs/ToastProvider.js +105 -0
- package/dist/cjs/ToastProvider.js.map +6 -0
- package/dist/cjs/ToastProvider.native.js +159 -0
- package/dist/cjs/ToastProvider.native.js.map +1 -0
- package/dist/cjs/ToastState.cjs +248 -0
- package/dist/cjs/ToastState.js +160 -0
- package/dist/cjs/ToastState.js.map +6 -0
- package/dist/cjs/ToastState.native.js +257 -0
- package/dist/cjs/ToastState.native.js.map +1 -0
- package/dist/cjs/ToastViewport.cjs +278 -0
- package/dist/cjs/ToastViewport.js +263 -0
- package/dist/cjs/ToastViewport.js.map +6 -0
- package/dist/cjs/ToastViewport.native.js +316 -0
- package/dist/cjs/ToastViewport.native.js.map +1 -0
- package/dist/cjs/Toaster.cjs +219 -0
- package/dist/cjs/Toaster.js +177 -0
- package/dist/cjs/Toaster.js.map +6 -0
- package/dist/cjs/Toaster.native.js +279 -0
- package/dist/cjs/Toaster.native.js.map +1 -0
- package/dist/cjs/constants.cjs +28 -0
- package/dist/cjs/constants.js +22 -0
- package/dist/cjs/constants.js.map +6 -0
- package/dist/cjs/constants.native.js +31 -0
- package/dist/cjs/constants.native.js.map +1 -0
- package/dist/cjs/createNativeToast.cjs +51 -0
- package/dist/cjs/createNativeToast.js +44 -0
- package/dist/cjs/createNativeToast.js.map +6 -0
- package/dist/cjs/createNativeToast.native.js +47 -0
- package/dist/cjs/createNativeToast.native.js.map +1 -0
- package/dist/cjs/index.cjs +28 -0
- package/dist/cjs/index.js +22 -0
- package/dist/cjs/index.js.map +6 -0
- package/dist/cjs/index.native.js +31 -0
- package/dist/cjs/index.native.js.map +1 -0
- package/dist/cjs/types.cjs +16 -0
- package/dist/cjs/types.js +14 -0
- package/dist/cjs/types.js.map +6 -0
- package/dist/cjs/types.native.js +19 -0
- package/dist/cjs/types.native.js.map +1 -0
- package/dist/cjs/useDragGesture.cjs +129 -0
- package/dist/cjs/useDragGesture.js +100 -0
- package/dist/cjs/useDragGesture.js.map +6 -0
- package/dist/cjs/useDragGesture.native.js +146 -0
- package/dist/cjs/useDragGesture.native.js.map +1 -0
- package/dist/esm/Toast.js +107 -0
- package/dist/esm/Toast.js.map +6 -0
- package/dist/esm/Toast.mjs +131 -0
- package/dist/esm/Toast.mjs.map +1 -0
- package/dist/esm/Toast.native.js +132 -0
- package/dist/esm/Toast.native.js.map +1 -0
- package/dist/esm/ToastAnnounce.js +55 -0
- package/dist/esm/ToastAnnounce.js.map +6 -0
- package/dist/esm/ToastAnnounce.mjs +62 -0
- package/dist/esm/ToastAnnounce.mjs.map +1 -0
- package/dist/esm/ToastAnnounce.native.js +67 -0
- package/dist/esm/ToastAnnounce.native.js.map +1 -0
- package/dist/esm/ToastImperative.js +50 -0
- package/dist/esm/ToastImperative.js.map +6 -0
- package/dist/esm/ToastImperative.mjs +63 -0
- package/dist/esm/ToastImperative.mjs.map +1 -0
- package/dist/esm/ToastImperative.native.js +82 -0
- package/dist/esm/ToastImperative.native.js.map +1 -0
- package/dist/esm/ToastImpl.js +225 -0
- package/dist/esm/ToastImpl.js.map +6 -0
- package/dist/esm/ToastImpl.mjs +256 -0
- package/dist/esm/ToastImpl.mjs.map +1 -0
- package/dist/esm/ToastImpl.native.js +288 -0
- package/dist/esm/ToastImpl.native.js.map +1 -0
- package/dist/esm/ToastItem.js +339 -0
- package/dist/esm/ToastItem.js.map +6 -0
- package/dist/esm/ToastItem.mjs +432 -0
- package/dist/esm/ToastItem.mjs.map +1 -0
- package/dist/esm/ToastItem.native.js +510 -0
- package/dist/esm/ToastItem.native.js.map +1 -0
- package/dist/esm/ToastPortal.js +13 -0
- package/dist/esm/ToastPortal.js.map +6 -0
- package/dist/esm/ToastPortal.mjs +21 -0
- package/dist/esm/ToastPortal.mjs.map +1 -0
- package/dist/esm/ToastPortal.native.js +21 -0
- package/dist/esm/ToastPortal.native.js.map +1 -0
- package/dist/esm/ToastProvider.js +87 -0
- package/dist/esm/ToastProvider.js.map +6 -0
- package/dist/esm/ToastProvider.mjs +108 -0
- package/dist/esm/ToastProvider.mjs.map +1 -0
- package/dist/esm/ToastProvider.native.js +118 -0
- package/dist/esm/ToastProvider.native.js.map +1 -0
- package/dist/esm/ToastState.js +144 -0
- package/dist/esm/ToastState.js.map +6 -0
- package/dist/esm/ToastState.mjs +224 -0
- package/dist/esm/ToastState.mjs.map +1 -0
- package/dist/esm/ToastState.native.js +230 -0
- package/dist/esm/ToastState.native.js.map +1 -0
- package/dist/esm/ToastViewport.js +250 -0
- package/dist/esm/ToastViewport.js.map +6 -0
- package/dist/esm/ToastViewport.mjs +241 -0
- package/dist/esm/ToastViewport.mjs.map +1 -0
- package/dist/esm/ToastViewport.native.js +276 -0
- package/dist/esm/ToastViewport.native.js.map +1 -0
- package/dist/esm/Toaster.js +160 -0
- package/dist/esm/Toaster.js.map +6 -0
- package/dist/esm/Toaster.mjs +185 -0
- package/dist/esm/Toaster.mjs.map +1 -0
- package/dist/esm/Toaster.native.js +242 -0
- package/dist/esm/Toaster.native.js.map +1 -0
- package/dist/esm/constants.js +6 -0
- package/dist/esm/constants.js.map +6 -0
- package/dist/esm/constants.mjs +4 -0
- package/dist/esm/constants.mjs.map +1 -0
- package/dist/esm/constants.native.js +4 -0
- package/dist/esm/constants.native.js.map +1 -0
- package/dist/esm/createNativeToast.js +28 -0
- package/dist/esm/createNativeToast.js.map +6 -0
- package/dist/esm/createNativeToast.mjs +27 -0
- package/dist/esm/createNativeToast.mjs.map +1 -0
- package/dist/esm/createNativeToast.native.js +20 -0
- package/dist/esm/createNativeToast.native.js.map +1 -0
- package/dist/esm/index.js +7 -0
- package/dist/esm/index.js.map +6 -0
- package/dist/esm/index.mjs +4 -0
- package/dist/esm/index.mjs.map +1 -0
- package/dist/esm/index.native.js +4 -0
- package/dist/esm/index.native.js.map +1 -0
- package/dist/esm/types.js +1 -0
- package/dist/esm/types.js.map +6 -0
- package/dist/esm/types.mjs +2 -0
- package/dist/esm/types.mjs.map +1 -0
- package/dist/esm/types.native.js +2 -0
- package/dist/esm/types.native.js.map +1 -0
- package/dist/esm/useDragGesture.js +76 -0
- package/dist/esm/useDragGesture.js.map +6 -0
- package/dist/esm/useDragGesture.mjs +95 -0
- package/dist/esm/useDragGesture.mjs.map +1 -0
- package/dist/esm/useDragGesture.native.js +109 -0
- package/dist/esm/useDragGesture.native.js.map +1 -0
- package/dist/jsx/Toast.js +107 -0
- package/dist/jsx/Toast.js.map +6 -0
- package/dist/jsx/Toast.mjs +131 -0
- package/dist/jsx/Toast.mjs.map +1 -0
- package/dist/jsx/Toast.native.js +174 -0
- package/dist/jsx/Toast.native.js.map +1 -0
- package/dist/jsx/ToastAnnounce.js +55 -0
- package/dist/jsx/ToastAnnounce.js.map +6 -0
- package/dist/jsx/ToastAnnounce.mjs +62 -0
- package/dist/jsx/ToastAnnounce.mjs.map +1 -0
- package/dist/jsx/ToastAnnounce.native.js +105 -0
- package/dist/jsx/ToastAnnounce.native.js.map +1 -0
- package/dist/jsx/ToastImperative.js +50 -0
- package/dist/jsx/ToastImperative.js.map +6 -0
- package/dist/jsx/ToastImperative.mjs +63 -0
- package/dist/jsx/ToastImperative.mjs.map +1 -0
- package/dist/jsx/ToastImperative.native.js +122 -0
- package/dist/jsx/ToastImperative.native.js.map +1 -0
- package/dist/jsx/ToastImpl.js +225 -0
- package/dist/jsx/ToastImpl.js.map +6 -0
- package/dist/jsx/ToastImpl.mjs +256 -0
- package/dist/jsx/ToastImpl.mjs.map +1 -0
- package/dist/jsx/ToastImpl.native.js +327 -0
- package/dist/jsx/ToastImpl.native.js.map +1 -0
- package/dist/jsx/ToastItem.js +339 -0
- package/dist/jsx/ToastItem.js.map +6 -0
- package/dist/jsx/ToastItem.mjs +432 -0
- package/dist/jsx/ToastItem.mjs.map +1 -0
- package/dist/jsx/ToastItem.native.js +547 -0
- package/dist/jsx/ToastItem.native.js.map +1 -0
- package/dist/jsx/ToastPortal.js +13 -0
- package/dist/jsx/ToastPortal.js.map +6 -0
- package/dist/jsx/ToastPortal.mjs +21 -0
- package/dist/jsx/ToastPortal.mjs.map +1 -0
- package/dist/jsx/ToastPortal.native.js +47 -0
- package/dist/jsx/ToastPortal.native.js.map +1 -0
- package/dist/jsx/ToastProvider.js +87 -0
- package/dist/jsx/ToastProvider.js.map +6 -0
- package/dist/jsx/ToastProvider.mjs +108 -0
- package/dist/jsx/ToastProvider.mjs.map +1 -0
- package/dist/jsx/ToastProvider.native.js +159 -0
- package/dist/jsx/ToastProvider.native.js.map +1 -0
- package/dist/jsx/ToastState.js +144 -0
- package/dist/jsx/ToastState.js.map +6 -0
- package/dist/jsx/ToastState.mjs +224 -0
- package/dist/jsx/ToastState.mjs.map +1 -0
- package/dist/jsx/ToastState.native.js +257 -0
- package/dist/jsx/ToastState.native.js.map +1 -0
- package/dist/jsx/ToastViewport.js +250 -0
- package/dist/jsx/ToastViewport.js.map +6 -0
- package/dist/jsx/ToastViewport.mjs +241 -0
- package/dist/jsx/ToastViewport.mjs.map +1 -0
- package/dist/jsx/ToastViewport.native.js +316 -0
- package/dist/jsx/ToastViewport.native.js.map +1 -0
- package/dist/jsx/Toaster.js +160 -0
- package/dist/jsx/Toaster.js.map +6 -0
- package/dist/jsx/Toaster.mjs +185 -0
- package/dist/jsx/Toaster.mjs.map +1 -0
- package/dist/jsx/Toaster.native.js +279 -0
- package/dist/jsx/Toaster.native.js.map +1 -0
- package/dist/jsx/constants.js +6 -0
- package/dist/jsx/constants.js.map +6 -0
- package/dist/jsx/constants.mjs +4 -0
- package/dist/jsx/constants.mjs.map +1 -0
- package/dist/jsx/constants.native.js +31 -0
- package/dist/jsx/constants.native.js.map +1 -0
- package/dist/jsx/createNativeToast.js +28 -0
- package/dist/jsx/createNativeToast.js.map +6 -0
- package/dist/jsx/createNativeToast.mjs +27 -0
- package/dist/jsx/createNativeToast.mjs.map +1 -0
- package/dist/jsx/createNativeToast.native.js +47 -0
- package/dist/jsx/createNativeToast.native.js.map +1 -0
- package/dist/jsx/index.js +7 -0
- package/dist/jsx/index.js.map +6 -0
- package/dist/jsx/index.mjs +4 -0
- package/dist/jsx/index.mjs.map +1 -0
- package/dist/jsx/index.native.js +31 -0
- package/dist/jsx/index.native.js.map +1 -0
- package/dist/jsx/types.js +1 -0
- package/dist/jsx/types.js.map +6 -0
- package/dist/jsx/types.mjs +2 -0
- package/dist/jsx/types.mjs.map +1 -0
- package/dist/jsx/types.native.js +19 -0
- package/dist/jsx/types.native.js.map +1 -0
- package/dist/jsx/useDragGesture.js +76 -0
- package/dist/jsx/useDragGesture.js.map +6 -0
- package/dist/jsx/useDragGesture.mjs +95 -0
- package/dist/jsx/useDragGesture.mjs.map +1 -0
- package/dist/jsx/useDragGesture.native.js +146 -0
- package/dist/jsx/useDragGesture.native.js.map +1 -0
- package/package.json +77 -0
- package/src/Toast.tsx +219 -0
- package/src/ToastAnnounce.tsx +102 -0
- package/src/ToastImperative.tsx +190 -0
- package/src/ToastImpl.tsx +503 -0
- package/src/ToastItem.tsx +694 -0
- package/src/ToastPortal.tsx +19 -0
- package/src/ToastProvider.tsx +197 -0
- package/src/ToastState.ts +397 -0
- package/src/ToastViewport.tsx +430 -0
- package/src/Toaster.tsx +445 -0
- package/src/constants.ts +2 -0
- package/src/createNativeToast.native.tsx +22 -0
- package/src/createNativeToast.tsx +48 -0
- package/src/index.ts +17 -0
- package/src/types.ts +71 -0
- package/src/useDragGesture.native.ts +199 -0
- package/src/useDragGesture.ts +218 -0
- package/types/Toast.d.ts +84 -0
- package/types/Toast.d.ts.map +1 -0
- package/types/ToastAnnounce.d.ts +18 -0
- package/types/ToastAnnounce.d.ts.map +1 -0
- package/types/ToastImperative.d.ts +95 -0
- package/types/ToastImperative.d.ts.map +1 -0
- package/types/ToastImpl.d.ts +109 -0
- package/types/ToastImpl.d.ts.map +1 -0
- package/types/ToastItem.d.ts +34 -0
- package/types/ToastItem.d.ts.map +1 -0
- package/types/ToastPortal.d.ts +8 -0
- package/types/ToastPortal.d.ts.map +1 -0
- package/types/ToastProvider.d.ts +92 -0
- package/types/ToastProvider.d.ts.map +1 -0
- package/types/ToastState.d.ts +177 -0
- package/types/ToastState.d.ts.map +1 -0
- package/types/ToastViewport.d.ts +75 -0
- package/types/ToastViewport.d.ts.map +1 -0
- package/types/Toaster.d.ts +120 -0
- package/types/Toaster.d.ts.map +1 -0
- package/types/constants.d.ts +3 -0
- package/types/constants.d.ts.map +1 -0
- package/types/createNativeToast.d.ts +4 -0
- package/types/createNativeToast.d.ts.map +1 -0
- package/types/createNativeToast.native.d.ts +4 -0
- package/types/createNativeToast.native.d.ts.map +1 -0
- package/types/index.d.ts +7 -0
- package/types/index.d.ts.map +1 -0
- package/types/types.d.ts +61 -0
- package/types/types.d.ts.map +1 -0
- package/types/useDragGesture.d.ts +32 -0
- package/types/useDragGesture.d.ts.map +1 -0
- package/types/useDragGesture.native.d.ts +26 -0
- package/types/useDragGesture.native.d.ts.map +1 -0
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf,
|
|
6
|
+
__hasOwnProp = Object.prototype.hasOwnProperty;
|
|
7
|
+
var __export = (target, all) => {
|
|
8
|
+
for (var name in all) __defProp(target, name, {
|
|
9
|
+
get: all[name],
|
|
10
|
+
enumerable: !0
|
|
11
|
+
});
|
|
12
|
+
},
|
|
13
|
+
__copyProps = (to, from, except, desc) => {
|
|
14
|
+
if (from && typeof from == "object" || typeof from == "function") for (let key of __getOwnPropNames(from)) !__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, {
|
|
15
|
+
get: () => from[key],
|
|
16
|
+
enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable
|
|
17
|
+
});
|
|
18
|
+
return to;
|
|
19
|
+
};
|
|
20
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
21
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
22
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
23
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
24
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
25
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", {
|
|
26
|
+
value: mod,
|
|
27
|
+
enumerable: !0
|
|
28
|
+
}) : target, mod)),
|
|
29
|
+
__toCommonJS = mod => __copyProps(__defProp({}, "__esModule", {
|
|
30
|
+
value: !0
|
|
31
|
+
}), mod);
|
|
32
|
+
var ToastViewport_exports = {};
|
|
33
|
+
__export(ToastViewport_exports, {
|
|
34
|
+
ToastViewport: () => ToastViewport,
|
|
35
|
+
VIEWPORT_DEFAULT_HOTKEY: () => VIEWPORT_DEFAULT_HOTKEY,
|
|
36
|
+
VIEWPORT_PAUSE: () => VIEWPORT_PAUSE,
|
|
37
|
+
VIEWPORT_RESUME: () => VIEWPORT_RESUME
|
|
38
|
+
});
|
|
39
|
+
module.exports = __toCommonJS(ToastViewport_exports);
|
|
40
|
+
var import_animate_presence = require("@tamagui/animate-presence"),
|
|
41
|
+
import_compose_refs = require("@tamagui/compose-refs"),
|
|
42
|
+
import_constants = require("@tamagui/constants"),
|
|
43
|
+
import_core = require("@tamagui/core"),
|
|
44
|
+
import_portal = require("@tamagui/portal"),
|
|
45
|
+
import_stacks = require("@tamagui/stacks"),
|
|
46
|
+
import_visually_hidden = require("@tamagui/visually-hidden"),
|
|
47
|
+
React = __toESM(require("react"), 1),
|
|
48
|
+
import_constants2 = require("./constants.cjs"),
|
|
49
|
+
import_ToastPortal = require("./ToastPortal.cjs"),
|
|
50
|
+
import_ToastProvider = require("./ToastProvider.cjs"),
|
|
51
|
+
import_jsx_runtime = require("react/jsx-runtime");
|
|
52
|
+
const VIEWPORT_NAME = "ToastViewport",
|
|
53
|
+
VIEWPORT_DEFAULT_HOTKEY = ["F8"],
|
|
54
|
+
VIEWPORT_PAUSE = "toast.viewportPause",
|
|
55
|
+
VIEWPORT_RESUME = "toast.viewportResume",
|
|
56
|
+
ToastViewportWrapperFrame = (0, import_core.styled)(import_stacks.YStack, {
|
|
57
|
+
name: "ViewportWrapper",
|
|
58
|
+
variants: {
|
|
59
|
+
unstyled: {
|
|
60
|
+
false: {
|
|
61
|
+
pointerEvents: "box-none",
|
|
62
|
+
top: 0,
|
|
63
|
+
bottom: 0,
|
|
64
|
+
left: 0,
|
|
65
|
+
right: 0,
|
|
66
|
+
position: import_constants.isWeb ? "fixed" : "absolute",
|
|
67
|
+
maxWidth: "100%",
|
|
68
|
+
tabIndex: 0,
|
|
69
|
+
zIndex: 1e5
|
|
70
|
+
}
|
|
71
|
+
}
|
|
72
|
+
},
|
|
73
|
+
defaultVariants: {
|
|
74
|
+
unstyled: process.env.TAMAGUI_HEADLESS === "1"
|
|
75
|
+
}
|
|
76
|
+
}),
|
|
77
|
+
ToastViewportFrame = (0, import_core.styled)(import_stacks.YStack, {
|
|
78
|
+
name: VIEWPORT_NAME,
|
|
79
|
+
variants: {
|
|
80
|
+
unstyled: {
|
|
81
|
+
false: {
|
|
82
|
+
pointerEvents: "box-none",
|
|
83
|
+
position: import_constants.isWeb ? "fixed" : "absolute",
|
|
84
|
+
maxWidth: "100%"
|
|
85
|
+
}
|
|
86
|
+
}
|
|
87
|
+
},
|
|
88
|
+
defaultVariants: {
|
|
89
|
+
unstyled: process.env.TAMAGUI_HEADLESS === "1"
|
|
90
|
+
}
|
|
91
|
+
}),
|
|
92
|
+
ToastViewport = React.memo(React.forwardRef((props, forwardedRef) => {
|
|
93
|
+
const {
|
|
94
|
+
scope,
|
|
95
|
+
hotkey = VIEWPORT_DEFAULT_HOTKEY,
|
|
96
|
+
label = "Notifications ({hotkey})",
|
|
97
|
+
name = "default",
|
|
98
|
+
multipleToasts,
|
|
99
|
+
zIndex,
|
|
100
|
+
portalToRoot,
|
|
101
|
+
...viewportProps
|
|
102
|
+
} = props,
|
|
103
|
+
context = (0, import_ToastProvider.useToastProviderContext)(scope),
|
|
104
|
+
getItems = (0, import_ToastProvider.useCollection)(scope || import_constants2.TOAST_CONTEXT),
|
|
105
|
+
headFocusProxyRef = React.useRef(null),
|
|
106
|
+
tailFocusProxyRef = React.useRef(null),
|
|
107
|
+
wrapperRef = React.useRef(null),
|
|
108
|
+
ref = React.useRef(null),
|
|
109
|
+
onViewportChange = React.useCallback(el => {
|
|
110
|
+
context.viewports[name] !== el && context.onViewportChange(name, el);
|
|
111
|
+
}, [name, context.viewports]),
|
|
112
|
+
composedRefs = (0, import_compose_refs.useComposedRefs)(forwardedRef, ref, onViewportChange),
|
|
113
|
+
hotkeyLabel = hotkey.join("+").replace(/Key/g, "").replace(/Digit/g, ""),
|
|
114
|
+
hasToasts = context.toastCount > 0;
|
|
115
|
+
React.useEffect(() => {
|
|
116
|
+
if (!import_constants.isWeb || context.toastCount === 0) return;
|
|
117
|
+
const handleKeyDown = event => {
|
|
118
|
+
hotkey.every(key => event[key] || event.code === key) && ref.current?.focus();
|
|
119
|
+
};
|
|
120
|
+
return document.addEventListener("keydown", handleKeyDown), () => {
|
|
121
|
+
document.removeEventListener("keydown", handleKeyDown);
|
|
122
|
+
};
|
|
123
|
+
}, [hotkey, context.toastCount]), React.useEffect(() => {
|
|
124
|
+
if (!import_constants.isWeb || context.toastCount === 0) return;
|
|
125
|
+
const wrapper = wrapperRef.current,
|
|
126
|
+
viewport = ref.current;
|
|
127
|
+
if (hasToasts && wrapper && viewport) {
|
|
128
|
+
const handlePause = () => {
|
|
129
|
+
if (!context.isClosePausedRef.current) {
|
|
130
|
+
const pauseEvent = new CustomEvent(VIEWPORT_PAUSE);
|
|
131
|
+
viewport.dispatchEvent(pauseEvent), context.isClosePausedRef.current = !0;
|
|
132
|
+
}
|
|
133
|
+
},
|
|
134
|
+
handleResume = () => {
|
|
135
|
+
if (context.isClosePausedRef.current) {
|
|
136
|
+
const resumeEvent = new CustomEvent(VIEWPORT_RESUME);
|
|
137
|
+
viewport.dispatchEvent(resumeEvent), context.isClosePausedRef.current = !1;
|
|
138
|
+
}
|
|
139
|
+
},
|
|
140
|
+
handleFocusOutResume = event => {
|
|
141
|
+
!wrapper.contains(event.relatedTarget) && handleResume();
|
|
142
|
+
},
|
|
143
|
+
handlePointerLeaveResume = () => {
|
|
144
|
+
wrapper.contains(document.activeElement) || handleResume();
|
|
145
|
+
};
|
|
146
|
+
return wrapper.addEventListener("focusin", handlePause), wrapper.addEventListener("focusout", handleFocusOutResume), wrapper.addEventListener("pointermove", handlePause), wrapper.addEventListener("pointerleave", handlePointerLeaveResume), window.addEventListener("blur", handlePause), window.addEventListener("focus", handleResume), () => {
|
|
147
|
+
wrapper.removeEventListener("focusin", handlePause), wrapper.removeEventListener("focusout", handleFocusOutResume), wrapper.removeEventListener("pointermove", handlePause), wrapper.removeEventListener("pointerleave", handlePointerLeaveResume), window.removeEventListener("blur", handlePause), window.removeEventListener("focus", handleResume);
|
|
148
|
+
};
|
|
149
|
+
}
|
|
150
|
+
}, [hasToasts, context.isClosePausedRef, context.toastCount]);
|
|
151
|
+
const getSortedTabbableCandidates = React.useCallback(({
|
|
152
|
+
tabbingDirection
|
|
153
|
+
}) => {
|
|
154
|
+
const tabbableCandidates = getItems().map(toastItem => {
|
|
155
|
+
const toastNode = toastItem.ref.current,
|
|
156
|
+
toastTabbableCandidates = [toastNode, ...getTabbableCandidates(toastNode)];
|
|
157
|
+
return tabbingDirection === "forwards" ? toastTabbableCandidates : toastTabbableCandidates.reverse();
|
|
158
|
+
});
|
|
159
|
+
return (tabbingDirection === "forwards" ? tabbableCandidates.reverse() : tabbableCandidates).flat();
|
|
160
|
+
}, [getItems]);
|
|
161
|
+
React.useEffect(() => {
|
|
162
|
+
if (!import_constants.isWeb || context.toastCount === 0) return;
|
|
163
|
+
const viewport = ref.current;
|
|
164
|
+
if (viewport) {
|
|
165
|
+
const handleKeyDown = event => {
|
|
166
|
+
const isMetaKey = event.altKey || event.ctrlKey || event.metaKey;
|
|
167
|
+
if (event.key === "Tab" && !isMetaKey) {
|
|
168
|
+
const focusedElement = document.activeElement,
|
|
169
|
+
isTabbingBackwards = event.shiftKey;
|
|
170
|
+
if (event.target === viewport && isTabbingBackwards) {
|
|
171
|
+
headFocusProxyRef.current?.focus();
|
|
172
|
+
return;
|
|
173
|
+
}
|
|
174
|
+
const sortedCandidates = getSortedTabbableCandidates({
|
|
175
|
+
tabbingDirection: isTabbingBackwards ? "backwards" : "forwards"
|
|
176
|
+
}),
|
|
177
|
+
index = sortedCandidates.findIndex(candidate => candidate === focusedElement);
|
|
178
|
+
focusFirst(sortedCandidates.slice(index + 1)) ? event.preventDefault() : isTabbingBackwards ?
|
|
179
|
+
// @ts-ignore ali TODO type
|
|
180
|
+
headFocusProxyRef.current?.focus() :
|
|
181
|
+
// @ts-ignore ali TODO type
|
|
182
|
+
tailFocusProxyRef.current?.focus();
|
|
183
|
+
}
|
|
184
|
+
};
|
|
185
|
+
return viewport.addEventListener("keydown", handleKeyDown), () => viewport.removeEventListener("keydown", handleKeyDown);
|
|
186
|
+
}
|
|
187
|
+
}, [getItems, getSortedTabbableCandidates, context.toastCount]);
|
|
188
|
+
const contents = /* @__PURE__ */(0, import_jsx_runtime.jsxs)(ToastViewportWrapperFrame, {
|
|
189
|
+
ref: wrapperRef,
|
|
190
|
+
role: "region",
|
|
191
|
+
"aria-label": label.replace("{hotkey}", hotkeyLabel),
|
|
192
|
+
tabIndex: -1,
|
|
193
|
+
children: [hasToasts && /* @__PURE__ */(0, import_jsx_runtime.jsx)(FocusProxy, {
|
|
194
|
+
context,
|
|
195
|
+
viewportName: name,
|
|
196
|
+
ref: headFocusProxyRef,
|
|
197
|
+
onFocusFromOutsideViewport: () => {
|
|
198
|
+
const tabbableCandidates = getSortedTabbableCandidates({
|
|
199
|
+
tabbingDirection: "forwards"
|
|
200
|
+
});
|
|
201
|
+
focusFirst(tabbableCandidates);
|
|
202
|
+
}
|
|
203
|
+
}), /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_ToastProvider.Collection.Slot, {
|
|
204
|
+
scope: context.toastScope,
|
|
205
|
+
children: /* @__PURE__ */(0, import_jsx_runtime.jsx)(ToastViewportFrame, {
|
|
206
|
+
focusable: context.toastCount > 0,
|
|
207
|
+
ref: composedRefs,
|
|
208
|
+
...viewportProps,
|
|
209
|
+
children: /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_portal.PortalHost, {
|
|
210
|
+
render: children => /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_animate_presence.AnimatePresence, {
|
|
211
|
+
exitBeforeEnter: !multipleToasts,
|
|
212
|
+
children
|
|
213
|
+
}),
|
|
214
|
+
name: name ?? "default"
|
|
215
|
+
})
|
|
216
|
+
})
|
|
217
|
+
}), hasToasts && /* @__PURE__ */(0, import_jsx_runtime.jsx)(FocusProxy, {
|
|
218
|
+
context,
|
|
219
|
+
viewportName: name,
|
|
220
|
+
ref: tailFocusProxyRef,
|
|
221
|
+
onFocusFromOutsideViewport: () => {
|
|
222
|
+
const tabbableCandidates = getSortedTabbableCandidates({
|
|
223
|
+
tabbingDirection: "backwards"
|
|
224
|
+
});
|
|
225
|
+
focusFirst(tabbableCandidates);
|
|
226
|
+
}
|
|
227
|
+
})]
|
|
228
|
+
});
|
|
229
|
+
return portalToRoot ? /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_ToastPortal.ToastPortal, {
|
|
230
|
+
context,
|
|
231
|
+
...(typeof zIndex == "number" ? {
|
|
232
|
+
zIndex
|
|
233
|
+
} : {}),
|
|
234
|
+
children: contents
|
|
235
|
+
}) : contents;
|
|
236
|
+
}));
|
|
237
|
+
ToastViewport.displayName = VIEWPORT_NAME;
|
|
238
|
+
const FOCUS_PROXY_NAME = "ToastFocusProxy",
|
|
239
|
+
FocusProxy = React.forwardRef((props, forwardedRef) => {
|
|
240
|
+
const {
|
|
241
|
+
onFocusFromOutsideViewport,
|
|
242
|
+
viewportName,
|
|
243
|
+
context,
|
|
244
|
+
...proxyProps
|
|
245
|
+
} = props,
|
|
246
|
+
viewport = context.viewports[viewportName];
|
|
247
|
+
return /* @__PURE__ */(0, import_jsx_runtime.jsx)(import_visually_hidden.VisuallyHidden, {
|
|
248
|
+
"aria-hidden": !0,
|
|
249
|
+
tabIndex: 0,
|
|
250
|
+
...proxyProps,
|
|
251
|
+
ref: forwardedRef,
|
|
252
|
+
position: import_constants.isWeb ? "fixed" : "absolute",
|
|
253
|
+
onFocus: event => {
|
|
254
|
+
if (!import_constants.isWeb) return;
|
|
255
|
+
const prevFocusedElement = event.relatedTarget;
|
|
256
|
+
!viewport?.contains(prevFocusedElement) && onFocusFromOutsideViewport();
|
|
257
|
+
}
|
|
258
|
+
});
|
|
259
|
+
});
|
|
260
|
+
FocusProxy.displayName = FOCUS_PROXY_NAME;
|
|
261
|
+
function focusFirst(candidates) {
|
|
262
|
+
if (!import_constants.isWeb) return;
|
|
263
|
+
const previouslyFocusedElement = document.activeElement;
|
|
264
|
+
return candidates.some(candidate => candidate === previouslyFocusedElement ? !0 : (candidate.focus(), document.activeElement !== previouslyFocusedElement));
|
|
265
|
+
}
|
|
266
|
+
function getTabbableCandidates(container) {
|
|
267
|
+
if (!import_constants.isWeb) return [];
|
|
268
|
+
const containerHtml = container,
|
|
269
|
+
nodes = [],
|
|
270
|
+
walker = document.createTreeWalker(containerHtml, NodeFilter.SHOW_ELEMENT, {
|
|
271
|
+
acceptNode: node => {
|
|
272
|
+
const isHiddenInput = node.tagName === "INPUT" && node.type === "hidden";
|
|
273
|
+
return node.disabled || node.hidden || isHiddenInput ? NodeFilter.FILTER_SKIP : node.tabIndex >= 0 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;
|
|
274
|
+
}
|
|
275
|
+
});
|
|
276
|
+
for (; walker.nextNode();) nodes.push(walker.currentNode);
|
|
277
|
+
return nodes;
|
|
278
|
+
}
|
|
@@ -0,0 +1,263 @@
|
|
|
1
|
+
var __create = Object.create;
|
|
2
|
+
var __defProp = Object.defineProperty;
|
|
3
|
+
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
4
|
+
var __getOwnPropNames = Object.getOwnPropertyNames;
|
|
5
|
+
var __getProtoOf = Object.getPrototypeOf, __hasOwnProp = Object.prototype.hasOwnProperty;
|
|
6
|
+
var __export = (target, all) => {
|
|
7
|
+
for (var name in all)
|
|
8
|
+
__defProp(target, name, { get: all[name], enumerable: !0 });
|
|
9
|
+
}, __copyProps = (to, from, except, desc) => {
|
|
10
|
+
if (from && typeof from == "object" || typeof from == "function")
|
|
11
|
+
for (let key of __getOwnPropNames(from))
|
|
12
|
+
!__hasOwnProp.call(to, key) && key !== except && __defProp(to, key, { get: () => from[key], enumerable: !(desc = __getOwnPropDesc(from, key)) || desc.enumerable });
|
|
13
|
+
return to;
|
|
14
|
+
};
|
|
15
|
+
var __toESM = (mod, isNodeMode, target) => (target = mod != null ? __create(__getProtoOf(mod)) : {}, __copyProps(
|
|
16
|
+
// If the importer is in node compatibility mode or this is not an ESM
|
|
17
|
+
// file that has been converted to a CommonJS file using a Babel-
|
|
18
|
+
// compatible transform (i.e. "__esModule" has not been set), then set
|
|
19
|
+
// "default" to the CommonJS "module.exports" for node compatibility.
|
|
20
|
+
isNodeMode || !mod || !mod.__esModule ? __defProp(target, "default", { value: mod, enumerable: !0 }) : target,
|
|
21
|
+
mod
|
|
22
|
+
)), __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: !0 }), mod);
|
|
23
|
+
var ToastViewport_exports = {};
|
|
24
|
+
__export(ToastViewport_exports, {
|
|
25
|
+
ToastViewport: () => ToastViewport,
|
|
26
|
+
VIEWPORT_DEFAULT_HOTKEY: () => VIEWPORT_DEFAULT_HOTKEY,
|
|
27
|
+
VIEWPORT_PAUSE: () => VIEWPORT_PAUSE,
|
|
28
|
+
VIEWPORT_RESUME: () => VIEWPORT_RESUME
|
|
29
|
+
});
|
|
30
|
+
module.exports = __toCommonJS(ToastViewport_exports);
|
|
31
|
+
var import_animate_presence = require("@tamagui/animate-presence"), import_compose_refs = require("@tamagui/compose-refs"), import_constants = require("@tamagui/constants"), import_core = require("@tamagui/core"), import_portal = require("@tamagui/portal"), import_stacks = require("@tamagui/stacks"), import_visually_hidden = require("@tamagui/visually-hidden"), React = __toESM(require("react"), 1), import_constants2 = require("./constants"), import_ToastPortal = require("./ToastPortal"), import_ToastProvider = require("./ToastProvider"), import_jsx_runtime = require("react/jsx-runtime");
|
|
32
|
+
const VIEWPORT_NAME = "ToastViewport", VIEWPORT_DEFAULT_HOTKEY = ["F8"], VIEWPORT_PAUSE = "toast.viewportPause", VIEWPORT_RESUME = "toast.viewportResume", ToastViewportWrapperFrame = (0, import_core.styled)(import_stacks.YStack, {
|
|
33
|
+
name: "ViewportWrapper",
|
|
34
|
+
variants: {
|
|
35
|
+
unstyled: {
|
|
36
|
+
false: {
|
|
37
|
+
pointerEvents: "box-none",
|
|
38
|
+
top: 0,
|
|
39
|
+
bottom: 0,
|
|
40
|
+
left: 0,
|
|
41
|
+
right: 0,
|
|
42
|
+
position: import_constants.isWeb ? "fixed" : "absolute",
|
|
43
|
+
maxWidth: "100%",
|
|
44
|
+
tabIndex: 0,
|
|
45
|
+
zIndex: 1e5
|
|
46
|
+
}
|
|
47
|
+
}
|
|
48
|
+
},
|
|
49
|
+
defaultVariants: {
|
|
50
|
+
unstyled: process.env.TAMAGUI_HEADLESS === "1"
|
|
51
|
+
}
|
|
52
|
+
}), ToastViewportFrame = (0, import_core.styled)(import_stacks.YStack, {
|
|
53
|
+
name: VIEWPORT_NAME,
|
|
54
|
+
variants: {
|
|
55
|
+
unstyled: {
|
|
56
|
+
false: {
|
|
57
|
+
pointerEvents: "box-none",
|
|
58
|
+
position: import_constants.isWeb ? "fixed" : "absolute",
|
|
59
|
+
maxWidth: "100%"
|
|
60
|
+
}
|
|
61
|
+
}
|
|
62
|
+
},
|
|
63
|
+
defaultVariants: {
|
|
64
|
+
unstyled: process.env.TAMAGUI_HEADLESS === "1"
|
|
65
|
+
}
|
|
66
|
+
}), ToastViewport = React.memo(
|
|
67
|
+
React.forwardRef(
|
|
68
|
+
(props, forwardedRef) => {
|
|
69
|
+
const {
|
|
70
|
+
scope,
|
|
71
|
+
hotkey = VIEWPORT_DEFAULT_HOTKEY,
|
|
72
|
+
label = "Notifications ({hotkey})",
|
|
73
|
+
name = "default",
|
|
74
|
+
multipleToasts,
|
|
75
|
+
zIndex,
|
|
76
|
+
portalToRoot,
|
|
77
|
+
...viewportProps
|
|
78
|
+
} = props, context = (0, import_ToastProvider.useToastProviderContext)(scope), getItems = (0, import_ToastProvider.useCollection)(scope || import_constants2.TOAST_CONTEXT), headFocusProxyRef = React.useRef(null), tailFocusProxyRef = React.useRef(null), wrapperRef = React.useRef(null), ref = React.useRef(null), onViewportChange = React.useCallback(
|
|
79
|
+
(el) => {
|
|
80
|
+
context.viewports[name] !== el && context.onViewportChange(name, el);
|
|
81
|
+
},
|
|
82
|
+
[name, context.viewports]
|
|
83
|
+
), composedRefs = (0, import_compose_refs.useComposedRefs)(forwardedRef, ref, onViewportChange), hotkeyLabel = hotkey.join("+").replace(/Key/g, "").replace(/Digit/g, ""), hasToasts = context.toastCount > 0;
|
|
84
|
+
React.useEffect(() => {
|
|
85
|
+
if (!import_constants.isWeb || context.toastCount === 0) return;
|
|
86
|
+
const handleKeyDown = (event) => {
|
|
87
|
+
hotkey.every(
|
|
88
|
+
(key) => event[key] || event.code === key
|
|
89
|
+
) && ref.current?.focus();
|
|
90
|
+
};
|
|
91
|
+
return document.addEventListener("keydown", handleKeyDown), () => {
|
|
92
|
+
document.removeEventListener("keydown", handleKeyDown);
|
|
93
|
+
};
|
|
94
|
+
}, [hotkey, context.toastCount]), React.useEffect(() => {
|
|
95
|
+
if (!import_constants.isWeb || context.toastCount === 0) return;
|
|
96
|
+
const wrapper = wrapperRef.current, viewport = ref.current;
|
|
97
|
+
if (hasToasts && wrapper && viewport) {
|
|
98
|
+
const handlePause = () => {
|
|
99
|
+
if (!context.isClosePausedRef.current) {
|
|
100
|
+
const pauseEvent = new CustomEvent(VIEWPORT_PAUSE);
|
|
101
|
+
viewport.dispatchEvent(pauseEvent), context.isClosePausedRef.current = !0;
|
|
102
|
+
}
|
|
103
|
+
}, handleResume = () => {
|
|
104
|
+
if (context.isClosePausedRef.current) {
|
|
105
|
+
const resumeEvent = new CustomEvent(VIEWPORT_RESUME);
|
|
106
|
+
viewport.dispatchEvent(resumeEvent), context.isClosePausedRef.current = !1;
|
|
107
|
+
}
|
|
108
|
+
}, handleFocusOutResume = (event) => {
|
|
109
|
+
!wrapper.contains(
|
|
110
|
+
event.relatedTarget
|
|
111
|
+
) && handleResume();
|
|
112
|
+
}, handlePointerLeaveResume = () => {
|
|
113
|
+
wrapper.contains(document.activeElement) || handleResume();
|
|
114
|
+
};
|
|
115
|
+
return wrapper.addEventListener("focusin", handlePause), wrapper.addEventListener("focusout", handleFocusOutResume), wrapper.addEventListener("pointermove", handlePause), wrapper.addEventListener("pointerleave", handlePointerLeaveResume), window.addEventListener("blur", handlePause), window.addEventListener("focus", handleResume), () => {
|
|
116
|
+
wrapper.removeEventListener("focusin", handlePause), wrapper.removeEventListener("focusout", handleFocusOutResume), wrapper.removeEventListener("pointermove", handlePause), wrapper.removeEventListener("pointerleave", handlePointerLeaveResume), window.removeEventListener("blur", handlePause), window.removeEventListener("focus", handleResume);
|
|
117
|
+
};
|
|
118
|
+
}
|
|
119
|
+
}, [hasToasts, context.isClosePausedRef, context.toastCount]);
|
|
120
|
+
const getSortedTabbableCandidates = React.useCallback(
|
|
121
|
+
({ tabbingDirection }) => {
|
|
122
|
+
const tabbableCandidates = getItems().map((toastItem) => {
|
|
123
|
+
const toastNode = toastItem.ref.current, toastTabbableCandidates = [
|
|
124
|
+
toastNode,
|
|
125
|
+
...getTabbableCandidates(toastNode)
|
|
126
|
+
];
|
|
127
|
+
return tabbingDirection === "forwards" ? toastTabbableCandidates : toastTabbableCandidates.reverse();
|
|
128
|
+
});
|
|
129
|
+
return (tabbingDirection === "forwards" ? tabbableCandidates.reverse() : tabbableCandidates).flat();
|
|
130
|
+
},
|
|
131
|
+
[getItems]
|
|
132
|
+
);
|
|
133
|
+
React.useEffect(() => {
|
|
134
|
+
if (!import_constants.isWeb || context.toastCount === 0) return;
|
|
135
|
+
const viewport = ref.current;
|
|
136
|
+
if (viewport) {
|
|
137
|
+
const handleKeyDown = (event) => {
|
|
138
|
+
const isMetaKey = event.altKey || event.ctrlKey || event.metaKey;
|
|
139
|
+
if (event.key === "Tab" && !isMetaKey) {
|
|
140
|
+
const focusedElement = document.activeElement, isTabbingBackwards = event.shiftKey;
|
|
141
|
+
if (event.target === viewport && isTabbingBackwards) {
|
|
142
|
+
headFocusProxyRef.current?.focus();
|
|
143
|
+
return;
|
|
144
|
+
}
|
|
145
|
+
const sortedCandidates = getSortedTabbableCandidates({ tabbingDirection: isTabbingBackwards ? "backwards" : "forwards" }), index = sortedCandidates.findIndex(
|
|
146
|
+
(candidate) => candidate === focusedElement
|
|
147
|
+
);
|
|
148
|
+
focusFirst(sortedCandidates.slice(index + 1)) ? event.preventDefault() : isTabbingBackwards ? (
|
|
149
|
+
// @ts-ignore ali TODO type
|
|
150
|
+
headFocusProxyRef.current?.focus()
|
|
151
|
+
) : (
|
|
152
|
+
// @ts-ignore ali TODO type
|
|
153
|
+
tailFocusProxyRef.current?.focus()
|
|
154
|
+
);
|
|
155
|
+
}
|
|
156
|
+
};
|
|
157
|
+
return viewport.addEventListener("keydown", handleKeyDown), () => viewport.removeEventListener("keydown", handleKeyDown);
|
|
158
|
+
}
|
|
159
|
+
}, [getItems, getSortedTabbableCandidates, context.toastCount]);
|
|
160
|
+
const contents = /* @__PURE__ */ (0, import_jsx_runtime.jsxs)(
|
|
161
|
+
ToastViewportWrapperFrame,
|
|
162
|
+
{
|
|
163
|
+
ref: wrapperRef,
|
|
164
|
+
role: "region",
|
|
165
|
+
"aria-label": label.replace("{hotkey}", hotkeyLabel),
|
|
166
|
+
tabIndex: -1,
|
|
167
|
+
children: [
|
|
168
|
+
hasToasts && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
169
|
+
FocusProxy,
|
|
170
|
+
{
|
|
171
|
+
context,
|
|
172
|
+
viewportName: name,
|
|
173
|
+
ref: headFocusProxyRef,
|
|
174
|
+
onFocusFromOutsideViewport: () => {
|
|
175
|
+
const tabbableCandidates = getSortedTabbableCandidates({
|
|
176
|
+
tabbingDirection: "forwards"
|
|
177
|
+
});
|
|
178
|
+
focusFirst(tabbableCandidates);
|
|
179
|
+
}
|
|
180
|
+
}
|
|
181
|
+
),
|
|
182
|
+
/* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_ToastProvider.Collection.Slot, { scope: context.toastScope, children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
183
|
+
ToastViewportFrame,
|
|
184
|
+
{
|
|
185
|
+
focusable: context.toastCount > 0,
|
|
186
|
+
ref: composedRefs,
|
|
187
|
+
...viewportProps,
|
|
188
|
+
children: /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
189
|
+
import_portal.PortalHost,
|
|
190
|
+
{
|
|
191
|
+
render: (children) => /* @__PURE__ */ (0, import_jsx_runtime.jsx)(import_animate_presence.AnimatePresence, { exitBeforeEnter: !multipleToasts, children }),
|
|
192
|
+
name: name ?? "default"
|
|
193
|
+
}
|
|
194
|
+
)
|
|
195
|
+
}
|
|
196
|
+
) }),
|
|
197
|
+
hasToasts && /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
198
|
+
FocusProxy,
|
|
199
|
+
{
|
|
200
|
+
context,
|
|
201
|
+
viewportName: name,
|
|
202
|
+
ref: tailFocusProxyRef,
|
|
203
|
+
onFocusFromOutsideViewport: () => {
|
|
204
|
+
const tabbableCandidates = getSortedTabbableCandidates({
|
|
205
|
+
tabbingDirection: "backwards"
|
|
206
|
+
});
|
|
207
|
+
focusFirst(tabbableCandidates);
|
|
208
|
+
}
|
|
209
|
+
}
|
|
210
|
+
)
|
|
211
|
+
]
|
|
212
|
+
}
|
|
213
|
+
);
|
|
214
|
+
return portalToRoot ? /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
215
|
+
import_ToastPortal.ToastPortal,
|
|
216
|
+
{
|
|
217
|
+
context,
|
|
218
|
+
...typeof zIndex == "number" ? { zIndex } : {},
|
|
219
|
+
children: contents
|
|
220
|
+
}
|
|
221
|
+
) : contents;
|
|
222
|
+
}
|
|
223
|
+
)
|
|
224
|
+
);
|
|
225
|
+
ToastViewport.displayName = VIEWPORT_NAME;
|
|
226
|
+
const FOCUS_PROXY_NAME = "ToastFocusProxy", FocusProxy = React.forwardRef(
|
|
227
|
+
(props, forwardedRef) => {
|
|
228
|
+
const { onFocusFromOutsideViewport, viewportName, context, ...proxyProps } = props, viewport = context.viewports[viewportName];
|
|
229
|
+
return /* @__PURE__ */ (0, import_jsx_runtime.jsx)(
|
|
230
|
+
import_visually_hidden.VisuallyHidden,
|
|
231
|
+
{
|
|
232
|
+
"aria-hidden": !0,
|
|
233
|
+
tabIndex: 0,
|
|
234
|
+
...proxyProps,
|
|
235
|
+
ref: forwardedRef,
|
|
236
|
+
position: import_constants.isWeb ? "fixed" : "absolute",
|
|
237
|
+
onFocus: (event) => {
|
|
238
|
+
if (!import_constants.isWeb) return;
|
|
239
|
+
const prevFocusedElement = event.relatedTarget;
|
|
240
|
+
!viewport?.contains(prevFocusedElement) && onFocusFromOutsideViewport();
|
|
241
|
+
}
|
|
242
|
+
}
|
|
243
|
+
);
|
|
244
|
+
}
|
|
245
|
+
);
|
|
246
|
+
FocusProxy.displayName = FOCUS_PROXY_NAME;
|
|
247
|
+
function focusFirst(candidates) {
|
|
248
|
+
if (!import_constants.isWeb) return;
|
|
249
|
+
const previouslyFocusedElement = document.activeElement;
|
|
250
|
+
return candidates.some((candidate) => candidate === previouslyFocusedElement ? !0 : (candidate.focus(), document.activeElement !== previouslyFocusedElement));
|
|
251
|
+
}
|
|
252
|
+
function getTabbableCandidates(container) {
|
|
253
|
+
if (!import_constants.isWeb) return [];
|
|
254
|
+
const containerHtml = container, nodes = [], walker = document.createTreeWalker(containerHtml, NodeFilter.SHOW_ELEMENT, {
|
|
255
|
+
acceptNode: (node) => {
|
|
256
|
+
const isHiddenInput = node.tagName === "INPUT" && node.type === "hidden";
|
|
257
|
+
return node.disabled || node.hidden || isHiddenInput ? NodeFilter.FILTER_SKIP : node.tabIndex >= 0 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;
|
|
258
|
+
}
|
|
259
|
+
});
|
|
260
|
+
for (; walker.nextNode(); ) nodes.push(walker.currentNode);
|
|
261
|
+
return nodes;
|
|
262
|
+
}
|
|
263
|
+
//# sourceMappingURL=ToastViewport.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/ToastViewport.tsx"],
|
|
4
|
+
"mappings": "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",
|
|
5
|
+
"names": ["import_constants"]
|
|
6
|
+
}
|