@zentauri-ui/zentauri-components 2.1.2 → 2.1.4

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 (115) hide show
  1. package/README.md +17 -16
  2. package/cli/index.mjs +4 -10
  3. package/dist/{chunk-F6W3GJJ2.mjs → chunk-2UK6QZA6.mjs} +3 -3
  4. package/dist/{chunk-F6W3GJJ2.mjs.map → chunk-2UK6QZA6.mjs.map} +1 -1
  5. package/dist/{chunk-ZMFRJHO6.mjs → chunk-3BL5PO3K.mjs} +3 -3
  6. package/dist/{chunk-ZMFRJHO6.mjs.map → chunk-3BL5PO3K.mjs.map} +1 -1
  7. package/dist/{chunk-NNGL2AFQ.js → chunk-6KVTKYTB.js} +35 -35
  8. package/dist/{chunk-NNGL2AFQ.js.map → chunk-6KVTKYTB.js.map} +1 -1
  9. package/dist/{chunk-TT33BIIT.js → chunk-BJDT7P2I.js} +35 -35
  10. package/dist/{chunk-TT33BIIT.js.map → chunk-BJDT7P2I.js.map} +1 -1
  11. package/dist/{chunk-7N2UYQBJ.mjs → chunk-BL6UVCV7.mjs} +6 -6
  12. package/dist/{chunk-7N2UYQBJ.mjs.map → chunk-BL6UVCV7.mjs.map} +1 -1
  13. package/dist/{chunk-HVMYPW3Q.mjs → chunk-CZBM6ISF.mjs} +19 -6
  14. package/dist/chunk-CZBM6ISF.mjs.map +1 -0
  15. package/dist/chunk-D2GISTDL.js +19 -0
  16. package/dist/{chunk-R4D5V7NT.js.map → chunk-D2GISTDL.js.map} +1 -1
  17. package/dist/{chunk-5TVBPPS6.js → chunk-DKBMNS6F.js} +11 -11
  18. package/dist/{chunk-5TVBPPS6.js.map → chunk-DKBMNS6F.js.map} +1 -1
  19. package/dist/{chunk-4LCH4OJ5.js → chunk-E7P4O3ET.js} +10 -10
  20. package/dist/{chunk-4LCH4OJ5.js.map → chunk-E7P4O3ET.js.map} +1 -1
  21. package/dist/{chunk-6Q4EOLKN.js → chunk-NDF3HORF.js} +3 -3
  22. package/dist/{chunk-WIKNEHPJ.mjs.map → chunk-NDF3HORF.js.map} +1 -1
  23. package/dist/{chunk-42ZSQNDF.mjs → chunk-NIVJFG5Z.mjs} +35 -35
  24. package/dist/{chunk-42ZSQNDF.mjs.map → chunk-NIVJFG5Z.mjs.map} +1 -1
  25. package/dist/{chunk-V2LI5QZD.js → chunk-NZSZE36T.js} +34 -34
  26. package/dist/{chunk-V2LI5QZD.js.map → chunk-NZSZE36T.js.map} +1 -1
  27. package/dist/{chunk-BIQZC26Q.js → chunk-OH5VOGNW.js} +4 -4
  28. package/dist/chunk-OH5VOGNW.js.map +1 -0
  29. package/dist/{chunk-3N575QVC.mjs → chunk-PAG5CTLN.mjs} +3 -3
  30. package/dist/{chunk-3N575QVC.mjs.map → chunk-PAG5CTLN.mjs.map} +1 -1
  31. package/dist/{chunk-VHYUH5OH.js → chunk-RENXBUZY.js} +6 -6
  32. package/dist/{chunk-VHYUH5OH.js.map → chunk-RENXBUZY.js.map} +1 -1
  33. package/dist/{chunk-APCN6NUH.js → chunk-SYEEHZXL.js} +23 -9
  34. package/dist/chunk-SYEEHZXL.js.map +1 -0
  35. package/dist/{chunk-EDJ6TVL3.js → chunk-UEE2ASYK.js} +12 -12
  36. package/dist/{chunk-EDJ6TVL3.js.map → chunk-UEE2ASYK.js.map} +1 -1
  37. package/dist/{chunk-TYBQZO6Y.mjs → chunk-WBZKMSXW.mjs} +3 -3
  38. package/dist/{chunk-TYBQZO6Y.mjs.map → chunk-WBZKMSXW.mjs.map} +1 -1
  39. package/dist/{chunk-COVTMJIQ.mjs → chunk-XFJIX2YP.mjs} +35 -35
  40. package/dist/{chunk-COVTMJIQ.mjs.map → chunk-XFJIX2YP.mjs.map} +1 -1
  41. package/dist/{chunk-TVEK6PKH.mjs → chunk-XY3TKIIH.mjs} +4 -4
  42. package/dist/chunk-XY3TKIIH.mjs.map +1 -0
  43. package/dist/{chunk-WIKNEHPJ.mjs → chunk-ZBAKTM2R.mjs} +3 -3
  44. package/dist/chunk-ZBAKTM2R.mjs.map +1 -0
  45. package/dist/{chunk-GOH2THVW.mjs → chunk-ZNI3AB3W.mjs} +3 -3
  46. package/dist/{chunk-GOH2THVW.mjs.map → chunk-ZNI3AB3W.mjs.map} +1 -1
  47. package/dist/design-system/alert.d.ts +33 -33
  48. package/dist/design-system/facade.js +6 -6
  49. package/dist/design-system/facade.mjs +5 -5
  50. package/dist/design-system/skeleton.d.ts +33 -33
  51. package/dist/design-system/tabs.d.ts +2 -2
  52. package/dist/design-system/toast.d.ts +1 -1
  53. package/dist/ui/alert/animated.js +3 -3
  54. package/dist/ui/alert/animated.mjs +2 -2
  55. package/dist/ui/alert.js +11 -11
  56. package/dist/ui/alert.mjs +3 -3
  57. package/dist/ui/buttons/animated.js +8 -8
  58. package/dist/ui/buttons/animated.mjs +6 -6
  59. package/dist/ui/buttons.js +9 -9
  60. package/dist/ui/buttons.mjs +7 -7
  61. package/dist/ui/context-menu/context-menu.d.ts.map +1 -1
  62. package/dist/ui/context-menu/types.d.ts +3 -1
  63. package/dist/ui/context-menu/types.d.ts.map +1 -1
  64. package/dist/ui/context-menu.js +17 -0
  65. package/dist/ui/context-menu.js.map +1 -1
  66. package/dist/ui/context-menu.mjs +17 -0
  67. package/dist/ui/context-menu.mjs.map +1 -1
  68. package/dist/ui/dropdown/dropdown.d.ts +1 -1
  69. package/dist/ui/dropdown/dropdown.d.ts.map +1 -1
  70. package/dist/ui/dropdown.js +43 -2
  71. package/dist/ui/dropdown.js.map +1 -1
  72. package/dist/ui/dropdown.mjs +44 -3
  73. package/dist/ui/dropdown.mjs.map +1 -1
  74. package/dist/ui/dynamic-stepper.js +18 -18
  75. package/dist/ui/dynamic-stepper.mjs +7 -7
  76. package/dist/ui/pagination.js +14 -14
  77. package/dist/ui/pagination.mjs +6 -6
  78. package/dist/ui/skeleton/animated.js +9 -9
  79. package/dist/ui/skeleton/animated.mjs +2 -2
  80. package/dist/ui/skeleton.js +10 -10
  81. package/dist/ui/skeleton.mjs +2 -2
  82. package/dist/ui/tabs/animated.js +3 -3
  83. package/dist/ui/tabs/animated.mjs +2 -2
  84. package/dist/ui/tabs.js +10 -10
  85. package/dist/ui/tabs.mjs +2 -2
  86. package/dist/ui/toast/animated/toast-animated.d.ts.map +1 -1
  87. package/dist/ui/toast/animated.js +9 -9
  88. package/dist/ui/toast/animated.js.map +1 -1
  89. package/dist/ui/toast/animated.mjs +3 -3
  90. package/dist/ui/toast/animated.mjs.map +1 -1
  91. package/dist/ui/toast/toast-base.d.ts.map +1 -1
  92. package/dist/ui/toast/use-toast-portal.d.ts +11 -0
  93. package/dist/ui/toast/use-toast-portal.d.ts.map +1 -0
  94. package/dist/ui/toast.js +13 -13
  95. package/dist/ui/toast.mjs +2 -2
  96. package/package.json +8 -2
  97. package/src/design-system/alert.ts +33 -33
  98. package/src/design-system/skeleton.ts +33 -33
  99. package/src/design-system/tabs.ts +2 -2
  100. package/src/design-system/toast.ts +1 -1
  101. package/src/hooks/useTableFilter/useTableFilter.test.ts +12 -2
  102. package/src/ui/context-menu/context-menu.test.tsx +38 -0
  103. package/src/ui/context-menu/context-menu.tsx +17 -1
  104. package/src/ui/context-menu/types.ts +3 -0
  105. package/src/ui/dropdown/dropdown.tsx +59 -2
  106. package/src/ui/skeleton/skeleton.test.tsx +9 -0
  107. package/src/ui/toast/animated/toast-animated.tsx +3 -1
  108. package/src/ui/toast/toast-base.tsx +3 -1
  109. package/src/ui/toast/use-toast-portal.ts +29 -0
  110. package/dist/chunk-6Q4EOLKN.js.map +0 -1
  111. package/dist/chunk-APCN6NUH.js.map +0 -1
  112. package/dist/chunk-BIQZC26Q.js.map +0 -1
  113. package/dist/chunk-HVMYPW3Q.mjs.map +0 -1
  114. package/dist/chunk-R4D5V7NT.js +0 -19
  115. package/dist/chunk-TVEK6PKH.mjs.map +0 -1
