@mbao01/common 0.8.0 → 0.9.0

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 (276) hide show
  1. package/dist/types/components/ActivityFeed/ActivityFeed.d.ts +6 -0
  2. package/dist/types/components/ActivityFeed/constants.d.ts +6 -0
  3. package/dist/types/components/ActivityFeed/index.d.ts +2 -0
  4. package/dist/types/components/ActivityFeed/types.d.ts +21 -0
  5. package/dist/types/components/Amount/Amount.d.ts +6 -0
  6. package/dist/types/components/Amount/index.d.ts +2 -0
  7. package/dist/types/components/Amount/types.d.ts +19 -0
  8. package/dist/types/components/AnimatedCounter/AnimatedCounter.d.ts +6 -0
  9. package/dist/types/components/AnimatedCounter/index.d.ts +2 -0
  10. package/dist/types/components/AnimatedCounter/types.d.ts +13 -0
  11. package/dist/types/components/AnimatedGroup/AnimatedGroup.d.ts +6 -0
  12. package/dist/types/components/AnimatedGroup/index.d.ts +2 -0
  13. package/dist/types/components/AnimatedGroup/types.d.ts +22 -0
  14. package/dist/types/components/AnimatedList/AnimatedList.d.ts +6 -0
  15. package/dist/types/components/AnimatedList/index.d.ts +2 -0
  16. package/dist/types/components/AnimatedList/types.d.ts +13 -0
  17. package/dist/types/components/BorderBeam/BorderBeam.d.ts +6 -0
  18. package/dist/types/components/BorderBeam/index.d.ts +2 -0
  19. package/dist/types/components/BorderBeam/types.d.ts +13 -0
  20. package/dist/types/components/Box/Box.d.ts +4 -0
  21. package/dist/types/components/Box/constants.d.ts +4 -0
  22. package/dist/types/components/CalendarHeatmap/CalendarHeatmap.d.ts +6 -0
  23. package/dist/types/components/CalendarHeatmap/index.d.ts +2 -0
  24. package/dist/types/components/CalendarHeatmap/types.d.ts +25 -0
  25. package/dist/types/components/Chart/components/ChartLegend.d.ts +1 -2
  26. package/dist/types/components/Chart/stories/args/index.d.ts +1 -1
  27. package/dist/types/components/Chart/stories/examples/AreaChart.d.ts +6 -0
  28. package/dist/types/components/Chart/stories/examples/BarChart.d.ts +11 -0
  29. package/dist/types/components/Chart/stories/examples/LineChart.d.ts +10 -0
  30. package/dist/types/components/Chart/stories/examples/PieChart.d.ts +5 -0
  31. package/dist/types/components/Chart/stories/examples/RadialChart.d.ts +5 -0
  32. package/dist/types/components/Chart/types.d.ts +1 -1
  33. package/dist/types/components/CircularProgress/CircularProgress.d.ts +6 -0
  34. package/dist/types/components/CircularProgress/constants.d.ts +5 -0
  35. package/dist/types/components/CircularProgress/index.d.ts +2 -0
  36. package/dist/types/components/CircularProgress/types.d.ts +17 -0
  37. package/dist/types/components/ComparisonBar/ComparisonBar.d.ts +6 -0
  38. package/dist/types/components/ComparisonBar/constants.d.ts +4 -0
  39. package/dist/types/components/ComparisonBar/index.d.ts +2 -0
  40. package/dist/types/components/ComparisonBar/types.d.ts +21 -0
  41. package/dist/types/components/Confetti/Confetti.d.ts +6 -0
  42. package/dist/types/components/Confetti/index.d.ts +2 -0
  43. package/dist/types/components/Confetti/types.d.ts +19 -0
  44. package/dist/types/components/CountdownTimer/CountdownTimer.d.ts +6 -0
  45. package/dist/types/components/CountdownTimer/index.d.ts +2 -0
  46. package/dist/types/components/CountdownTimer/types.d.ts +13 -0
  47. package/dist/types/components/DataList/DataList.d.ts +6 -0
  48. package/dist/types/components/DataList/constants.d.ts +12 -0
  49. package/dist/types/components/DataList/index.d.ts +2 -0
  50. package/dist/types/components/DataList/types.d.ts +15 -0
  51. package/dist/types/components/DatePicker/DateRangePresetPicker.d.ts +2 -0
  52. package/dist/types/components/DatePicker/index.d.ts +1 -0
  53. package/dist/types/components/DatePicker/types.d.ts +19 -0
  54. package/dist/types/components/Description/Description.d.ts +2 -1
  55. package/dist/types/components/Description/DescriptionGroup.d.ts +6 -0
  56. package/dist/types/components/Description/constants.d.ts +23 -0
  57. package/dist/types/components/Description/index.d.ts +2 -0
  58. package/dist/types/components/Description/types.d.ts +28 -3
  59. package/dist/types/components/Form/DatetimeInput/DatetimeInput.d.ts +1 -1
  60. package/dist/types/components/GlowCard/GlowCard.d.ts +6 -0
  61. package/dist/types/components/GlowCard/index.d.ts +2 -0
  62. package/dist/types/components/GlowCard/types.d.ts +8 -0
  63. package/dist/types/components/GradientText/GradientText.d.ts +6 -0
  64. package/dist/types/components/GradientText/index.d.ts +2 -0
  65. package/dist/types/components/GradientText/types.d.ts +14 -0
  66. package/dist/types/components/Greeting/Greeting.d.ts +6 -0
  67. package/dist/types/components/Greeting/index.d.ts +2 -0
  68. package/dist/types/components/Greeting/types.d.ts +9 -0
  69. package/dist/types/components/KPICard/KPICard.d.ts +6 -0
  70. package/dist/types/components/KPICard/index.d.ts +2 -0
  71. package/dist/types/components/KPICard/types.d.ts +21 -0
  72. package/dist/types/components/Marquee/Marquee.d.ts +6 -0
  73. package/dist/types/components/Marquee/index.d.ts +2 -0
  74. package/dist/types/components/Marquee/types.d.ts +12 -0
  75. package/dist/types/components/Meteors/Meteors.d.ts +6 -0
  76. package/dist/types/components/Meteors/index.d.ts +2 -0
  77. package/dist/types/components/Meteors/types.d.ts +5 -0
  78. package/dist/types/components/MiniAreaChart/MiniAreaChart.d.ts +6 -0
  79. package/dist/types/components/MiniAreaChart/index.d.ts +2 -0
  80. package/dist/types/components/MiniAreaChart/types.d.ts +10 -0
  81. package/dist/types/components/MiniBarChart/MiniBarChart.d.ts +6 -0
  82. package/dist/types/components/MiniBarChart/index.d.ts +2 -0
  83. package/dist/types/components/MiniBarChart/types.d.ts +15 -0
  84. package/dist/types/components/MiniDonutChart/MiniDonutChart.d.ts +6 -0
  85. package/dist/types/components/MiniDonutChart/index.d.ts +2 -0
  86. package/dist/types/components/MiniDonutChart/types.d.ts +15 -0
  87. package/dist/types/components/MiniStackedBar/MiniStackedBar.d.ts +6 -0
  88. package/dist/types/components/MiniStackedBar/index.d.ts +2 -0
  89. package/dist/types/components/MiniStackedBar/types.d.ts +13 -0
  90. package/dist/types/components/NumberTicker/NumberTicker.d.ts +6 -0
  91. package/dist/types/components/NumberTicker/index.d.ts +2 -0
  92. package/dist/types/components/NumberTicker/types.d.ts +11 -0
  93. package/dist/types/components/Pulse/Pulse.d.ts +6 -0
  94. package/dist/types/components/Pulse/constants.d.ts +10 -0
  95. package/dist/types/components/Pulse/index.d.ts +2 -0
  96. package/dist/types/components/Pulse/types.d.ts +11 -0
  97. package/dist/types/components/Resizable/Resizable.d.ts +1 -1
  98. package/dist/types/components/ShinyButton/ShinyButton.d.ts +6 -0
  99. package/dist/types/components/ShinyButton/index.d.ts +2 -0
  100. package/dist/types/components/ShinyButton/types.d.ts +4 -0
  101. package/dist/types/components/Sparkline/Sparkline.d.ts +6 -0
  102. package/dist/types/components/Sparkline/index.d.ts +2 -0
  103. package/dist/types/components/Sparkline/types.d.ts +17 -0
  104. package/dist/types/components/SpotlightCard/SpotlightCard.d.ts +6 -0
  105. package/dist/types/components/SpotlightCard/index.d.ts +2 -0
  106. package/dist/types/components/SpotlightCard/types.d.ts +7 -0
  107. package/dist/types/components/StatCard/StatCard.d.ts +6 -0
  108. package/dist/types/components/StatCard/index.d.ts +2 -0
  109. package/dist/types/components/StatCard/types.d.ts +15 -0
  110. package/dist/types/components/TextShimmer/TextShimmer.d.ts +6 -0
  111. package/dist/types/components/TextShimmer/index.d.ts +2 -0
  112. package/dist/types/components/TextShimmer/types.d.ts +7 -0
  113. package/dist/types/components/TrendBadge/TrendBadge.d.ts +6 -0
  114. package/dist/types/components/TrendBadge/constants.d.ts +7 -0
  115. package/dist/types/components/TrendBadge/index.d.ts +2 -0
  116. package/dist/types/components/TrendBadge/types.d.ts +15 -0
  117. package/dist/types/components/WidgetShell/WidgetShell.d.ts +6 -0
  118. package/dist/types/components/WidgetShell/index.d.ts +2 -0
  119. package/dist/types/components/WidgetShell/types.d.ts +20 -0
  120. package/dist/types/index.d.ts +33 -0
  121. package/package.json +58 -58
  122. package/src/components/Accordion/constants.ts +1 -1
  123. package/src/components/ActivityFeed/ActivityFeed.tsx +51 -0
  124. package/src/components/ActivityFeed/constants.ts +19 -0
  125. package/src/components/ActivityFeed/index.ts +2 -0
  126. package/src/components/ActivityFeed/types.ts +23 -0
  127. package/src/components/Alert/constants.ts +1 -1
  128. package/src/components/AlertDialog/constants.ts +1 -1
  129. package/src/components/Amount/Amount.tsx +50 -0
  130. package/src/components/Amount/index.ts +2 -0
  131. package/src/components/Amount/types.ts +20 -0
  132. package/src/components/AnimatedCounter/AnimatedCounter.tsx +68 -0
  133. package/src/components/AnimatedCounter/index.ts +2 -0
  134. package/src/components/AnimatedCounter/types.ts +14 -0
  135. package/src/components/AnimatedGroup/AnimatedGroup.tsx +97 -0
  136. package/src/components/AnimatedGroup/index.ts +2 -0
  137. package/src/components/AnimatedGroup/types.ts +21 -0
  138. package/src/components/AnimatedList/AnimatedList.tsx +42 -0
  139. package/src/components/AnimatedList/index.ts +2 -0
  140. package/src/components/AnimatedList/types.ts +15 -0
  141. package/src/components/Badge/constants.ts +1 -1
  142. package/src/components/Banner/constants.ts +1 -1
  143. package/src/components/BorderBeam/BorderBeam.tsx +41 -0
  144. package/src/components/BorderBeam/index.ts +2 -0
  145. package/src/components/BorderBeam/types.ts +14 -0
  146. package/src/components/Box/Box.tsx +8 -2
  147. package/src/components/Box/constants.ts +35 -0
  148. package/src/components/Button/constants.ts +66 -63
  149. package/src/components/CalendarHeatmap/CalendarHeatmap.tsx +141 -0
  150. package/src/components/CalendarHeatmap/index.ts +2 -0
  151. package/src/components/CalendarHeatmap/types.ts +27 -0
  152. package/src/components/Card/constants.ts +24 -21
  153. package/src/components/Carousel/constants.ts +2 -2
  154. package/src/components/Chart/components/ChartTooltip.tsx +1 -1
  155. package/src/components/Chart/stories/args/index.ts +2 -1
  156. package/src/components/Chart/stories/examples/AreaChart.tsx +55 -0
  157. package/src/components/Chart/stories/examples/BarChart.tsx +104 -6
  158. package/src/components/Chart/stories/examples/LineChart.tsx +111 -0
  159. package/src/components/Chart/stories/examples/PieChart.tsx +55 -0
  160. package/src/components/Chart/stories/examples/RadialChart.tsx +65 -0
  161. package/src/components/Chart/types.ts +1 -1
  162. package/src/components/CircularProgress/CircularProgress.tsx +46 -0
  163. package/src/components/CircularProgress/constants.ts +32 -0
  164. package/src/components/CircularProgress/index.ts +2 -0
  165. package/src/components/CircularProgress/types.ts +18 -0
  166. package/src/components/Command/constants.ts +1 -1
  167. package/src/components/ComparisonBar/ComparisonBar.tsx +65 -0
  168. package/src/components/ComparisonBar/constants.ts +23 -0
  169. package/src/components/ComparisonBar/index.ts +2 -0
  170. package/src/components/ComparisonBar/types.ts +23 -0
  171. package/src/components/Confetti/Confetti.tsx +82 -0
  172. package/src/components/Confetti/index.ts +2 -0
  173. package/src/components/Confetti/types.ts +20 -0
  174. package/src/components/CountdownTimer/CountdownTimer.tsx +91 -0
  175. package/src/components/CountdownTimer/index.ts +2 -0
  176. package/src/components/CountdownTimer/types.ts +14 -0
  177. package/src/components/DataList/DataList.tsx +32 -0
  178. package/src/components/DataList/constants.ts +47 -0
  179. package/src/components/DataList/index.ts +2 -0
  180. package/src/components/DataList/types.ts +17 -0
  181. package/src/components/DatePicker/DateRangePresetPicker.tsx +122 -0
  182. package/src/components/DatePicker/index.ts +1 -0
  183. package/src/components/DatePicker/types.ts +22 -0
  184. package/src/components/Description/Description.tsx +67 -5
  185. package/src/components/Description/DescriptionGroup.tsx +39 -0
  186. package/src/components/Description/constants.ts +128 -0
  187. package/src/components/Description/index.ts +10 -0
  188. package/src/components/Description/types.ts +31 -3
  189. package/src/components/Dialog/constants.ts +2 -2
  190. package/src/components/Dock/constants.ts +2 -2
  191. package/src/components/Drawer/constants.ts +2 -2
  192. package/src/components/Form/Checkbox/constants.ts +1 -1
  193. package/src/components/Form/DatetimeInput/constants.ts +1 -1
  194. package/src/components/Form/Input/constants.ts +1 -1
  195. package/src/components/Form/MultiSelect/constants.ts +1 -1
  196. package/src/components/Form/NativeSelect/constants.ts +1 -1
  197. package/src/components/Form/Radio/constants.ts +1 -1
  198. package/src/components/Form/Select/constants.ts +1 -1
  199. package/src/components/Form/Slider/constants.ts +1 -1
  200. package/src/components/Form/Switch/constants.ts +1 -1
  201. package/src/components/Form/Textarea/constants.ts +1 -1
  202. package/src/components/GlowCard/GlowCard.tsx +46 -0
  203. package/src/components/GlowCard/index.ts +2 -0
  204. package/src/components/GlowCard/types.ts +9 -0
  205. package/src/components/GradientText/GradientText.tsx +36 -0
  206. package/src/components/GradientText/index.ts +2 -0
  207. package/src/components/GradientText/types.ts +15 -0
  208. package/src/components/Greeting/Greeting.tsx +46 -0
  209. package/src/components/Greeting/index.ts +2 -0
  210. package/src/components/Greeting/types.ts +10 -0
  211. package/src/components/KPICard/KPICard.tsx +85 -0
  212. package/src/components/KPICard/index.ts +2 -0
  213. package/src/components/KPICard/types.ts +22 -0
  214. package/src/components/Marquee/Marquee.tsx +45 -0
  215. package/src/components/Marquee/index.ts +2 -0
  216. package/src/components/Marquee/types.ts +13 -0
  217. package/src/components/Menu/Menubar/constants.ts +2 -2
  218. package/src/components/Menu/NavigationMenu/constants.ts +2 -2
  219. package/src/components/Meteors/Meteors.tsx +38 -0
  220. package/src/components/Meteors/index.ts +2 -0
  221. package/src/components/Meteors/types.ts +6 -0
  222. package/src/components/MiniAreaChart/MiniAreaChart.tsx +68 -0
  223. package/src/components/MiniAreaChart/index.ts +2 -0
  224. package/src/components/MiniAreaChart/types.ts +11 -0
  225. package/src/components/MiniBarChart/MiniBarChart.tsx +49 -0
  226. package/src/components/MiniBarChart/index.ts +2 -0
  227. package/src/components/MiniBarChart/types.ts +16 -0
  228. package/src/components/MiniDonutChart/MiniDonutChart.tsx +87 -0
  229. package/src/components/MiniDonutChart/index.ts +2 -0
  230. package/src/components/MiniDonutChart/types.ts +17 -0
  231. package/src/components/MiniStackedBar/MiniStackedBar.tsx +61 -0
  232. package/src/components/MiniStackedBar/index.ts +2 -0
  233. package/src/components/MiniStackedBar/types.ts +15 -0
  234. package/src/components/NumberTicker/NumberTicker.tsx +58 -0
  235. package/src/components/NumberTicker/index.ts +2 -0
  236. package/src/components/NumberTicker/types.ts +12 -0
  237. package/src/components/Pagination/constants.ts +2 -2
  238. package/src/components/Progress/constants.ts +1 -1
  239. package/src/components/Pulse/Pulse.tsx +26 -0
  240. package/src/components/Pulse/constants.ts +55 -0
  241. package/src/components/Pulse/index.ts +2 -0
  242. package/src/components/Pulse/types.ts +12 -0
  243. package/src/components/Resizable/constants.ts +1 -1
  244. package/src/components/Sheet/constants.ts +1 -1
  245. package/src/components/ShinyButton/ShinyButton.tsx +57 -0
  246. package/src/components/ShinyButton/index.ts +2 -0
  247. package/src/components/ShinyButton/types.ts +8 -0
  248. package/src/components/Skeleton/constants.ts +1 -1
  249. package/src/components/Sonner/constants.ts +1 -1
  250. package/src/components/Sparkline/Sparkline.tsx +108 -0
  251. package/src/components/Sparkline/index.ts +2 -0
  252. package/src/components/Sparkline/types.ts +18 -0
  253. package/src/components/SpotlightCard/SpotlightCard.tsx +56 -0
  254. package/src/components/SpotlightCard/index.ts +2 -0
  255. package/src/components/SpotlightCard/types.ts +8 -0
  256. package/src/components/Stat/constants.ts +1 -1
  257. package/src/components/StatCard/StatCard.tsx +59 -0
  258. package/src/components/StatCard/index.ts +2 -0
  259. package/src/components/StatCard/types.ts +16 -0
  260. package/src/components/Tabs/constants.ts +1 -1
  261. package/src/components/TextShimmer/TextShimmer.tsx +34 -0
  262. package/src/components/TextShimmer/index.ts +2 -0
  263. package/src/components/TextShimmer/types.ts +8 -0
  264. package/src/components/Timeline/constants.ts +1 -1
  265. package/src/components/Toggle/constants.ts +1 -1
  266. package/src/components/Tooltip/constants.ts +1 -1
  267. package/src/components/TrendBadge/TrendBadge.tsx +40 -0
  268. package/src/components/TrendBadge/constants.ts +38 -0
  269. package/src/components/TrendBadge/index.ts +2 -0
  270. package/src/components/TrendBadge/types.ts +16 -0
  271. package/src/components/WidgetShell/WidgetShell.tsx +101 -0
  272. package/src/components/WidgetShell/index.ts +2 -0
  273. package/src/components/WidgetShell/types.ts +22 -0
  274. package/src/index.ts +35 -0
  275. package/src/stylesheets/tailwind.css +210 -0
  276. package/src/utilities/getSubpaths/getSubpaths.ts +1 -2
