@nexus-cross/design-system 1.0.3-beta.1

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 (256) hide show
  1. package/cursor-rules/nexus-project-setup.mdc +188 -0
  2. package/cursor-rules/nexus-ui-api.mdc +698 -0
  3. package/cursor-rules/nexus-ui-components.mdc +104 -0
  4. package/dist/accordion.d.mts +28 -0
  5. package/dist/accordion.d.ts +28 -0
  6. package/dist/accordion.js +28 -0
  7. package/dist/accordion.mjs +3 -0
  8. package/dist/avatar.d.mts +17 -0
  9. package/dist/avatar.d.ts +17 -0
  10. package/dist/avatar.js +16 -0
  11. package/dist/avatar.mjs +3 -0
  12. package/dist/button.d.mts +15 -0
  13. package/dist/button.d.ts +15 -0
  14. package/dist/button.js +16 -0
  15. package/dist/button.mjs +3 -0
  16. package/dist/carousel.d.mts +36 -0
  17. package/dist/carousel.d.ts +36 -0
  18. package/dist/carousel.js +32 -0
  19. package/dist/carousel.mjs +3 -0
  20. package/dist/checkbox.d.mts +21 -0
  21. package/dist/checkbox.d.ts +21 -0
  22. package/dist/checkbox.js +20 -0
  23. package/dist/checkbox.mjs +3 -0
  24. package/dist/chip.d.mts +16 -0
  25. package/dist/chip.d.ts +16 -0
  26. package/dist/chip.js +16 -0
  27. package/dist/chip.mjs +3 -0
  28. package/dist/chunks/chunk-22ULI3BF.js +21 -0
  29. package/dist/chunks/chunk-2JTPRBHZ.mjs +36 -0
  30. package/dist/chunks/chunk-377KBJQG.js +74 -0
  31. package/dist/chunks/chunk-3CHRUKSJ.mjs +120 -0
  32. package/dist/chunks/chunk-4ITJA3IS.mjs +83 -0
  33. package/dist/chunks/chunk-4J3GCZ7W.mjs +102 -0
  34. package/dist/chunks/chunk-53A2SL62.js +218 -0
  35. package/dist/chunks/chunk-54IA2P2Z.mjs +40 -0
  36. package/dist/chunks/chunk-5I2VRWWU.js +172 -0
  37. package/dist/chunks/chunk-5TBXVD56.js +88 -0
  38. package/dist/chunks/chunk-6DZVNFVY.js +82 -0
  39. package/dist/chunks/chunk-6FHK6CBR.js +117 -0
  40. package/dist/chunks/chunk-6H7V2I3X.mjs +270 -0
  41. package/dist/chunks/chunk-6MRM5K2N.js +106 -0
  42. package/dist/chunks/chunk-6NTASYZO.js +132 -0
  43. package/dist/chunks/chunk-76CY4STF.js +165 -0
  44. package/dist/chunks/chunk-76K6KXCT.js +100 -0
  45. package/dist/chunks/chunk-7MT3QYE6.js +92 -0
  46. package/dist/chunks/chunk-7OEK2KX3.mjs +81 -0
  47. package/dist/chunks/chunk-AKIBUO5A.mjs +83 -0
  48. package/dist/chunks/chunk-AOVU67NI.mjs +139 -0
  49. package/dist/chunks/chunk-AOXXE5UQ.mjs +14 -0
  50. package/dist/chunks/chunk-AWBGWBFS.js +135 -0
  51. package/dist/chunks/chunk-AZ2URLDD.js +39 -0
  52. package/dist/chunks/chunk-BEA727LO.mjs +108 -0
  53. package/dist/chunks/chunk-C3E7CSKG.mjs +115 -0
  54. package/dist/chunks/chunk-C6H2UNOX.js +83 -0
  55. package/dist/chunks/chunk-CVYXRSXT.mjs +8 -0
  56. package/dist/chunks/chunk-EIOP4DOE.mjs +292 -0
  57. package/dist/chunks/chunk-FA2OPP3U.mjs +140 -0
  58. package/dist/chunks/chunk-FHPHDK3O.mjs +89 -0
  59. package/dist/chunks/chunk-FKHW7QYG.js +725 -0
  60. package/dist/chunks/chunk-FKZI2HTI.js +104 -0
  61. package/dist/chunks/chunk-G4XJG7XI.js +66 -0
  62. package/dist/chunks/chunk-GMIGQ5VP.mjs +86 -0
  63. package/dist/chunks/chunk-GSLIY6WW.js +109 -0
  64. package/dist/chunks/chunk-HHXDOKXY.js +108 -0
  65. package/dist/chunks/chunk-HUPAHDJ7.js +273 -0
  66. package/dist/chunks/chunk-I252NERB.mjs +21 -0
  67. package/dist/chunks/chunk-I7YJB2F5.js +143 -0
  68. package/dist/chunks/chunk-IB5UCYQY.mjs +66 -0
  69. package/dist/chunks/chunk-IJG7J2VU.mjs +148 -0
  70. package/dist/chunks/chunk-INP2AH3B.js +27 -0
  71. package/dist/chunks/chunk-IUNNTSD2.mjs +195 -0
  72. package/dist/chunks/chunk-JNMCYWGY.js +10 -0
  73. package/dist/chunks/chunk-JZ3PWHKS.mjs +51 -0
  74. package/dist/chunks/chunk-KWPIEHD2.mjs +78 -0
  75. package/dist/chunks/chunk-LBKBCI2K.mjs +44 -0
  76. package/dist/chunks/chunk-LVTD2UQN.mjs +48 -0
  77. package/dist/chunks/chunk-MPKRXMCJ.js +93 -0
  78. package/dist/chunks/chunk-NCQDOPBR.mjs +86 -0
  79. package/dist/chunks/chunk-NHDGKOAM.js +104 -0
  80. package/dist/chunks/chunk-OTGS6BDQ.mjs +25 -0
  81. package/dist/chunks/chunk-Q2TMXHPK.js +178 -0
  82. package/dist/chunks/chunk-Q7GQVAYY.js +88 -0
  83. package/dist/chunks/chunk-Q7H6LCNN.js +169 -0
  84. package/dist/chunks/chunk-QJNQCLMV.js +25 -0
  85. package/dist/chunks/chunk-QK6NCII4.js +36 -0
  86. package/dist/chunks/chunk-RLP3U52D.mjs +153 -0
  87. package/dist/chunks/chunk-T2IY2TSR.js +43 -0
  88. package/dist/chunks/chunk-TLTEUIBY.js +112 -0
  89. package/dist/chunks/chunk-TPBKQ3WC.js +303 -0
  90. package/dist/chunks/chunk-TR5JBBEA.mjs +116 -0
  91. package/dist/chunks/chunk-TWHDXCKR.js +61 -0
  92. package/dist/chunks/chunk-U56AGSLE.mjs +106 -0
  93. package/dist/chunks/chunk-U6KOUYWX.mjs +66 -0
  94. package/dist/chunks/chunk-U76LT5GE.js +70 -0
  95. package/dist/chunks/chunk-UDQXLI5Y.mjs +81 -0
  96. package/dist/chunks/chunk-UH667FUK.mjs +712 -0
  97. package/dist/chunks/chunk-UR6JOKVB.mjs +65 -0
  98. package/dist/chunks/chunk-VH5FF6DZ.mjs +38 -0
  99. package/dist/chunks/chunk-WJ2OVQD3.mjs +105 -0
  100. package/dist/chunks/chunk-WNFJ4NJN.mjs +55 -0
  101. package/dist/chunks/chunk-WSWD5ZUJ.js +106 -0
  102. package/dist/chunks/chunk-XALPBGSC.mjs +23 -0
  103. package/dist/chunks/chunk-XEHFB62A.js +82 -0
  104. package/dist/chunks/chunk-YEGPB7A7.js +83 -0
  105. package/dist/chunks/chunk-YEWKPWK3.mjs +80 -0
  106. package/dist/chunks/chunk-Z7OKV6NW.mjs +59 -0
  107. package/dist/chunks/chunk-ZCMKIB5U.js +140 -0
  108. package/dist/client-only.d.mts +13 -0
  109. package/dist/client-only.d.ts +13 -0
  110. package/dist/client-only.js +11 -0
  111. package/dist/client-only.mjs +2 -0
  112. package/dist/countdown.d.mts +27 -0
  113. package/dist/countdown.d.ts +27 -0
  114. package/dist/countdown.js +16 -0
  115. package/dist/countdown.mjs +3 -0
  116. package/dist/counter.d.mts +15 -0
  117. package/dist/counter.d.ts +15 -0
  118. package/dist/counter.js +11 -0
  119. package/dist/counter.mjs +2 -0
  120. package/dist/divider.d.mts +14 -0
  121. package/dist/divider.d.ts +14 -0
  122. package/dist/divider.js +16 -0
  123. package/dist/divider.mjs +3 -0
  124. package/dist/drawer.d.mts +42 -0
  125. package/dist/drawer.d.ts +42 -0
  126. package/dist/drawer.js +44 -0
  127. package/dist/drawer.mjs +3 -0
  128. package/dist/ellipsis.d.mts +16 -0
  129. package/dist/ellipsis.d.ts +16 -0
  130. package/dist/ellipsis.js +12 -0
  131. package/dist/ellipsis.mjs +3 -0
  132. package/dist/error-boundary.d.mts +20 -0
  133. package/dist/error-boundary.d.ts +20 -0
  134. package/dist/error-boundary.js +11 -0
  135. package/dist/error-boundary.mjs +2 -0
  136. package/dist/hooks/useCheckDevice.d.mts +47 -0
  137. package/dist/hooks/useCheckDevice.d.ts +47 -0
  138. package/dist/hooks/useCheckDevice.js +8 -0
  139. package/dist/hooks/useCheckDevice.mjs +2 -0
  140. package/dist/hooks/useClickOutside.d.mts +12 -0
  141. package/dist/hooks/useClickOutside.d.ts +12 -0
  142. package/dist/hooks/useClickOutside.js +8 -0
  143. package/dist/hooks/useClickOutside.mjs +2 -0
  144. package/dist/hooks/useDraggableBottomSheet.d.mts +24 -0
  145. package/dist/hooks/useDraggableBottomSheet.d.ts +24 -0
  146. package/dist/hooks/useDraggableBottomSheet.js +11 -0
  147. package/dist/hooks/useDraggableBottomSheet.mjs +2 -0
  148. package/dist/hooks/useDraggableWindow.d.mts +21 -0
  149. package/dist/hooks/useDraggableWindow.d.ts +21 -0
  150. package/dist/hooks/useDraggableWindow.js +11 -0
  151. package/dist/hooks/useDraggableWindow.mjs +2 -0
  152. package/dist/hooks/useInView.d.mts +14 -0
  153. package/dist/hooks/useInView.d.ts +14 -0
  154. package/dist/hooks/useInView.js +17 -0
  155. package/dist/hooks/useInView.mjs +2 -0
  156. package/dist/hooks/useModal.d.mts +2 -0
  157. package/dist/hooks/useModal.d.ts +2 -0
  158. package/dist/hooks/useModal.js +11 -0
  159. package/dist/hooks/useModal.mjs +2 -0
  160. package/dist/index.d.mts +74 -0
  161. package/dist/index.d.ts +74 -0
  162. package/dist/index.js +633 -0
  163. package/dist/index.mjs +227 -0
  164. package/dist/infinite-scroll.d.mts +26 -0
  165. package/dist/infinite-scroll.d.ts +26 -0
  166. package/dist/infinite-scroll.js +12 -0
  167. package/dist/infinite-scroll.mjs +3 -0
  168. package/dist/marquee.d.mts +12 -0
  169. package/dist/marquee.d.ts +12 -0
  170. package/dist/marquee.js +12 -0
  171. package/dist/marquee.mjs +3 -0
  172. package/dist/modal/index.d.mts +87 -0
  173. package/dist/modal/index.d.ts +87 -0
  174. package/dist/modal/index.js +54 -0
  175. package/dist/modal/index.mjs +9 -0
  176. package/dist/number-input.d.mts +21 -0
  177. package/dist/number-input.d.ts +21 -0
  178. package/dist/number-input.js +16 -0
  179. package/dist/number-input.mjs +3 -0
  180. package/dist/pagination.d.mts +21 -0
  181. package/dist/pagination.d.ts +21 -0
  182. package/dist/pagination.js +20 -0
  183. package/dist/pagination.mjs +3 -0
  184. package/dist/popover.d.mts +25 -0
  185. package/dist/popover.d.ts +25 -0
  186. package/dist/popover.js +32 -0
  187. package/dist/popover.mjs +3 -0
  188. package/dist/radio-group.d.mts +29 -0
  189. package/dist/radio-group.d.ts +29 -0
  190. package/dist/radio-group.js +24 -0
  191. package/dist/radio-group.mjs +3 -0
  192. package/dist/select.d.mts +31 -0
  193. package/dist/select.d.ts +31 -0
  194. package/dist/select.js +24 -0
  195. package/dist/select.mjs +3 -0
  196. package/dist/spinner.d.mts +9 -0
  197. package/dist/spinner.d.ts +9 -0
  198. package/dist/spinner.js +12 -0
  199. package/dist/spinner.mjs +3 -0
  200. package/dist/styles.css +2 -0
  201. package/dist/styles.d.mts +3 -0
  202. package/dist/styles.d.ts +3 -0
  203. package/dist/styles.js +19 -0
  204. package/dist/styles.mjs +17 -0
  205. package/dist/switch.d.mts +15 -0
  206. package/dist/switch.d.ts +15 -0
  207. package/dist/switch.js +16 -0
  208. package/dist/switch.mjs +3 -0
  209. package/dist/tab.d.mts +36 -0
  210. package/dist/tab.d.ts +36 -0
  211. package/dist/tab.js +20 -0
  212. package/dist/tab.mjs +3 -0
  213. package/dist/table.d.mts +80 -0
  214. package/dist/table.d.ts +80 -0
  215. package/dist/table.js +32 -0
  216. package/dist/table.mjs +3 -0
  217. package/dist/text-area.d.mts +15 -0
  218. package/dist/text-area.d.ts +15 -0
  219. package/dist/text-area.js +16 -0
  220. package/dist/text-area.mjs +3 -0
  221. package/dist/text-input.d.mts +17 -0
  222. package/dist/text-input.d.ts +17 -0
  223. package/dist/text-input.js +16 -0
  224. package/dist/text-input.mjs +3 -0
  225. package/dist/theme-provider.d.mts +25 -0
  226. package/dist/theme-provider.d.ts +25 -0
  227. package/dist/theme-provider.js +15 -0
  228. package/dist/theme-provider.mjs +2 -0
  229. package/dist/toast.d.mts +42 -0
  230. package/dist/toast.d.ts +42 -0
  231. package/dist/toast.js +20 -0
  232. package/dist/toast.mjs +3 -0
  233. package/dist/tooltip.d.mts +24 -0
  234. package/dist/tooltip.d.ts +24 -0
  235. package/dist/tooltip.js +20 -0
  236. package/dist/tooltip.mjs +3 -0
  237. package/dist/typography.d.mts +19 -0
  238. package/dist/typography.d.ts +19 -0
  239. package/dist/typography.js +102 -0
  240. package/dist/typography.mjs +79 -0
  241. package/dist/useModal-BsGIcP8t.d.mts +128 -0
  242. package/dist/useModal-BsGIcP8t.d.ts +128 -0
  243. package/dist/utils/cn.d.mts +15 -0
  244. package/dist/utils/cn.d.ts +15 -0
  245. package/dist/utils/cn.js +11 -0
  246. package/dist/utils/cn.mjs +2 -0
  247. package/dist/utils/scroll.d.mts +4 -0
  248. package/dist/utils/scroll.d.ts +4 -0
  249. package/dist/utils/scroll.js +15 -0
  250. package/dist/utils/scroll.mjs +2 -0
  251. package/dist/virtual-scroll.d.mts +34 -0
  252. package/dist/virtual-scroll.d.ts +34 -0
  253. package/dist/virtual-scroll.js +16 -0
  254. package/dist/virtual-scroll.mjs +3 -0
  255. package/package.json +271 -0
  256. package/scripts/setup-cursor-rules.cjs +92 -0