@@ -1,8 +1,8 @@
1
1
  "use client";
2
2
  'use strict';
3
3
 
4
- var chunkEDJ6TVL3_js = require('../chunk-EDJ6TVL3.js');
5
- require('../chunk-NNGL2AFQ.js');
4
+ var chunkUEE2ASYK_js = require('../chunk-UEE2ASYK.js');
5
+ require('../chunk-6KVTKYTB.js');
6
6
  require('../chunk-ZS5756ZC.js');
7
7
  require('../chunk-PZ5AY32C.js');
8
8
 
@@ -10,35 +10,35 @@ require('../chunk-PZ5AY32C.js');
10
10
 
11
11
  Object.defineProperty(exports, "Skeleton", {
12
12
  enumerable: true,
13
- get: function () { return chunkEDJ6TVL3_js.SkeletonBase; }
13
+ get: function () { return chunkUEE2ASYK_js.SkeletonBase; }
14
14
  });
15
15
  Object.defineProperty(exports, "SkeletonAvatar", {
16
16
  enumerable: true,
17
- get: function () { return chunkEDJ6TVL3_js.SkeletonAvatarBase; }
17
+ get: function () { return chunkUEE2ASYK_js.SkeletonAvatarBase; }
18
18
  });
19
19
  Object.defineProperty(exports, "SkeletonButton", {
20
20
  enumerable: true,
21
- get: function () { return chunkEDJ6TVL3_js.SkeletonButtonBase; }
21
+ get: function () { return chunkUEE2ASYK_js.SkeletonButtonBase; }
22
22
  });
23
23
  Object.defineProperty(exports, "SkeletonCard", {
24
24
  enumerable: true,
25
- get: function () { return chunkEDJ6TVL3_js.SkeletonCardBase; }
25
+ get: function () { return chunkUEE2ASYK_js.SkeletonCardBase; }
26
26
  });
27
27
  Object.defineProperty(exports, "SkeletonText", {
28
28
  enumerable: true,
29
- get: function () { return chunkEDJ6TVL3_js.SkeletonTextBase; }
29
+ get: function () { return chunkUEE2ASYK_js.SkeletonTextBase; }
30
30
  });
31
31
  Object.defineProperty(exports, "skeletonShimmerGradientClasses", {
32
32
  enumerable: true,
33
- get: function () { return chunkEDJ6TVL3_js.skeletonShimmerGradientClasses; }
33
+ get: function () { return chunkUEE2ASYK_js.skeletonShimmerGradientClasses; }
34
34
  });
35
35
  Object.defineProperty(exports, "skeletonTextLineVariants", {
36
36
  enumerable: true,
37
- get: function () { return chunkEDJ6TVL3_js.skeletonTextLineVariants; }
37
+ get: function () { return chunkUEE2ASYK_js.skeletonTextLineVariants; }
38
38
  });
39
39
  Object.defineProperty(exports, "skeletonVariants", {
40
40
  enumerable: true,
41
- get: function () { return chunkEDJ6TVL3_js.skeletonVariants; }
41
+ get: function () { return chunkUEE2ASYK_js.skeletonVariants; }
42
42
  });
43
43
  //# sourceMappingURL=skeleton.js.map
44
44
  //# sourceMappingURL=skeleton.js.map
@@ -1,6 +1,6 @@
1
1
  "use client";