@@ -0,0 +1,16 @@
1
+ import type { HTMLAttributes } from "react";
2
+
3
+ export type TrendBadgeProps = Omit<HTMLAttributes<HTMLSpanElement>, "children"> & {
4
+ /** The change value (positive = up, negative = down, zero = neutral) */
5
+ value: number;
6
+ /** Number of decimal places to display */
7
+ decimalPlaces?: number;
8
+ /** Whether to show the percentage sign */
9
+ showPercent?: boolean;
10
+ /** Whether to show the trend arrow icon */
11
+ showIcon?: boolean;
12
+ /** Size variant */
13
+ size?: "xs" | "sm" | "md" | "lg";
14
+ /** Override automatic trend direction */
15
+ trend?: "up" | "down" | "neutral";
16
+ };
@@ -0,0 +1,101 @@
1
+ import { AlertCircleIcon, InboxIcon, RefreshCwIcon } from "lucide-react";
2
+ import { cn } from "../../utilities";
3
+ import type { WidgetShellProps } from "./types";
4
+
5
+ const WidgetShell = ({
6
+ state = "ready",
7
+ title,
8
+ description,
9
+ children,
10
+ className,
11
+ errorContent,
12
+ emptyContent,
13
+ skeletonLines = 3,
14
+ onRetry,
15
+ ...props
16
+ }: WidgetShellProps) => {
17
+ return (
18
+ <div
19
+ className={cn(
20
+ "rounded-lg border bg-base-100 shadow-sm transition-shadow duration-300",
21
+ className
22
+ )}
23
+ {...props}
24
+ >
25
+ {(title || description) && (
26
+ <div className="border-b px-4 py-3">
27
+ {title && (
28
+ <h3 className="text-sm font-semibold">
29
+ {state === "loading" ? (
30
+ <span className="skeleton inline-block h-4 w-32 rounded" />
31
+ ) : (
32
+ title
33
+ )}
34
+ </h3>
35
+ )}
36
+ {description && (
37
+ <p className="mt-0.5 text-xs text-base-content/60">
38
+ {state === "loading" ? (
39
+ <span className="skeleton inline-block h-3 w-48 rounded" />
40
+ ) : (
41
+ description
42
+ )}
43
+ </p>
44
+ )}
45
+ </div>
46
+ )}
47
+
48
+ <div className="p-4">
49
+ {state === "loading" && (
50
+ <div className="flex flex-col gap-3" role="status" aria-label="Loading">
51
+ {Array.from({ length: skeletonLines }, (_, i) => (
52
+ <span
53
+ key={i}
54
+ className="skeleton h-4 rounded"
55
+ style={{ width: `${100 - i * 15}%` }}
56
+ />
57
+ ))}
58
+ </div>
59
+ )}
60
+
61
+ {state === "error" &&
62
+ (errorContent ?? (
63
+ <div className="flex flex-col items-center justify-center gap-3 py-6 text-center">
64
+ <AlertCircleIcon className="size-8 text-error/60" />
65
+ <div>
66
+ <p className="text-sm font-medium">Something went wrong</p>
67
+ <p className="text-xs text-base-content/60">Failed to load data</p>
68
+ </div>
69
+ {onRetry && (
70
+ <button
71
+ type="button"
72
+ onClick={onRetry}
73
+ className="inline-flex items-center gap-1.5 rounded-md border px-3 py-1.5 text-xs font-medium transition-colors duration-200 hover:bg-base-200"
74
+ >
75
+ <RefreshCwIcon className="size-3" />
76
+ Retry
77
+ </button>
78
+ )}
79
+ </div>
80
+ ))}
81
+
82
+ {state === "empty" &&
83
+ (emptyContent ?? (
84
+ <div className="flex flex-col items-center justify-center gap-3 py-6 text-center">
85
+ <InboxIcon className="size-8 text-base-content/30" />
86
+ <div>
87
+ <p className="text-sm font-medium">No data</p>
88
+ <p className="text-xs text-base-content/60">Nothing to display yet</p>
89
+ </div>
90
+ </div>
91
+ ))}
92
+
93
+ {state === "ready" && children}
94
+ </div>
95
+ </div>
96
+ );
97
+ };
98
+
99
+ WidgetShell.displayName = "WidgetShell";
100
+
101
+ export { WidgetShell };
@@ -0,0 +1,2 @@
1
+ export { WidgetShell } from "./WidgetShell";
2
+ export type { WidgetShellProps, WidgetShellState } from "./types";
@@ -0,0 +1,22 @@
1
+ import type { HTMLAttributes, ReactNode } from "react";
2
+
3
+ export type WidgetShellState = "loading" | "error" | "empty" | "ready";
4
+
5
+ export type WidgetShellProps = HTMLAttributes<HTMLDivElement> & {
6
+ /** Current state of the widget */
7
+ state?: WidgetShellState;
8
+ /** Widget title */
9
+ title?: ReactNode;
10
+ /** Widget description */
11
+ description?: ReactNode;
12
+ /** Content to show when state is "ready" */
13
+ children: ReactNode;
14
+ /** Custom content for error state */
15
+ errorContent?: ReactNode;
16
+ /** Custom content for empty state */
17
+ emptyContent?: ReactNode;
18
+ /** Number of skeleton lines to show in loading state */
19
+ skeletonLines?: number;
20
+ /** Callback when retry is clicked in error state */
21
+ onRetry?: () => void;
22
+ };
package/src/index.ts CHANGED
@@ -29,12 +29,17 @@ export * from "./components/Spinner";
29
29
 
