@radix-ui/react-toast 1.1.6-rc.6 → 1.2.0-rc.2

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