@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,225 @@
|
|
|
1
|
+
import { useIsPresent } from "@tamagui/animate-presence";
|
|
2
|
+
import { useComposedRefs } from "@tamagui/compose-refs";
|
|
3
|
+
import { isWeb } from "@tamagui/constants";
|
|
4
|
+
import {
|
|
5
|
+
View,
|
|
6
|
+
Theme,
|
|
7
|
+
createStyledContext,
|
|
8
|
+
styled,
|
|
9
|
+
useConfiguration,
|
|
10
|
+
useEvent,
|
|
11
|
+
useThemeName
|
|
12
|
+
} from "@tamagui/core";
|
|
13
|
+
import { Dismissable } from "@tamagui/dismissable";
|
|
14
|
+
import { composeEventHandlers } from "@tamagui/helpers";
|
|
15
|
+
import { PortalItem } from "@tamagui/portal";
|
|
16
|
+
import { YStack } from "@tamagui/stacks";
|
|
17
|
+
import * as React from "react";
|
|
18
|
+
import { PanResponder } from "react-native-web";
|
|
19
|
+
import { TOAST_NAME } from "./constants";
|
|
20
|
+
import { ToastAnnounce } from "./ToastAnnounce";
|
|
21
|
+
import { Collection, useToastProviderContext } from "./ToastProvider";
|
|
22
|
+
import { VIEWPORT_PAUSE, VIEWPORT_RESUME } from "./ToastViewport";
|
|
23
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
24
|
+
const ToastImplFrame = styled(YStack, {
|
|
25
|
+
name: "ToastImpl",
|
|
26
|
+
focusable: !0,
|
|
27
|
+
variants: {
|
|
28
|
+
unstyled: {
|
|
29
|
+
false: {
|
|
30
|
+
focusStyle: {
|
|
31
|
+
outlineStyle: "solid",
|
|
32
|
+
outlineWidth: 2,
|
|
33
|
+
outlineColor: "$outlineColor"
|
|
34
|
+
},
|
|
35
|
+
backgroundColor: "$color6",
|
|
36
|
+
borderRadius: "$4",
|
|
37
|
+
paddingHorizontal: "$4",
|
|
38
|
+
paddingVertical: "$3",
|
|
39
|
+
marginHorizontal: "auto",
|
|
40
|
+
marginVertical: "$1",
|
|
41
|
+
elevation: "$3"
|
|
42
|
+
}
|
|
43
|
+
}
|
|
44
|
+
},
|
|
45
|
+
defaultVariants: {
|
|
46
|
+
unstyled: process.env.TAMAGUI_HEADLESS === "1"
|
|
47
|
+
}
|
|
48
|
+
}), {
|
|
49
|
+
Provider: ToastInteractiveProvider,
|
|
50
|
+
useStyledContext: useToastInteractiveContext
|
|
51
|
+
} = createStyledContext({
|
|
52
|
+
onClose() {
|
|
53
|
+
}
|
|
54
|
+
}), ToastImpl = React.forwardRef(
|
|
55
|
+
(props, forwardedRef) => {
|
|
56
|
+
const {
|
|
57
|
+
scope,
|
|
58
|
+
type = "foreground",
|
|
59
|
+
duration: durationProp,
|
|
60
|
+
open,
|
|
61
|
+
onClose,
|
|
62
|
+
onEscapeKeyDown,
|
|
63
|
+
onPause,
|
|
64
|
+
onResume,
|
|
65
|
+
onSwipeStart,
|
|
66
|
+
onSwipeMove,
|
|
67
|
+
onSwipeCancel,
|
|
68
|
+
onSwipeEnd,
|
|
69
|
+
viewportName = "default",
|
|
70
|
+
...toastProps
|
|
71
|
+
} = props, isPresent = useIsPresent(), context = useToastProviderContext(scope), [node, setNode] = React.useState(null), composedRefs = useComposedRefs(forwardedRef, setNode), duration = durationProp || context.duration, closeTimerStartTimeRef = React.useRef(0), closeTimerRemainingTimeRef = React.useRef(duration), closeTimerRef = React.useRef(0), { onToastAdd, onToastRemove } = context, viewport = React.useMemo(() => context.viewports[viewportName], [context.viewports, viewportName]), handleClose = useEvent(() => {
|
|
72
|
+
isPresent && (isWeb && node?.contains(
|
|
73
|
+
document.activeElement
|
|
74
|
+
) && viewport?.focus(), onClose());
|
|
75
|
+
}), startTimer = React.useCallback(
|
|
76
|
+
(duration2) => {
|
|
77
|
+
!duration2 || duration2 === Number.POSITIVE_INFINITY || (clearTimeout(closeTimerRef.current), closeTimerStartTimeRef.current = (/* @__PURE__ */ new Date()).getTime(), closeTimerRef.current = setTimeout(handleClose, duration2));
|
|
78
|
+
},
|
|
79
|
+
[handleClose]
|
|
80
|
+
), handleResume = React.useCallback(() => {
|
|
81
|
+
startTimer(closeTimerRemainingTimeRef.current), onResume?.();
|
|
82
|
+
}, [onResume, startTimer]), handlePause = React.useCallback(() => {
|
|
83
|
+
const elapsedTime = (/* @__PURE__ */ new Date()).getTime() - closeTimerStartTimeRef.current;
|
|
84
|
+
closeTimerRemainingTimeRef.current = closeTimerRemainingTimeRef.current - elapsedTime, window.clearTimeout(closeTimerRef.current), onPause?.();
|
|
85
|
+
}, [onPause]);
|
|
86
|
+
React.useEffect(() => {
|
|
87
|
+
if (isWeb && viewport)
|
|
88
|
+
return viewport.addEventListener(VIEWPORT_PAUSE, handlePause), viewport.addEventListener(VIEWPORT_RESUME, handleResume), () => {
|
|
89
|
+
viewport.removeEventListener(VIEWPORT_PAUSE, handlePause), viewport.removeEventListener(VIEWPORT_RESUME, handleResume);
|
|
90
|
+
};
|
|
91
|
+
}, [viewport, duration, onPause, onResume, startTimer]), React.useEffect(() => {
|
|
92
|
+
open && !context.isClosePausedRef.current && startTimer(duration);
|
|
93
|
+
}, [open, duration, context.isClosePausedRef, startTimer]), React.useEffect(() => (onToastAdd(), () => onToastRemove()), [onToastAdd, onToastRemove]);
|
|
94
|
+
const announceTextContent = React.useMemo(() => isWeb && node ? getAnnounceTextContent(node) : null, [node]), isHorizontalSwipe = ["left", "right", "horizontal"].includes(
|
|
95
|
+
context.swipeDirection
|
|
96
|
+
), { animationDriver } = useConfiguration();
|
|
97
|
+
if (!animationDriver)
|
|
98
|
+
throw new Error("Must set animations in tamagui.config.ts");
|
|
99
|
+
const { useAnimatedNumber, useAnimatedNumberStyle } = animationDriver, animatedNumber = useAnimatedNumber(0), AnimatedView = animationDriver.NumberView ?? animationDriver.View ?? View, animatedStyles = useAnimatedNumberStyle(animatedNumber, (val) => {
|
|
100
|
+
"worklet";
|
|
101
|
+
return {
|
|
102
|
+
transform: [isHorizontalSwipe ? { translateX: val } : { translateY: val }]
|
|
103
|
+
};
|
|
104
|
+
}), panResponder = React.useMemo(() => PanResponder.create({
|
|
105
|
+
onMoveShouldSetPanResponder: (e, gesture) => shouldGrantGestureMove(context.swipeDirection, gesture) ? (onSwipeStart?.(e), !0) : !1,
|
|
106
|
+
onPanResponderGrant: (e) => {
|
|
107
|
+
isWeb || handlePause?.();
|
|
108
|
+
},
|
|
109
|
+
onPanResponderMove: (e, gesture) => {
|
|
110
|
+
const { x, y } = getGestureDistance(context.swipeDirection, gesture), delta = { x, y };
|
|
111
|
+
animatedNumber.setValue(isHorizontalSwipe ? x : y, { type: "direct" }), isDeltaInDirection(delta, context.swipeDirection, context.swipeThreshold) && onSwipeEnd?.(e), onSwipeMove?.(e);
|
|
112
|
+
},
|
|
113
|
+
onPanResponderEnd: (e, { dx, dy }) => {
|
|
114
|
+
isDeltaInDirection(
|
|
115
|
+
{ x: dx, y: dy },
|
|
116
|
+
context.swipeDirection,
|
|
117
|
+
context.swipeThreshold
|
|
118
|
+
) || (isWeb || handleResume?.(), onSwipeCancel?.(e), animatedNumber.setValue(0, { type: "spring" }));
|
|
119
|
+
}
|
|
120
|
+
}), [handlePause, handleResume]), themeName = useThemeName();
|
|
121
|
+
return /* @__PURE__ */ jsxs(Fragment, { children: [
|
|
122
|
+
announceTextContent && /* @__PURE__ */ jsx(
|
|
123
|
+
ToastAnnounce,
|
|
124
|
+
{
|
|
125
|
+
scope,
|
|
126
|
+
role: "status",
|
|
127
|
+
"aria-live": type === "foreground" ? "assertive" : "polite",
|
|
128
|
+
"aria-atomic": !0,
|
|
129
|
+
children: announceTextContent
|
|
130
|
+
}
|
|
131
|
+
),
|
|
132
|
+
/* @__PURE__ */ jsx(PortalItem, { hostName: viewportName ?? "default", children: /* @__PURE__ */ jsx(
|
|
133
|
+
ToastInteractiveProvider,
|
|
134
|
+
{
|
|
135
|
+
scope,
|
|
136
|
+
onClose: () => {
|
|
137
|
+
handleClose();
|
|
138
|
+
},
|
|
139
|
+
children: /* @__PURE__ */ jsx(
|
|
140
|
+
Dismissable,
|
|
141
|
+
{
|
|
142
|
+
onEscapeKeyDown: composeEventHandlers(onEscapeKeyDown, () => {
|
|
143
|
+
context.isFocusedToastEscapeKeyDownRef.current || handleClose(), context.isFocusedToastEscapeKeyDownRef.current = !1;
|
|
144
|
+
}),
|
|
145
|
+
children: /* @__PURE__ */ jsx(Theme, { contain: !0, forceClassName: !0, name: themeName, children: /* @__PURE__ */ jsx(
|
|
146
|
+
AnimatedView,
|
|
147
|
+
{
|
|
148
|
+
...panResponder?.panHandlers,
|
|
149
|
+
style: [{ margin: "auto" }, animatedStyles],
|
|
150
|
+
children: /* @__PURE__ */ jsx(Collection.ItemSlot, { scope: context.toastScope, children: /* @__PURE__ */ jsx(
|
|
151
|
+
ToastImplFrame,
|
|
152
|
+
{
|
|
153
|
+
role: "status",
|
|
154
|
+
"aria-live": "off",
|
|
155
|
+
"aria-atomic": !0,
|
|
156
|
+
"data-state": open ? "open" : "closed",
|
|
157
|
+
"data-swipe-direction": context.swipeDirection,
|
|
158
|
+
pointerEvents: "auto",
|
|
159
|
+
"$platform-web": {
|
|
160
|
+
touchAction: "none",
|
|
161
|
+
userSelect: "none"
|
|
162
|
+
},
|
|
163
|
+
...toastProps,
|
|
164
|
+
ref: composedRefs,
|
|
165
|
+
...isWeb && {
|
|
166
|
+
onKeyDown: composeEventHandlers(props.onKeyDown, (event) => {
|
|
167
|
+
event.key === "Escape" && (onEscapeKeyDown?.(event), event.defaultPrevented || (context.isFocusedToastEscapeKeyDownRef.current = !0, handleClose()));
|
|
168
|
+
})
|
|
169
|
+
}
|
|
170
|
+
}
|
|
171
|
+
) })
|
|
172
|
+
}
|
|
173
|
+
) })
|
|
174
|
+
}
|
|
175
|
+
)
|
|
176
|
+
},
|
|
177
|
+
props.id
|
|
178
|
+
) })
|
|
179
|
+
] });
|
|
180
|
+
}
|
|
181
|
+
);
|
|
182
|
+
ToastImpl.propTypes = {
|
|
183
|
+
type(props) {
|
|
184
|
+
if (props.type && !["foreground", "background"].includes(props.type)) {
|
|
185
|
+
const error = `Invalid prop \`type\` supplied to \`${TOAST_NAME}\`. Expected \`foreground | background\`.`;
|
|
186
|
+
return new Error(error);
|
|
187
|
+
}
|
|
188
|
+
return null;
|
|
189
|
+
}
|
|
190
|
+
};
|
|
191
|
+
const isDeltaInDirection = (delta, direction, threshold = 0) => {
|
|
192
|
+
const deltaX = Math.abs(delta.x), deltaY = Math.abs(delta.y), isDeltaX = deltaX > deltaY;
|
|
193
|
+
return direction === "left" || direction === "right" || direction === "horizontal" ? isDeltaX && deltaX > threshold : !isDeltaX && deltaY > threshold;
|
|
194
|
+
};
|
|
195
|
+
function getAnnounceTextContent(container) {
|
|
196
|
+
if (!isWeb) return "";
|
|
197
|
+
const textContent = [];
|
|
198
|
+
return Array.from(container.childNodes).forEach((node) => {
|
|
199
|
+
if (node.nodeType === node.TEXT_NODE && node.textContent && textContent.push(node.textContent), isHTMLElement(node)) {
|
|
200
|
+
const isHidden = node.ariaHidden || node.hidden || node.style.display === "none", isExcluded = node.dataset.toastAnnounceExclude === "";
|
|
201
|
+
if (!isHidden)
|
|
202
|
+
if (isExcluded) {
|
|
203
|
+
const altText = node.dataset.toastAnnounceAlt;
|
|
204
|
+
altText && textContent.push(altText);
|
|
205
|
+
} else
|
|
206
|
+
textContent.push(...getAnnounceTextContent(node));
|
|
207
|
+
}
|
|
208
|
+
}), textContent;
|
|
209
|
+
}
|
|
210
|
+
function isHTMLElement(node) {
|
|
211
|
+
return node.nodeType === node.ELEMENT_NODE;
|
|
212
|
+
}
|
|
213
|
+
const GESTURE_GRANT_THRESHOLD = 10, shouldGrantGestureMove = (dir, { dx, dy }) => (dir === "horizontal" || dir === "left") && dx < -GESTURE_GRANT_THRESHOLD || (dir === "horizontal" || dir === "right") && dx > GESTURE_GRANT_THRESHOLD || (dir === "vertical" || dir === "up") && dy > -GESTURE_GRANT_THRESHOLD || (dir === "vertical" || dir === "down") && dy < GESTURE_GRANT_THRESHOLD, getGestureDistance = (dir, { dx, dy }) => {
|
|
214
|
+
let y = 0, x = 0;
|
|
215
|
+
return dir === "horizontal" ? x = dx : dir === "left" ? x = Math.min(0, dx) : dir === "right" ? x = Math.max(0, dx) : dir === "vertical" ? y = dy : dir === "up" ? y = Math.min(0, dy) : dir === "down" && (y = Math.max(0, dy)), {
|
|
216
|
+
x,
|
|
217
|
+
y
|
|
218
|
+
};
|
|
219
|
+
};
|
|
220
|
+
export {
|
|
221
|
+
ToastImpl,
|
|
222
|
+
ToastImplFrame,
|
|
223
|
+
useToastInteractiveContext
|
|
224
|
+
};
|
|
225
|
+
//# sourceMappingURL=ToastImpl.js.map
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
{
|
|
2
|
+
"version": 3,
|
|
3
|
+
"sources": ["../../src/ToastImpl.tsx"],
|
|
4
|
+
"mappings": "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",
|
|
5
|
+
"names": ["duration"]
|
|
6
|
+
}
|
|
@@ -0,0 +1,256 @@
|
|
|
1
|
+
import { useIsPresent } from "@tamagui/animate-presence";
|
|
2
|
+
import { useComposedRefs } from "@tamagui/compose-refs";
|
|
3
|
+
import { isWeb } from "@tamagui/constants";
|
|
4
|
+
import { View, Theme, createStyledContext, styled, useConfiguration, useEvent, useThemeName } from "@tamagui/core";
|
|
5
|
+
import { Dismissable } from "@tamagui/dismissable";
|
|
6
|
+
import { composeEventHandlers } from "@tamagui/helpers";
|
|
7
|
+
import { PortalItem } from "@tamagui/portal";
|
|
8
|
+
import { YStack } from "@tamagui/stacks";
|
|
9
|
+
import * as React from "react";
|
|
10
|
+
import { PanResponder } from "react-native-web";
|
|
11
|
+
import { TOAST_NAME } from "./constants.mjs";
|
|
12
|
+
import { ToastAnnounce } from "./ToastAnnounce.mjs";
|
|
13
|
+
import { Collection, useToastProviderContext } from "./ToastProvider.mjs";
|
|
14
|
+
import { VIEWPORT_PAUSE, VIEWPORT_RESUME } from "./ToastViewport.mjs";
|
|
15
|
+
import { Fragment, jsx, jsxs } from "react/jsx-runtime";
|
|
16
|
+
const ToastImplFrame = styled(YStack, {
|
|
17
|
+
name: "ToastImpl",
|
|
18
|
+
focusable: !0,
|
|
19
|
+
variants: {
|
|
20
|
+
unstyled: {
|
|
21
|
+
false: {
|
|
22
|
+
focusStyle: {
|
|
23
|
+
outlineStyle: "solid",
|
|
24
|
+
outlineWidth: 2,
|
|
25
|
+
outlineColor: "$outlineColor"
|
|
26
|
+
},
|
|
27
|
+
backgroundColor: "$color6",
|
|
28
|
+
borderRadius: "$4",
|
|
29
|
+
paddingHorizontal: "$4",
|
|
30
|
+
paddingVertical: "$3",
|
|
31
|
+
marginHorizontal: "auto",
|
|
32
|
+
marginVertical: "$1",
|
|
33
|
+
elevation: "$3"
|
|
34
|
+
}
|
|
35
|
+
}
|
|
36
|
+
},
|
|
37
|
+
defaultVariants: {
|
|
38
|
+
unstyled: process.env.TAMAGUI_HEADLESS === "1"
|
|
39
|
+
}
|
|
40
|
+
}),
|
|
41
|
+
{
|
|
42
|
+
Provider: ToastInteractiveProvider,
|
|
43
|
+
useStyledContext: useToastInteractiveContext
|
|
44
|
+
} = createStyledContext({
|
|
45
|
+
onClose() {}
|
|
46
|
+
}),
|
|
47
|
+
ToastImpl = React.forwardRef((props, forwardedRef) => {
|
|
48
|
+
const {
|
|
49
|
+
scope,
|
|
50
|
+
type = "foreground",
|
|
51
|
+
duration: durationProp,
|
|
52
|
+
open,
|
|
53
|
+
onClose,
|
|
54
|
+
onEscapeKeyDown,
|
|
55
|
+
onPause,
|
|
56
|
+
onResume,
|
|
57
|
+
onSwipeStart,
|
|
58
|
+
onSwipeMove,
|
|
59
|
+
onSwipeCancel,
|
|
60
|
+
onSwipeEnd,
|
|
61
|
+
viewportName = "default",
|
|
62
|
+
...toastProps
|
|
63
|
+
} = props,
|
|
64
|
+
isPresent = useIsPresent(),
|
|
65
|
+
context = useToastProviderContext(scope),
|
|
66
|
+
[node, setNode] = React.useState(null),
|
|
67
|
+
composedRefs = useComposedRefs(forwardedRef, setNode),
|
|
68
|
+
duration = durationProp || context.duration,
|
|
69
|
+
closeTimerStartTimeRef = React.useRef(0),
|
|
70
|
+
closeTimerRemainingTimeRef = React.useRef(duration),
|
|
71
|
+
closeTimerRef = React.useRef(0),
|
|
72
|
+
{
|
|
73
|
+
onToastAdd,
|
|
74
|
+
onToastRemove
|
|
75
|
+
} = context,
|
|
76
|
+
viewport = React.useMemo(() => context.viewports[viewportName], [context.viewports, viewportName]),
|
|
77
|
+
handleClose = useEvent(() => {
|
|
78
|
+
isPresent && (isWeb && node?.contains(document.activeElement) && viewport?.focus(), onClose());
|
|
79
|
+
}),
|
|
80
|
+
startTimer = React.useCallback(duration2 => {
|
|
81
|
+
!duration2 || duration2 === Number.POSITIVE_INFINITY || (clearTimeout(closeTimerRef.current), closeTimerStartTimeRef.current = (/* @__PURE__ */new Date()).getTime(), closeTimerRef.current = setTimeout(handleClose, duration2));
|
|
82
|
+
}, [handleClose]),
|
|
83
|
+
handleResume = React.useCallback(() => {
|
|
84
|
+
startTimer(closeTimerRemainingTimeRef.current), onResume?.();
|
|
85
|
+
}, [onResume, startTimer]),
|
|
86
|
+
handlePause = React.useCallback(() => {
|
|
87
|
+
const elapsedTime = (/* @__PURE__ */new Date()).getTime() - closeTimerStartTimeRef.current;
|
|
88
|
+
closeTimerRemainingTimeRef.current = closeTimerRemainingTimeRef.current - elapsedTime, window.clearTimeout(closeTimerRef.current), onPause?.();
|
|
89
|
+
}, [onPause]);
|
|
90
|
+
React.useEffect(() => {
|
|
91
|
+
if (isWeb && viewport) return viewport.addEventListener(VIEWPORT_PAUSE, handlePause), viewport.addEventListener(VIEWPORT_RESUME, handleResume), () => {
|
|
92
|
+
viewport.removeEventListener(VIEWPORT_PAUSE, handlePause), viewport.removeEventListener(VIEWPORT_RESUME, handleResume);
|
|
93
|
+
};
|
|
94
|
+
}, [viewport, duration, onPause, onResume, startTimer]), React.useEffect(() => {
|
|
95
|
+
open && !context.isClosePausedRef.current && startTimer(duration);
|
|
96
|
+
}, [open, duration, context.isClosePausedRef, startTimer]), React.useEffect(() => (onToastAdd(), () => onToastRemove()), [onToastAdd, onToastRemove]);
|
|
97
|
+
const announceTextContent = React.useMemo(() => isWeb && node ? getAnnounceTextContent(node) : null, [node]),
|
|
98
|
+
isHorizontalSwipe = ["left", "right", "horizontal"].includes(context.swipeDirection),
|
|
99
|
+
{
|
|
100
|
+
animationDriver
|
|
101
|
+
} = useConfiguration();
|
|
102
|
+
if (!animationDriver) throw new Error("Must set animations in tamagui.config.ts");
|
|
103
|
+
const {
|
|
104
|
+
useAnimatedNumber,
|
|
105
|
+
useAnimatedNumberStyle
|
|
106
|
+
} = animationDriver,
|
|
107
|
+
animatedNumber = useAnimatedNumber(0),
|
|
108
|
+
AnimatedView = animationDriver.NumberView ?? animationDriver.View ?? View,
|
|
109
|
+
animatedStyles = useAnimatedNumberStyle(animatedNumber, val => {
|
|
110
|
+
"worklet";
|
|
111
|
+
|
|
112
|
+
return {
|
|
113
|
+
transform: [isHorizontalSwipe ? {
|
|
114
|
+
translateX: val
|
|
115
|
+
} : {
|
|
116
|
+
translateY: val
|
|
117
|
+
}]
|
|
118
|
+
};
|
|
119
|
+
}),
|
|
120
|
+
panResponder = React.useMemo(() => PanResponder.create({
|
|
121
|
+
onMoveShouldSetPanResponder: (e, gesture) => shouldGrantGestureMove(context.swipeDirection, gesture) ? (onSwipeStart?.(e), !0) : !1,
|
|
122
|
+
onPanResponderGrant: e => {
|
|
123
|
+
isWeb || handlePause?.();
|
|
124
|
+
},
|
|
125
|
+
onPanResponderMove: (e, gesture) => {
|
|
126
|
+
const {
|
|
127
|
+
x,
|
|
128
|
+
y
|
|
129
|
+
} = getGestureDistance(context.swipeDirection, gesture),
|
|
130
|
+
delta = {
|
|
131
|
+
x,
|
|
132
|
+
y
|
|
133
|
+
};
|
|
134
|
+
animatedNumber.setValue(isHorizontalSwipe ? x : y, {
|
|
135
|
+
type: "direct"
|
|
136
|
+
}), isDeltaInDirection(delta, context.swipeDirection, context.swipeThreshold) && onSwipeEnd?.(e), onSwipeMove?.(e);
|
|
137
|
+
},
|
|
138
|
+
onPanResponderEnd: (e, {
|
|
139
|
+
dx,
|
|
140
|
+
dy
|
|
141
|
+
}) => {
|
|
142
|
+
isDeltaInDirection({
|
|
143
|
+
x: dx,
|
|
144
|
+
y: dy
|
|
145
|
+
}, context.swipeDirection, context.swipeThreshold) || (isWeb || handleResume?.(), onSwipeCancel?.(e), animatedNumber.setValue(0, {
|
|
146
|
+
type: "spring"
|
|
147
|
+
}));
|
|
148
|
+
}
|
|
149
|
+
}), [handlePause, handleResume]),
|
|
150
|
+
themeName = useThemeName();
|
|
151
|
+
return /* @__PURE__ */jsxs(Fragment, {
|
|
152
|
+
children: [announceTextContent && /* @__PURE__ */jsx(ToastAnnounce, {
|
|
153
|
+
scope,
|
|
154
|
+
role: "status",
|
|
155
|
+
"aria-live": type === "foreground" ? "assertive" : "polite",
|
|
156
|
+
"aria-atomic": !0,
|
|
157
|
+
children: announceTextContent
|
|
158
|
+
}), /* @__PURE__ */jsx(PortalItem, {
|
|
159
|
+
hostName: viewportName ?? "default",
|
|
160
|
+
children: /* @__PURE__ */jsx(ToastInteractiveProvider, {
|
|
161
|
+
scope,
|
|
162
|
+
onClose: () => {
|
|
163
|
+
handleClose();
|
|
164
|
+
},
|
|
165
|
+
children: /* @__PURE__ */jsx(Dismissable, {
|
|
166
|
+
onEscapeKeyDown: composeEventHandlers(onEscapeKeyDown, () => {
|
|
167
|
+
context.isFocusedToastEscapeKeyDownRef.current || handleClose(), context.isFocusedToastEscapeKeyDownRef.current = !1;
|
|
168
|
+
}),
|
|
169
|
+
children: /* @__PURE__ */jsx(Theme, {
|
|
170
|
+
contain: !0,
|
|
171
|
+
forceClassName: !0,
|
|
172
|
+
name: themeName,
|
|
173
|
+
children: /* @__PURE__ */jsx(AnimatedView, {
|
|
174
|
+
...panResponder?.panHandlers,
|
|
175
|
+
style: [{
|
|
176
|
+
margin: "auto"
|
|
177
|
+
}, animatedStyles],
|
|
178
|
+
children: /* @__PURE__ */jsx(Collection.ItemSlot, {
|
|
179
|
+
scope: context.toastScope,
|
|
180
|
+
children: /* @__PURE__ */jsx(ToastImplFrame, {
|
|
181
|
+
role: "status",
|
|
182
|
+
"aria-live": "off",
|
|
183
|
+
"aria-atomic": !0,
|
|
184
|
+
"data-state": open ? "open" : "closed",
|
|
185
|
+
"data-swipe-direction": context.swipeDirection,
|
|
186
|
+
pointerEvents: "auto",
|
|
187
|
+
"$platform-web": {
|
|
188
|
+
touchAction: "none",
|
|
189
|
+
userSelect: "none"
|
|
190
|
+
},
|
|
191
|
+
...toastProps,
|
|
192
|
+
ref: composedRefs,
|
|
193
|
+
...(isWeb && {
|
|
194
|
+
onKeyDown: composeEventHandlers(props.onKeyDown, event => {
|
|
195
|
+
event.key === "Escape" && (onEscapeKeyDown?.(event), event.defaultPrevented || (context.isFocusedToastEscapeKeyDownRef.current = !0, handleClose()));
|
|
196
|
+
})
|
|
197
|
+
})
|
|
198
|
+
})
|
|
199
|
+
})
|
|
200
|
+
})
|
|
201
|
+
})
|
|
202
|
+
})
|
|
203
|
+
}, props.id)
|
|
204
|
+
})]
|
|
205
|
+
});
|
|
206
|
+
});
|
|
207
|
+
ToastImpl.propTypes = {
|
|
208
|
+
type(props) {
|
|
209
|
+
if (props.type && !["foreground", "background"].includes(props.type)) {
|
|
210
|
+
const error = `Invalid prop \`type\` supplied to \`${TOAST_NAME}\`. Expected \`foreground | background\`.`;
|
|
211
|
+
return new Error(error);
|
|
212
|
+
}
|
|
213
|
+
return null;
|
|
214
|
+
}
|
|
215
|
+
};
|
|
216
|
+
const isDeltaInDirection = (delta, direction, threshold = 0) => {
|
|
217
|
+
const deltaX = Math.abs(delta.x),
|
|
218
|
+
deltaY = Math.abs(delta.y),
|
|
219
|
+
isDeltaX = deltaX > deltaY;
|
|
220
|
+
return direction === "left" || direction === "right" || direction === "horizontal" ? isDeltaX && deltaX > threshold : !isDeltaX && deltaY > threshold;
|
|
221
|
+
};
|
|
222
|
+
function getAnnounceTextContent(container) {
|
|
223
|
+
if (!isWeb) return "";
|
|
224
|
+
const textContent = [];
|
|
225
|
+
return Array.from(container.childNodes).forEach(node => {
|
|
226
|
+
if (node.nodeType === node.TEXT_NODE && node.textContent && textContent.push(node.textContent), isHTMLElement(node)) {
|
|
227
|
+
const isHidden = node.ariaHidden || node.hidden || node.style.display === "none",
|
|
228
|
+
isExcluded = node.dataset.toastAnnounceExclude === "";
|
|
229
|
+
if (!isHidden) if (isExcluded) {
|
|
230
|
+
const altText = node.dataset.toastAnnounceAlt;
|
|
231
|
+
altText && textContent.push(altText);
|
|
232
|
+
} else textContent.push(...getAnnounceTextContent(node));
|
|
233
|
+
}
|
|
234
|
+
}), textContent;
|
|
235
|
+
}
|
|
236
|
+
function isHTMLElement(node) {
|
|
237
|
+
return node.nodeType === node.ELEMENT_NODE;
|
|
238
|
+
}
|
|
239
|
+
const GESTURE_GRANT_THRESHOLD = 10,
|
|
240
|
+
shouldGrantGestureMove = (dir, {
|
|
241
|
+
dx,
|
|
242
|
+
dy
|
|
243
|
+
}) => (dir === "horizontal" || dir === "left") && dx < -GESTURE_GRANT_THRESHOLD || (dir === "horizontal" || dir === "right") && dx > GESTURE_GRANT_THRESHOLD || (dir === "vertical" || dir === "up") && dy > -GESTURE_GRANT_THRESHOLD || (dir === "vertical" || dir === "down") && dy < GESTURE_GRANT_THRESHOLD,
|
|
244
|
+
getGestureDistance = (dir, {
|
|
245
|
+
dx,
|
|
246
|
+
dy
|
|
247
|
+
}) => {
|
|
248
|
+
let y = 0,
|
|
249
|
+
x = 0;
|
|
250
|
+
return dir === "horizontal" ? x = dx : dir === "left" ? x = Math.min(0, dx) : dir === "right" ? x = Math.max(0, dx) : dir === "vertical" ? y = dy : dir === "up" ? y = Math.min(0, dy) : dir === "down" && (y = Math.max(0, dy)), {
|
|
251
|
+
x,
|
|
252
|
+
y
|
|
253
|
+
};
|
|
254
|
+
};
|
|
255
|
+
export { ToastImpl, ToastImplFrame, useToastInteractiveContext };
|
|
256
|
+
//# sourceMappingURL=ToastImpl.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"names":["useIsPresent","useComposedRefs","isWeb","View","Theme","createStyledContext","styled","useConfiguration","useEvent","useThemeName","Dismissable","composeEventHandlers","PortalItem","YStack","React","PanResponder","TOAST_NAME","ToastAnnounce","Collection","useToastProviderContext","VIEWPORT_PAUSE","VIEWPORT_RESUME","Fragment","jsx","jsxs","ToastImplFrame","name","focusable","variants","unstyled","false","focusStyle","outlineStyle","outlineWidth","outlineColor","backgroundColor","borderRadius","paddingHorizontal","paddingVertical","marginHorizontal","marginVertical","elevation","defaultVariants","process","env","TAMAGUI_HEADLESS","Provider","ToastInteractiveProvider","useStyledContext","useToastInteractiveContext","onClose","ToastImpl","forwardRef","props","forwardedRef","scope","type","duration","durationProp","open","onEscapeKeyDown","onPause","onResume","onSwipeStart","onSwipeMove","onSwipeCancel","onSwipeEnd","viewportName","toastProps","isPresent","context","node","setNode","useState","composedRefs","closeTimerStartTimeRef","useRef","closeTimerRemainingTimeRef","closeTimerRef","onToastAdd","onToastRemove","viewport","useMemo","viewports","handleClose","contains","document","activeElement","focus","startTimer","useCallback","duration2","Number","POSITIVE_INFINITY","clearTimeout","current","Date","getTime","setTimeout","handleResume","handlePause","elapsedTime","window","useEffect","addEventListener","removeEventListener","isClosePausedRef","announceTextContent","getAnnounceTextContent","isHorizontalSwipe","includes","swipeDirection","animationDriver","Error","useAnimatedNumber","useAnimatedNumberStyle","animatedNumber","AnimatedView","NumberView","animatedStyles","val","transform","translateX","translateY","panResponder","create","onMoveShouldSetPanResponder","e","gesture","shouldGrantGestureMove","onPanResponderGrant","onPanResponderMove","x","y","getGestureDistance","delta","setValue","isDeltaInDirection","swipeThreshold","onPanResponderEnd","dx","dy","themeName","children","role","hostName","isFocusedToastEscapeKeyDownRef","contain","forceClassName","panHandlers","style","margin","ItemSlot","toastScope","pointerEvents","touchAction","userSelect","ref","onKeyDown","event","key","defaultPrevented","id","propTypes","error","direction","threshold","deltaX","Math","abs","deltaY","isDeltaX","container","textContent","Array","from","childNodes","forEach","nodeType","TEXT_NODE","push","isHTMLElement","isHidden","ariaHidden","hidden","display","isExcluded","dataset","toastAnnounceExclude","altText","toastAnnounceAlt","ELEMENT_NODE","GESTURE_GRANT_THRESHOLD","dir","min","max"],"sources":["../../src/ToastImpl.tsx"],"sourcesContent":[null],"mappings":"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","ignoreList":[]}
|