30
30
  /** data display */
31
31
  export * from "./components/Accordion";
32
+ export * from "./components/ActivityFeed";
32
33
  export * from "./components/Alert";
34
+ export * from "./components/Amount";
33
35
  export * from "./components/Avatar";
34
36
  export * from "./components/Badge";
35
37
  export * from "./components/Card";
36
38
  export * from "./components/Calendar";
39
+ export * from "./components/CircularProgress";
37
40
  export * from "./components/Collapsible";
41
+ export * from "./components/CountdownTimer";
42
+ export * from "./components/DataList";
38
43
  export * from "./components/Description";
39
44
  export * from "./components/Dock";
40
45
  export * from "./components/Indicator";
@@ -44,15 +49,21 @@ export * from "./components/List";
44
49
  export * from "./components/Progress";
45
50
  export * from "./components/Resizable";
46
51
  export * from "./components/ScrollArea";
52
+ export * from "./components/ComparisonBar";
47
53
  export * from "./components/Separator";
48
54
  export * from "./components/Sonner";
55
+ export * from "./components/Sparkline";
49
56
  export * from "./components/Stack";
50
57
  export * from "./components/Stat";
58
+ export * from "./components/StatCard";
51
59
  export * from "./components/Status";
52
60
  export * from "./components/Table";
