shared-features 0.0.4 → 0.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 (90) hide show
  1. package/dist/{AdBanner-CZz8trdz.cjs → AnnouncementModal-Bqy0pn3V.cjs} +428 -3
  2. package/dist/AnnouncementModal-Bqy0pn3V.cjs.map +1 -0
  3. package/dist/{AdBanner-DF1QuMxR.js → AnnouncementModal-sxH4K5gy.js} +430 -5
  4. package/dist/AnnouncementModal-sxH4K5gy.js.map +1 -0
  5. package/dist/admin-notifications-D9n9h-eY.cjs +362 -0
  6. package/dist/admin-notifications-D9n9h-eY.cjs.map +1 -0
  7. package/dist/admin-notifications-p1dy3zIP.js +363 -0
  8. package/dist/admin-notifications-p1dy3zIP.js.map +1 -0
  9. package/dist/{analytics-CdpCtTpu.js → analytics-40-S_fHC.js} +3 -2
  10. package/dist/{analytics-CdpCtTpu.js.map → analytics-40-S_fHC.js.map} +1 -1
  11. package/dist/{analytics--ZSO9ova.cjs → analytics-lEzOx2vl.cjs} +2 -1
  12. package/dist/{analytics--ZSO9ova.cjs.map → analytics-lEzOx2vl.cjs.map} +1 -1
  13. package/dist/broadcasts-3_WfQMNL.cjs +278 -0
  14. package/dist/broadcasts-3_WfQMNL.cjs.map +1 -0
  15. package/dist/broadcasts-DgZUzqMf.js +257 -0
  16. package/dist/broadcasts-DgZUzqMf.js.map +1 -0
  17. package/dist/components/index.cjs +23 -20
  18. package/dist/components/index.cjs.map +1 -1
  19. package/dist/components/index.d.ts +1 -0
  20. package/dist/components/index.d.ts.map +1 -1
  21. package/dist/components/index.js +4 -1
  22. package/dist/components/notifications/AnnouncementModal.d.ts +21 -0
  23. package/dist/components/notifications/AnnouncementModal.d.ts.map +1 -0
  24. package/dist/components/notifications/BroadcastBanner.d.ts +55 -0
  25. package/dist/components/notifications/BroadcastBanner.d.ts.map +1 -0
  26. package/dist/components/notifications/index.d.ts +11 -0
  27. package/dist/components/notifications/index.d.ts.map +1 -0
  28. package/dist/hooks/index.cjs +9 -1
  29. package/dist/hooks/index.cjs.map +1 -1
  30. package/dist/hooks/index.d.ts +2 -0
  31. package/dist/hooks/index.d.ts.map +1 -1
  32. package/dist/hooks/index.js +9 -1
  33. package/dist/hooks/index.js.map +1 -1
  34. package/dist/hooks/useBroadcasts.d.ts +122 -0
  35. package/dist/hooks/useBroadcasts.d.ts.map +1 -0
  36. package/dist/index.cjs +99 -22
  37. package/dist/index.cjs.map +1 -1
  38. package/dist/index.d.ts +2 -0
  39. package/dist/index.d.ts.map +1 -1
  40. package/dist/index.js +94 -17
  41. package/dist/index.js.map +1 -1
  42. package/dist/notifications/events/index.d.ts +14 -0
  43. package/dist/notifications/events/index.d.ts.map +1 -0
  44. package/dist/notifications/events/registry.d.ts +75 -0
  45. package/dist/notifications/events/registry.d.ts.map +1 -0
  46. package/dist/notifications/events/templates/engine.d.ts +57 -0
  47. package/dist/notifications/events/templates/engine.d.ts.map +1 -0
  48. package/dist/notifications/events/templates/standard.d.ts +20 -0
  49. package/dist/notifications/events/templates/standard.d.ts.map +1 -0
  50. package/dist/notifications/events/useNotificationEvents.d.ts +36 -0
  51. package/dist/notifications/events/useNotificationEvents.d.ts.map +1 -0
  52. package/dist/notifications/index.cjs +25 -0
  53. package/dist/notifications/index.cjs.map +1 -0
  54. package/dist/notifications/index.d.ts +9 -0
  55. package/dist/notifications/index.d.ts.map +1 -0
  56. package/dist/notifications/index.js +25 -0
  57. package/dist/notifications/index.js.map +1 -0
  58. package/dist/services/admin-notifications.d.ts +95 -0
  59. package/dist/services/admin-notifications.d.ts.map +1 -0
  60. package/dist/services/broadcasts.d.ts +55 -0
  61. package/dist/services/broadcasts.d.ts.map +1 -0
  62. package/dist/services/index.cjs +34 -1
  63. package/dist/services/index.cjs.map +1 -1
  64. package/dist/services/index.d.ts +2 -0
  65. package/dist/services/index.d.ts.map +1 -1
  66. package/dist/services/index.js +35 -2
  67. package/dist/services/index.js.map +1 -1
  68. package/dist/types/index.cjs +108 -0
  69. package/dist/types/index.cjs.map +1 -1
  70. package/dist/types/index.d.ts +1 -0
  71. package/dist/types/index.d.ts.map +1 -1
  72. package/dist/types/index.js +109 -1
  73. package/dist/types/index.js.map +1 -1
  74. package/dist/types/notifications.d.ts +634 -0
  75. package/dist/types/notifications.d.ts.map +1 -0
  76. package/dist/useBroadcasts-DzpCcbC8.js +161 -0
  77. package/dist/useBroadcasts-DzpCcbC8.js.map +1 -0
  78. package/dist/useBroadcasts-FP6ZrcY_.cjs +160 -0
  79. package/dist/useBroadcasts-FP6ZrcY_.cjs.map +1 -0
  80. package/dist/{useCampaigns-Dltisb9N.cjs → useCampaigns-BOZ9dDsG.cjs} +2 -2
  81. package/dist/{useCampaigns-Dltisb9N.cjs.map → useCampaigns-BOZ9dDsG.cjs.map} +1 -1
  82. package/dist/{useCampaigns-nwfsALsN.js → useCampaigns-D46b9zuf.js} +2 -2
  83. package/dist/{useCampaigns-nwfsALsN.js.map → useCampaigns-D46b9zuf.js.map} +1 -1
  84. package/dist/useNotificationEvents-BXeMqdak.cjs +954 -0
  85. package/dist/useNotificationEvents-BXeMqdak.cjs.map +1 -0
  86. package/dist/useNotificationEvents-D8DVxah1.js +955 -0
  87. package/dist/useNotificationEvents-D8DVxah1.js.map +1 -0
  88. package/package.json +11 -3
  89. package/dist/AdBanner-CZz8trdz.cjs.map +0 -1
  90. package/dist/AdBanner-DF1QuMxR.js.map +0 -1