2
- export { SkeletonBase as Skeleton, SkeletonAvatarBase as SkeletonAvatar, SkeletonButtonBase as SkeletonButton, SkeletonCardBase as SkeletonCard, SkeletonTextBase as SkeletonText, skeletonShimmerGradientClasses, skeletonTextLineVariants, skeletonVariants } from '../chunk-F6W3GJJ2.mjs';
3
- import '../chunk-COVTMJIQ.mjs';
2
+ export { SkeletonBase as Skeleton, SkeletonAvatarBase as SkeletonAvatar, SkeletonButtonBase as SkeletonButton, SkeletonCardBase as SkeletonCard, SkeletonTextBase as SkeletonText, skeletonShimmerGradientClasses, skeletonTextLineVariants, skeletonVariants } from '../chunk-2UK6QZA6.mjs';
3
+ import '../chunk-XFJIX2YP.mjs';
4
4
  import '../chunk-4D54YOL6.mjs';
5
5
  import '../chunk-J5LGTIGS.mjs';
6
6
  //# sourceMappingURL=skeleton.mjs.map
@@ -1,8 +1,8 @@
1
1
  "use client";
2
2
  'use strict';
3
3
 
4
- var chunk5TVBPPS6_js = require('../../chunk-5TVBPPS6.js');
5
- require('../../chunk-BIQZC26Q.js');
4
+ var chunkDKBMNS6F_js = require('../../chunk-DKBMNS6F.js');
5
+ require('../../chunk-OH5VOGNW.js');
6
6
  var chunkZS5756ZC_js = require('../../chunk-ZS5756ZC.js');
7
7
  require('../../chunk-PZ5AY32C.js');
8
8
  var framerMotion = require('framer-motion');
@@ -56,7 +56,7 @@ function TabsContentAnimated({
56
56
  orientation,
57
57
  tabTriggerId,
58
58
  tabPanelId
59
- } = chunk5TVBPPS6_js.useTabs();
59
+ } = chunkDKBMNS6F_js.useTabs();
60
60
  const prefersReducedMotion2 = framerMotion.useReducedMotion();
61
61
  if (activeValue !== value) return null;
