@sparrowengg/integrations-templates-frontend 8.0.4 → 8.0.5

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.
Files changed (41) hide show
  1. package/dist/cjs/contact-import/components/ContactImportHeader.js +2 -6
  2. package/dist/cjs/contact-import/components/ContactImportHeader.js.map +1 -1
  3. package/dist/cjs/contact-import/index.js +2 -1
  4. package/dist/cjs/contact-import/index.js.map +1 -1
  5. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/hooks/use-toast.js +38 -1
  6. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/hooks/use-toast.js.map +1 -1
  7. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/node_modules/@radix-ui/react-dismissable-layer/dist/index.js +4 -0
  8. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/node_modules/@radix-ui/react-dismissable-layer/dist/index.js.map +1 -1
  9. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/node_modules/@radix-ui/react-toast/dist/index.js +731 -0
  10. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/node_modules/@radix-ui/react-toast/dist/index.js.map +1 -0
  11. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/alert-fill.js +66 -0
  12. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/alert-fill.js.map +1 -0
  13. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/info-fill.js +88 -0
  14. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/info-fill.js.map +1 -0
  15. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/tick-circle-fill.js +66 -0
  16. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/tick-circle-fill.js.map +1 -0
  17. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/toast/toast.js +507 -0
  18. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/toast/toast.js.map +1 -0
  19. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/toast/toastr.js +87 -0
  20. package/dist/cjs/node_modules/@sparrowengg/twigs-react/dist/es/toast/toastr.js.map +1 -0
  21. package/dist/es/contact-import/components/ContactImportHeader.js +2 -6
  22. package/dist/es/contact-import/components/ContactImportHeader.js.map +1 -1
  23. package/dist/es/contact-import/index.js +2 -1
  24. package/dist/es/contact-import/index.js.map +1 -1
  25. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/hooks/use-toast.js +19 -2
  26. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/hooks/use-toast.js.map +1 -1
  27. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/node_modules/@radix-ui/react-dismissable-layer/dist/index.js +3 -1
  28. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/node_modules/@radix-ui/react-dismissable-layer/dist/index.js.map +1 -1
  29. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/node_modules/@radix-ui/react-toast/dist/index.js +696 -0
  30. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/node_modules/@radix-ui/react-toast/dist/index.js.map +1 -0
  31. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/alert-fill.js +64 -0
  32. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/alert-fill.js.map +1 -0
  33. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/info-fill.js +86 -0
  34. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/info-fill.js.map +1 -0
  35. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/tick-circle-fill.js +64 -0
  36. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/packages/react-icons/dist/es/icons/tick-circle-fill.js.map +1 -0
  37. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/toast/toast.js +501 -0
  38. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/toast/toast.js.map +1 -0
  39. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/toast/toastr.js +85 -0
  40. package/dist/es/node_modules/@sparrowengg/twigs-react/dist/es/toast/toastr.js.map +1 -0
  41. package/package.json +1 -1