@@ -0,0 +1,140 @@
1
+ import { cn } from './chunk-XALPBGSC.mjs';
2
+ import * as SelectPrimitive from '@radix-ui/react-select';
3
+ import { cva } from 'class-variance-authority';
4
+ import { useState } from 'react';
5
+ import { jsx, jsxs } from 'react/jsx-runtime';
6
+
7
+ var selectTriggerVariants = cva(
8
+ [
9
+ "nx:relative",
10
+ "nx:flex nx:h-10 nx:items-center nx:justify-between nx:rounded nx:border nx:bg-surface-default nx:border-border-default",
11
+ "nx:placeholder:text-text-tertiary",
12
+ "nx:disabled:cursor-not-allowed nx:disabled:opacity-50",
13
+ "nx:hover:border-border-strong nx:transition-all nx:duration-200"
14
+ ],
15
+ {
16
+ variants: {
17
+ variant: {
18
+ default: "nx:bg-surface-hover",
19
+ outline: "nx:bg-surface-default"
20
+ },
21
+ size: {
22
+ sm: "nx:w-16",
23
+ md: "nx:w-32",
24
+ lg: "nx:w-48",
25
+ full: "nx:w-full"
26
+ }
27
+ },
28
+ defaultVariants: { variant: "default", size: "full" }
29
+ }
30
+ );
31
+ var selectContentVariants = cva(
32
+ [
33
+ "nx:relative nx:z-50 nx:max-h-96 nx:overflow-hidden nx:rounded nx:border nx:bg-surface-default nx:border-border-default nx:shadow-lg",
34
+ "nx:data-[state=open]:animate-in nx:data-[state=closed]:animate-out",
35
+ "nx:data-[state=closed]:fade-out-0 nx:data-[state=open]:fade-in-0",
36
+ "nx:data-[state=closed]:zoom-out-95 nx:data-[state=open]:zoom-in-95",
37
+ "nx:data-[side=bottom]:slide-in-from-top-2 nx:data-[side=left]:slide-in-from-right-2",
38
+ "nx:data-[side=right]:slide-in-from-left-2 nx:data-[side=top]:slide-in-from-bottom-2"
39
+ ],
40
+ {
41
+ variants: {
42
+ size: {
43
+ sm: "nx:w-16",
44
+ md: "nx:w-32",
45
+ lg: "nx:w-48",
46
+ full: "nx:w-[var(--radix-popper-anchor-width)]"
47
+ }
48
+ },
49
+ defaultVariants: { size: "full" }
50
+ }
51
+ );
52
+ var ChevronDown = ({ className }) => /* @__PURE__ */ jsx("svg", { className, viewBox: "0 0 16 16", fill: "currentColor", children: /* @__PURE__ */ jsx("path", { d: "M4 6l4 4 4-4", fill: "none", stroke: "currentColor", strokeWidth: "2", strokeLinecap: "round" }) });
53
+ var Select = ({
54
+ children,
55
+ value,
56
+ onValueChange,
57
+ placeholder,
58
+ disabled,
59
+ size,
60
+ variant,
61
+ className = "",
62
+ triggerClassName = "",
63
+ displayComponent
64
+ }) => {
65
+ const [isOpen, setIsOpen] = useState(false);
66
+ return /* @__PURE__ */ jsx(
67
+ SelectPrimitive.Root,
68
+ {
69
+ value,
70
+ onValueChange,
71
+ disabled,
72
+ onOpenChange: setIsOpen,
73
+ children: /* @__PURE__ */ jsxs(
74
+ "div",
75
+ {
76
+ className: cn(
77
+ selectTriggerVariants({ size, variant }),
78
+ displayComponent && "nx:justify-end",
79
+ className
80
+ ),
81
+ children: [
82
+ displayComponent && /* @__PURE__ */ jsx("div", { className: "nx:absolute nx:top-0 nx:left-0 nx:flex nx:h-full nx:w-[calc(100%-30px)] nx:items-center", children: displayComponent }),
83
+ /* @__PURE__ */ jsxs(
84
+ SelectPrimitive.Trigger,
85
+ {
86
+ className: cn(
87
+ "nx:flex nx:h-full nx:w-full nx:flex-row-reverse nx:items-center nx:justify-between nx:rounded nx:px-3 nx:py-2 nx:focus:outline-none",
88
+ triggerClassName
89
+ ),
90
+ children: [
91
+ /* @__PURE__ */ jsx(SelectPrimitive.Icon, { asChild: true, children: /* @__PURE__ */ jsx(
92
+ ChevronDown,
93
+ {
94
+ className: cn(
95
+ "nx:size-3 nx:opacity-50 nx:transition-transform nx:duration-200",
96
+ isOpen && "nx:rotate-180"
97
+ )
98
+ }
99
+ ) }),
100
+ !displayComponent && /* @__PURE__ */ jsx(SelectPrimitive.Value, { placeholder })
101
+ ]
102
+ }
103
+ ),
104
+ /* @__PURE__ */ jsx(SelectPrimitive.Portal, { children: /* @__PURE__ */ jsx(
105
+ SelectPrimitive.Content,
106
+ {
107
+ className: cn(selectContentVariants({ size })),
108
+ position: "popper",
109
+ children: /* @__PURE__ */ jsx(SelectPrimitive.Viewport, { className: "nx:p-1", children })
110
+ }
111
+ ) })
112
+ ]
113
+ }
114
+ )
115
+ }
116
+ );
117
+ };
118
+ var SelectItem = ({
119
+ children,
120
+ value,
121
+ disabled,
122
+ className = ""
123
+ }) => /* @__PURE__ */ jsx(
124
+ SelectPrimitive.Item,
125
+ {
126
+ value,
127
+ disabled,
128
+ className: cn(
129
+ "nx:relative nx:flex nx:w-full nx:cursor-pointer nx:items-center nx:rounded nx:px-3 nx:py-2 nx:transition-colors nx:outline-none nx:select-none",
130
+ "nx:hover:bg-surface-hover",
131
+ "nx:focus:bg-surface-hover",
132
+ "nx:data-[disabled]:pointer-events-none nx:data-[disabled]:opacity-50",
133
+ "nx:data-[highlighted]:bg-surface-hover",
134
+ className
135
+ ),
136
+ children: /* @__PURE__ */ jsx(SelectPrimitive.ItemText, { children })
137
+ }
138
+ );
139
+
140
+ export { Select, SelectItem, selectContentVariants, selectTriggerVariants };
@@ -0,0 +1,89 @@
1
+ import { cn } from './chunk-XALPBGSC.mjs';
2
+ import * as React from 'react';
3
+ import { jsx, jsxs } from 'react/jsx-runtime';
4
+
5
+ function calcTimeLeft(endTimestamp) {
6
+ const total = Math.max(0, endTimestamp - Date.now());
7
+ const isFinished = total <= 0;
8
+ return {
9
+ days: Math.floor(total / (1e3 * 60 * 60 * 24)),
10
+ hours: Math.floor(total / (1e3 * 60 * 60) % 24),
11
+ minutes: Math.floor(total / (1e3 * 60) % 60),
12
+ seconds: Math.floor(total / 1e3 % 60),
13
+ total,
14
+ isFinished
15
+ };
16
+ }
17
+ function useCountdown(endTimestamp, onEnd) {
18
+ const [timeLeft, setTimeLeft] = React.useState(() => calcTimeLeft(endTimestamp));
19
+ const onEndRef = React.useRef(onEnd);
20
+ onEndRef.current = onEnd;
21
+ React.useEffect(() => {
22
+ setTimeLeft(calcTimeLeft(endTimestamp));
23
+ const id = setInterval(() => {
24
+ const next = calcTimeLeft(endTimestamp);
25
+ setTimeLeft(next);
26
+ if (next.isFinished) {
27
+ clearInterval(id);
28
+ onEndRef.current?.();
29
+ }
30
+ }, 1e3);
31
+ const handleVisibility = () => {
32
+ if (!document.hidden) setTimeLeft(calcTimeLeft(endTimestamp));
33
+ };
34
+ document.addEventListener("visibilitychange", handleVisibility);
35
+ return () => {
36
+ clearInterval(id);
37
+ document.removeEventListener("visibilitychange", handleVisibility);
38
+ };
39
+ }, [endTimestamp]);
40
+ return timeLeft;
41
+ }
42
+ var pad = (n) => n.toString().padStart(2, "0");
43
+ var Countdown = React.forwardRef(
44
+ ({
45
+ endTimestamp,
46
+ separator = ":",
47
+ showDays = true,
48
+ labels,
49
+ onEnd,
50
+ render,
51
+ className,
52
+ ...props
53
+ }, ref) => {
54
+ const timeLeft = useCountdown(endTimestamp, onEnd);
55
+ if (render) {
56
+ return /* @__PURE__ */ jsx("div", { ref, className, ...props, children: render(timeLeft) });
57
+ }
58
+ const units = [];
59
+ if (showDays && timeLeft.days > 0) {
60
+ units.push({ value: timeLeft.days.toString(), label: labels?.days });
61
+ }
62
+ units.push(
63
+ { value: pad(timeLeft.hours), label: labels?.hours },
64
+ { value: pad(timeLeft.minutes), label: labels?.minutes },
65
+ { value: pad(timeLeft.seconds), label: labels?.seconds }
66
+ );
67
+ return /* @__PURE__ */ jsx(
68
+ "div",
69
+ {
70
+ ref,
71
+ className: cn("nx:inline-flex nx:items-center nx:gap-1 nx:font-mono nx:tabular-nums", className),
72
+ role: "timer",
73
+ "aria-live": "polite",
74
+ "aria-atomic": "true",
75
+ ...props,
76
+ children: units.map((unit, i) => /* @__PURE__ */ jsxs(React.Fragment, { children: [
77
+ i > 0 && separator && /* @__PURE__ */ jsx("span", { className: "nx:text-text-tertiary nx:mx-0.5", children: separator }),
78
+ /* @__PURE__ */ jsxs("span", { children: [
79
+ unit.value,
80
+ unit.label && /* @__PURE__ */ jsx("span", { className: "nx:text-text-tertiary nx:text-xs nx:ml-0.5", children: unit.label })
81
+ ] })
82
+ ] }, i))
83
+ }
84
+ );
85
+ }
86
+ );
87
+ Countdown.displayName = "Countdown";
88
+
89
+ export { Countdown, useCountdown };