62
62
  const motionProps = getTabsContentMotionProps(
@@ -1,6 +1,6 @@
1
1
  "use client";
2
- import { useTabs } from '../../chunk-GOH2THVW.mjs';
3
- import '../../chunk-TVEK6PKH.mjs';
2
+ import { useTabs } from '../../chunk-ZNI3AB3W.mjs';
3
+ import '../../chunk-XY3TKIIH.mjs';
4
4
  import { cn } from '../../chunk-4D54YOL6.mjs';
5
5
  import '../../chunk-J5LGTIGS.mjs';
6
6
  import { useReducedMotion, motion } from 'framer-motion';
package/dist/ui/tabs.js CHANGED
@@ -1,8 +1,8 @@
1
1
  "use client";
2
2
  'use strict';
3
3
 
4
- var chunk5TVBPPS6_js = require('../chunk-5TVBPPS6.js');
5
- require('../chunk-BIQZC26Q.js');
4
+ var chunkDKBMNS6F_js = require('../chunk-DKBMNS6F.js');
5
+ require('../chunk-OH5VOGNW.js');
6
6
  require('../chunk-ZS5756ZC.js');
7
7
  require('../chunk-PZ5AY32C.js');
8
8
 
@@ -10,35 +10,35 @@ require('../chunk-PZ5AY32C.js');
10
10
 
11
11
  Object.defineProperty(exports, "Tabs", {
12
12
  enumerable: true,
13
- get: function () { return chunk5TVBPPS6_js.Tabs; }
13
+ get: function () { return chunkDKBMNS6F_js.Tabs; }
14
14
  });
15
15
  Object.defineProperty(exports, "TabsContent", {
16
16
  enumerable: true,
17
- get: function () { return chunk5TVBPPS6_js.TabsContent; }
17
+ get: function () { return chunkDKBMNS6F_js.TabsContent; }
18
18
  });
19
19
  Object.defineProperty(exports, "TabsContext", {
20
20
  enumerable: true,
21
- get: function () { return chunk5TVBPPS6_js.TabsContext; }
21
+ get: function () { return chunkDKBMNS6F_js.TabsContext; }
22
22
  });
23
23
  Object.defineProperty(exports, "TabsList", {
24
24
  enumerable: true,
25
- get: function () { return chunk5TVBPPS6_js.TabsList; }
25
+ get: function () { return chunkDKBMNS6F_js.TabsList; }
26
26
  });
27
27
  Object.defineProperty(exports, "TabsTrigger", {
28
28
  enumerable: true,
29
- get: function () { return chunk5TVBPPS6_js.TabsTrigger; }
29
+ get: function () { return chunkDKBMNS6F_js.TabsTrigger; }
30
30
  });
31
31
  Object.defineProperty(exports, "tabsListVariants", {
32
32
  enumerable: true,
33
- get: function () { return chunk5TVBPPS6_js.tabsListVariants; }
33
+ get: function () { return chunkDKBMNS6F_js.tabsListVariants; }
34
34
  });
35
35
  Object.defineProperty(exports, "tabsTriggerVariants", {
36
36
  enumerable: true,
37
- get: function () { return chunk5TVBPPS6_js.tabsTriggerVariants; }
37
+ get: function () { return chunkDKBMNS6F_js.tabsTriggerVariants; }
38
38
  });
39
39
  Object.defineProperty(exports, "useTabs", {
40
40
  enumerable: true,
41
- get: function () { return chunk5TVBPPS6_js.useTabs; }
41
+ get: function () { return chunkDKBMNS6F_js.useTabs; }
42
42
  });
43
43
  //# sourceMappingURL=tabs.js.map
44
44
  //# sourceMappingURL=tabs.js.map
package/dist/ui/tabs.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  "use client";
2
- export { Tabs, TabsContent, TabsContext, TabsList, TabsTrigger, tabsListVariants, tabsTriggerVariants, useTabs } from '../chunk-GOH2THVW.mjs';
3
- import '../chunk-TVEK6PKH.mjs';
2
+ export { Tabs, TabsContent, TabsContext, TabsList, TabsTrigger, tabsListVariants, tabsTriggerVariants, useTabs } from '../chunk-ZNI3AB3W.mjs';
3
+ import '../chunk-XY3TKIIH.mjs';
4
4
  import '../chunk-4D54YOL6.mjs';
5
5
  import '../chunk-J5LGTIGS.mjs';
6
6
  //# sourceMappingURL=tabs.mjs.map
@@ -1 +1 @@
1
- {"version":3,"file":"toast-animated.d.ts","sourceRoot":"","sources":["../../../../src/ui/toast/animated/toast-animated.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAS/D,wBAAgB,qBAAqB,CAAC,EACpC,QAAyB,EACzB,SAAS,GACV,EAAE,kBAAkB,sCAsCpB;yBAzCe,qBAAqB;;;AA6CrC,wBAAgB,aAAa,CAAC,EAC5B,OAAO,EAAE,QAAQ,EACjB,UAAU,EACV,IAAI,EACJ,SAAmB,EACnB,SAAS,EACT,QAAQ,GACT,EAAE,UAAU,2CAyBZ;yBAhCe,aAAa"}
1
+ {"version":3,"file":"toast-animated.d.ts","sourceRoot":"","sources":["../../../../src/ui/toast/animated/toast-animated.tsx"],"names":[],"mappings":"AASA,OAAO,KAAK,EAAE,UAAU,EAAE,kBAAkB,EAAE,MAAM,UAAU,CAAC;AAU/D,wBAAgB,qBAAqB,CAAC,EACpC,QAAyB,EACzB,SAAS,GACV,EAAE,kBAAkB,sCAuCpB;yBA1Ce,qBAAqB;;;AA8CrC,wBAAgB,aAAa,CAAC,EAC5B,OAAO,EAAE,QAAQ,EACjB,UAAU,EACV,IAAI,EACJ,SAAmB,EACnB,SAAS,EACT,QAAQ,GACT,EAAE,UAAU,2CAyBZ;yBAhCe,aAAa"}
@@ -1,8 +1,8 @@
1
1
  "use client";
2
2
  'use strict';
3
3
 
4
- var chunkAPCN6NUH_js = require('../../chunk-APCN6NUH.js');
5
- require('../../chunk-6Q4EOLKN.js');
4
+ var chunkSYEEHZXL_js = require('../../chunk-SYEEHZXL.js');
5
+ require('../../chunk-NDF3HORF.js');
6
6
  var chunkZS5756ZC_js = require('../../chunk-ZS5756ZC.js');
7
7
  require('../../chunk-PZ5AY32C.js');
8
8
  var framerMotion = require('framer-motion');
@@ -30,13 +30,13 @@ function ToastViewportAnimated({
30
30
  position = "bottom-right",
31
31
  className
32
32
  }) {
33
- const ctx = react.useContext(chunkAPCN6NUH_js.ToastStoreContext);
33
+ const ctx = react.useContext(chunkSYEEHZXL_js.ToastStoreContext);
34
+ const portalTarget = chunkSYEEHZXL_js.useToastPortal();
34
35
  if (!ctx) {
35
36
  throw new Error(
36
37
  "ToastViewportAnimated must be used within <ToastProvider>"
37
38
  );
38
39
  }
39
- const portalTarget = typeof document !== "undefined" ? document.body : null;
40
40
  if (!portalTarget) {
41
41
  return null;
42
42
  }
@@ -44,7 +44,7 @@ function ToastViewportAnimated({
44
44
  /* @__PURE__ */ jsxRuntime.jsx(
45
45
  "div",
46
46
  {
47
- className: chunkZS5756ZC_js.cn(chunkAPCN6NUH_js.toastViewportVariants({ position }), className),
47
+ className: chunkZS5756ZC_js.cn(chunkSYEEHZXL_js.toastViewportVariants({ position }), className),
48
48
  "data-slot": "toast-viewport",
49
49
  children: /* @__PURE__ */ jsxRuntime.jsx(framerMotion.AnimatePresence, { children: ctx.toasts.map((item) => /* @__PURE__ */ jsxRuntime.jsxs(
50
50
  ToastAnimated,
@@ -54,9 +54,9 @@ function ToastViewportAnimated({
54
54
  size: item.size,
55
55
  animation: item.animation,
56
56
  children: [
57
- /* @__PURE__ */ jsxRuntime.jsx(chunkAPCN6NUH_js.ToastTitle, { children: item.title }),
58
- item.description ? /* @__PURE__ */ jsxRuntime.jsx(chunkAPCN6NUH_js.ToastDescription, { children: item.description }) : null,
59
- /* @__PURE__ */ jsxRuntime.jsx(chunkAPCN6NUH_js.ToastClose, { onClick: () => ctx.dismiss(item.id) })
57
+ /* @__PURE__ */ jsxRuntime.jsx(chunkSYEEHZXL_js.ToastTitle, { children: item.title }),
58
+ item.description ? /* @__PURE__ */ jsxRuntime.jsx(chunkSYEEHZXL_js.ToastDescription, { children: item.description }) : null,
59
+ /* @__PURE__ */ jsxRuntime.jsx(chunkSYEEHZXL_js.ToastClose, { onClick: () => ctx.dismiss(item.id) })
60
60
  ]
61
61
  },
62
62
  item.id
@@ -87,7 +87,7 @@ function ToastAnimated({
87
87
  "aria-atomic": "true",
88
88
  className: chunkZS5756ZC_js.cn(
89
89
  "relative",
90
- chunkAPCN6NUH_js.toastRootVariants({ appearance, size }),
90
+ chunkSYEEHZXL_js.toastRootVariants({ appearance, size }),
91
91
  className
92
92
  ),
93
93
  initial: animation === "none" ? false : motionProps.initial,
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/ui/toast/animated/animations.ts","../../../src/ui/toast/animated/toast-animated.tsx"],"names":["useContext","ToastStoreContext","createPortal","jsx","cn","toastViewportVariants","AnimatePresence","jsxs","ToastTitle","ToastDescription","ToastClose","motion","toastRootVariants"],"mappings":"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","file":"animated.js","sourcesContent":["import type { ToastAnimationPresets } from \"./types\";\n\nexport const toastAnimationPresets: ToastAnimationPresets = {\n none: {},\n slide: {\n initial: { opacity: 0, x: 24 },\n animate: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: 16 },\n transition: { type: \"spring\", stiffness: 380, damping: 28 },\n },\n fade: {\n initial: { opacity: 0 },\n animate: { opacity: 1 },\n exit: { opacity: 0 },\n transition: { duration: 0.18 },\n },\n};\n","\"use client\";\n\nimport { AnimatePresence, motion } from \"framer-motion\";\nimport { useContext } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nimport { cn } from \"../../../lib/utils\";\n\nimport { toastAnimationPresets } from \"./animations\";\nimport type { ToastProps, ToastViewportProps } from \"../types\";\nimport { toastRootVariants, toastViewportVariants } from \"../variants\";\nimport {\n ToastClose,\n ToastDescription,\n ToastStoreContext,\n ToastTitle,\n} from \"../toast-base\";\n\nexport function ToastViewportAnimated({\n position = \"bottom-right\",\n className,\n}: ToastViewportProps) {\n const ctx = useContext(ToastStoreContext);\n if (!ctx) {\n throw new Error(\n \"ToastViewportAnimated must be used within <ToastProvider>\",\n );\n }\n\n const portalTarget = typeof document !== \"undefined\" ? document.body : null;\n if (!portalTarget) {\n return null;\n }\n\n return createPortal(\n <div\n className={cn(toastViewportVariants({ position }), className)}\n data-slot=\"toast-viewport\"\n >\n <AnimatePresence>\n {ctx.toasts.map((item) => (\n <ToastAnimated\n key={item.id}\n toastId={item.id}\n appearance={item.appearance}\n size={item.size}\n animation={item.animation}\n >\n <ToastTitle>{item.title}</ToastTitle>\n {item.description ? (\n <ToastDescription>{item.description}</ToastDescription>\n ) : null}\n <ToastClose onClick={() => ctx.dismiss(item.id)} />\n </ToastAnimated>\n ))}\n </AnimatePresence>\n </div>,\n portalTarget,\n );\n}\n\nToastViewportAnimated.displayName = \"ToastViewport\";\n\nexport function ToastAnimated({\n toastId: _toastId,\n appearance,\n size,\n animation = \"slide\",\n className,\n children,\n}: ToastProps) {\n const live = appearance === \"error\" ? \"assertive\" : \"polite\";\n\n const motionProps = toastAnimationPresets[animation];\n\n return (\n <motion.div\n layout\n data-slot=\"toast\"\n role={appearance === \"error\" ? \"alert\" : \"status\"}\n aria-live={live}\n aria-atomic=\"true\"\n className={cn(\n \"relative\",\n toastRootVariants({ appearance, size }),\n className,\n )}\n initial={animation === \"none\" ? false : motionProps.initial}\n animate={animation === \"none\" ? undefined : motionProps.animate}\n exit={animation === \"none\" ? undefined : motionProps.exit}\n transition={motionProps.transition}\n >\n {children}\n </motion.div>\n );\n}\n\nToastAnimated.displayName = \"Toast\";\n"]}
1
+ {"version":3,"sources":["../../../src/ui/toast/animated/animations.ts","../../../src/ui/toast/animated/toast-animated.tsx"],"names":["useContext","ToastStoreContext","useToastPortal","createPortal","jsx","cn","toastViewportVariants","AnimatePresence","jsxs","ToastTitle","ToastDescription","ToastClose","motion","toastRootVariants"],"mappings":"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","file":"animated.js","sourcesContent":["import type { ToastAnimationPresets } from \"./types\";\n\nexport const toastAnimationPresets: ToastAnimationPresets = {\n none: {},\n slide: {\n initial: { opacity: 0, x: 24 },\n animate: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: 16 },\n transition: { type: \"spring\", stiffness: 380, damping: 28 },\n },\n fade: {\n initial: { opacity: 0 },\n animate: { opacity: 1 },\n exit: { opacity: 0 },\n transition: { duration: 0.18 },\n },\n};\n","\"use client\";\n\nimport { AnimatePresence, motion } from \"framer-motion\";\nimport { useContext } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nimport { cn } from \"../../../lib/utils\";\n\nimport { toastAnimationPresets } from \"./animations\";\nimport type { ToastProps, ToastViewportProps } from \"../types\";\nimport { useToastPortal } from \"../use-toast-portal\";\nimport { toastRootVariants, toastViewportVariants } from \"../variants\";\nimport {\n ToastClose,\n ToastDescription,\n ToastStoreContext,\n ToastTitle,\n} from \"../toast-base\";\n\nexport function ToastViewportAnimated({\n position = \"bottom-right\",\n className,\n}: ToastViewportProps) {\n const ctx = useContext(ToastStoreContext);\n const portalTarget = useToastPortal();\n\n if (!ctx) {\n throw new Error(\n \"ToastViewportAnimated must be used within <ToastProvider>\",\n );\n }\n\n if (!portalTarget) {\n return null;\n }\n\n return createPortal(\n <div\n className={cn(toastViewportVariants({ position }), className)}\n data-slot=\"toast-viewport\"\n >\n <AnimatePresence>\n {ctx.toasts.map((item) => (\n <ToastAnimated\n key={item.id}\n toastId={item.id}\n appearance={item.appearance}\n size={item.size}\n animation={item.animation}\n >\n <ToastTitle>{item.title}</ToastTitle>\n {item.description ? (\n <ToastDescription>{item.description}</ToastDescription>\n ) : null}\n <ToastClose onClick={() => ctx.dismiss(item.id)} />\n </ToastAnimated>\n ))}\n </AnimatePresence>\n </div>,\n portalTarget,\n );\n}\n\nToastViewportAnimated.displayName = \"ToastViewport\";\n\nexport function ToastAnimated({\n toastId: _toastId,\n appearance,\n size,\n animation = \"slide\",\n className,\n children,\n}: ToastProps) {\n const live = appearance === \"error\" ? \"assertive\" : \"polite\";\n\n const motionProps = toastAnimationPresets[animation];\n\n return (\n <motion.div\n layout\n data-slot=\"toast\"\n role={appearance === \"error\" ? \"alert\" : \"status\"}\n aria-live={live}\n aria-atomic=\"true\"\n className={cn(\n \"relative\",\n toastRootVariants({ appearance, size }),\n className,\n )}\n initial={animation === \"none\" ? false : motionProps.initial}\n animate={animation === \"none\" ? undefined : motionProps.animate}\n exit={animation === \"none\" ? undefined : motionProps.exit}\n transition={motionProps.transition}\n >\n {children}\n </motion.div>\n );\n}\n\nToastAnimated.displayName = \"Toast\";\n"]}
@@ -1,6 +1,6 @@
1
1
  "use client";
2
- import { ToastStoreContext, ToastTitle, ToastDescription, ToastClose, toastViewportVariants, toastRootVariants } from '../../chunk-HVMYPW3Q.mjs';
3
- import '../../chunk-WIKNEHPJ.mjs';
2
+ import { ToastStoreContext, useToastPortal, ToastTitle, ToastDescription, ToastClose, toastViewportVariants, toastRootVariants } from '../../chunk-CZBM6ISF.mjs';
3
+ import '../../chunk-ZBAKTM2R.mjs';
4
4
  import { cn } from '../../chunk-4D54YOL6.mjs';
5
5
  import '../../chunk-J5LGTIGS.mjs';
6
6
  import { AnimatePresence, motion } from 'framer-motion';
@@ -29,12 +29,12 @@ function ToastViewportAnimated({
29
29
  className
30
30
  }) {
31
31
  const ctx = useContext(ToastStoreContext);
32
+ const portalTarget = useToastPortal();
32
33
  if (!ctx) {
33
34
  throw new Error(
34
35
  "ToastViewportAnimated must be used within <ToastProvider>"
35
36
  );
36
37
  }
37
- const portalTarget = typeof document !== "undefined" ? document.body : null;
38
38
  if (!portalTarget) {
39
39
  return null;
40
40
  }
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../src/ui/toast/animated/animations.ts","../../../src/ui/toast/animated/toast-animated.tsx"],"names":[],"mappings":"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","file":"animated.mjs","sourcesContent":["import type { ToastAnimationPresets } from \"./types\";\n\nexport const toastAnimationPresets: ToastAnimationPresets = {\n none: {},\n slide: {\n initial: { opacity: 0, x: 24 },\n animate: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: 16 },\n transition: { type: \"spring\", stiffness: 380, damping: 28 },\n },\n fade: {\n initial: { opacity: 0 },\n animate: { opacity: 1 },\n exit: { opacity: 0 },\n transition: { duration: 0.18 },\n },\n};\n","\"use client\";\n\nimport { AnimatePresence, motion } from \"framer-motion\";\nimport { useContext } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nimport { cn } from \"../../../lib/utils\";\n\nimport { toastAnimationPresets } from \"./animations\";\nimport type { ToastProps, ToastViewportProps } from \"../types\";\nimport { toastRootVariants, toastViewportVariants } from \"../variants\";\nimport {\n ToastClose,\n ToastDescription,\n ToastStoreContext,\n ToastTitle,\n} from \"../toast-base\";\n\nexport function ToastViewportAnimated({\n position = \"bottom-right\",\n className,\n}: ToastViewportProps) {\n const ctx = useContext(ToastStoreContext);\n if (!ctx) {\n throw new Error(\n \"ToastViewportAnimated must be used within <ToastProvider>\",\n );\n }\n\n const portalTarget = typeof document !== \"undefined\" ? document.body : null;\n if (!portalTarget) {\n return null;\n }\n\n return createPortal(\n <div\n className={cn(toastViewportVariants({ position }), className)}\n data-slot=\"toast-viewport\"\n >\n <AnimatePresence>\n {ctx.toasts.map((item) => (\n <ToastAnimated\n key={item.id}\n toastId={item.id}\n appearance={item.appearance}\n size={item.size}\n animation={item.animation}\n >\n <ToastTitle>{item.title}</ToastTitle>\n {item.description ? (\n <ToastDescription>{item.description}</ToastDescription>\n ) : null}\n <ToastClose onClick={() => ctx.dismiss(item.id)} />\n </ToastAnimated>\n ))}\n </AnimatePresence>\n </div>,\n portalTarget,\n );\n}\n\nToastViewportAnimated.displayName = \"ToastViewport\";\n\nexport function ToastAnimated({\n toastId: _toastId,\n appearance,\n size,\n animation = \"slide\",\n className,\n children,\n}: ToastProps) {\n const live = appearance === \"error\" ? \"assertive\" : \"polite\";\n\n const motionProps = toastAnimationPresets[animation];\n\n return (\n <motion.div\n layout\n data-slot=\"toast\"\n role={appearance === \"error\" ? \"alert\" : \"status\"}\n aria-live={live}\n aria-atomic=\"true\"\n className={cn(\n \"relative\",\n toastRootVariants({ appearance, size }),\n className,\n )}\n initial={animation === \"none\" ? false : motionProps.initial}\n animate={animation === \"none\" ? undefined : motionProps.animate}\n exit={animation === \"none\" ? undefined : motionProps.exit}\n transition={motionProps.transition}\n >\n {children}\n </motion.div>\n );\n}\n\nToastAnimated.displayName = \"Toast\";\n"]}
1
+ {"version":3,"sources":["../../../src/ui/toast/animated/animations.ts","../../../src/ui/toast/animated/toast-animated.tsx"],"names":[],"mappings":"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","file":"animated.mjs","sourcesContent":["import type { ToastAnimationPresets } from \"./types\";\n\nexport const toastAnimationPresets: ToastAnimationPresets = {\n none: {},\n slide: {\n initial: { opacity: 0, x: 24 },\n animate: { opacity: 1, x: 0 },\n exit: { opacity: 0, x: 16 },\n transition: { type: \"spring\", stiffness: 380, damping: 28 },\n },\n fade: {\n initial: { opacity: 0 },\n animate: { opacity: 1 },\n exit: { opacity: 0 },\n transition: { duration: 0.18 },\n },\n};\n","\"use client\";\n\nimport { AnimatePresence, motion } from \"framer-motion\";\nimport { useContext } from \"react\";\nimport { createPortal } from \"react-dom\";\n\nimport { cn } from \"../../../lib/utils\";\n\nimport { toastAnimationPresets } from \"./animations\";\nimport type { ToastProps, ToastViewportProps } from \"../types\";\nimport { useToastPortal } from \"../use-toast-portal\";\nimport { toastRootVariants, toastViewportVariants } from \"../variants\";\nimport {\n ToastClose,\n ToastDescription,\n ToastStoreContext,\n ToastTitle,\n} from \"../toast-base\";\n\nexport function ToastViewportAnimated({\n position = \"bottom-right\",\n className,\n}: ToastViewportProps) {\n const ctx = useContext(ToastStoreContext);\n const portalTarget = useToastPortal();\n\n if (!ctx) {\n throw new Error(\n \"ToastViewportAnimated must be used within <ToastProvider>\",\n );\n }\n\n if (!portalTarget) {\n return null;\n }\n\n return createPortal(\n <div\n className={cn(toastViewportVariants({ position }), className)}\n data-slot=\"toast-viewport\"\n >\n <AnimatePresence>\n {ctx.toasts.map((item) => (\n <ToastAnimated\n key={item.id}\n toastId={item.id}\n appearance={item.appearance}\n size={item.size}\n animation={item.animation}\n >\n <ToastTitle>{item.title}</ToastTitle>\n {item.description ? (\n <ToastDescription>{item.description}</ToastDescription>\n ) : null}\n <ToastClose onClick={() => ctx.dismiss(item.id)} />\n </ToastAnimated>\n ))}\n </AnimatePresence>\n </div>,\n portalTarget,\n );\n}\n\nToastViewportAnimated.displayName = \"ToastViewport\";\n\nexport function ToastAnimated({\n toastId: _toastId,\n appearance,\n size,\n animation = \"slide\",\n className,\n children,\n}: ToastProps) {\n const live = appearance === \"error\" ? \"assertive\" : \"polite\";\n\n const motionProps = toastAnimationPresets[animation];\n\n return (\n <motion.div\n layout\n data-slot=\"toast\"\n role={appearance === \"error\" ? \"alert\" : \"status\"}\n aria-live={live}\n aria-atomic=\"true\"\n className={cn(\n \"relative\",\n toastRootVariants({ appearance, size }),\n className,\n )}\n initial={animation === \"none\" ? false : motionProps.initial}\n animate={animation === \"none\" ? undefined : motionProps.animate}\n exit={animation === \"none\" ? undefined : motionProps.exit}\n transition={motionProps.transition}\n >\n {children}\n </motion.div>\n );\n}\n\nToastAnimated.displayName = \"Toast\";\n"]}
@@ -1 +1 @@
1
- {"version":3,"file":"toast-base.d.ts","sourceRoot":"","sources":["../../../src/ui/toast/toast-base.tsx"],"names":[],"mappings":"AAeA,OAAO,KAAK,EACV,iBAAiB,EACjB,sBAAsB,EAEtB,UAAU,EACV,UAAU,EACV,kBAAkB,EAClB,iBAAiB,EACjB,kBAAkB,EACnB,MAAM,SAAS,CAAC;AAGjB,eAAO,MAAM,iBAAiB,wDAE7B,CAAC;AAIF,wBAAgB,KAAK,CAAC,KAAK,EAAE,UAAU,UAKtC;AAED,wBAAgB,QAAQ,IAAI,iBAAiB,CAM5C;AAED,wBAAgB,aAAa,CAAC,EAAE,QAAQ,EAAE,EAAE,kBAAkB,2CAoD7D;yBApDe,aAAa;;;AAwD7B,wBAAgB,aAAa,CAAC,EAC5B,QAAyB,EACzB,SAAS,GACV,EAAE,kBAAkB,sCAkCpB;yBArCe,aAAa;;;AAyC7B,wBAAgB,KAAK,CAAC,EACpB,OAAO,EAAE,QAAQ,EACjB,UAAU,EACV,IAAI,EACJ,SAAS,EAAE,UAAoB,EAC/B,SAAS,EACT,QAAQ,GACT,EAAE,UAAU,2CAkBZ;yBAzBe,KAAK;;;AA6BrB,wBAAgB,UAAU,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,iBAAiB,2CAMpE;yBANe,UAAU;;;AAU1B,wBAAgB,gBAAgB,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,iBAAiB,2CAM1E;yBANe,gBAAgB;;;AAUhC,wBAAgB,WAAW,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,iBAAiB,2CAMrE;yBANe,WAAW;;;AAU3B,wBAAgB,UAAU,CAAC,EACzB,SAAS,EACT,QAAQ,EACR,OAAO,EACP,GAAG,IAAI,EACR,EAAE,iBAAiB,GAAG;IAAE,OAAO,CAAC,EAAE,MAAM,IAAI,CAAA;CAAE,2CAgB9C;yBArBe,UAAU"}
1
+ {"version":3,"file":"toast-base.d.ts","sourceRoot":"","sources":["../../../src/ui/toast/toast-base.tsx"],"names":[],"mappings":"AAeA,OAAO,KAAK,EACV,iBAAiB,EACjB,sBAAsB,EAEtB,UAAU,EACV,UAAU,EACV,kBAAkB,EAClB,iBAAiB,EACjB,kBAAkB,EACnB,MAAM,SAAS,CAAC;AAIjB,eAAO,MAAM,iBAAiB,wDAE7B,CAAC;AAIF,wBAAgB,KAAK,CAAC,KAAK,EAAE,UAAU,UAKtC;AAED,wBAAgB,QAAQ,IAAI,iBAAiB,CAM5C;AAED,wBAAgB,aAAa,CAAC,EAAE,QAAQ,EAAE,EAAE,kBAAkB,2CAoD7D;yBApDe,aAAa;;;AAwD7B,wBAAgB,aAAa,CAAC,EAC5B,QAAyB,EACzB,SAAS,GACV,EAAE,kBAAkB,sCAmCpB;yBAtCe,aAAa;;;AA0C7B,wBAAgB,KAAK,CAAC,EACpB,OAAO,EAAE,QAAQ,EACjB,UAAU,EACV,IAAI,EACJ,SAAS,EAAE,UAAoB,EAC/B,SAAS,EACT,QAAQ,GACT,EAAE,UAAU,2CAkBZ;yBAzBe,KAAK;;;AA6BrB,wBAAgB,UAAU,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,iBAAiB,2CAMpE;yBANe,UAAU;;;AAU1B,wBAAgB,gBAAgB,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,iBAAiB,2CAM1E;yBANe,gBAAgB;;;AAUhC,wBAAgB,WAAW,CAAC,EAAE,SAAS,EAAE,QAAQ,EAAE,EAAE,iBAAiB,2CAMrE;yBANe,WAAW;;;AAU3B,wBAAgB,UAAU,CAAC,EACzB,SAAS,EACT,QAAQ,EACR,OAAO,EACP,GAAG,IAAI,EACR,EAAE,iBAAiB,GAAG;IAAE,OAAO,CAAC,EAAE,MAAM,IAAI,CAAA;CAAE,2CAgB9C;yBArBe,UAAU"}
@@ -0,0 +1,11 @@
1
+ /**
2
+ * Creates a dedicated portal target appended to `document.body` for rendering
3
+ * toasts, and removes it on unmount. Shared by both the static
4
+ * (`ToastViewport`) and animated (`ToastViewportAnimated`) viewports so the
5
+ * portal lifecycle stays in one place.
6
+ *
7
+ * Returns `null` until the target exists (i.e. after the first client effect),
8
+ * so callers should bail out of rendering the portal while it is `null`.
9
+ */
10
+ export declare function useToastPortal(): HTMLElement | null;
11
+ //# sourceMappingURL=use-toast-portal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"use-toast-portal.d.ts","sourceRoot":"","sources":["../../../src/ui/toast/use-toast-portal.ts"],"names":[],"mappings":"AAIA;;;;;;;;GAQG;AACH,wBAAgB,cAAc,IAAI,WAAW,GAAG,IAAI,CAenD"}
package/dist/ui/toast.js CHANGED
@@ -1,8 +1,8 @@
1
1
  "use client";
2
2
  'use strict';
3
3
 
4
- var chunkAPCN6NUH_js = require('../chunk-APCN6NUH.js');
5
- require('../chunk-6Q4EOLKN.js');
4
+ var chunkSYEEHZXL_js = require('../chunk-SYEEHZXL.js');
5
+ require('../chunk-NDF3HORF.js');
6
6
  require('../chunk-ZS5756ZC.js');
7
7
  require('../chunk-PZ5AY32C.js');
8
8
 
@@ -10,47 +10,47 @@ require('../chunk-PZ5AY32C.js');
10
10
 
11
11
  Object.defineProperty(exports, "Toast", {
12
12
  enumerable: true,
13
- get: function () { return chunkAPCN6NUH_js.Toast; }
13
+ get: function () { return chunkSYEEHZXL_js.Toast; }
14
14
  });
15
15
  Object.defineProperty(exports, "ToastAction", {
16
16
  enumerable: true,
17
- get: function () { return chunkAPCN6NUH_js.ToastAction; }
17
+ get: function () { return chunkSYEEHZXL_js.ToastAction; }
18
18
  });
19
19
  Object.defineProperty(exports, "ToastClose", {
20
20
  enumerable: true,
21
- get: function () { return chunkAPCN6NUH_js.ToastClose; }
21
+ get: function () { return chunkSYEEHZXL_js.ToastClose; }
22
22
  });
23
23
  Object.defineProperty(exports, "ToastDescription", {
24
24
  enumerable: true,
25
- get: function () { return chunkAPCN6NUH_js.ToastDescription; }
25
+ get: function () { return chunkSYEEHZXL_js.ToastDescription; }
26
26
  });
27
27
  Object.defineProperty(exports, "ToastProvider", {
28
28
  enumerable: true,
29
- get: function () { return chunkAPCN6NUH_js.ToastProvider; }
29
+ get: function () { return chunkSYEEHZXL_js.ToastProvider; }
30
30
  });
31
31
  Object.defineProperty(exports, "ToastTitle", {
32
32
  enumerable: true,
33
- get: function () { return chunkAPCN6NUH_js.ToastTitle; }
33
+ get: function () { return chunkSYEEHZXL_js.ToastTitle; }
34
34
  });
35
35
  Object.defineProperty(exports, "ToastViewport", {
36
36
  enumerable: true,
37
- get: function () { return chunkAPCN6NUH_js.ToastViewport; }
37
+ get: function () { return chunkSYEEHZXL_js.ToastViewport; }
38
38
  });
39
39
  Object.defineProperty(exports, "toast", {
40
40
  enumerable: true,
41
- get: function () { return chunkAPCN6NUH_js.toast; }
41
+ get: function () { return chunkSYEEHZXL_js.toast; }
42
42
  });
43
43
  Object.defineProperty(exports, "toastRootVariants", {
44
44
  enumerable: true,
45
- get: function () { return chunkAPCN6NUH_js.toastRootVariants; }
45
+ get: function () { return chunkSYEEHZXL_js.toastRootVariants; }
46
46
  });
47
47
  Object.defineProperty(exports, "toastViewportVariants", {
48
48
  enumerable: true,
49
- get: function () { return chunkAPCN6NUH_js.toastViewportVariants; }
49
+ get: function () { return chunkSYEEHZXL_js.toastViewportVariants; }
50
50
  });
51
51
  Object.defineProperty(exports, "useToast", {
52
52
  enumerable: true,
53
- get: function () { return chunkAPCN6NUH_js.useToast; }
53
+ get: function () { return chunkSYEEHZXL_js.useToast; }
54
54
  });
55
55
  //# sourceMappingURL=toast.js.map
56
56
  //# sourceMappingURL=toast.js.map
package/dist/ui/toast.mjs CHANGED
@@ -1,6 +1,6 @@
1
1
  "use client";
2
- export { Toast, ToastAction, ToastClose, ToastDescription, ToastProvider, ToastTitle, ToastViewport, toast, toastRootVariants, toastViewportVariants, useToast } from '../chunk-HVMYPW3Q.mjs';
3
- import '../chunk-WIKNEHPJ.mjs';
2
+ export { Toast, ToastAction, ToastClose, ToastDescription, ToastProvider, ToastTitle, ToastViewport, toast, toastRootVariants, toastViewportVariants, useToast } from '../chunk-CZBM6ISF.mjs';
3
+ import '../chunk-ZBAKTM2R.mjs';
4
4
  import '../chunk-4D54YOL6.mjs';
5
5
  import '../chunk-J5LGTIGS.mjs';
6
6
  //# sourceMappingURL=toast.mjs.map
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@zentauri-ui/zentauri-components",
3
- "version": "2.1.2",
3
+ "version": "2.1.4",
4
4
  "description": "React + Tailwind UI kit with charts, ESM/CJS builds, per-entry exports, and a zentauri-components / zentauri-ui CLI to vendor UI or hook source into your app",
5
5
  "keywords": [
6
6
  "react",
@@ -101,8 +101,11 @@
101
101
  "check:tokens": "node scripts/check-design-tokens.mjs",
102
102
  "check:exports": "node scripts/check-exports.mjs",
103
103
  "prepack": "npm run build && node scripts/generate-registry.mjs && node scripts/check-design-tokens.mjs && node scripts/check-exports.mjs",
104
+ "lint": "eslint .",
105
+ "check-types": "tsc -p tsconfig.check-types.json --noEmit",
104
106
  "test": "vitest run",
105
- "test:a11y": "vitest run src/accessibility/axe-core.test.tsx",
107
+ "test:coverage": "vitest run --coverage --maxWorkers=2",
108
+ "test:a11y": "vitest run src/accessibility",
106
109
  "test:watch": "vitest",
107
110
  "test:all": "pnpm test && pnpm test:a11y"
108
111
  },
@@ -128,6 +131,7 @@
128
131
  }
129
132
  },
130
133
  "devDependencies": {
134
+ "@repo/eslint-config": "workspace:*",
131
135
  "@repo/typescript-config": "workspace:*",
132
136
  "@testing-library/jest-dom": "^6.9.1",
133
137
  "@testing-library/react": "^16.3.0",
@@ -135,8 +139,10 @@
135
139
  "@types/node": "^20.19.39",
136
140
  "@types/react": "^19",
137
141
  "@types/react-dom": "^19",
142
+ "@vitest/coverage-v8": "^4.1.4",
138
143
  "axe-core": "^4.12.0",
139
144
  "cross-env": "^7.0.3",
145
+ "eslint": "^9.39.1",
140
146
  "jsdom": "^26.1.0",
141
147
  "tsup": "^8.5.1",
142
148
  "typescript": "^5",