@@ -0,0 +1,731 @@
1
+ 'use strict';
2
+
3
+ var React = require('react');
4
+ var ReactDOM = require('react-dom');
5
+ var index$6 = require('../../primitive/dist/index.js');
6
+ var index$2 = require('../../react-compose-refs/dist/index.js');
7
+ var index$1 = require('../../react-collection/dist/index.js');
8
+ var index$8 = require('../../react-context/dist/index.js');
9
+ var index$3 = require('../../react-dismissable-layer/dist/index.js');
10
+ var index$a = require('../../react-portal/dist/index.js');
11
+ var index$5 = require('../../react-presence/dist/index.js');
12
+ var index = require('../../react-primitive/dist/index.js');
13
+ var index$7 = require('../../react-use-callback-ref/dist/index.js');
14
+ var index$4 = require('../../react-use-controllable-state/dist/index.js');
15
+ var index$b = require('../../react-use-layout-effect/dist/index.js');
16
+ var index$9 = require('../../react-visually-hidden/dist/index.js');
17
+ var jsxRuntime = require('react/jsx-runtime');
18
+
19
+ function _interopNamespaceDefault(e) {
20
+ var n = Object.create(null);
21
+ if (e) {
22
+ Object.keys(e).forEach(function (k) {
23
+ if (k !== 'default') {
24
+ var d = Object.getOwnPropertyDescriptor(e, k);
25
+ Object.defineProperty(n, k, d.get ? d : {
26
+ enumerable: true,
27
+ get: function () { return e[k]; }
28
+ });
29
+ }
30
+ });
31
+ }
32
+ n.default = e;
33
+ return Object.freeze(n);
34
+ }
35
+
36
+ var React__namespace = /*#__PURE__*/_interopNamespaceDefault(React);
37
+ var ReactDOM__namespace = /*#__PURE__*/_interopNamespaceDefault(ReactDOM);
38
+
39
+ var __defProp = Object.defineProperty;
40
+ var __defProps = Object.defineProperties;
41
+ var __getOwnPropDescs = Object.getOwnPropertyDescriptors;
42
+ var __getOwnPropSymbols = Object.getOwnPropertySymbols;
43
+ var __hasOwnProp = Object.prototype.hasOwnProperty;
44
+ var __propIsEnum = Object.prototype.propertyIsEnumerable;
45
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
46
+ var __spreadValues = (a, b) => {
47
+ for (var prop in b || (b = {}))
48
+ if (__hasOwnProp.call(b, prop))
49
+ __defNormalProp(a, prop, b[prop]);
50
+ if (__getOwnPropSymbols)
51
+ for (var prop of __getOwnPropSymbols(b)) {
52
+ if (__propIsEnum.call(b, prop))
53
+ __defNormalProp(a, prop, b[prop]);
54
+ }
55
+ return a;
56
+ };
57
+ var __spreadProps = (a, b) => __defProps(a, __getOwnPropDescs(b));
58
+ var __objRest = (source, exclude) => {
59
+ var target = {};
60
+ for (var prop in source)
61
+ if (__hasOwnProp.call(source, prop) && exclude.indexOf(prop) < 0)
62
+ target[prop] = source[prop];
63
+ if (source != null && __getOwnPropSymbols)
64
+ for (var prop of __getOwnPropSymbols(source)) {
65
+ if (exclude.indexOf(prop) < 0 && __propIsEnum.call(source, prop))
66
+ target[prop] = source[prop];
67
+ }
68
+ return target;
69
+ };
70
+ var PROVIDER_NAME = "ToastProvider";
71
+ var [Collection, useCollection, createCollectionScope] = index$1.createCollection("Toast");
72
+ var [createToastContext] = index$8.createContextScope("Toast", [createCollectionScope]);
73
+ var [ToastProviderProvider, useToastProviderContext] = createToastContext(PROVIDER_NAME);
74
+ var ToastProvider = (props) => {
75
+ const {
76
+ __scopeToast,
77
+ label = "Notification",
78
+ duration = 5e3,
79
+ swipeDirection = "right",
80
+ swipeThreshold = 50,
81
+ children
82
+ } = props;
83
+ const [viewport, setViewport] = React__namespace.useState(null);
84
+ const [toastCount, setToastCount] = React__namespace.useState(0);
85
+ const isFocusedToastEscapeKeyDownRef = React__namespace.useRef(false);
86
+ const isClosePausedRef = React__namespace.useRef(false);
87
+ if (!label.trim()) {
88
+ console.error(
89
+ `Invalid prop \`label\` supplied to \`${PROVIDER_NAME}\`. Expected non-empty \`string\`.`
90
+ );
91
+ }
92
+ return /* @__PURE__ */ jsxRuntime.jsx(Collection.Provider, { scope: __scopeToast, children: /* @__PURE__ */ jsxRuntime.jsx(
93
+ ToastProviderProvider,
94
+ {
95
+ scope: __scopeToast,
96
+ label,
97
+ duration,
98
+ swipeDirection,
99
+ swipeThreshold,
100
+ toastCount,
101
+ viewport,
102
+ onViewportChange: setViewport,
103
+ onToastAdd: React__namespace.useCallback(() => setToastCount((prevCount) => prevCount + 1), []),
104
+ onToastRemove: React__namespace.useCallback(() => setToastCount((prevCount) => prevCount - 1), []),
105
+ isFocusedToastEscapeKeyDownRef,
106
+ isClosePausedRef,
107
+ children
108
+ }
109
+ ) });
110
+ };
111
+ ToastProvider.displayName = PROVIDER_NAME;
112
+ var VIEWPORT_NAME = "ToastViewport";
113
+ var VIEWPORT_DEFAULT_HOTKEY = ["F8"];
114
+ var VIEWPORT_PAUSE = "toast.viewportPause";
115
+ var VIEWPORT_RESUME = "toast.viewportResume";
116
+ var ToastViewport = React__namespace.forwardRef(
117
+ (props, forwardedRef) => {
118
+ const _a = props, {
119
+ __scopeToast,
120
+ hotkey = VIEWPORT_DEFAULT_HOTKEY,
121
+ label = "Notifications ({hotkey})"
122
+ } = _a, viewportProps = __objRest(_a, [
123
+ "__scopeToast",
124
+ "hotkey",
125
+ "label"
126
+ ]);
127
+ const context = useToastProviderContext(VIEWPORT_NAME, __scopeToast);
128
+ const getItems = useCollection(__scopeToast);
129
+ const wrapperRef = React__namespace.useRef(null);
130
+ const headFocusProxyRef = React__namespace.useRef(null);
131
+ const tailFocusProxyRef = React__namespace.useRef(null);
132
+ const ref = React__namespace.useRef(null);
133
+ const composedRefs = index$2.useComposedRefs(forwardedRef, ref, context.onViewportChange);
134
+ const hotkeyLabel = hotkey.join("+").replace(/Key/g, "").replace(/Digit/g, "");
135
+ const hasToasts = context.toastCount > 0;
136
+ React__namespace.useEffect(() => {
137
+ const handleKeyDown = (event) => {
138
+ var _a2;
139
+ const isHotkeyPressed = hotkey.length !== 0 && hotkey.every((key) => event[key] || event.code === key);
140
+ if (isHotkeyPressed)
141
+ (_a2 = ref.current) == null ? void 0 : _a2.focus();
142
+ };
143
+ document.addEventListener("keydown", handleKeyDown);
144
+ return () => document.removeEventListener("keydown", handleKeyDown);
145
+ }, [hotkey]);
146
+ React__namespace.useEffect(() => {
147
+ const wrapper = wrapperRef.current;
148
+ const viewport = ref.current;
149
+ if (hasToasts && wrapper && viewport) {
150
+ const handlePause = () => {
151
+ if (!context.isClosePausedRef.current) {
152
+ const pauseEvent = new CustomEvent(VIEWPORT_PAUSE);
153
+ viewport.dispatchEvent(pauseEvent);
154
+ context.isClosePausedRef.current = true;
155
+ }
156
+ };
157
+ const handleResume = () => {
158
+ if (context.isClosePausedRef.current) {
159
+ const resumeEvent = new CustomEvent(VIEWPORT_RESUME);
160
+ viewport.dispatchEvent(resumeEvent);
161
+ context.isClosePausedRef.current = false;
162
+ }
163
+ };
164
+ const handleFocusOutResume = (event) => {
165
+ const isFocusMovingOutside = !wrapper.contains(event.relatedTarget);
166
+ if (isFocusMovingOutside)
167
+ handleResume();
168
+ };
169
+ const handlePointerLeaveResume = () => {
170
+ const isFocusInside = wrapper.contains(document.activeElement);
171
+ if (!isFocusInside)
172
+ handleResume();
173
+ };
174
+ wrapper.addEventListener("focusin", handlePause);
175
+ wrapper.addEventListener("focusout", handleFocusOutResume);
176
+ wrapper.addEventListener("pointermove", handlePause);
177
+ wrapper.addEventListener("pointerleave", handlePointerLeaveResume);
178
+ window.addEventListener("blur", handlePause);
179
+ window.addEventListener("focus", handleResume);
180
+ return () => {
181
+ wrapper.removeEventListener("focusin", handlePause);
182
+ wrapper.removeEventListener("focusout", handleFocusOutResume);
183
+ wrapper.removeEventListener("pointermove", handlePause);
184
+ wrapper.removeEventListener("pointerleave", handlePointerLeaveResume);
185
+ window.removeEventListener("blur", handlePause);
186
+ window.removeEventListener("focus", handleResume);
187
+ };
188
+ }
189
+ }, [hasToasts, context.isClosePausedRef]);
190
+ const getSortedTabbableCandidates = React__namespace.useCallback(
191
+ ({ tabbingDirection }) => {
192
+ const toastItems = getItems();
193
+ const tabbableCandidates = toastItems.map((toastItem) => {
194
+ const toastNode = toastItem.ref.current;
195
+ const toastTabbableCandidates = [toastNode, ...getTabbableCandidates(toastNode)];
196
+ return tabbingDirection === "forwards" ? toastTabbableCandidates : toastTabbableCandidates.reverse();
197
+ });
198
+ return (tabbingDirection === "forwards" ? tabbableCandidates.reverse() : tabbableCandidates).flat();
199
+ },
200
+ [getItems]
201
+ );
202
+ React__namespace.useEffect(() => {
203
+ const viewport = ref.current;
204
+ if (viewport) {
205
+ const handleKeyDown = (event) => {
206
+ var _a2, _b, _c;
207
+ const isMetaKey = event.altKey || event.ctrlKey || event.metaKey;
208
+ const isTabKey = event.key === "Tab" && !isMetaKey;
209
+ if (isTabKey) {
210
+ const focusedElement = document.activeElement;
211
+ const isTabbingBackwards = event.shiftKey;
212
+ const targetIsViewport = event.target === viewport;
213
+ if (targetIsViewport && isTabbingBackwards) {
214
+ (_a2 = headFocusProxyRef.current) == null ? void 0 : _a2.focus();
215
+ return;
216
+ }
217
+ const tabbingDirection = isTabbingBackwards ? "backwards" : "forwards";
218
+ const sortedCandidates = getSortedTabbableCandidates({ tabbingDirection });
219
+ const index = sortedCandidates.findIndex((candidate) => candidate === focusedElement);
220
+ if (focusFirst(sortedCandidates.slice(index + 1))) {
221
+ event.preventDefault();
222
+ } else {
223
+ isTabbingBackwards ? (_b = headFocusProxyRef.current) == null ? void 0 : _b.focus() : (_c = tailFocusProxyRef.current) == null ? void 0 : _c.focus();
224
+ }
225
+ }
226
+ };
227
+ viewport.addEventListener("keydown", handleKeyDown);
228
+ return () => viewport.removeEventListener("keydown", handleKeyDown);
229
+ }
230
+ }, [getItems, getSortedTabbableCandidates]);
231
+ return /* @__PURE__ */ jsxRuntime.jsxs(
232
+ index$3.Branch,
233
+ {
234
+ ref: wrapperRef,
235
+ role: "region",
236
+ "aria-label": label.replace("{hotkey}", hotkeyLabel),
237
+ tabIndex: -1,
238
+ style: { pointerEvents: hasToasts ? void 0 : "none" },
239
+ children: [
240
+ hasToasts && /* @__PURE__ */ jsxRuntime.jsx(
241
+ FocusProxy,
242
+ {
243
+ ref: headFocusProxyRef,
244
+ onFocusFromOutsideViewport: () => {
245
+ const tabbableCandidates = getSortedTabbableCandidates({
246
+ tabbingDirection: "forwards"
247
+ });
248
+ focusFirst(tabbableCandidates);
249
+ }
250
+ }
251
+ ),
252
+ /* @__PURE__ */ jsxRuntime.jsx(Collection.Slot, { scope: __scopeToast, children: /* @__PURE__ */ jsxRuntime.jsx(index.Primitive.ol, __spreadProps(__spreadValues({ tabIndex: -1 }, viewportProps), { ref: composedRefs })) }),
253
+ hasToasts && /* @__PURE__ */ jsxRuntime.jsx(
254
+ FocusProxy,
255
+ {
256
+ ref: tailFocusProxyRef,
257
+ onFocusFromOutsideViewport: () => {
258
+ const tabbableCandidates = getSortedTabbableCandidates({
259
+ tabbingDirection: "backwards"
260
+ });
261
+ focusFirst(tabbableCandidates);
262
+ }
263
+ }
264
+ )
265
+ ]
266
+ }
267
+ );
268
+ }
269
+ );
270
+ ToastViewport.displayName = VIEWPORT_NAME;
271
+ var FOCUS_PROXY_NAME = "ToastFocusProxy";
272
+ var FocusProxy = React__namespace.forwardRef(
273
+ (props, forwardedRef) => {
274
+ const _a = props, { __scopeToast, onFocusFromOutsideViewport } = _a, proxyProps = __objRest(_a, ["__scopeToast", "onFocusFromOutsideViewport"]);
275
+ const context = useToastProviderContext(FOCUS_PROXY_NAME, __scopeToast);
276
+ return /* @__PURE__ */ jsxRuntime.jsx(
277
+ index$9.VisuallyHidden,
278
+ __spreadProps(__spreadValues({
279
+ tabIndex: 0
280
+ }, proxyProps), {
281
+ ref: forwardedRef,
282
+ style: { position: "fixed" },
283
+ onFocus: (event) => {
284
+ var _a2;
285
+ const prevFocusedElement = event.relatedTarget;
286
+ const isFocusFromOutsideViewport = !((_a2 = context.viewport) == null ? void 0 : _a2.contains(prevFocusedElement));
287
+ if (isFocusFromOutsideViewport)
288
+ onFocusFromOutsideViewport();
289
+ }
290
+ })
291
+ );
292
+ }
293
+ );
294
+ FocusProxy.displayName = FOCUS_PROXY_NAME;
295
+ var TOAST_NAME = "Toast";
296
+ var TOAST_SWIPE_START = "toast.swipeStart";
297
+ var TOAST_SWIPE_MOVE = "toast.swipeMove";
298
+ var TOAST_SWIPE_CANCEL = "toast.swipeCancel";
299
+ var TOAST_SWIPE_END = "toast.swipeEnd";
300
+ var Toast = React__namespace.forwardRef(
301
+ (props, forwardedRef) => {
302
+ const _a = props, { forceMount, open: openProp, defaultOpen, onOpenChange } = _a, toastProps = __objRest(_a, ["forceMount", "open", "defaultOpen", "onOpenChange"]);
303
+ const [open, setOpen] = index$4.useControllableState({
304
+ prop: openProp,
305
+ defaultProp: defaultOpen != null ? defaultOpen : true,
306
+ onChange: onOpenChange,
307
+ caller: TOAST_NAME
308
+ });
309
+ return /* @__PURE__ */ jsxRuntime.jsx(index$5.Presence, { present: forceMount || open, children: /* @__PURE__ */ jsxRuntime.jsx(
310
+ ToastImpl,
311
+ __spreadProps(__spreadValues({
312
+ open
313
+ }, toastProps), {
314
+ ref: forwardedRef,
315
+ onClose: () => setOpen(false),
316
+ onPause: index$7.useCallbackRef(props.onPause),
317
+ onResume: index$7.useCallbackRef(props.onResume),
318
+ onSwipeStart: index$6.composeEventHandlers(props.onSwipeStart, (event) => {
319
+ event.currentTarget.setAttribute("data-swipe", "start");
320
+ }),
321
+ onSwipeMove: index$6.composeEventHandlers(props.onSwipeMove, (event) => {
322
+ const { x, y } = event.detail.delta;
323
+ event.currentTarget.setAttribute("data-swipe", "move");
324
+ event.currentTarget.style.setProperty("--radix-toast-swipe-move-x", `${x}px`);
325
+ event.currentTarget.style.setProperty("--radix-toast-swipe-move-y", `${y}px`);
326
+ }),
327
+ onSwipeCancel: index$6.composeEventHandlers(props.onSwipeCancel, (event) => {
328
+ event.currentTarget.setAttribute("data-swipe", "cancel");
329
+ event.currentTarget.style.removeProperty("--radix-toast-swipe-move-x");
330
+ event.currentTarget.style.removeProperty("--radix-toast-swipe-move-y");
331
+ event.currentTarget.style.removeProperty("--radix-toast-swipe-end-x");
332
+ event.currentTarget.style.removeProperty("--radix-toast-swipe-end-y");
333
+ }),
334
+ onSwipeEnd: index$6.composeEventHandlers(props.onSwipeEnd, (event) => {
335
+ const { x, y } = event.detail.delta;
336
+ event.currentTarget.setAttribute("data-swipe", "end");
337
+ event.currentTarget.style.removeProperty("--radix-toast-swipe-move-x");
338
+ event.currentTarget.style.removeProperty("--radix-toast-swipe-move-y");
339
+ event.currentTarget.style.setProperty("--radix-toast-swipe-end-x", `${x}px`);
340
+ event.currentTarget.style.setProperty("--radix-toast-swipe-end-y", `${y}px`);
341
+ setOpen(false);
342
+ })
343
+ })
344
+ ) });
345
+ }
346
+ );
347
+ Toast.displayName = TOAST_NAME;
348
+ var [ToastInteractiveProvider, useToastInteractiveContext] = createToastContext(TOAST_NAME, {
349
+ onClose() {
350
+ }
351
+ });
352
+ var ToastImpl = React__namespace.forwardRef(
353
+ (props, forwardedRef) => {
354
+ const _a = props, {
355
+ __scopeToast,
356
+ type = "foreground",
357
+ duration: durationProp,
358
+ open,
359
+ onClose,
360
+ onEscapeKeyDown,
361
+ onPause,
362
+ onResume,
363
+ onSwipeStart,
364
+ onSwipeMove,
365
+ onSwipeCancel,
366
+ onSwipeEnd
367
+ } = _a, toastProps = __objRest(_a, [
368
+ "__scopeToast",
369
+ "type",
370
+ "duration",
371
+ "open",
372
+ "onClose",
373
+ "onEscapeKeyDown",
374
+ "onPause",
375
+ "onResume",
376
+ "onSwipeStart",
377
+ "onSwipeMove",
378
+ "onSwipeCancel",
379
+ "onSwipeEnd"
380
+ ]);
381
+ const context = useToastProviderContext(TOAST_NAME, __scopeToast);
382
+ const [node, setNode] = React__namespace.useState(null);
383
+ const composedRefs = index$2.useComposedRefs(forwardedRef, (node2) => setNode(node2));
384
+ const pointerStartRef = React__namespace.useRef(null);
385
+ const swipeDeltaRef = React__namespace.useRef(null);
386
+ const duration = durationProp || context.duration;
387
+ const closeTimerStartTimeRef = React__namespace.useRef(0);
388
+ const closeTimerRemainingTimeRef = React__namespace.useRef(duration);
389
+ const closeTimerRef = React__namespace.useRef(0);
390
+ const { onToastAdd, onToastRemove } = context;
391
+ const handleClose = index$7.useCallbackRef(() => {
392
+ var _a2;
393
+ const isFocusInToast = node == null ? void 0 : node.contains(document.activeElement);
394
+ if (isFocusInToast)
395
+ (_a2 = context.viewport) == null ? void 0 : _a2.focus();
396
+ onClose();
397
+ });
398
+ const startTimer = React__namespace.useCallback(
399
+ (duration2) => {
400
+ if (!duration2 || duration2 === Infinity)
401
+ return;
402
+ window.clearTimeout(closeTimerRef.current);
403
+ closeTimerStartTimeRef.current = (/* @__PURE__ */ new Date()).getTime();
404
+ closeTimerRef.current = window.setTimeout(handleClose, duration2);
405
+ },
406
+ [handleClose]
407
+ );
408
+ React__namespace.useEffect(() => {
409
+ const viewport = context.viewport;
410
+ if (viewport) {
411
+ const handleResume = () => {
412
+ startTimer(closeTimerRemainingTimeRef.current);
413
+ onResume == null ? void 0 : onResume();
414
+ };
415
+ const handlePause = () => {
416
+ const elapsedTime = (/* @__PURE__ */ new Date()).getTime() - closeTimerStartTimeRef.current;
417
+ closeTimerRemainingTimeRef.current = closeTimerRemainingTimeRef.current - elapsedTime;
418
+ window.clearTimeout(closeTimerRef.current);
419
+ onPause == null ? void 0 : onPause();
420
+ };
421
+ viewport.addEventListener(VIEWPORT_PAUSE, handlePause);
422
+ viewport.addEventListener(VIEWPORT_RESUME, handleResume);
423
+ return () => {
424
+ viewport.removeEventListener(VIEWPORT_PAUSE, handlePause);
425
+ viewport.removeEventListener(VIEWPORT_RESUME, handleResume);
426
+ };
427
+ }
428
+ }, [context.viewport, duration, onPause, onResume, startTimer]);
429
+ React__namespace.useEffect(() => {
430
+ if (open && !context.isClosePausedRef.current)
431
+ startTimer(duration);
432
+ }, [open, duration, context.isClosePausedRef, startTimer]);
433
+ React__namespace.useEffect(() => {
434
+ onToastAdd();
435
+ return () => onToastRemove();
436
+ }, [onToastAdd, onToastRemove]);
437
+ const announceTextContent = React__namespace.useMemo(() => {
438
+ return node ? getAnnounceTextContent(node) : null;
439
+ }, [node]);
440
+ if (!context.viewport)
441
+ return null;
442
+ return /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
443
+ announceTextContent && /* @__PURE__ */ jsxRuntime.jsx(
444
+ ToastAnnounce,
445
+ {
446
+ __scopeToast,
447
+ role: "status",
448
+ "aria-live": type === "foreground" ? "assertive" : "polite",
449
+ children: announceTextContent
450
+ }
451
+ ),
452
+ /* @__PURE__ */ jsxRuntime.jsx(ToastInteractiveProvider, { scope: __scopeToast, onClose: handleClose, children: ReactDOM__namespace.createPortal(
453
+ /* @__PURE__ */ jsxRuntime.jsx(Collection.ItemSlot, { scope: __scopeToast, children: /* @__PURE__ */ jsxRuntime.jsx(
454
+ index$3.Root,
455
+ {
456
+ asChild: true,
457
+ onEscapeKeyDown: index$6.composeEventHandlers(onEscapeKeyDown, () => {
458
+ if (!context.isFocusedToastEscapeKeyDownRef.current)
459
+ handleClose();
460
+ context.isFocusedToastEscapeKeyDownRef.current = false;
461
+ }),
462
+ children: /* @__PURE__ */ jsxRuntime.jsx(
463
+ index.Primitive.li,
464
+ __spreadProps(__spreadValues({
465
+ tabIndex: 0,
466
+ "data-state": open ? "open" : "closed",
467
+ "data-swipe-direction": context.swipeDirection
468
+ }, toastProps), {
469
+ ref: composedRefs,
470
+ style: __spreadValues({ userSelect: "none", touchAction: "none" }, props.style),
471
+ onKeyDown: index$6.composeEventHandlers(props.onKeyDown, (event) => {
472
+ if (event.key !== "Escape")
473
+ return;
474
+ onEscapeKeyDown == null ? void 0 : onEscapeKeyDown(event.nativeEvent);
475
+ if (!event.nativeEvent.defaultPrevented) {
476
+ context.isFocusedToastEscapeKeyDownRef.current = true;
477
+ handleClose();
478
+ }
479
+ }),
480
+ onPointerDown: index$6.composeEventHandlers(props.onPointerDown, (event) => {
481
+ if (event.button !== 0)
482
+ return;
483
+ pointerStartRef.current = { x: event.clientX, y: event.clientY };
484
+ }),
485
+ onPointerMove: index$6.composeEventHandlers(props.onPointerMove, (event) => {
486
+ if (!pointerStartRef.current)
487
+ return;
488
+ const x = event.clientX - pointerStartRef.current.x;
489
+ const y = event.clientY - pointerStartRef.current.y;
490
+ const hasSwipeMoveStarted = Boolean(swipeDeltaRef.current);
491
+ const isHorizontalSwipe = ["left", "right"].includes(context.swipeDirection);
492
+ const clamp = ["left", "up"].includes(context.swipeDirection) ? Math.min : Math.max;
493
+ const clampedX = isHorizontalSwipe ? clamp(0, x) : 0;
494
+ const clampedY = !isHorizontalSwipe ? clamp(0, y) : 0;
495
+ const moveStartBuffer = event.pointerType === "touch" ? 10 : 2;
496
+ const delta = { x: clampedX, y: clampedY };
497
+ const eventDetail = { originalEvent: event, delta };
498
+ if (hasSwipeMoveStarted) {
499
+ swipeDeltaRef.current = delta;
500
+ handleAndDispatchCustomEvent(TOAST_SWIPE_MOVE, onSwipeMove, eventDetail, {
501
+ discrete: false
502
+ });
503
+ } else if (isDeltaInDirection(delta, context.swipeDirection, moveStartBuffer)) {
504
+ swipeDeltaRef.current = delta;
505
+ handleAndDispatchCustomEvent(TOAST_SWIPE_START, onSwipeStart, eventDetail, {
506
+ discrete: false
507
+ });
508
+ event.target.setPointerCapture(event.pointerId);
509
+ } else if (Math.abs(x) > moveStartBuffer || Math.abs(y) > moveStartBuffer) {
510
+ pointerStartRef.current = null;
511
+ }
512
+ }),
513
+ onPointerUp: index$6.composeEventHandlers(props.onPointerUp, (event) => {
514
+ const delta = swipeDeltaRef.current;
515
+ const target = event.target;
516
+ if (target.hasPointerCapture(event.pointerId)) {
517
+ target.releasePointerCapture(event.pointerId);
518
+ }
519
+ swipeDeltaRef.current = null;
520
+ pointerStartRef.current = null;
521
+ if (delta) {
522
+ const toast = event.currentTarget;
523
+ const eventDetail = { originalEvent: event, delta };
524
+ if (isDeltaInDirection(delta, context.swipeDirection, context.swipeThreshold)) {
525
+ handleAndDispatchCustomEvent(TOAST_SWIPE_END, onSwipeEnd, eventDetail, {
526
+ discrete: true
527
+ });
528
+ } else {
529
+ handleAndDispatchCustomEvent(
530
+ TOAST_SWIPE_CANCEL,
531
+ onSwipeCancel,
532
+ eventDetail,
533
+ {
534
+ discrete: true
535
+ }
536
+ );
537
+ }
538
+ toast.addEventListener("click", (event2) => event2.preventDefault(), {
539
+ once: true
540
+ });
541
+ }
542
+ })
543
+ })
544
+ )
545
+ }
546
+ ) }),
547
+ context.viewport
548
+ ) })
549
+ ] });
550
+ }
551
+ );
552
+ var ToastAnnounce = (props) => {
553
+ const _a = props, { __scopeToast, children } = _a, announceProps = __objRest(_a, ["__scopeToast", "children"]);
554
+ const context = useToastProviderContext(TOAST_NAME, __scopeToast);
555
+ const [renderAnnounceText, setRenderAnnounceText] = React__namespace.useState(false);
556
+ const [isAnnounced, setIsAnnounced] = React__namespace.useState(false);
557
+ useNextFrame(() => setRenderAnnounceText(true));
558
+ React__namespace.useEffect(() => {
559
+ const timer = window.setTimeout(() => setIsAnnounced(true), 1e3);
560
+ return () => window.clearTimeout(timer);
561
+ }, []);
562
+ return isAnnounced ? null : /* @__PURE__ */ jsxRuntime.jsx(index$a.Portal, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(index$9.VisuallyHidden, __spreadProps(__spreadValues({}, announceProps), { children: renderAnnounceText && /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
563
+ context.label,
564
+ " ",
565
+ children
566
+ ] }) })) });
567
+ };
568
+ var TITLE_NAME = "ToastTitle";
569
+ var ToastTitle = React__namespace.forwardRef(
570
+ (props, forwardedRef) => {
571
+ const _a = props, { __scopeToast } = _a, titleProps = __objRest(_a, ["__scopeToast"]);
572
+ return /* @__PURE__ */ jsxRuntime.jsx(index.Primitive.div, __spreadProps(__spreadValues({}, titleProps), { ref: forwardedRef }));
573
+ }
574
+ );
575
+ ToastTitle.displayName = TITLE_NAME;
576
+ var DESCRIPTION_NAME = "ToastDescription";
577
+ var ToastDescription = React__namespace.forwardRef(
578
+ (props, forwardedRef) => {
579
+ const _a = props, { __scopeToast } = _a, descriptionProps = __objRest(_a, ["__scopeToast"]);
580
+ return /* @__PURE__ */ jsxRuntime.jsx(index.Primitive.div, __spreadProps(__spreadValues({}, descriptionProps), { ref: forwardedRef }));
581
+ }
582
+ );
583
+ ToastDescription.displayName = DESCRIPTION_NAME;
584
+ var ACTION_NAME = "ToastAction";
585
+ var ToastAction = React__namespace.forwardRef(
586
+ (props, forwardedRef) => {
587
+ const _a = props, { altText } = _a, actionProps = __objRest(_a, ["altText"]);
588
+ if (!altText.trim()) {
589
+ console.error(
590
+ `Invalid prop \`altText\` supplied to \`${ACTION_NAME}\`. Expected non-empty \`string\`.`
591
+ );
592
+ return null;
593
+ }
594
+ return /* @__PURE__ */ jsxRuntime.jsx(ToastAnnounceExclude, { altText, asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(ToastClose, __spreadProps(__spreadValues({}, actionProps), { ref: forwardedRef })) });
595
+ }
596
+ );
597
+ ToastAction.displayName = ACTION_NAME;
598
+ var CLOSE_NAME = "ToastClose";
599
+ var ToastClose = React__namespace.forwardRef(
600
+ (props, forwardedRef) => {
601
+ const _a = props, { __scopeToast } = _a, closeProps = __objRest(_a, ["__scopeToast"]);
602
+ const interactiveContext = useToastInteractiveContext(CLOSE_NAME, __scopeToast);
603
+ return /* @__PURE__ */ jsxRuntime.jsx(ToastAnnounceExclude, { asChild: true, children: /* @__PURE__ */ jsxRuntime.jsx(
604
+ index.Primitive.button,
605
+ __spreadProps(__spreadValues({
606
+ type: "button"
607
+ }, closeProps), {
608
+ ref: forwardedRef,
609
+ onClick: index$6.composeEventHandlers(props.onClick, interactiveContext.onClose)
610
+ })
611
+ ) });
612
+ }
613
+ );
614
+ ToastClose.displayName = CLOSE_NAME;
615
+ var ToastAnnounceExclude = React__namespace.forwardRef((props, forwardedRef) => {
616
+ const _a = props, { __scopeToast, altText } = _a, announceExcludeProps = __objRest(_a, ["__scopeToast", "altText"]);
617
+ return /* @__PURE__ */ jsxRuntime.jsx(
618
+ index.Primitive.div,
619
+ __spreadProps(__spreadValues({
620
+ "data-radix-toast-announce-exclude": "",
621
+ "data-radix-toast-announce-alt": altText || void 0
622
+ }, announceExcludeProps), {
623
+ ref: forwardedRef
624
+ })
625
+ );
626
+ });
627
+ function getAnnounceTextContent(container) {
628
+ const textContent = [];
629
+ const childNodes = Array.from(container.childNodes);
630
+ childNodes.forEach((node) => {
631
+ if (node.nodeType === node.TEXT_NODE && node.textContent)
632
+ textContent.push(node.textContent);
633
+ if (isHTMLElement(node)) {
634
+ const isHidden = node.ariaHidden || node.hidden || node.style.display === "none";
635
+ const isExcluded = node.dataset.radixToastAnnounceExclude === "";
636
+ if (!isHidden) {
637
+ if (isExcluded) {
638
+ const altText = node.dataset.radixToastAnnounceAlt;
639
+ if (altText)
640
+ textContent.push(altText);
641
+ } else {
642
+ textContent.push(...getAnnounceTextContent(node));
643
+ }
644
+ }
645
+ }
646
+ });
647
+ return textContent;
648
+ }
649
+ function handleAndDispatchCustomEvent(name, handler, detail, { discrete }) {
650
+ const currentTarget = detail.originalEvent.currentTarget;
651
+ const event = new CustomEvent(name, { bubbles: true, cancelable: true, detail });
652
+ if (handler)
653
+ currentTarget.addEventListener(name, handler, { once: true });
654
+ if (discrete) {
655
+ index.dispatchDiscreteCustomEvent(currentTarget, event);
656
+ } else {
657
+ currentTarget.dispatchEvent(event);
658
+ }
659
+ }
660
+ var isDeltaInDirection = (delta, direction, threshold = 0) => {
661
+ const deltaX = Math.abs(delta.x);
662
+ const deltaY = Math.abs(delta.y);
663
+ const isDeltaX = deltaX > deltaY;
664
+ if (direction === "left" || direction === "right") {
665
+ return isDeltaX && deltaX > threshold;
666
+ } else {
667
+ return !isDeltaX && deltaY > threshold;
668
+ }
669
+ };
670
+ function useNextFrame(callback = () => {
671
+ }) {
672
+ const fn = index$7.useCallbackRef(callback);
673
+ index$b.useLayoutEffect(() => {
674
+ let raf1 = 0;
675
+ let raf2 = 0;
676
+ raf1 = window.requestAnimationFrame(() => raf2 = window.requestAnimationFrame(fn));
677
+ return () => {
678
+ window.cancelAnimationFrame(raf1);
679
+ window.cancelAnimationFrame(raf2);
680
+ };
681
+ }, [fn]);
682
+ }
683
+ function isHTMLElement(node) {
684
+ return node.nodeType === node.ELEMENT_NODE;
685
+ }
686
+ function getTabbableCandidates(container) {
687
+ const nodes = [];
688
+ const walker = document.createTreeWalker(container, NodeFilter.SHOW_ELEMENT, {
689
+ acceptNode: (node) => {
690
+ const isHiddenInput = node.tagName === "INPUT" && node.type === "hidden";
691
+ if (node.disabled || node.hidden || isHiddenInput)
692
+ return NodeFilter.FILTER_SKIP;
693
+ return node.tabIndex >= 0 ? NodeFilter.FILTER_ACCEPT : NodeFilter.FILTER_SKIP;
694
+ }
695
+ });
696
+ while (walker.nextNode())
697
+ nodes.push(walker.currentNode);
698
+ return nodes;
699
+ }
700
+ function focusFirst(candidates) {
701
+ const previouslyFocusedElement = document.activeElement;
702
+ return candidates.some((candidate) => {
703
+ if (candidate === previouslyFocusedElement)
704
+ return true;
705
+ candidate.focus();
706
+ return document.activeElement !== previouslyFocusedElement;
707
+ });
708
+ }
709
+ var Provider = ToastProvider;
710
+ var Viewport = ToastViewport;
711
+ var Root2 = Toast;
712
+ var Title = ToastTitle;
713
+ var Description = ToastDescription;
714
+ var Action = ToastAction;
715
+ var Close = ToastClose;
716
+
717
+ exports.Action = Action;
718
+ exports.Close = Close;
719
+ exports.Description = Description;
720
+ exports.Provider = Provider;
721
+ exports.Root = Root2;
722
+ exports.Title = Title;
723
+ exports.Toast = Toast;
724
+ exports.ToastAction = ToastAction;
725
+ exports.ToastClose = ToastClose;
726
+ exports.ToastDescription = ToastDescription;
727
+ exports.ToastProvider = ToastProvider;
728
+ exports.ToastTitle = ToastTitle;
729
+ exports.ToastViewport = ToastViewport;
730
+ exports.Viewport = Viewport;
731
+ //# sourceMappingURL=index.js.map