53
61
  export * from "./components/Tabs";
54
62
  export * from "./components/Text";
55
63
  export * from "./components/Timeline";
64
+ export * from "./components/TrendBadge";
65
+ export * from "./components/CalendarHeatmap";
66
+ export * from "./components/Greeting";
56
67
 
57
68
  /** data input */
58
69
  export * from "./components/DatetimePicker";
@@ -72,9 +83,11 @@ export * from "./components/Chart";
72
83
  export * from "./components/Command";
73
84
  export * from "./components/Dialog";
74
85
  export * from "./components/HoverCard";
86
+ export * from "./components/KPICard";
75
87
  export * from "./components/Popover";
76
88
  export * from "./components/Slot";
77
89
  export * from "./components/Widget";
90
+ export * from "./components/WidgetShell";
78
91
 
79
92
  /** molecules */
80
93
  export * from "./components/Banner";
@@ -86,3 +99,25 @@ export * from "./components/Footer";
86
99
  export * from "./components/Header";
87
100
  export * from "./components/Panel";
88
101
  export * from "./components/Sheet";
102
+
103
+ /** inline charts */
104
+ export * from "./components/MiniAreaChart";
105
+ export * from "./components/MiniBarChart";
106
+ export * from "./components/MiniDonutChart";
107
+ export * from "./components/MiniStackedBar";
108
+
109
+ /** effects */
110
+ export * from "./components/AnimatedCounter";
111
+ export * from "./components/AnimatedGroup";
112
+ export * from "./components/AnimatedList";
113
+ export * from "./components/BorderBeam";
114
+ export * from "./components/Confetti";
115
+ export * from "./components/GlowCard";
116
+ export * from "./components/GradientText";
117
+ export * from "./components/Marquee";
118
+ export * from "./components/Meteors";
119
+ export * from "./components/NumberTicker";
120
+ export * from "./components/Pulse";
121
+ export * from "./components/ShinyButton";
122
+ export * from "./components/SpotlightCard";
123
+ export * from "./components/TextShimmer";
@@ -151,6 +151,214 @@
151
151
  opacity: 0;