@@ -3,9 +3,9 @@ const jsxRuntime = require("react/jsx-runtime");
3
3
  const react = require("react");
4
4
  const themes = require("@radix-ui/themes");
5
5
  const reactIcons = require("@radix-ui/react-icons");
6
- const useCampaigns = require("./useCampaigns-Dltisb9N.cjs");
6
+ const useCampaigns = require("./useCampaigns-BOZ9dDsG.cjs");
7
7
  const lucideReact = require("lucide-react");
8
- const analytics = require("./analytics--ZSO9ova.cjs");
8
+ const analytics = require("./analytics-lEzOx2vl.cjs");
9
9
  function AdPanel({
10
10
  placement,
11
11
  variant: _variant = "small_panel_2",
@@ -1408,11 +1408,436 @@ function AdBanner({
1408
1408
  }
1409
1409
  );
1410
1410
  }
1411
+ const TYPE_STYLES = {
1412
+ info: {
1413
+ icon: lucideReact.Info,
1414
+ bgColor: "var(--blue-2)",
1415
+ borderColor: "var(--blue-6)",
1416
+ textColor: "var(--blue-11)",
1417
+ iconColor: "var(--blue-9)"
1418
+ },
1419
+ success: {
1420
+ icon: lucideReact.CheckCircle,
1421
+ bgColor: "var(--green-2)",
1422
+ borderColor: "var(--green-6)",
1423
+ textColor: "var(--green-11)",
1424
+ iconColor: "var(--green-9)"
1425
+ },
1426
+ warning: {
1427
+ icon: lucideReact.AlertTriangle,
1428
+ bgColor: "var(--yellow-2)",
1429
+ borderColor: "var(--yellow-6)",
1430
+ textColor: "var(--yellow-11)",
1431
+ iconColor: "var(--yellow-9)"
1432
+ },
1433
+ error: {
1434
+ icon: lucideReact.AlertCircle,
1435
+ bgColor: "var(--red-2)",
1436
+ borderColor: "var(--red-6)",
1437
+ textColor: "var(--red-11)",
1438
+ iconColor: "var(--red-9)"
1439
+ },
1440
+ reminder: {
1441
+ icon: lucideReact.AlertTriangle,
1442
+ bgColor: "var(--orange-2)",
1443
+ borderColor: "var(--orange-6)",
1444
+ textColor: "var(--orange-11)",
1445
+ iconColor: "var(--orange-9)"
1446
+ },
1447
+ milestone: {
1448
+ icon: lucideReact.CheckCircle,
1449
+ bgColor: "var(--violet-2)",
1450
+ borderColor: "var(--violet-6)",
1451
+ textColor: "var(--violet-11)",
1452
+ iconColor: "var(--violet-9)"
1453
+ },
1454
+ announcement: {
1455
+ icon: lucideReact.Megaphone,
1456
+ bgColor: "var(--iris-2)",
1457
+ borderColor: "var(--iris-6)",
1458
+ textColor: "var(--iris-11)",
1459
+ iconColor: "var(--iris-9)"
1460
+ }
1461
+ };
1462
+ function BroadcastBanner({
1463
+ broadcast,
1464
+ onActionClick,
1465
+ onDismiss,
1466
+ className
1467
+ }) {
1468
+ const impressionTrackedRef = react.useRef(false);
1469
+ react.useEffect(() => {
1470
+ if (!impressionTrackedRef.current) {
1471
+ impressionTrackedRef.current = true;
1472
+ }
1473
+ }, []);
1474
+ const handleActionClick = react.useCallback(() => {
1475
+ onActionClick?.();
1476
+ if (broadcast.actionUrl) {
1477
+ window.open(broadcast.actionUrl, "_blank");
1478
+ }
1479
+ }, [broadcast.actionUrl, onActionClick]);
1480
+ const handleDismiss = react.useCallback(() => {
1481
+ onDismiss?.();
1482
+ }, [onDismiss]);
1483
+ if (!analytics.isInitialized()) {
1484
+ return null;
1485
+ }
1486
+ const typeStyle = TYPE_STYLES[broadcast.type] || TYPE_STYLES.info;
1487
+ const Icon = typeStyle.icon;
1488
+ return /* @__PURE__ */ jsxRuntime.jsxs(
1489
+ themes.Box,
1490
+ {
1491
+ className,
1492
+ style: {
1493
+ background: typeStyle.bgColor,
1494
+ borderBottom: `1px solid ${typeStyle.borderColor}`,
1495
+ position: "relative"
1496
+ },
1497
+ children: [
1498
+ /* @__PURE__ */ jsxRuntime.jsx(
1499
+ themes.Box,
1500
+ {
1501
+ style: {
1502
+ position: "absolute",
1503
+ left: 0,
1504
+ top: 0,
1505
+ bottom: 0,
1506
+ width: 4,
1507
+ background: typeStyle.iconColor
1508
+ }
1509
+ }
1510
+ ),
1511
+ /* @__PURE__ */ jsxRuntime.jsxs(
1512
+ themes.Flex,
1513
+ {
1514
+ align: "center",
1515
+ justify: "between",
1516
+ gap: "3",
1517
+ py: "3",
1518
+ px: "4",
1519
+ style: { paddingLeft: 20 },
1520
+ children: [
1521
+ /* @__PURE__ */ jsxRuntime.jsxs(themes.Flex, { align: "center", gap: "3", style: { flex: 1, minWidth: 0 }, children: [
1522
+ /* @__PURE__ */ jsxRuntime.jsx(
1523
+ themes.Box,
1524
+ {
1525
+ style: {
1526
+ width: 32,
1527
+ height: 32,
1528
+ borderRadius: 8,
1529
+ background: `color-mix(in srgb, ${typeStyle.iconColor} 15%, transparent)`,
1530
+ display: "flex",
1531
+ alignItems: "center",
1532
+ justifyContent: "center",
1533
+ flexShrink: 0
1534
+ },
1535
+ children: /* @__PURE__ */ jsxRuntime.jsx(Icon, { size: 18, color: typeStyle.iconColor })
1536
+ }
1537
+ ),
1538
+ /* @__PURE__ */ jsxRuntime.jsxs(themes.Flex, { direction: "column", gap: "0", style: { minWidth: 0 }, children: [
1539
+ /* @__PURE__ */ jsxRuntime.jsx(
1540
+ themes.Text,
1541
+ {
1542
+ size: "2",
1543
+ weight: "bold",
1544
+ style: {
1545
+ color: typeStyle.textColor,
1546
+ display: "-webkit-box",
1547
+ WebkitLineClamp: 1,
1548
+ WebkitBoxOrient: "vertical",
1549
+ overflow: "hidden"
1550
+ },
1551
+ children: broadcast.title
1552
+ }
1553
+ ),
1554
+ /* @__PURE__ */ jsxRuntime.jsx(
1555
+ themes.Text,
1556
+ {
1557
+ size: "2",
1558
+ style: {
1559
+ color: "var(--gray-11)",
1560
+ display: "-webkit-box",
1561
+ WebkitLineClamp: 1,
1562
+ WebkitBoxOrient: "vertical",
1563
+ overflow: "hidden"
1564
+ },
1565
+ children: broadcast.message
1566
+ }
1567
+ )
1568
+ ] })
1569
+ ] }),
1570
+ /* @__PURE__ */ jsxRuntime.jsxs(themes.Flex, { align: "center", gap: "2", style: { flexShrink: 0 }, children: [
1571
+ broadcast.actionUrl && /* @__PURE__ */ jsxRuntime.jsxs(
1572
+ themes.Button,
1573
+ {
1574
+ size: "1",
1575
+ variant: "soft",
1576
+ onClick: handleActionClick,
1577
+ style: {
1578
+ background: `color-mix(in srgb, ${typeStyle.iconColor} 15%, transparent)`,
1579
+ color: typeStyle.iconColor
1580
+ },
1581
+ children: [
1582
+ broadcast.actionText || "Learn More",
1583
+ /* @__PURE__ */ jsxRuntime.jsx(lucideReact.ExternalLink, { size: 12 })
1584
+ ]
1585
+ }
1586
+ ),
1587
+ broadcast.dismissible && /* @__PURE__ */ jsxRuntime.jsx(
1588
+ themes.IconButton,
1589
+ {
1590
+ size: "1",
1591
+ variant: "ghost",
1592
+ color: "gray",
1593
+ onClick: handleDismiss,
1594
+ style: { opacity: 0.7 },
1595
+ children: /* @__PURE__ */ jsxRuntime.jsx(lucideReact.X, { size: 16 })
1596
+ }
1597
+ )
1598
+ ] })
1599
+ ]
1600
+ }
1601
+ )
1602
+ ]
1603
+ }
1604
+ );
1605
+ }
1606
+ function BroadcastBanners({
1607
+ broadcasts,
1608
+ onDismiss,
1609
+ onActionClick,
1610
+ maxBanners = 3,
1611
+ className
1612
+ }) {
1613
+ const displayBroadcasts = broadcasts.slice(0, maxBanners);
1614
+ if (displayBroadcasts.length === 0) {
1615
+ return null;
1616
+ }
1617
+ return /* @__PURE__ */ jsxRuntime.jsx(themes.Box, { className, children: displayBroadcasts.map((broadcast) => /* @__PURE__ */ jsxRuntime.jsx(
1618
+ BroadcastBanner,
1619
+ {
1620
+ broadcast,
1621
+ onDismiss: () => onDismiss?.(broadcast.id),
1622
+ onActionClick: () => onActionClick?.(broadcast.id)
1623
+ },
1624
+ broadcast.id
1625
+ )) });
1626
+ }
1627
+ const TYPE_CONFIG = {
1628
+ info: {
1629
+ icon: lucideReact.Info,
1630
+ gradient: "linear-gradient(135deg, var(--blue-3) 0%, var(--blue-2) 100%)",
1631
+ accentColor: "var(--blue-9)",
1632
+ iconBg: "var(--blue-4)"
1633
+ },
1634
+ success: {
1635
+ icon: lucideReact.CheckCircle,
1636
+ gradient: "linear-gradient(135deg, var(--green-3) 0%, var(--green-2) 100%)",
1637
+ accentColor: "var(--green-9)",
1638
+ iconBg: "var(--green-4)"
1639
+ },
1640
+ warning: {
1641
+ icon: lucideReact.AlertTriangle,
1642
+ gradient: "linear-gradient(135deg, var(--yellow-3) 0%, var(--yellow-2) 100%)",
1643
+ accentColor: "var(--yellow-9)",
1644
+ iconBg: "var(--yellow-4)"
1645
+ },
1646
+ error: {
1647
+ icon: lucideReact.AlertCircle,
1648
+ gradient: "linear-gradient(135deg, var(--red-3) 0%, var(--red-2) 100%)",
1649
+ accentColor: "var(--red-9)",
1650
+ iconBg: "var(--red-4)"
1651
+ },
1652
+ reminder: {
1653
+ icon: lucideReact.Bell,
1654
+ gradient: "linear-gradient(135deg, var(--orange-3) 0%, var(--orange-2) 100%)",
1655
+ accentColor: "var(--orange-9)",
1656
+ iconBg: "var(--orange-4)"
1657
+ },
1658
+ milestone: {
1659
+ icon: lucideReact.Sparkles,
1660
+ gradient: "linear-gradient(135deg, var(--violet-3) 0%, var(--violet-2) 100%)",
1661
+ accentColor: "var(--violet-9)",
1662
+ iconBg: "var(--violet-4)"
1663
+ },
1664
+ announcement: {
1665
+ icon: lucideReact.Megaphone,
1666
+ gradient: "linear-gradient(135deg, var(--iris-3) 0%, var(--iris-2) 100%)",
1667
+ accentColor: "var(--iris-9)",
1668
+ iconBg: "var(--iris-4)"
1669
+ }
1670
+ };
1671
+ function AnnouncementModal({
1672
+ broadcast,
1673
+ isOpen,
1674
+ onClose,
1675
+ onActionClick
1676
+ }) {
1677
+ const impressionTrackedRef = react.useRef(false);
1678
+ react.useEffect(() => {
1679
+ if (isOpen && broadcast && !impressionTrackedRef.current) {
1680
+ impressionTrackedRef.current = true;
1681
+ }
1682
+ }, [isOpen, broadcast]);
1683
+ const handleActionClick = react.useCallback(() => {
1684
+ onActionClick?.();
1685
+ if (broadcast?.actionUrl) {
1686
+ window.open(broadcast.actionUrl, "_blank");
1687
+ }
1688
+ onClose();
1689
+ }, [broadcast, onActionClick, onClose]);
1690
+ const handleClose = react.useCallback(() => {
1691
+ onClose();
1692
+ }, [onClose]);
1693
+ if (!analytics.isInitialized() || !broadcast) {
1694
+ return null;
1695
+ }
1696
+ const typeConfig = TYPE_CONFIG[broadcast.type] || TYPE_CONFIG.announcement;
1697
+ const Icon = typeConfig.icon;
1698
+ return /* @__PURE__ */ jsxRuntime.jsx(themes.Dialog.Root, { open: isOpen, onOpenChange: (open) => !open && handleClose(), children: /* @__PURE__ */ jsxRuntime.jsxs(
1699
+ themes.Dialog.Content,
1700
+ {
1701
+ style: {
1702
+ maxWidth: 480,
1703
+ padding: 0,
1704
+ overflow: "hidden"
1705
+ },
1706
+ children: [
1707
+ /* @__PURE__ */ jsxRuntime.jsxs(
1708
+ themes.Box,
1709
+ {
1710
+ style: {
1711
+ background: typeConfig.gradient,
1712
+ padding: "var(--space-6)",
1713
+ position: "relative"
1714
+ },
1715
+ children: [
1716
+ broadcast.dismissible && /* @__PURE__ */ jsxRuntime.jsx(
1717
+ themes.Box,
1718
+ {
1719
+ style: {
1720
+ position: "absolute",
1721
+ top: "var(--space-3)",
1722
+ right: "var(--space-3)"
1723
+ },
1724
+ children: /* @__PURE__ */ jsxRuntime.jsx(themes.Dialog.Close, { children: /* @__PURE__ */ jsxRuntime.jsx(themes.Button, { variant: "ghost", size: "1", color: "gray", children: /* @__PURE__ */ jsxRuntime.jsx(lucideReact.X, { size: 18 }) }) })
1725
+ }
1726
+ ),
1727
+ /* @__PURE__ */ jsxRuntime.jsxs(themes.Flex, { direction: "column", align: "center", gap: "4", children: [
1728
+ /* @__PURE__ */ jsxRuntime.jsx(
1729
+ themes.Box,
1730
+ {
1731
+ style: {
1732
+ width: 72,
1733
+ height: 72,
1734
+ borderRadius: "var(--radius-4)",
1735
+ background: typeConfig.iconBg,
1736
+ display: "flex",
1737
+ alignItems: "center",
1738
+ justifyContent: "center",
1739
+ boxShadow: "0 4px 12px rgba(0, 0, 0, 0.1)"
1740
+ },
1741
+ children: /* @__PURE__ */ jsxRuntime.jsx(Icon, { size: 36, color: typeConfig.accentColor })
1742
+ }
1743
+ ),
1744
+ /* @__PURE__ */ jsxRuntime.jsx(
1745
+ themes.Heading,
1746
+ {
1747
+ size: "5",
1748
+ weight: "bold",
1749
+ align: "center",
1750
+ style: { color: "var(--gray-12)" },
1751
+ children: broadcast.title
1752
+ }
1753
+ )
1754
+ ] })
1755
+ ]
1756
+ }
1757
+ ),
1758
+ /* @__PURE__ */ jsxRuntime.jsxs(themes.Box, { p: "5", children: [
1759
+ /* @__PURE__ */ jsxRuntime.jsx(
1760
+ themes.Text,
1761
+ {
1762
+ as: "p",
1763
+ size: "3",
1764
+ align: "center",
1765
+ style: {
1766
+ color: "var(--gray-11)",
1767
+ lineHeight: 1.6
1768
+ },
1769
+ children: broadcast.message
1770
+ }
1771
+ ),
1772
+ broadcast.isImportant && /* @__PURE__ */ jsxRuntime.jsx(themes.Flex, { justify: "center", mt: "4", children: /* @__PURE__ */ jsxRuntime.jsxs(
1773
+ themes.Box,
1774
+ {
1775
+ style: {
1776
+ padding: "var(--space-1) var(--space-3)",
1777
+ borderRadius: "var(--radius-2)",
1778
+ background: typeConfig.iconBg,
1779
+ display: "inline-flex",
1780
+ alignItems: "center",
1781
+ gap: "var(--space-1)"
1782
+ },
1783
+ children: [
1784
+ /* @__PURE__ */ jsxRuntime.jsx(lucideReact.Sparkles, { size: 12, color: typeConfig.accentColor }),
1785
+ /* @__PURE__ */ jsxRuntime.jsx(themes.Text, { size: "1", weight: "medium", style: { color: typeConfig.accentColor }, children: "Important" })
1786
+ ]
1787
+ }
1788
+ ) })
1789
+ ] }),
1790
+ /* @__PURE__ */ jsxRuntime.jsx(
1791
+ themes.Flex,
1792
+ {
1793
+ gap: "3",
1794
+ p: "4",
1795
+ justify: "center",
1796
+ style: {
1797
+ borderTop: "1px solid var(--gray-4)",
1798
+ background: "var(--gray-2)"
1799
+ },
1800
+ children: broadcast.actionUrl ? /* @__PURE__ */ jsxRuntime.jsxs(jsxRuntime.Fragment, { children: [
1801
+ /* @__PURE__ */ jsxRuntime.jsx(themes.Dialog.Close, { children: /* @__PURE__ */ jsxRuntime.jsx(themes.Button, { variant: "soft", color: "gray", size: "2", children: "Maybe Later" }) }),
1802
+ /* @__PURE__ */ jsxRuntime.jsxs(
1803
+ themes.Button,
1804
+ {
1805
+ size: "2",
1806
+ onClick: handleActionClick,
1807
+ style: {
1808
+ background: typeConfig.accentColor
1809
+ },
1810
+ children: [
1811
+ broadcast.actionText || "Learn More",
1812
+ /* @__PURE__ */ jsxRuntime.jsx(lucideReact.ExternalLink, { size: 14 })
1813
+ ]
1814
+ }
1815
+ )
1816
+ ] }) : /* @__PURE__ */ jsxRuntime.jsx(themes.Dialog.Close, { children: /* @__PURE__ */ jsxRuntime.jsx(
1817
+ themes.Button,
1818
+ {
1819
+ size: "2",
1820
+ style: {
1821
+ background: typeConfig.accentColor,
1822
+ minWidth: 120
1823
+ },
1824
+ children: "Got It"
1825
+ }
1826
+ ) })
1827
+ }
1828
+ )
1829
+ ]
1830
+ }
1831
+ ) });
1832
+ }
1411
1833
  exports.AdBanner = AdBanner;
1412
1834
  exports.AdModal = AdModal;
1413
1835
  exports.AdPanel = AdPanel;
1414
1836
  exports.AdSlider = AdSlider;
1415
1837
  exports.AdUpdateModal = AdUpdateModal;
1838
+ exports.AnnouncementModal = AnnouncementModal;
1839
+ exports.BroadcastBanner = BroadcastBanner;
1840
+ exports.BroadcastBanners = BroadcastBanners;
1416
1841
  exports.CardVariant = CardVariant;
1417
1842
  exports.ComparisonVariant = ComparisonVariant;
1418
1843
  exports.FeatureGridVariant = FeatureGridVariant;
@@ -1427,4 +1852,4 @@ exports.TestimonialVariant = TestimonialVariant;
1427
1852
  exports.VideoVariant = VideoVariant;
1428
1853
  exports.getLargePanelVariant = getLargePanelVariant;
1429
1854
  exports.getSmallPanelVariant = getSmallPanelVariant;
1430
- //# sourceMappingURL=AdBanner-CZz8trdz.cjs.map
1855
+ //# sourceMappingURL=AnnouncementModal-Bqy0pn3V.cjs.map