@radix-ui/react-toast 0.1.2-rc.5 → 0.1.2-rc.50

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/index.js CHANGED
@@ -1,2 +1,691 @@
1
- var e,t=require("@radix-ui/react-visually-hidden").VisuallyHidden,r=require("@radix-ui/react-use-layout-effect").useLayoutEffect,o=require("@radix-ui/react-use-controllable-state").useControllableState,n=require("@radix-ui/react-use-callback-ref").useCallbackRef,s=require("@radix-ui/react-primitive").Primitive,a=require("@radix-ui/react-presence").Presence,i=require("@radix-ui/react-portal").UnstablePortal,c=f({},require("@radix-ui/react-dismissable-layer")),u=require("@radix-ui/react-context").createContextScope,l=require("@radix-ui/react-compose-refs").useComposedRefs,d=require("@radix-ui/primitive").composeEventHandlers,p=f({},require("react-dom")),w=f({},require("react")),v=(e=require("@babel/runtime/helpers/extends"))&&e.__esModule?e.default:e;function f(e,t){return Object.keys(t).forEach((function(r){"default"!==r&&"__esModule"!==r&&Object.defineProperty(e,r,{enumerable:!0,get:function(){return t[r]}})})),e}const[m,E]=u("Toast");exports.createToastScope=E;const[T,y]=m("ToastProvider"),x=e=>{const{__scopeToast:t,label:r="Notification",duration:o=5e3,swipeDirection:n="right",swipeThreshold:s=50,children:a}=e,[i,c]=w.useState(null),[u,l]=w.useState(0),d=w.useRef(!1),p=w.useRef(!1);/*#__PURE__*/return w.createElement(T,{scope:t,label:r,duration:o,swipeDirection:n,swipeThreshold:s,toastCount:u,viewport:i,onViewportChange:c,onToastAdd:w.useCallback((()=>l((e=>e+1))),[]),onToastRemove:w.useCallback((()=>l((e=>e-1))),[]),isFocusedToastEscapeKeyDownRef:d,isClosePausedRef:p},a)};exports.ToastProvider=x;const g=["F8"],b=/*#__PURE__*/w.forwardRef(((e,t)=>{const{__scopeToast:r,hotkey:o=g,label:n="Notifications ({hotkey})",...a}=e,i=y("ToastViewport",r),u=w.useRef(null),d=w.useRef(null),p=l(t,d,i.onViewportChange),f=o.join("+").replace(/Key/g,"").replace(/Digit/g,"");return w.useEffect((()=>{const e=e=>{var t;o.every((t=>e[t]||e.code===t))&&(null===(t=d.current)||void 0===t||t.focus())};return document.addEventListener("keydown",e),()=>document.removeEventListener("keydown",e)}),[o]),w.useEffect((()=>{const e=u.current,t=d.current;if(e&&t){const r=()=>{const e=new Event("toast.viewportPause");t.dispatchEvent(e),i.isClosePausedRef.current=!0},o=()=>{const e=new Event("toast.viewportResume");t.dispatchEvent(e),i.isClosePausedRef.current=!1};return e.addEventListener("focusin",r),e.addEventListener("focusout",o),e.addEventListener("pointerenter",r),e.addEventListener("pointerleave",o),window.addEventListener("blur",r),window.addEventListener("focus",o),()=>{e.removeEventListener("focusin",r),e.removeEventListener("focusout",o),e.removeEventListener("pointerenter",r),e.removeEventListener("pointerleave",o),window.removeEventListener("blur",r),window.removeEventListener("focus",o)}}}),[i.isClosePausedRef]),w.useEffect((()=>{const e=d.current;if(e){const t=new Set,r=new MutationObserver((r=>{r.map((e=>Array.from(e.addedNodes))).reduce(((e,t)=>e.concat(t))).forEach((r=>{t.has(r)?t.delete(r):(e.prepend(r),t.add(r))}))}));return r.observe(e,{childList:!0}),()=>r.disconnect()}}),[]),/*#__PURE__*/w.createElement(c.Branch,{ref:u,role:"region","aria-label":n.replace("{hotkey}",f),tabIndex:-1,style:{pointerEvents:i.toastCount>0?void 0:"none"}},/*#__PURE__*/w.createElement(s.ol,v({tabIndex:-1},a,{ref:p})))}));exports.ToastViewport=b;const h=/*#__PURE__*/w.forwardRef(((e,t)=>{const{forceMount:r,open:n,defaultOpen:s,onOpenChange:i,...c}=e,[u=!0,l]=o({prop:n,defaultProp:s,onChange:i});/*#__PURE__*/return w.createElement(a,{present:r||u},/*#__PURE__*/w.createElement(R,v({open:u},c,{ref:t,onClose:()=>l(!1),onSwipeStart:d(e.onSwipeStart,(e=>{e.currentTarget.setAttribute("data-swipe","start")})),onSwipeMove:d(e.onSwipeMove,(e=>{const{x:t,y:r}=e.detail.delta;e.currentTarget.setAttribute("data-swipe","move"),e.currentTarget.style.setProperty("--radix-toast-swipe-move-x",`${t}px`),e.currentTarget.style.setProperty("--radix-toast-swipe-move-y",`${r}px`)})),onSwipeCancel:d(e.onSwipeCancel,(e=>{e.currentTarget.setAttribute("data-swipe","cancel"),e.currentTarget.style.removeProperty("--radix-toast-swipe-move-x"),e.currentTarget.style.removeProperty("--radix-toast-swipe-move-y"),e.currentTarget.style.removeProperty("--radix-toast-swipe-end-x"),e.currentTarget.style.removeProperty("--radix-toast-swipe-end-y")})),onSwipeEnd:d(e.onSwipeEnd,(e=>{const{x:t,y:r}=e.detail.delta;e.currentTarget.setAttribute("data-swipe","end"),e.currentTarget.style.removeProperty("--radix-toast-swipe-move-x"),e.currentTarget.style.removeProperty("--radix-toast-swipe-move-y"),e.currentTarget.style.setProperty("--radix-toast-swipe-end-x",`${t}px`),e.currentTarget.style.setProperty("--radix-toast-swipe-end-y",`${r}px`),l(!1)}))})))}));exports.Toast=h;const[C,P]=m("Toast",{isInteractive:!1,onClose(){}}),R=/*#__PURE__*/w.forwardRef(((e,t)=>{const{__scopeToast:r,type:o="foreground",duration:a,open:i,onClose:u,onEscapeKeyDown:f,onSwipeStart:m,onSwipeMove:E,onSwipeCancel:T,onSwipeEnd:x,...g}=e,b=y("Toast",r),h=w.useRef(null),P=l(t,h),R=w.useRef(null),D=w.useRef(null),L=a||b.duration,_=w.useRef(0),k=w.useRef(L),A=w.useRef(0),{onToastAdd:F,onToastRemove:I}=b,K=n((()=>{var e,t;(null===(e=h.current)||void 0===e?void 0:e.contains(document.activeElement))&&(null===(t=b.viewport)||void 0===t||t.focus()),u()})),V=w.useCallback((e=>{e&&e!==1/0&&(window.clearTimeout(A.current),_.current=(new Date).getTime(),A.current=window.setTimeout(K,e))}),[K]);return w.useEffect((()=>{const e=b.viewport;if(e){const t=()=>{V(k.current)},r=()=>{const e=(new Date).getTime()-_.current;k.current=k.current-e,window.clearTimeout(A.current)};return e.addEventListener("toast.viewportPause",r),e.addEventListener("toast.viewportResume",t),()=>{e.removeEventListener("toast.viewportPause",r),e.removeEventListener("toast.viewportResume",t)}}}),[b.viewport,L,V]),w.useEffect((()=>{i&&!b.isClosePausedRef.current&&V(L)}),[i,L,b.isClosePausedRef,V]),w.useEffect((()=>(F(),()=>I())),[F,I]),b.viewport?/*#__PURE__*/w.createElement(w.Fragment,null,/*#__PURE__*/w.createElement(S,{__scopeToast:r,role:"status","aria-live":"foreground"===o?"assertive":"polite","aria-atomic":!0},e.children),/*#__PURE__*/w.createElement(C,{scope:r,isInteractive:!0,onClose:K},/*#__PURE__*/p.createPortal(/*#__PURE__*/w.createElement(c.Root,{asChild:!0,onEscapeKeyDown:d(f,(()=>{b.isFocusedToastEscapeKeyDownRef.current||K(),b.isFocusedToastEscapeKeyDownRef.current=!1}))},/*#__PURE__*/w.createElement(s.li,v({role:"status","aria-live":"off","aria-atomic":!0,tabIndex:0,"data-state":i?"open":"closed","data-swipe-direction":b.swipeDirection},g,{ref:P,style:{userSelect:"none",touchAction:"none",...e.style},onKeyDown:d(e.onKeyDown,(e=>{"Escape"===e.key&&(null==f||f(e.nativeEvent),e.nativeEvent.defaultPrevented||(b.isFocusedToastEscapeKeyDownRef.current=!0,K()))})),onPointerDown:d(e.onPointerDown,(e=>{0===e.button&&(R.current={x:e.clientX,y:e.clientY})})),onPointerMove:d(e.onPointerMove,(e=>{if(!R.current)return;const t=e.clientX-R.current.x,r=e.clientY-R.current.y,o=Boolean(D.current),n=["left","right"].includes(b.swipeDirection),s=["left","up"].includes(b.swipeDirection)?Math.min:Math.max,a=n?s(0,t):0,i=n?0:s(0,r),c="touch"===e.pointerType?10:2,u={x:a,y:i},l={originalEvent:e,delta:u};o?(D.current=u,M("toast.swipeMove",E,l)):q(u,b.swipeDirection,c)?(D.current=u,M("toast.swipeStart",m,l),e.target.setPointerCapture(e.pointerId)):(Math.abs(t)>c||Math.abs(r)>c)&&(R.current=null)})),onPointerUp:d(e.onPointerUp,(e=>{const t=D.current;if(e.target.releasePointerCapture(e.pointerId),D.current=null,R.current=null,t){const r=e.currentTarget,o={originalEvent:e,delta:t};q(t,b.swipeDirection,b.swipeThreshold)?M("toast.swipeEnd",x,o):M("toast.swipeCancel",T,o),r.addEventListener("click",(e=>e.preventDefault()),{once:!0})}}))}))),b.viewport))):null}));R.propTypes={type(e){if(e.type&&!["foreground","background"].includes(e.type)){throw new Error("Invalid prop `type` supplied to `Toast`. Expected `foreground | background`.")}return null}};const S=e=>{const{__scopeToast:o,...s}=e,a=y("Toast",o),[c,u]=w.useState(!1),[l,d]=w.useState(!1);return function(e=(()=>{})){const t=n(e);r((()=>{let e=0,r=0;return e=window.requestAnimationFrame((()=>r=window.requestAnimationFrame(t))),()=>{window.cancelAnimationFrame(e),window.cancelAnimationFrame(r)}}),[t])}((()=>u(!0))),w.useEffect((()=>{const e=window.setTimeout((()=>d(!0)),1e3);return()=>window.clearTimeout(e)}),[]),l?null:/*#__PURE__*/w.createElement(i,{asChild:!0},/*#__PURE__*/w.createElement(t,{asChild:!0},/*#__PURE__*/w.createElement("div",s,c&&/*#__PURE__*/w.createElement(w.Fragment,null,a.label," ",e.children))))},D=/*#__PURE__*/w.forwardRef(((e,t)=>{const{__scopeToast:r,...o}=e;/*#__PURE__*/return w.createElement(s.div,v({},o,{ref:t}))}));exports.ToastTitle=D;const L=/*#__PURE__*/w.forwardRef(((e,t)=>{const{__scopeToast:r,...o}=e;/*#__PURE__*/return w.createElement(s.div,v({},o,{ref:t}))}));exports.ToastDescription=L;const _=/*#__PURE__*/w.forwardRef(((e,t)=>{const{altText:r,...o}=e,n=P("ToastAction",e.__scopeToast);return r?n.isInteractive?/*#__PURE__*/w.createElement(k,v({},o,{ref:t})):/*#__PURE__*/w.createElement("span",null,r):null}));exports.ToastAction=_,_.propTypes={altText(e){if(!e.altText)throw new Error("Missing prop `altText` expected on `ToastAction`");return null}};const k=/*#__PURE__*/w.forwardRef(((e,t)=>{const{__scopeToast:r,...o}=e,n=P("ToastClose",r);return n.isInteractive?/*#__PURE__*/w.createElement(s.button,v({type:"button"},o,{ref:t,onClick:d(e.onClick,n.onClose)})):null}));function M(e,t,r){const o=r.originalEvent.currentTarget,n=new CustomEvent(e,{bubbles:!0,cancelable:!0,detail:r});t&&o.addEventListener(e,t,{once:!0}),o.dispatchEvent(n)}exports.ToastClose=k;const q=(e,t,r=0)=>{const o=Math.abs(e.x),n=Math.abs(e.y),s=o>n;return"left"===t||"right"===t?s&&o>r:!s&&n>r};const A=x;exports.Provider=A;const F=b;exports.Viewport=F;const I=h;exports.Root=I;const K=D;exports.Title=K;const V=L;exports.Description=V;const O=_;exports.Action=O;const $=k;exports.Close=$;
1
+ var $iTyic$babelruntimehelpersextends = require("@babel/runtime/helpers/extends");
2
+ var $iTyic$react = require("react");
3
+ var $iTyic$reactdom = require("react-dom");
4
+ var $iTyic$radixuiprimitive = require("@radix-ui/primitive");
5
+ var $iTyic$radixuireactcomposerefs = require("@radix-ui/react-compose-refs");
6
+ var $iTyic$radixuireactcollection = require("@radix-ui/react-collection");
7
+ var $iTyic$radixuireactcontext = require("@radix-ui/react-context");
8
+ var $iTyic$radixuireactdismissablelayer = require("@radix-ui/react-dismissable-layer");
9
+ var $iTyic$radixuireactpresence = require("@radix-ui/react-presence");
10
+ var $iTyic$radixuireactprimitive = require("@radix-ui/react-primitive");
11
+ var $iTyic$radixuireactslot = require("@radix-ui/react-slot");
12
+ var $iTyic$radixuireactusecallbackref = require("@radix-ui/react-use-callback-ref");
13
+ var $iTyic$radixuireactusecontrollablestate = require("@radix-ui/react-use-controllable-state");
14
+ var $iTyic$radixuireactuselayouteffect = require("@radix-ui/react-use-layout-effect");
15
+ var $iTyic$radixuireactvisuallyhidden = require("@radix-ui/react-visually-hidden");
16
+
17
+ function $parcel$exportWildcard(dest, source) {
18
+ Object.keys(source).forEach(function(key) {
19
+ if (key === 'default' || key === '__esModule' || dest.hasOwnProperty(key)) {
20
+ return;
21
+ }
22
+
23
+ Object.defineProperty(dest, key, {
24
+ enumerable: true,
25
+ get: function get() {
26
+ return source[key];
27
+ }
28
+ });
29
+ });
30
+
31
+ return dest;
32
+ }
33
+ function $parcel$interopDefault(a) {
34
+ return a && a.__esModule ? a.default : a;
35
+ }
36
+ function $parcel$export(e, n, v, s) {
37
+ Object.defineProperty(e, n, {get: v, set: s, enumerable: true, configurable: true});
38
+ }
39
+ var $9208a85b3e79d33f$exports = {};
40
+
41
+ $parcel$export($9208a85b3e79d33f$exports, "createToastScope", () => $9208a85b3e79d33f$export$8a359da18fbc9073);
42
+ $parcel$export($9208a85b3e79d33f$exports, "ToastProvider", () => $9208a85b3e79d33f$export$f5d03d415824e0e);
43
+ $parcel$export($9208a85b3e79d33f$exports, "ToastViewport", () => $9208a85b3e79d33f$export$6192c2425ecfd989);
44
+ $parcel$export($9208a85b3e79d33f$exports, "Toast", () => $9208a85b3e79d33f$export$8d8dc7d5f743331b);
45
+ $parcel$export($9208a85b3e79d33f$exports, "ToastTitle", () => $9208a85b3e79d33f$export$16d42d7c29b95a4);
46
+ $parcel$export($9208a85b3e79d33f$exports, "ToastDescription", () => $9208a85b3e79d33f$export$ecddd96c53621d9a);
47
+ $parcel$export($9208a85b3e79d33f$exports, "ToastAction", () => $9208a85b3e79d33f$export$3019feecfda683d2);
48
+ $parcel$export($9208a85b3e79d33f$exports, "ToastClose", () => $9208a85b3e79d33f$export$811e70f61c205839);
49
+ $parcel$export($9208a85b3e79d33f$exports, "Provider", () => $9208a85b3e79d33f$export$2881499e37b75b9a);
50
+ $parcel$export($9208a85b3e79d33f$exports, "Viewport", () => $9208a85b3e79d33f$export$d5c6c08dc2d3ca7);
51
+ $parcel$export($9208a85b3e79d33f$exports, "Root", () => $9208a85b3e79d33f$export$be92b6f5f03c0fe9);
52
+ $parcel$export($9208a85b3e79d33f$exports, "Title", () => $9208a85b3e79d33f$export$f99233281efd08a0);
53
+ $parcel$export($9208a85b3e79d33f$exports, "Description", () => $9208a85b3e79d33f$export$393edc798c47379d);
54
+ $parcel$export($9208a85b3e79d33f$exports, "Action", () => $9208a85b3e79d33f$export$e19cd5f9376f8cee);
55
+ $parcel$export($9208a85b3e79d33f$exports, "Close", () => $9208a85b3e79d33f$export$f39c2d165cd861fe);
56
+
57
+
58
+
59
+
60
+
61
+
62
+
63
+
64
+
65
+
66
+
67
+
68
+
69
+
70
+
71
+ /* -------------------------------------------------------------------------------------------------
72
+ * ToastProvider
73
+ * -----------------------------------------------------------------------------------------------*/ const $9208a85b3e79d33f$var$PROVIDER_NAME = 'ToastProvider';
74
+ const [$9208a85b3e79d33f$var$Collection, $9208a85b3e79d33f$var$useCollection, $9208a85b3e79d33f$var$createCollectionScope] = $iTyic$radixuireactcollection.createCollection('Toast');
75
+ const [$9208a85b3e79d33f$var$createToastContext, $9208a85b3e79d33f$export$8a359da18fbc9073] = $iTyic$radixuireactcontext.createContextScope('Toast', [
76
+ $9208a85b3e79d33f$var$createCollectionScope
77
+ ]);
78
+ const [$9208a85b3e79d33f$var$ToastProviderProvider, $9208a85b3e79d33f$var$useToastProviderContext] = $9208a85b3e79d33f$var$createToastContext($9208a85b3e79d33f$var$PROVIDER_NAME);
79
+ const $9208a85b3e79d33f$export$f5d03d415824e0e = (props)=>{
80
+ const { __scopeToast: __scopeToast , label: label = 'Notification' , duration: duration = 5000 , swipeDirection: swipeDirection = 'right' , swipeThreshold: swipeThreshold = 50 , children: children } = props;
81
+ const [viewport, setViewport] = $iTyic$react.useState(null);
82
+ const [toastCount, setToastCount] = $iTyic$react.useState(0);
83
+ const isFocusedToastEscapeKeyDownRef = $iTyic$react.useRef(false);
84
+ const isClosePausedRef = $iTyic$react.useRef(false);
85
+ return /*#__PURE__*/ $iTyic$react.createElement($9208a85b3e79d33f$var$Collection.Provider, {
86
+ scope: __scopeToast
87
+ }, /*#__PURE__*/ $iTyic$react.createElement($9208a85b3e79d33f$var$ToastProviderProvider, {
88
+ scope: __scopeToast,
89
+ label: label,
90
+ duration: duration,
91
+ swipeDirection: swipeDirection,
92
+ swipeThreshold: swipeThreshold,
93
+ toastCount: toastCount,
94
+ viewport: viewport,
95
+ onViewportChange: setViewport,
96
+ onToastAdd: $iTyic$react.useCallback(()=>setToastCount((prevCount)=>prevCount + 1
97
+ )
98
+ , []),
99
+ onToastRemove: $iTyic$react.useCallback(()=>setToastCount((prevCount)=>prevCount - 1
100
+ )
101
+ , []),
102
+ isFocusedToastEscapeKeyDownRef: isFocusedToastEscapeKeyDownRef,
103
+ isClosePausedRef: isClosePausedRef
104
+ }, children));
105
+ };
106
+ $9208a85b3e79d33f$export$f5d03d415824e0e.propTypes = {
107
+ label (props) {
108
+ if (props.label && typeof props.label === 'string' && !props.label.trim()) {
109
+ const error = `Invalid prop \`label\` supplied to \`${$9208a85b3e79d33f$var$PROVIDER_NAME}\`. Expected non-empty \`string\`.`;
110
+ return new Error(error);
111
+ }
112
+ return null;
113
+ }
114
+ };
115
+ /*#__PURE__*/ Object.assign($9208a85b3e79d33f$export$f5d03d415824e0e, {
116
+ displayName: $9208a85b3e79d33f$var$PROVIDER_NAME
117
+ });
118
+ /* -------------------------------------------------------------------------------------------------
119
+ * ToastViewport
120
+ * -----------------------------------------------------------------------------------------------*/ const $9208a85b3e79d33f$var$VIEWPORT_NAME = 'ToastViewport';
121
+ const $9208a85b3e79d33f$var$VIEWPORT_DEFAULT_HOTKEY = [
122
+ 'F8'
123
+ ];
124
+ const $9208a85b3e79d33f$var$VIEWPORT_PAUSE = 'toast.viewportPause';
125
+ const $9208a85b3e79d33f$var$VIEWPORT_RESUME = 'toast.viewportResume';
126
+ const $9208a85b3e79d33f$export$6192c2425ecfd989 = /*#__PURE__*/ $iTyic$react.forwardRef((props, forwardedRef)=>{
127
+ const { __scopeToast: __scopeToast , hotkey: hotkey = $9208a85b3e79d33f$var$VIEWPORT_DEFAULT_HOTKEY , label: label = 'Notifications ({hotkey})' , ...viewportProps } = props;
128
+ const context = $9208a85b3e79d33f$var$useToastProviderContext($9208a85b3e79d33f$var$VIEWPORT_NAME, __scopeToast);
129
+ const getItems = $9208a85b3e79d33f$var$useCollection(__scopeToast);
130
+ const wrapperRef = $iTyic$react.useRef(null);
131
+ const headFocusProxyRef = $iTyic$react.useRef(null);
132
+ const tailFocusProxyRef = $iTyic$react.useRef(null);
133
+ const ref = $iTyic$react.useRef(null);
134
+ const composedRefs = $iTyic$radixuireactcomposerefs.useComposedRefs(forwardedRef, ref, context.onViewportChange);
135
+ const hotkeyLabel = hotkey.join('+').replace(/Key/g, '').replace(/Digit/g, '');
136
+ const hasToasts = context.toastCount > 0;
137
+ $iTyic$react.useEffect(()=>{
138
+ const handleKeyDown = (event)=>{
139
+ var _ref$current;
140
+ // we use `event.code` as it is consistent regardless of meta keys that were pressed.
141
+ // for example, `event.key` for `Control+Alt+t` is `†` and `t !== †`
142
+ const isHotkeyPressed = hotkey.every((key)=>event[key] || event.code === key
143
+ );
144
+ if (isHotkeyPressed) (_ref$current = ref.current) === null || _ref$current === void 0 || _ref$current.focus();
145
+ };
146
+ document.addEventListener('keydown', handleKeyDown);
147
+ return ()=>document.removeEventListener('keydown', handleKeyDown)
148
+ ;
149
+ }, [
150
+ hotkey
151
+ ]);
152
+ $iTyic$react.useEffect(()=>{
153
+ const wrapper = wrapperRef.current;
154
+ const viewport = ref.current;
155
+ if (wrapper && viewport) {
156
+ const handlePause = ()=>{
157
+ const pauseEvent = new CustomEvent($9208a85b3e79d33f$var$VIEWPORT_PAUSE);
158
+ viewport.dispatchEvent(pauseEvent);
159
+ context.isClosePausedRef.current = true;
160
+ };
161
+ const handleResume = ()=>{
162
+ const resumeEvent = new CustomEvent($9208a85b3e79d33f$var$VIEWPORT_RESUME);
163
+ viewport.dispatchEvent(resumeEvent);
164
+ context.isClosePausedRef.current = false;
165
+ }; // Toasts are not in the viewport React tree so we need to bind DOM events
166
+ wrapper.addEventListener('focusin', handlePause);
167
+ wrapper.addEventListener('focusout', handleResume);
168
+ wrapper.addEventListener('pointerenter', handlePause);
169
+ wrapper.addEventListener('pointerleave', handleResume);
170
+ window.addEventListener('blur', handlePause);
171
+ window.addEventListener('focus', handleResume);
172
+ return ()=>{
173
+ wrapper.removeEventListener('focusin', handlePause);
174
+ wrapper.removeEventListener('focusout', handleResume);
175
+ wrapper.removeEventListener('pointerenter', handlePause);
176
+ wrapper.removeEventListener('pointerleave', handleResume);
177
+ window.removeEventListener('blur', handlePause);
178
+ window.removeEventListener('focus', handleResume);
179
+ };
180
+ }
181
+ }, [
182
+ context.isClosePausedRef
183
+ ]);
184
+ const getSortedTabbableCandidates = $iTyic$react.useCallback(({ tabbingDirection: tabbingDirection })=>{
185
+ const toastItems = getItems();
186
+ const tabbableCandidates = toastItems.map((toastItem)=>{
187
+ const toastNode = toastItem.ref.current;
188
+ const toastTabbableCandidates = [
189
+ toastNode,
190
+ ...$9208a85b3e79d33f$var$getTabbableCandidates(toastNode)
191
+ ];
192
+ return tabbingDirection === 'forwards' ? toastTabbableCandidates : toastTabbableCandidates.reverse();
193
+ });
194
+ return (tabbingDirection === 'forwards' ? tabbableCandidates.reverse() : tabbableCandidates).flat();
195
+ }, [
196
+ getItems
197
+ ]);
198
+ $iTyic$react.useEffect(()=>{
199
+ const viewport = ref.current; // We programmatically manage tabbing as we are unable to influence
200
+ // the source order with portals, this allows us to reverse the
201
+ // tab order so that it runs from most recent toast to least
202
+ if (viewport) {
203
+ const handleKeyDown = (event)=>{
204
+ const isMetaKey = event.altKey || event.ctrlKey || event.metaKey;
205
+ const isTabKey = event.key === 'Tab' && !isMetaKey;
206
+ if (isTabKey) {
207
+ const focusedElement = document.activeElement;
208
+ const isTabbingBackwards = event.shiftKey;
209
+ const targetIsViewport = event.target === viewport; // If we're back tabbing after jumping to the viewport then we simply
210
+ // proxy focus out to the preceding document
211
+ if (targetIsViewport && isTabbingBackwards) {
212
+ var _headFocusProxyRef$cu;
213
+ (_headFocusProxyRef$cu = headFocusProxyRef.current) === null || _headFocusProxyRef$cu === void 0 || _headFocusProxyRef$cu.focus();
214
+ return;
215
+ }
216
+ const tabbingDirection = isTabbingBackwards ? 'backwards' : 'forwards';
217
+ const sortedCandidates = getSortedTabbableCandidates({
218
+ tabbingDirection: tabbingDirection
219
+ });
220
+ const index = sortedCandidates.findIndex((candidate)=>candidate === focusedElement
221
+ );
222
+ if ($9208a85b3e79d33f$var$focusFirst(sortedCandidates.slice(index + 1))) event.preventDefault();
223
+ else {
224
+ var _headFocusProxyRef$cu2, _tailFocusProxyRef$cu;
225
+ // If we can't focus that means we're at the edges so we
226
+ // proxy to the corresponding exit point and let the browser handle
227
+ // tab/shift+tab keypress and implicitly pass focus to the next valid element in the document
228
+ isTabbingBackwards ? (_headFocusProxyRef$cu2 = headFocusProxyRef.current) === null || _headFocusProxyRef$cu2 === void 0 || _headFocusProxyRef$cu2.focus() : (_tailFocusProxyRef$cu = tailFocusProxyRef.current) === null || _tailFocusProxyRef$cu === void 0 || _tailFocusProxyRef$cu.focus();
229
+ }
230
+ }
231
+ }; // Toasts are not in the viewport React tree so we need to bind DOM events
232
+ viewport.addEventListener('keydown', handleKeyDown);
233
+ return ()=>viewport.removeEventListener('keydown', handleKeyDown)
234
+ ;
235
+ }
236
+ }, [
237
+ getItems,
238
+ getSortedTabbableCandidates
239
+ ]);
240
+ return /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactdismissablelayer.Branch, {
241
+ ref: wrapperRef,
242
+ role: "region",
243
+ "aria-label": label.replace('{hotkey}', hotkeyLabel) // Ensure virtual cursor from landmarks menus triggers focus/blur for pause/resume
244
+ ,
245
+ tabIndex: -1 // incase list has size when empty (e.g. padding), we remove pointer events so
246
+ ,
247
+ style: {
248
+ pointerEvents: hasToasts ? undefined : 'none'
249
+ }
250
+ }, hasToasts && /*#__PURE__*/ $iTyic$react.createElement($9208a85b3e79d33f$var$FocusProxy, {
251
+ ref: headFocusProxyRef,
252
+ onFocusFromOutsideViewport: ()=>{
253
+ const tabbableCandidates = getSortedTabbableCandidates({
254
+ tabbingDirection: 'forwards'
255
+ });
256
+ $9208a85b3e79d33f$var$focusFirst(tabbableCandidates);
257
+ }
258
+ }), /*#__PURE__*/ $iTyic$react.createElement($9208a85b3e79d33f$var$Collection.Slot, {
259
+ scope: __scopeToast
260
+ }, /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactprimitive.Primitive.ol, ($parcel$interopDefault($iTyic$babelruntimehelpersextends))({
261
+ tabIndex: -1
262
+ }, viewportProps, {
263
+ ref: composedRefs
264
+ }))), hasToasts && /*#__PURE__*/ $iTyic$react.createElement($9208a85b3e79d33f$var$FocusProxy, {
265
+ ref: tailFocusProxyRef,
266
+ onFocusFromOutsideViewport: ()=>{
267
+ const tabbableCandidates = getSortedTabbableCandidates({
268
+ tabbingDirection: 'backwards'
269
+ });
270
+ $9208a85b3e79d33f$var$focusFirst(tabbableCandidates);
271
+ }
272
+ }));
273
+ });
274
+ /*#__PURE__*/ Object.assign($9208a85b3e79d33f$export$6192c2425ecfd989, {
275
+ displayName: $9208a85b3e79d33f$var$VIEWPORT_NAME
276
+ });
277
+ /* -----------------------------------------------------------------------------------------------*/ const $9208a85b3e79d33f$var$FOCUS_PROXY_NAME = 'ToastFocusProxy';
278
+ const $9208a85b3e79d33f$var$FocusProxy = /*#__PURE__*/ $iTyic$react.forwardRef((props, forwardedRef)=>{
279
+ const { __scopeToast: __scopeToast , onFocusFromOutsideViewport: onFocusFromOutsideViewport , ...proxyProps } = props;
280
+ const context = $9208a85b3e79d33f$var$useToastProviderContext($9208a85b3e79d33f$var$FOCUS_PROXY_NAME, __scopeToast);
281
+ return /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactvisuallyhidden.VisuallyHidden, ($parcel$interopDefault($iTyic$babelruntimehelpersextends))({
282
+ "aria-hidden": true,
283
+ tabIndex: 0
284
+ }, proxyProps, {
285
+ ref: forwardedRef // Avoid page scrolling when focus is on the focus proxy
286
+ ,
287
+ style: {
288
+ position: 'fixed'
289
+ },
290
+ onFocus: (event)=>{
291
+ var _context$viewport;
292
+ const prevFocusedElement = event.relatedTarget;
293
+ const isFocusFromOutsideViewport = !((_context$viewport = context.viewport) !== null && _context$viewport !== void 0 && _context$viewport.contains(prevFocusedElement));
294
+ if (isFocusFromOutsideViewport) onFocusFromOutsideViewport();
295
+ }
296
+ }));
297
+ });
298
+ /*#__PURE__*/ Object.assign($9208a85b3e79d33f$var$FocusProxy, {
299
+ displayName: $9208a85b3e79d33f$var$FOCUS_PROXY_NAME
300
+ });
301
+ /* -------------------------------------------------------------------------------------------------
302
+ * Toast
303
+ * -----------------------------------------------------------------------------------------------*/ const $9208a85b3e79d33f$var$TOAST_NAME = 'Toast';
304
+ const $9208a85b3e79d33f$var$TOAST_SWIPE_START = 'toast.swipeStart';
305
+ const $9208a85b3e79d33f$var$TOAST_SWIPE_MOVE = 'toast.swipeMove';
306
+ const $9208a85b3e79d33f$var$TOAST_SWIPE_CANCEL = 'toast.swipeCancel';
307
+ const $9208a85b3e79d33f$var$TOAST_SWIPE_END = 'toast.swipeEnd';
308
+ const $9208a85b3e79d33f$export$8d8dc7d5f743331b = /*#__PURE__*/ $iTyic$react.forwardRef((props, forwardedRef)=>{
309
+ const { forceMount: forceMount , open: openProp , defaultOpen: defaultOpen , onOpenChange: onOpenChange , ...toastProps } = props;
310
+ const [open = true, setOpen] = $iTyic$radixuireactusecontrollablestate.useControllableState({
311
+ prop: openProp,
312
+ defaultProp: defaultOpen,
313
+ onChange: onOpenChange
314
+ });
315
+ return /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactpresence.Presence, {
316
+ present: forceMount || open
317
+ }, /*#__PURE__*/ $iTyic$react.createElement($9208a85b3e79d33f$var$ToastImpl, ($parcel$interopDefault($iTyic$babelruntimehelpersextends))({
318
+ open: open
319
+ }, toastProps, {
320
+ ref: forwardedRef,
321
+ onClose: ()=>setOpen(false)
322
+ ,
323
+ onSwipeStart: $iTyic$radixuiprimitive.composeEventHandlers(props.onSwipeStart, (event)=>{
324
+ event.currentTarget.setAttribute('data-swipe', 'start');
325
+ }),
326
+ onSwipeMove: $iTyic$radixuiprimitive.composeEventHandlers(props.onSwipeMove, (event)=>{
327
+ const { x: x , y: y } = event.detail.delta;
328
+ event.currentTarget.setAttribute('data-swipe', 'move');
329
+ event.currentTarget.style.setProperty('--radix-toast-swipe-move-x', `${x}px`);
330
+ event.currentTarget.style.setProperty('--radix-toast-swipe-move-y', `${y}px`);
331
+ }),
332
+ onSwipeCancel: $iTyic$radixuiprimitive.composeEventHandlers(props.onSwipeCancel, (event)=>{
333
+ event.currentTarget.setAttribute('data-swipe', 'cancel');
334
+ event.currentTarget.style.removeProperty('--radix-toast-swipe-move-x');
335
+ event.currentTarget.style.removeProperty('--radix-toast-swipe-move-y');
336
+ event.currentTarget.style.removeProperty('--radix-toast-swipe-end-x');
337
+ event.currentTarget.style.removeProperty('--radix-toast-swipe-end-y');
338
+ }),
339
+ onSwipeEnd: $iTyic$radixuiprimitive.composeEventHandlers(props.onSwipeEnd, (event)=>{
340
+ const { x: x , y: y } = event.detail.delta;
341
+ event.currentTarget.setAttribute('data-swipe', 'end');
342
+ event.currentTarget.style.removeProperty('--radix-toast-swipe-move-x');
343
+ event.currentTarget.style.removeProperty('--radix-toast-swipe-move-y');
344
+ event.currentTarget.style.setProperty('--radix-toast-swipe-end-x', `${x}px`);
345
+ event.currentTarget.style.setProperty('--radix-toast-swipe-end-y', `${y}px`);
346
+ setOpen(false);
347
+ })
348
+ })));
349
+ });
350
+ /*#__PURE__*/ Object.assign($9208a85b3e79d33f$export$8d8dc7d5f743331b, {
351
+ displayName: $9208a85b3e79d33f$var$TOAST_NAME
352
+ });
353
+ /* -----------------------------------------------------------------------------------------------*/ const [$9208a85b3e79d33f$var$ToastInteractiveProvider, $9208a85b3e79d33f$var$useToastInteractiveContext] = $9208a85b3e79d33f$var$createToastContext($9208a85b3e79d33f$var$TOAST_NAME, {
354
+ isInteractive: false,
355
+ onClose () {}
356
+ });
357
+ const $9208a85b3e79d33f$var$ToastImpl = /*#__PURE__*/ $iTyic$react.forwardRef((props, forwardedRef)=>{
358
+ const { __scopeToast: __scopeToast , children: children , type: type = 'foreground' , duration: durationProp , open: open , onClose: onClose , onEscapeKeyDown: onEscapeKeyDown , onSwipeStart: onSwipeStart , onSwipeMove: onSwipeMove , onSwipeCancel: onSwipeCancel , onSwipeEnd: onSwipeEnd , ...toastProps } = props;
359
+ const context = $9208a85b3e79d33f$var$useToastProviderContext($9208a85b3e79d33f$var$TOAST_NAME, __scopeToast);
360
+ const ref = $iTyic$react.useRef(null);
361
+ const composedRefs = $iTyic$radixuireactcomposerefs.useComposedRefs(forwardedRef, ref);
362
+ const pointerStartRef = $iTyic$react.useRef(null);
363
+ const swipeDeltaRef = $iTyic$react.useRef(null);
364
+ const duration1 = durationProp || context.duration;
365
+ const closeTimerStartTimeRef = $iTyic$react.useRef(0);
366
+ const closeTimerRemainingTimeRef = $iTyic$react.useRef(duration1);
367
+ const closeTimerRef = $iTyic$react.useRef(0);
368
+ const [renderLabel, setRenderLabel] = $iTyic$react.useState(false);
369
+ const { onToastAdd: onToastAdd , onToastRemove: onToastRemove } = context;
370
+ const handleClose = $iTyic$radixuireactusecallbackref.useCallbackRef(()=>{
371
+ var _ref$current2, _context$viewport2;
372
+ // focus viewport if focus is within toast to read the remaining toast
373
+ // count to SR users and ensure focus isn't lost
374
+ const isFocusInToast = (_ref$current2 = ref.current) === null || _ref$current2 === void 0 ? void 0 : _ref$current2.contains(document.activeElement);
375
+ if (isFocusInToast) (_context$viewport2 = context.viewport) === null || _context$viewport2 === void 0 || _context$viewport2.focus();
376
+ onClose();
377
+ });
378
+ const startTimer = $iTyic$react.useCallback((duration)=>{
379
+ if (!duration || duration === Infinity) return;
380
+ window.clearTimeout(closeTimerRef.current);
381
+ closeTimerStartTimeRef.current = new Date().getTime();
382
+ closeTimerRef.current = window.setTimeout(handleClose, duration);
383
+ }, [
384
+ handleClose
385
+ ]);
386
+ $iTyic$react.useEffect(()=>{
387
+ const viewport = context.viewport;
388
+ if (viewport) {
389
+ const handleResume = ()=>{
390
+ startTimer(closeTimerRemainingTimeRef.current);
391
+ };
392
+ const handlePause = ()=>{
393
+ const elapsedTime = new Date().getTime() - closeTimerStartTimeRef.current;
394
+ closeTimerRemainingTimeRef.current = closeTimerRemainingTimeRef.current - elapsedTime;
395
+ window.clearTimeout(closeTimerRef.current);
396
+ };
397
+ viewport.addEventListener($9208a85b3e79d33f$var$VIEWPORT_PAUSE, handlePause);
398
+ viewport.addEventListener($9208a85b3e79d33f$var$VIEWPORT_RESUME, handleResume);
399
+ return ()=>{
400
+ viewport.removeEventListener($9208a85b3e79d33f$var$VIEWPORT_PAUSE, handlePause);
401
+ viewport.removeEventListener($9208a85b3e79d33f$var$VIEWPORT_RESUME, handleResume);
402
+ };
403
+ }
404
+ }, [
405
+ context.viewport,
406
+ duration1,
407
+ startTimer
408
+ ]); // start timer when toast opens or duration changes.
409
+ // we include `open` in deps because closed !== unmounted when animating
410
+ // so it could reopen before being completely unmounted
411
+ $iTyic$react.useEffect(()=>{
412
+ if (open && !context.isClosePausedRef.current) startTimer(duration1);
413
+ }, [
414
+ open,
415
+ duration1,
416
+ context.isClosePausedRef,
417
+ startTimer
418
+ ]);
419
+ $iTyic$react.useEffect(()=>{
420
+ onToastAdd();
421
+ return ()=>onToastRemove()
422
+ ;
423
+ }, [
424
+ onToastAdd,
425
+ onToastRemove
426
+ ]); // render label in the next frame to trigger toast announcement in NVDA
427
+ $9208a85b3e79d33f$var$useNextFrame(()=>setRenderLabel(true)
428
+ );
429
+ if (!context.viewport) return null;
430
+ return /*#__PURE__*/ $iTyic$react.createElement($iTyic$react.Fragment, null, /*#__PURE__*/ $iTyic$react.createElement($9208a85b3e79d33f$var$ToastInteractiveProvider, {
431
+ scope: __scopeToast,
432
+ isInteractive: true,
433
+ onClose: handleClose
434
+ }, /*#__PURE__*/ $iTyic$reactdom.createPortal(/*#__PURE__*/ $iTyic$react.createElement($9208a85b3e79d33f$var$Collection.ItemSlot, {
435
+ scope: __scopeToast
436
+ }, /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactdismissablelayer.Root, {
437
+ asChild: true,
438
+ onEscapeKeyDown: $iTyic$radixuiprimitive.composeEventHandlers(onEscapeKeyDown, ()=>{
439
+ if (!context.isFocusedToastEscapeKeyDownRef.current) handleClose();
440
+ context.isFocusedToastEscapeKeyDownRef.current = false;
441
+ })
442
+ }, /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactprimitive.Primitive.li, ($parcel$interopDefault($iTyic$babelruntimehelpersextends))({
443
+ role: "status",
444
+ "aria-live": type === 'foreground' ? 'assertive' : 'polite',
445
+ "aria-atomic": true // Prevent voice over from announcing before the label is rendered
446
+ ,
447
+ "aria-hidden": !renderLabel || undefined,
448
+ tabIndex: 0,
449
+ "data-state": open ? 'open' : 'closed',
450
+ "data-swipe-direction": context.swipeDirection
451
+ }, toastProps, {
452
+ ref: composedRefs,
453
+ style: {
454
+ userSelect: 'none',
455
+ touchAction: 'none',
456
+ ...props.style
457
+ },
458
+ onKeyDown: $iTyic$radixuiprimitive.composeEventHandlers(props.onKeyDown, (event)=>{
459
+ if (event.key !== 'Escape') return;
460
+ onEscapeKeyDown === null || onEscapeKeyDown === void 0 || onEscapeKeyDown(event.nativeEvent);
461
+ if (!event.nativeEvent.defaultPrevented) {
462
+ context.isFocusedToastEscapeKeyDownRef.current = true;
463
+ handleClose();
464
+ }
465
+ }),
466
+ onPointerDown: $iTyic$radixuiprimitive.composeEventHandlers(props.onPointerDown, (event)=>{
467
+ if (event.button !== 0) return;
468
+ pointerStartRef.current = {
469
+ x: event.clientX,
470
+ y: event.clientY
471
+ };
472
+ }),
473
+ onPointerMove: $iTyic$radixuiprimitive.composeEventHandlers(props.onPointerMove, (event)=>{
474
+ if (!pointerStartRef.current) return;
475
+ const x = event.clientX - pointerStartRef.current.x;
476
+ const y = event.clientY - pointerStartRef.current.y;
477
+ const hasSwipeMoveStarted = Boolean(swipeDeltaRef.current);
478
+ const isHorizontalSwipe = [
479
+ 'left',
480
+ 'right'
481
+ ].includes(context.swipeDirection);
482
+ const clamp = [
483
+ 'left',
484
+ 'up'
485
+ ].includes(context.swipeDirection) ? Math.min : Math.max;
486
+ const clampedX = isHorizontalSwipe ? clamp(0, x) : 0;
487
+ const clampedY = !isHorizontalSwipe ? clamp(0, y) : 0;
488
+ const moveStartBuffer = event.pointerType === 'touch' ? 10 : 2;
489
+ const delta = {
490
+ x: clampedX,
491
+ y: clampedY
492
+ };
493
+ const eventDetail = {
494
+ originalEvent: event,
495
+ delta: delta
496
+ };
497
+ if (hasSwipeMoveStarted) {
498
+ swipeDeltaRef.current = delta;
499
+ $9208a85b3e79d33f$var$handleAndDispatchCustomEvent($9208a85b3e79d33f$var$TOAST_SWIPE_MOVE, onSwipeMove, eventDetail, {
500
+ discrete: false
501
+ });
502
+ } else if ($9208a85b3e79d33f$var$isDeltaInDirection(delta, context.swipeDirection, moveStartBuffer)) {
503
+ swipeDeltaRef.current = delta;
504
+ $9208a85b3e79d33f$var$handleAndDispatchCustomEvent($9208a85b3e79d33f$var$TOAST_SWIPE_START, onSwipeStart, eventDetail, {
505
+ discrete: false
506
+ });
507
+ event.target.setPointerCapture(event.pointerId);
508
+ } else if (Math.abs(x) > moveStartBuffer || Math.abs(y) > moveStartBuffer) // User is swiping in wrong direction so we disable swipe gesture
509
+ // for the current pointer down interaction
510
+ pointerStartRef.current = null;
511
+ }),
512
+ onPointerUp: $iTyic$radixuiprimitive.composeEventHandlers(props.onPointerUp, (event1)=>{
513
+ const delta = swipeDeltaRef.current;
514
+ event1.target.releasePointerCapture(event1.pointerId);
515
+ swipeDeltaRef.current = null;
516
+ pointerStartRef.current = null;
517
+ if (delta) {
518
+ const toast = event1.currentTarget;
519
+ const eventDetail = {
520
+ originalEvent: event1,
521
+ delta: delta
522
+ };
523
+ if ($9208a85b3e79d33f$var$isDeltaInDirection(delta, context.swipeDirection, context.swipeThreshold)) $9208a85b3e79d33f$var$handleAndDispatchCustomEvent($9208a85b3e79d33f$var$TOAST_SWIPE_END, onSwipeEnd, eventDetail, {
524
+ discrete: true
525
+ });
526
+ else $9208a85b3e79d33f$var$handleAndDispatchCustomEvent($9208a85b3e79d33f$var$TOAST_SWIPE_CANCEL, onSwipeCancel, eventDetail, {
527
+ discrete: true
528
+ });
529
+ // Prevent click event from triggering on items within the toast when
530
+ // pointer up is part of a swipe gesture
531
+ toast.addEventListener('click', (event)=>event.preventDefault()
532
+ , {
533
+ once: true
534
+ });
535
+ }
536
+ })
537
+ }), /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactvisuallyhidden.VisuallyHidden, null, renderLabel && context.label), /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactslot.Slottable, null, children)))), context.viewport)));
538
+ });
539
+ $9208a85b3e79d33f$var$ToastImpl.propTypes = {
540
+ type (props) {
541
+ if (props.type && ![
542
+ 'foreground',
543
+ 'background'
544
+ ].includes(props.type)) {
545
+ const error = `Invalid prop \`type\` supplied to \`${$9208a85b3e79d33f$var$TOAST_NAME}\`. Expected \`foreground | background\`.`;
546
+ return new Error(error);
547
+ }
548
+ return null;
549
+ }
550
+ };
551
+ /* -------------------------------------------------------------------------------------------------
552
+ * ToastTitle
553
+ * -----------------------------------------------------------------------------------------------*/ const $9208a85b3e79d33f$var$TITLE_NAME = 'ToastTitle';
554
+ const $9208a85b3e79d33f$export$16d42d7c29b95a4 = /*#__PURE__*/ $iTyic$react.forwardRef((props, forwardedRef)=>{
555
+ const { __scopeToast: __scopeToast , ...titleProps } = props;
556
+ return /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactprimitive.Primitive.div, ($parcel$interopDefault($iTyic$babelruntimehelpersextends))({}, titleProps, {
557
+ ref: forwardedRef
558
+ }));
559
+ });
560
+ /*#__PURE__*/ Object.assign($9208a85b3e79d33f$export$16d42d7c29b95a4, {
561
+ displayName: $9208a85b3e79d33f$var$TITLE_NAME
562
+ });
563
+ /* -------------------------------------------------------------------------------------------------
564
+ * ToastDescription
565
+ * -----------------------------------------------------------------------------------------------*/ const $9208a85b3e79d33f$var$DESCRIPTION_NAME = 'ToastDescription';
566
+ const $9208a85b3e79d33f$export$ecddd96c53621d9a = /*#__PURE__*/ $iTyic$react.forwardRef((props, forwardedRef)=>{
567
+ const { __scopeToast: __scopeToast , ...descriptionProps } = props;
568
+ return /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactprimitive.Primitive.div, ($parcel$interopDefault($iTyic$babelruntimehelpersextends))({}, descriptionProps, {
569
+ ref: forwardedRef
570
+ }));
571
+ });
572
+ /*#__PURE__*/ Object.assign($9208a85b3e79d33f$export$ecddd96c53621d9a, {
573
+ displayName: $9208a85b3e79d33f$var$DESCRIPTION_NAME
574
+ });
575
+ /* -------------------------------------------------------------------------------------------------
576
+ * ToastAction
577
+ * -----------------------------------------------------------------------------------------------*/ const $9208a85b3e79d33f$var$ACTION_NAME = 'ToastAction';
578
+ const $9208a85b3e79d33f$export$3019feecfda683d2 = /*#__PURE__*/ $iTyic$react.forwardRef((props, forwardedRef)=>{
579
+ const { altText: altText , ...actionProps } = props;
580
+ const context = $9208a85b3e79d33f$var$useToastInteractiveContext($9208a85b3e79d33f$var$ACTION_NAME, props.__scopeToast);
581
+ if (!altText) return null;
582
+ return context.isInteractive ? /*#__PURE__*/ $iTyic$react.createElement($9208a85b3e79d33f$export$811e70f61c205839, ($parcel$interopDefault($iTyic$babelruntimehelpersextends))({}, actionProps, {
583
+ ref: forwardedRef
584
+ })) : /*#__PURE__*/ $iTyic$react.createElement("span", null, altText);
585
+ });
586
+ $9208a85b3e79d33f$export$3019feecfda683d2.propTypes = {
587
+ altText (props) {
588
+ if (!props.altText) return new Error(`Missing prop \`altText\` expected on \`${$9208a85b3e79d33f$var$ACTION_NAME}\``);
589
+ return null;
590
+ }
591
+ };
592
+ /*#__PURE__*/ Object.assign($9208a85b3e79d33f$export$3019feecfda683d2, {
593
+ displayName: $9208a85b3e79d33f$var$ACTION_NAME
594
+ });
595
+ /* -------------------------------------------------------------------------------------------------
596
+ * ToastClose
597
+ * -----------------------------------------------------------------------------------------------*/ const $9208a85b3e79d33f$var$CLOSE_NAME = 'ToastClose';
598
+ const $9208a85b3e79d33f$export$811e70f61c205839 = /*#__PURE__*/ $iTyic$react.forwardRef((props, forwardedRef)=>{
599
+ const { __scopeToast: __scopeToast , ...closeProps } = props;
600
+ const interactiveContext = $9208a85b3e79d33f$var$useToastInteractiveContext($9208a85b3e79d33f$var$CLOSE_NAME, __scopeToast);
601
+ return interactiveContext.isInteractive ? /*#__PURE__*/ $iTyic$react.createElement($iTyic$radixuireactprimitive.Primitive.button, ($parcel$interopDefault($iTyic$babelruntimehelpersextends))({
602
+ type: "button"
603
+ }, closeProps, {
604
+ ref: forwardedRef,
605
+ onClick: $iTyic$radixuiprimitive.composeEventHandlers(props.onClick, interactiveContext.onClose)
606
+ })) : null;
607
+ });
608
+ /*#__PURE__*/ Object.assign($9208a85b3e79d33f$export$811e70f61c205839, {
609
+ displayName: $9208a85b3e79d33f$var$CLOSE_NAME
610
+ });
611
+ /* ---------------------------------------------------------------------------------------------- */ function $9208a85b3e79d33f$var$handleAndDispatchCustomEvent(name, handler, detail, { discrete: discrete }) {
612
+ const currentTarget = detail.originalEvent.currentTarget;
613
+ const event = new CustomEvent(name, {
614
+ bubbles: true,
615
+ cancelable: true,
616
+ detail: detail
617
+ });
618
+ if (handler) currentTarget.addEventListener(name, handler, {
619
+ once: true
620
+ });
621
+ if (discrete) $iTyic$radixuireactprimitive.dispatchDiscreteCustomEvent(currentTarget, event);
622
+ else currentTarget.dispatchEvent(event);
623
+ }
624
+ const $9208a85b3e79d33f$var$isDeltaInDirection = (delta, direction, threshold = 0)=>{
625
+ const deltaX = Math.abs(delta.x);
626
+ const deltaY = Math.abs(delta.y);
627
+ const isDeltaX = deltaX > deltaY;
628
+ if (direction === 'left' || direction === 'right') return isDeltaX && deltaX > threshold;
629
+ else return !isDeltaX && deltaY > threshold;
630
+ };
631
+ function $9208a85b3e79d33f$var$useNextFrame(callback = ()=>{}) {
632
+ const fn = $iTyic$radixuireactusecallbackref.useCallbackRef(callback);
633
+ $iTyic$radixuireactuselayouteffect.useLayoutEffect(()=>{
634
+ let raf1 = 0;
635
+ let raf2 = 0;
636
+ raf1 = window.requestAnimationFrame(()=>raf2 = window.requestAnimationFrame(fn)
637
+ );
638
+ return ()=>{
639
+ window.cancelAnimationFrame(raf1);
640
+ window.cancelAnimationFrame(raf2);
641
+ };
642
+ }, [
643
+ fn
644
+ ]);
645
+ }
646
+ /**
647
+ * Returns a list of potential tabbable candidates.
648
+ *
649
+ * NOTE: This is only a close approximation. For example it doesn't take into account cases like when
650
+ * elements are not visible. This cannot be worked out easily by just reading a property, but rather
651
+ * necessitate runtime knowledge (computed styles, etc). We deal with these cases separately.
652
+ *
653
+ * See: https://developer.mozilla.org/en-US/docs/Web/API/TreeWalker
654
+ * Credit: https://github.com/discord/focus-layers/blob/master/src/util/wrapFocus.tsx#L1
655
+ */ function $9208a85b3e79d33f$var$getTabbableCandidates(container) {
656
+ const nodes = [];
657
+ const walker = document.createTreeWalker(container, NodeFilter.SHOW_ELEMENT, {
658
+ acceptNode: (node)=>{
659
+ const isHiddenInput = node.tagName === 'INPUT' && node.type === 'hidden';
660
+ if (node.disabled || node.hidden || isHiddenInput) return NodeFilter.FILTER_SKIP; // `.tabIndex` is not the same as the `tabindex` attribute. It works on the
661
+ // runtime's understanding of tabbability, so this automatically accounts
662
+ // for any kind of element that could be tabbed to.
663
+ return node.tabIndex >= 0 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;
664
+ }
665
+ });
666
+ while(walker.nextNode())nodes.push(walker.currentNode); // we do not take into account the order of nodes with positive `tabIndex` as it
667
+ // hinders accessibility to have tab order different from visual order.
668
+ return nodes;
669
+ }
670
+ function $9208a85b3e79d33f$var$focusFirst(candidates) {
671
+ const previouslyFocusedElement = document.activeElement;
672
+ return candidates.some((candidate)=>{
673
+ // if focus is already where we want to go, we don't want to keep going through the candidates
674
+ if (candidate === previouslyFocusedElement) return true;
675
+ candidate.focus();
676
+ return document.activeElement !== previouslyFocusedElement;
677
+ });
678
+ }
679
+ const $9208a85b3e79d33f$export$2881499e37b75b9a = $9208a85b3e79d33f$export$f5d03d415824e0e;
680
+ const $9208a85b3e79d33f$export$d5c6c08dc2d3ca7 = $9208a85b3e79d33f$export$6192c2425ecfd989;
681
+ const $9208a85b3e79d33f$export$be92b6f5f03c0fe9 = $9208a85b3e79d33f$export$8d8dc7d5f743331b;
682
+ const $9208a85b3e79d33f$export$f99233281efd08a0 = $9208a85b3e79d33f$export$16d42d7c29b95a4;
683
+ const $9208a85b3e79d33f$export$393edc798c47379d = $9208a85b3e79d33f$export$ecddd96c53621d9a;
684
+ const $9208a85b3e79d33f$export$e19cd5f9376f8cee = $9208a85b3e79d33f$export$3019feecfda683d2;
685
+ const $9208a85b3e79d33f$export$f39c2d165cd861fe = $9208a85b3e79d33f$export$811e70f61c205839;
686
+
687
+
688
+ $parcel$exportWildcard(module.exports, $9208a85b3e79d33f$exports);
689
+
690
+
2
691
  //# sourceMappingURL=index.js.map