152
152
  }
153
153
  }
154
+
155
+ /* ─── Rich animation keyframes ──────────────────── */
156
+
157
+ --animate-shimmer: shimmer 2s linear infinite;
158
+ --animate-pulse-soft: pulse-soft 2s cubic-bezier(0.4, 0, 0.6, 1) infinite;
159
+ --animate-float: float 3s ease-in-out infinite;
160
+ --animate-wiggle: wiggle 1s ease-in-out infinite;
161
+ --animate-shake: shake 0.5s ease-in-out;
162
+ --animate-bounce-in: bounce-in 0.5s cubic-bezier(0.34, 1.56, 0.64, 1);
163
+ --animate-scale-in: scale-in 0.2s ease-out;
164
+ --animate-scale-out: scale-out 0.2s ease-in;
165
+ --animate-slide-up-fade: slide-up-fade 0.4s cubic-bezier(0.16, 1, 0.3, 1);
166
+ --animate-slide-down-fade: slide-down-fade 0.4s cubic-bezier(0.16, 1, 0.3, 1);
167
+ --animate-slide-left-fade: slide-left-fade 0.4s cubic-bezier(0.16, 1, 0.3, 1);
168
+ --animate-slide-right-fade: slide-right-fade 0.4s cubic-bezier(0.16, 1, 0.3, 1);
169
+ --animate-spotlight: spotlight 2s ease 0.75s 1 forwards;
170
+ --animate-gradient: gradient 8s linear infinite;
171
+ --animate-text-gradient: text-gradient 4s linear infinite;
172
+ --animate-border-beam: border-beam 4s linear infinite;
173
+ --animate-meteor: meteor 5s linear infinite;
174
+ --animate-marquee: marquee var(--tw-duration, 40s) linear infinite;
175
+
176
+ @keyframes shimmer {
177
+ 0% {
178
+ background-position: -200% 0;
179
+ }
180
+ 100% {
181
+ background-position: 200% 0;
182
+ }
183
+ }
184
+
185
+ @keyframes pulse-soft {
186
+ 0%, 100% {
187
+ opacity: 1;
188
+ }
189
+ 50% {
190
+ opacity: 0.7;
191
+ }
192
+ }
193
+
194
+ @keyframes float {
195
+ 0%, 100% {
196
+ transform: translateY(0);
197
+ }
198
+ 50% {
199
+ transform: translateY(-10px);
200
+ }
201
+ }
202
+
203
+ @keyframes wiggle {
204
+ 0%, 100% {
205
+ transform: rotate(-3deg);
206
+ }
207
+ 50% {
208
+ transform: rotate(3deg);
209
+ }
210
+ }
211
+
212
+ @keyframes shake {
213
+ 10%, 90% { transform: translateX(-1px); }
214
+ 20%, 80% { transform: translateX(2px); }
215
+ 30%, 50%, 70% { transform: translateX(-4px); }
216
+ 40%, 60% { transform: translateX(4px); }
217
+ }
218
+
219
+ @keyframes bounce-in {
220
+ 0% {
221
+ opacity: 0;
222
+ transform: scale(0.3);
223
+ }
224
+ 50% {
225
+ transform: scale(1.05);
226
+ }
227
+ 70% {
228
+ transform: scale(0.9);
229
+ }
230
+ 100% {
231
+ opacity: 1;
232
+ transform: scale(1);
233
+ }
234
+ }
235
+
236
+ @keyframes scale-in {
237
+ 0% {
238
+ opacity: 0;
239
+ transform: scale(0.95);
240
+ }
241
+ 100% {
242
+ opacity: 1;
243
+ transform: scale(1);
244
+ }
245
+ }
246
+
247
+ @keyframes scale-out {
248
+ 0% {
249
+ opacity: 1;
250
+ transform: scale(1);
251
+ }
252
+ 100% {
253
+ opacity: 0;
254
+ transform: scale(0.95);
255
+ }
256
+ }
257
+
258
+ @keyframes slide-up-fade {
259
+ 0% {
260
+ opacity: 0;
261
+ transform: translateY(8px);
262
+ }
263
+ 100% {
264
+ opacity: 1;
265
+ transform: translateY(0);
266
+ }
267
+ }
268
+
269
+ @keyframes slide-down-fade {
270
+ 0% {
271
+ opacity: 0;
272
+ transform: translateY(-8px);
273
+ }
274
+ 100% {
275
+ opacity: 1;
276
+ transform: translateY(0);
277
+ }
278
+ }
279
+
280
+ @keyframes slide-left-fade {
281
+ 0% {
282
+ opacity: 0;
283
+ transform: translateX(8px);
284
+ }
285
+ 100% {
286
+ opacity: 1;
287
+ transform: translateX(0);
288
+ }
289
+ }
290
+
291
+ @keyframes slide-right-fade {
292
+ 0% {
293
+ opacity: 0;
294
+ transform: translateX(-8px);
295
+ }
296
+ 100% {
297
+ opacity: 1;
298
+ transform: translateX(0);
299
+ }
300
+ }
301
+
302
+ @keyframes spotlight {
303
+ 0% {
304
+ opacity: 0;
305
+ transform: translate(-72%, -62%) scale(0.5);
306
+ }
307
+ 100% {
308
+ opacity: 1;
309
+ transform: translate(-50%, -40%) scale(1);
310
+ }
311
+ }
312
+
313
+ @keyframes gradient {
314
+ 0% {
315
+ background-position: 0% 50%;
316
+ }
317
+ 50% {
318
+ background-position: 100% 50%;
319
+ }
320
+ 100% {
321
+ background-position: 0% 50%;
322
+ }
323
+ }
324
+
325
+ @keyframes text-gradient {
326
+ to {
327
+ background-position: 200% center;
328
+ }
329
+ }
330
+
331
+ @keyframes border-beam {
332
+ 0% {
333
+ offset-distance: 0%;
334
+ }
335
+ 100% {
336
+ offset-distance: 100%;
337
+ }
338
+ }
339
+
340
+ @keyframes marquee {
341
+ from {
342
+ transform: translateX(0);
343
+ }
344
+ to {
345
+ transform: translateX(calc(-100% - var(--gap, 16px)));
346
+ }
347
+ }
348
+
349
+ @keyframes meteor {
350
+ 0% {
351
+ transform: rotate(215deg) translateX(0);
352
+ opacity: 1;
353
+ }
354
+ 70% {
355
+ opacity: 1;
356
+ }
357
+ 100% {
358
+ transform: rotate(215deg) translateX(-500px);
359
+ opacity: 0;
360
+ }
361
+ }
154
362
  }
155
363
 
156
364
  /* Utility classes */
@@ -307,3 +515,5 @@
307
515
  --tw-exit-translate-x: calc(--value(ratio) * 100%);
308
516
  --tw-exit-translate-x: --value(--translate- *, [percentage], [length]);
309
517
  }
518
+
519
+ @source "../../src/**/*.{ts,tsx}";
@@ -6,8 +6,7 @@ const createPathObject = (
6
6
  pathLabels?: Record<string, string>
7
7
  ) => ({
8
8
  href: { pathname },
9
- // eslint-disable-next-line @typescript-eslint/prefer-nullish-coalescing
10
- label: pathLabels?.[pathname] || segment, // always fallback to segment if label does not exist
9
+ label: pathLabels?.[pathname] || segment,
11
10
  });
12
11
 
13
12
  export const getSubpaths = (