@varity-labs/ui-kit 2.0.0-alpha.1 → 2.0.0-beta.10

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 (269) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +227 -203
  3. package/dist/components/Analytics/DataTable.js +1 -1
  4. package/dist/components/Analytics/DataTable.js.map +1 -1
  5. package/dist/components/Analytics/EnhancedKPICard.d.ts +21 -0
  6. package/dist/components/Analytics/EnhancedKPICard.d.ts.map +1 -0
  7. package/dist/components/Analytics/EnhancedKPICard.js +135 -0
  8. package/dist/components/Analytics/EnhancedKPICard.js.map +1 -0
  9. package/dist/components/Analytics/Sparkline.d.ts +44 -0
  10. package/dist/components/Analytics/Sparkline.d.ts.map +1 -0
  11. package/dist/components/Analytics/Sparkline.js +90 -0
  12. package/dist/components/Analytics/Sparkline.js.map +1 -0
  13. package/dist/components/Analytics/index.d.ts +2 -0
  14. package/dist/components/Analytics/index.d.ts.map +1 -1
  15. package/dist/components/Analytics/index.js +2 -0
  16. package/dist/components/Analytics/index.js.map +1 -1
  17. package/dist/components/Dashboard/DashboardFooter.d.ts.map +1 -1
  18. package/dist/components/Dashboard/DashboardFooter.js +22 -6
  19. package/dist/components/Dashboard/DashboardFooter.js.map +1 -1
  20. package/dist/components/Dashboard/DashboardHeader.d.ts +10 -0
  21. package/dist/components/Dashboard/DashboardHeader.d.ts.map +1 -1
  22. package/dist/components/Dashboard/DashboardHeader.js +191 -58
  23. package/dist/components/Dashboard/DashboardHeader.js.map +1 -1
  24. package/dist/components/Dashboard/DashboardLayout.d.ts +13 -3
  25. package/dist/components/Dashboard/DashboardLayout.d.ts.map +1 -1
  26. package/dist/components/Dashboard/DashboardLayout.js +9 -4
  27. package/dist/components/Dashboard/DashboardLayout.js.map +1 -1
  28. package/dist/components/Dashboard/DashboardSidebar.d.ts.map +1 -1
  29. package/dist/components/Dashboard/DashboardSidebar.js +41 -12
  30. package/dist/components/Dashboard/DashboardSidebar.js.map +1 -1
  31. package/dist/components/Dashboard/EmptyState.js +5 -5
  32. package/dist/components/Dashboard/EmptyState.js.map +1 -1
  33. package/dist/components/Dashboard/KPICard.js +5 -5
  34. package/dist/components/Dashboard/KPICard.js.map +1 -1
  35. package/dist/components/Display/Avatar.d.ts +21 -0
  36. package/dist/components/Display/Avatar.d.ts.map +1 -0
  37. package/dist/components/Display/Avatar.js +71 -0
  38. package/dist/components/Display/Avatar.js.map +1 -0
  39. package/dist/components/Display/Badge.d.ts +22 -0
  40. package/dist/components/Display/Badge.d.ts.map +1 -0
  41. package/dist/components/Display/Badge.js +60 -0
  42. package/dist/components/Display/Badge.js.map +1 -0
  43. package/dist/components/Display/ProgressBar.d.ts +12 -0
  44. package/dist/components/Display/ProgressBar.d.ts.map +1 -0
  45. package/dist/components/Display/ProgressBar.js +33 -0
  46. package/dist/components/Display/ProgressBar.js.map +1 -0
  47. package/dist/components/Display/index.d.ts +9 -0
  48. package/dist/components/Display/index.d.ts.map +1 -0
  49. package/dist/components/Display/index.js +9 -0
  50. package/dist/components/Display/index.js.map +1 -0
  51. package/dist/components/Feedback/Skeleton.d.ts +10 -0
  52. package/dist/components/Feedback/Skeleton.d.ts.map +1 -0
  53. package/dist/components/Feedback/Skeleton.js +25 -0
  54. package/dist/components/Feedback/Skeleton.js.map +1 -0
  55. package/dist/components/Feedback/Toast.d.ts +18 -0
  56. package/dist/components/Feedback/Toast.d.ts.map +1 -0
  57. package/dist/components/Feedback/Toast.js +38 -0
  58. package/dist/components/Feedback/Toast.js.map +1 -0
  59. package/dist/components/Feedback/ToastProvider.d.ts +11 -0
  60. package/dist/components/Feedback/ToastProvider.d.ts.map +1 -0
  61. package/dist/components/Feedback/ToastProvider.js +36 -0
  62. package/dist/components/Feedback/ToastProvider.js.map +1 -0
  63. package/dist/components/Feedback/index.d.ts +11 -0
  64. package/dist/components/Feedback/index.d.ts.map +1 -0
  65. package/dist/components/Feedback/index.js +9 -0
  66. package/dist/components/Feedback/index.js.map +1 -0
  67. package/dist/components/Feedback/useToast.d.ts +3 -0
  68. package/dist/components/Feedback/useToast.d.ts.map +1 -0
  69. package/dist/components/Feedback/useToast.js +10 -0
  70. package/dist/components/Feedback/useToast.js.map +1 -0
  71. package/dist/components/Form/Button.d.ts +12 -0
  72. package/dist/components/Form/Button.d.ts.map +1 -0
  73. package/dist/components/Form/Button.js +22 -0
  74. package/dist/components/Form/Button.js.map +1 -0
  75. package/dist/components/Form/Checkbox.d.ts +13 -0
  76. package/dist/components/Form/Checkbox.d.ts.map +1 -0
  77. package/dist/components/Form/Checkbox.js +36 -0
  78. package/dist/components/Form/Checkbox.js.map +1 -0
  79. package/dist/components/Form/Input.d.ts +9 -0
  80. package/dist/components/Form/Input.d.ts.map +1 -0
  81. package/dist/components/Form/Input.js +16 -0
  82. package/dist/components/Form/Input.js.map +1 -0
  83. package/dist/components/Form/RadioGroup.d.ts +20 -0
  84. package/dist/components/Form/RadioGroup.d.ts.map +1 -0
  85. package/dist/components/Form/RadioGroup.js +43 -0
  86. package/dist/components/Form/RadioGroup.js.map +1 -0
  87. package/dist/components/Form/Select.d.ts +12 -0
  88. package/dist/components/Form/Select.d.ts.map +1 -0
  89. package/dist/components/Form/Select.js +13 -0
  90. package/dist/components/Form/Select.js.map +1 -0
  91. package/dist/components/Form/Textarea.d.ts +8 -0
  92. package/dist/components/Form/Textarea.d.ts.map +1 -0
  93. package/dist/components/Form/Textarea.js +13 -0
  94. package/dist/components/Form/Textarea.js.map +1 -0
  95. package/dist/components/Form/Toggle.d.ts +12 -0
  96. package/dist/components/Form/Toggle.d.ts.map +1 -0
  97. package/dist/components/Form/Toggle.js +48 -0
  98. package/dist/components/Form/Toggle.js.map +1 -0
  99. package/dist/components/Form/index.d.ts +13 -0
  100. package/dist/components/Form/index.d.ts.map +1 -0
  101. package/dist/components/Form/index.js +13 -0
  102. package/dist/components/Form/index.js.map +1 -0
  103. package/dist/components/InAppWallet/InAppWalletProvider.d.ts +4 -4
  104. package/dist/components/InAppWallet/InAppWalletProvider.d.ts.map +1 -1
  105. package/dist/components/InAppWallet/InAppWalletProvider.js +15 -28
  106. package/dist/components/InAppWallet/InAppWalletProvider.js.map +1 -1
  107. package/dist/components/Navigation/Breadcrumb.d.ts +15 -0
  108. package/dist/components/Navigation/Breadcrumb.d.ts.map +1 -0
  109. package/dist/components/Navigation/Breadcrumb.js +28 -0
  110. package/dist/components/Navigation/Breadcrumb.js.map +1 -0
  111. package/dist/components/Navigation/CommandPalette.d.ts +26 -0
  112. package/dist/components/Navigation/CommandPalette.d.ts.map +1 -0
  113. package/dist/components/Navigation/CommandPalette.js +172 -0
  114. package/dist/components/Navigation/CommandPalette.js.map +1 -0
  115. package/dist/components/Navigation/index.d.ts +8 -0
  116. package/dist/components/Navigation/index.d.ts.map +1 -0
  117. package/dist/components/Navigation/index.js +8 -0
  118. package/dist/components/Navigation/index.js.map +1 -0
  119. package/dist/components/Onramp/BuyUSDCButton.d.ts +9 -7
  120. package/dist/components/Onramp/BuyUSDCButton.d.ts.map +1 -1
  121. package/dist/components/Onramp/BuyUSDCButton.js +37 -47
  122. package/dist/components/Onramp/BuyUSDCButton.js.map +1 -1
  123. package/dist/components/Onramp/OnrampWidget.d.ts +7 -6
  124. package/dist/components/Onramp/OnrampWidget.d.ts.map +1 -1
  125. package/dist/components/Onramp/OnrampWidget.js +58 -37
  126. package/dist/components/Onramp/OnrampWidget.js.map +1 -1
  127. package/dist/components/Onramp/index.d.ts +3 -5
  128. package/dist/components/Onramp/index.d.ts.map +1 -1
  129. package/dist/components/Onramp/index.js +3 -5
  130. package/dist/components/Onramp/index.js.map +1 -1
  131. package/dist/components/Overlay/ConfirmDialog.d.ts +14 -0
  132. package/dist/components/Overlay/ConfirmDialog.d.ts.map +1 -0
  133. package/dist/components/Overlay/ConfirmDialog.js +11 -0
  134. package/dist/components/Overlay/ConfirmDialog.js.map +1 -0
  135. package/dist/components/Overlay/Dialog.d.ts +11 -0
  136. package/dist/components/Overlay/Dialog.d.ts.map +1 -0
  137. package/dist/components/Overlay/Dialog.js +69 -0
  138. package/dist/components/Overlay/Dialog.js.map +1 -0
  139. package/dist/components/Overlay/DropdownMenu.d.ts +17 -0
  140. package/dist/components/Overlay/DropdownMenu.d.ts.map +1 -0
  141. package/dist/components/Overlay/DropdownMenu.js +123 -0
  142. package/dist/components/Overlay/DropdownMenu.js.map +1 -0
  143. package/dist/components/Overlay/index.d.ts +9 -0
  144. package/dist/components/Overlay/index.d.ts.map +1 -0
  145. package/dist/components/Overlay/index.js +9 -0
  146. package/dist/components/Overlay/index.js.map +1 -0
  147. package/dist/components/PaymentWidget/PaymentGate.d.ts +30 -0
  148. package/dist/components/PaymentWidget/PaymentGate.d.ts.map +1 -0
  149. package/dist/components/PaymentWidget/PaymentGate.js +54 -0
  150. package/dist/components/PaymentWidget/PaymentGate.js.map +1 -0
  151. package/dist/components/PaymentWidget/PaymentWidget.d.ts +40 -0
  152. package/dist/components/PaymentWidget/PaymentWidget.d.ts.map +1 -0
  153. package/dist/components/PaymentWidget/PaymentWidget.js +195 -0
  154. package/dist/components/PaymentWidget/PaymentWidget.js.map +1 -0
  155. package/dist/components/PaymentWidget/index.d.ts +30 -0
  156. package/dist/components/PaymentWidget/index.d.ts.map +1 -0
  157. package/dist/components/PaymentWidget/index.js +32 -0
  158. package/dist/components/PaymentWidget/index.js.map +1 -0
  159. package/dist/components/PaymentWidget/types.d.ts +200 -0
  160. package/dist/components/PaymentWidget/types.d.ts.map +1 -0
  161. package/dist/components/PaymentWidget/types.js +84 -0
  162. package/dist/components/PaymentWidget/types.js.map +1 -0
  163. package/dist/components/PaymentWidget/useSeamlessPayment.d.ts +51 -0
  164. package/dist/components/PaymentWidget/useSeamlessPayment.d.ts.map +1 -0
  165. package/dist/components/PaymentWidget/useSeamlessPayment.js +167 -0
  166. package/dist/components/PaymentWidget/useSeamlessPayment.js.map +1 -0
  167. package/dist/components/PaymentWidget/useVarityPayment.d.ts +20 -0
  168. package/dist/components/PaymentWidget/useVarityPayment.d.ts.map +1 -0
  169. package/dist/components/PaymentWidget/useVarityPayment.js +164 -0
  170. package/dist/components/PaymentWidget/useVarityPayment.js.map +1 -0
  171. package/dist/components/Payments/CheckoutModal.d.ts.map +1 -1
  172. package/dist/components/Payments/CheckoutModal.js +16 -5
  173. package/dist/components/Payments/CheckoutModal.js.map +1 -1
  174. package/dist/components/Payments/constants.js +1 -1
  175. package/dist/components/Payments/constants.js.map +1 -1
  176. package/dist/components/Privy/InitTimeoutScreen.d.ts.map +1 -1
  177. package/dist/components/Privy/InitTimeoutScreen.js +1 -1
  178. package/dist/components/Privy/InitTimeoutScreen.js.map +1 -1
  179. package/dist/components/Privy/InitializingScreen.d.ts +3 -3
  180. package/dist/components/Privy/InitializingScreen.d.ts.map +1 -1
  181. package/dist/components/Privy/InitializingScreen.js +6 -6
  182. package/dist/components/Privy/InitializingScreen.js.map +1 -1
  183. package/dist/components/index.d.ts +5 -2
  184. package/dist/components/index.d.ts.map +1 -1
  185. package/dist/components/index.js +20 -4
  186. package/dist/components/index.js.map +1 -1
  187. package/dist/config/chains.d.ts +5 -5
  188. package/dist/config/chains.d.ts.map +1 -1
  189. package/dist/config/chains.js +8 -8
  190. package/dist/config/chains.js.map +1 -1
  191. package/dist/hooks/index.d.ts +1 -11
  192. package/dist/hooks/index.d.ts.map +1 -1
  193. package/dist/hooks/index.js +54 -11
  194. package/dist/hooks/index.js.map +1 -1
  195. package/dist/index.d.ts +24 -42
  196. package/dist/index.d.ts.map +1 -1
  197. package/dist/index.js +180 -43
  198. package/dist/index.js.map +1 -1
  199. package/dist/providers/PrivyProvider.js +1 -1
  200. package/dist/providers/PrivyProvider.js.map +1 -1
  201. package/dist/providers/PrivyStack.d.ts +31 -73
  202. package/dist/providers/PrivyStack.d.ts.map +1 -1
  203. package/dist/providers/PrivyStack.js +32 -160
  204. package/dist/providers/PrivyStack.js.map +1 -1
  205. package/dist/providers/VarityDashboardProvider.d.ts +7 -10
  206. package/dist/providers/VarityDashboardProvider.d.ts.map +1 -1
  207. package/dist/providers/VarityDashboardProvider.js +12 -15
  208. package/dist/providers/VarityDashboardProvider.js.map +1 -1
  209. package/dist/providers/WalletSyncProvider.d.ts +17 -24
  210. package/dist/providers/WalletSyncProvider.d.ts.map +1 -1
  211. package/dist/providers/WalletSyncProvider.js +16 -27
  212. package/dist/providers/WalletSyncProvider.js.map +1 -1
  213. package/dist/providers/ZeroDevProvider.d.ts +69 -0
  214. package/dist/providers/ZeroDevProvider.d.ts.map +1 -0
  215. package/dist/providers/ZeroDevProvider.js +208 -0
  216. package/dist/providers/ZeroDevProvider.js.map +1 -0
  217. package/dist/providers/index.d.ts +1 -0
  218. package/dist/providers/index.d.ts.map +1 -1
  219. package/dist/providers/index.js +2 -0
  220. package/dist/providers/index.js.map +1 -1
  221. package/dist/wallets/SimpleSmartWallet.js +1 -1
  222. package/dist/wallets/SimpleSmartWallet.js.map +1 -1
  223. package/dist/wallets/SmartWalletProvider.js +1 -1
  224. package/dist/wallets/SmartWalletProvider.js.map +1 -1
  225. package/dist/wallets/config.d.ts +31 -8
  226. package/dist/wallets/config.d.ts.map +1 -1
  227. package/dist/wallets/config.js +33 -10
  228. package/dist/wallets/config.js.map +1 -1
  229. package/dist/wallets/index.d.ts +1 -1
  230. package/dist/wallets/index.d.ts.map +1 -1
  231. package/dist/wallets/index.js +1 -1
  232. package/dist/wallets/index.js.map +1 -1
  233. package/package.json +34 -26
  234. package/dist/core/VarityClient.d.ts +0 -76
  235. package/dist/core/VarityClient.d.ts.map +0 -1
  236. package/dist/core/VarityClient.js +0 -99
  237. package/dist/core/VarityClient.js.map +0 -1
  238. package/dist/core/config.d.ts +0 -136
  239. package/dist/core/config.d.ts.map +0 -1
  240. package/dist/core/config.js +0 -156
  241. package/dist/core/config.js.map +0 -1
  242. package/dist/hooks/useAnalytics.d.ts +0 -94
  243. package/dist/hooks/useAnalytics.d.ts.map +0 -1
  244. package/dist/hooks/useAnalytics.js +0 -116
  245. package/dist/hooks/useAnalytics.js.map +0 -1
  246. package/dist/hooks/useAuth.d.ts +0 -71
  247. package/dist/hooks/useAuth.d.ts.map +0 -1
  248. package/dist/hooks/useAuth.js +0 -198
  249. package/dist/hooks/useAuth.js.map +0 -1
  250. package/dist/hooks/useDashboard.d.ts +0 -110
  251. package/dist/hooks/useDashboard.d.ts.map +0 -1
  252. package/dist/hooks/useDashboard.js +0 -201
  253. package/dist/hooks/useDashboard.js.map +0 -1
  254. package/dist/hooks/useVarityAPI.d.ts +0 -88
  255. package/dist/hooks/useVarityAPI.d.ts.map +0 -1
  256. package/dist/hooks/useVarityAPI.js +0 -138
  257. package/dist/hooks/useVarityAPI.js.map +0 -1
  258. package/dist/hooks/useWalletAuth.d.ts +0 -108
  259. package/dist/hooks/useWalletAuth.d.ts.map +0 -1
  260. package/dist/hooks/useWalletAuth.js +0 -415
  261. package/dist/hooks/useWalletAuth.js.map +0 -1
  262. package/dist/modules/cache/index.d.ts +0 -2
  263. package/dist/modules/cache/index.d.ts.map +0 -1
  264. package/dist/modules/cache/index.js +0 -2
  265. package/dist/modules/cache/index.js.map +0 -1
  266. package/dist/types/api-extensions.d.ts +0 -92
  267. package/dist/types/api-extensions.d.ts.map +0 -1
  268. package/dist/types/api-extensions.js +0 -7
  269. package/dist/types/api-extensions.js.map +0 -1
@@ -0,0 +1,135 @@
1
+ 'use client';
2
+ import React, { useMemo } from 'react';
3
+ import { HelpCircle, Clock, TrendingUp, TrendingDown, Minus } from 'lucide-react';
4
+ import { Sparkline, getSparklineColors } from './Sparkline';
5
+ export function EnhancedKPICard({ title, value, change, icon, source, trend = 'neutral', color = 'blue', sparklineData, showSparkline = false, lastSynced, helpText, onClick, }) {
6
+ const colorClasses = {
7
+ blue: {
8
+ bg: 'bg-blue-50 dark:bg-blue-950',
9
+ icon: 'text-blue-600 dark:text-blue-400',
10
+ border: 'border-blue-100 dark:border-blue-800',
11
+ accent: 'text-blue-600 dark:text-blue-400',
12
+ },
13
+ green: {
14
+ bg: 'bg-green-50 dark:bg-green-950',
15
+ icon: 'text-green-600 dark:text-green-400',
16
+ border: 'border-green-100 dark:border-green-800',
17
+ accent: 'text-green-600 dark:text-green-400',
18
+ },
19
+ orange: {
20
+ bg: 'bg-orange-50 dark:bg-orange-950',
21
+ icon: 'text-orange-600 dark:text-orange-400',
22
+ border: 'border-orange-100 dark:border-orange-800',
23
+ accent: 'text-orange-600 dark:text-orange-400',
24
+ },
25
+ purple: {
26
+ bg: 'bg-purple-50 dark:bg-purple-950',
27
+ icon: 'text-purple-600 dark:text-purple-400',
28
+ border: 'border-purple-100 dark:border-purple-800',
29
+ accent: 'text-purple-600 dark:text-purple-400',
30
+ },
31
+ red: {
32
+ bg: 'bg-red-50 dark:bg-red-950',
33
+ icon: 'text-red-600 dark:text-red-400',
34
+ border: 'border-red-100 dark:border-red-800',
35
+ accent: 'text-red-600 dark:text-red-400',
36
+ },
37
+ };
38
+ const trendConfig = {
39
+ up: {
40
+ color: 'text-emerald-600 dark:text-emerald-400',
41
+ bgColor: 'bg-emerald-50 dark:bg-emerald-950',
42
+ icon: TrendingUp,
43
+ label: 'Up',
44
+ },
45
+ down: {
46
+ color: 'text-red-600 dark:text-red-400',
47
+ bgColor: 'bg-red-50 dark:bg-red-950',
48
+ icon: TrendingDown,
49
+ label: 'Down',
50
+ },
51
+ neutral: {
52
+ color: 'text-gray-600 dark:text-gray-400',
53
+ bgColor: 'bg-gray-50 dark:bg-gray-800',
54
+ icon: Minus,
55
+ label: 'No change',
56
+ },
57
+ };
58
+ const TrendIcon = trendConfig[trend].icon;
59
+ const sparklineColors = getSparklineColors(trend, color);
60
+ // Format last synced time
61
+ const formattedLastSynced = useMemo(() => {
62
+ if (!lastSynced)
63
+ return null;
64
+ // If it's already a relative string (e.g., "2 min ago"), return as-is
65
+ if (lastSynced.includes('ago') || lastSynced.includes('Just now')) {
66
+ return lastSynced;
67
+ }
68
+ // Otherwise, try to parse as ISO date
69
+ try {
70
+ const syncDate = new Date(lastSynced);
71
+ const now = new Date();
72
+ const diffMs = now.getTime() - syncDate.getTime();
73
+ const diffMins = Math.floor(diffMs / 60000);
74
+ const diffHours = Math.floor(diffMs / 3600000);
75
+ if (diffMins < 1)
76
+ return 'Just now';
77
+ if (diffMins < 60)
78
+ return `${diffMins}m ago`;
79
+ if (diffHours < 24)
80
+ return `${diffHours}h ago`;
81
+ return `${Math.floor(diffHours / 24)}d ago`;
82
+ }
83
+ catch {
84
+ return lastSynced;
85
+ }
86
+ }, [lastSynced]);
87
+ // Generate mock sparkline data if none provided
88
+ const displaySparklineData = useMemo(() => {
89
+ if (sparklineData && sparklineData.length >= 2)
90
+ return sparklineData;
91
+ // Generate plausible trend data based on current value and change
92
+ const baseValue = typeof value === 'number' ? value : parseFloat(value.replace(/[^0-9.-]/g, '')) || 100;
93
+ const changePercent = change?.value || 0;
94
+ const points = 7;
95
+ const data = [];
96
+ for (let i = 0; i < points; i++) {
97
+ const progress = i / (points - 1);
98
+ const trendValue = baseValue * (1 - changePercent / 100 * (1 - progress));
99
+ const noise = trendValue * 0.02 * (Math.random() - 0.5);
100
+ data.push(Math.max(0, trendValue + noise));
101
+ }
102
+ return data;
103
+ }, [sparklineData, value, change]);
104
+ return (React.createElement("div", { onClick: onClick, className: `bg-white dark:bg-gray-800 border border-gray-200 dark:border-gray-700 rounded-xl p-5 hover:shadow-lg hover:border-blue-300 dark:hover:border-blue-600 hover:-translate-y-0.5 transition-all duration-200 ${onClick ? 'cursor-pointer' : ''}`, role: onClick ? 'button' : undefined, tabIndex: onClick ? 0 : undefined, onKeyDown: onClick ? (e) => e.key === 'Enter' && onClick() : undefined },
105
+ React.createElement("div", { className: "flex items-start justify-between mb-3" },
106
+ React.createElement("div", { className: "flex items-center gap-2" },
107
+ React.createElement("div", { className: `w-10 h-10 ${colorClasses[color].bg} rounded-lg flex items-center justify-center text-xl` }, icon),
108
+ React.createElement("div", null,
109
+ React.createElement("div", { className: "flex items-center gap-1" },
110
+ React.createElement("h3", { className: "text-sm font-medium text-gray-700 dark:text-gray-300" }, title),
111
+ helpText && (React.createElement("div", { className: "relative group" },
112
+ React.createElement(HelpCircle, { className: "w-3.5 h-3.5 text-gray-400 dark:text-gray-500 cursor-help" }),
113
+ React.createElement("div", { className: "absolute bottom-full left-1/2 -translate-x-1/2 mb-2 px-2 py-1 bg-gray-900 dark:bg-gray-100 text-white dark:text-gray-900 text-xs rounded whitespace-nowrap opacity-0 invisible group-hover:opacity-100 group-hover:visible transition-all z-10" },
114
+ helpText,
115
+ React.createElement("div", { className: "absolute top-full left-1/2 -translate-x-1/2 border-4 border-transparent border-t-gray-900 dark:border-t-gray-100" }))))),
116
+ source && (React.createElement("span", { className: "text-[10px] text-gray-400 dark:text-gray-500 uppercase tracking-wide" }, source))))),
117
+ React.createElement("div", { className: "mb-3" },
118
+ React.createElement("p", { className: "text-3xl font-bold text-gray-900 dark:text-white tracking-tight" }, value)),
119
+ change && (React.createElement("div", { className: "flex items-center gap-2 mb-3" },
120
+ React.createElement("span", { className: `inline-flex items-center gap-1 text-xs font-semibold px-2 py-1 rounded ${trendConfig[trend].bgColor} ${trendConfig[trend].color}` },
121
+ React.createElement(TrendIcon, { className: "w-3.5 h-3.5" }),
122
+ React.createElement("span", null,
123
+ Math.abs(change.value).toFixed(1),
124
+ "%")),
125
+ React.createElement("span", { className: "text-xs text-gray-500 dark:text-gray-400" }, change.period))),
126
+ showSparkline && (React.createElement("div", { className: "mb-3" },
127
+ React.createElement(Sparkline, { data: displaySparklineData, width: 180, height: 36, strokeColor: sparklineColors.stroke, fillColor: sparklineColors.fill, strokeWidth: 2, showGradient: true, className: "w-full" }))),
128
+ formattedLastSynced && (React.createElement("div", { className: "flex items-center gap-1 text-[10px] text-gray-400 dark:text-gray-500 pt-2 border-t border-gray-100 dark:border-gray-700" },
129
+ React.createElement(Clock, { className: "w-3 h-3" }),
130
+ React.createElement("span", null,
131
+ "Synced ",
132
+ formattedLastSynced)))));
133
+ }
134
+ export default EnhancedKPICard;
135
+ //# sourceMappingURL=EnhancedKPICard.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"EnhancedKPICard.js","sourceRoot":"","sources":["../../../src/components/Analytics/EnhancedKPICard.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,44 @@
1
+ import React from 'react';
2
+ interface SparklineProps {
3
+ data: number[];
4
+ width?: number;
5
+ height?: number;
6
+ strokeColor?: string;
7
+ fillColor?: string;
8
+ strokeWidth?: number;
9
+ showGradient?: boolean;
10
+ className?: string;
11
+ }
12
+ export declare function Sparkline({ data, width, height, strokeColor, fillColor, strokeWidth, showGradient, className, }: SparklineProps): React.JSX.Element;
13
+ export declare const SPARKLINE_COLORS: {
14
+ positive: {
15
+ stroke: string;
16
+ fill: string;
17
+ };
18
+ negative: {
19
+ stroke: string;
20
+ fill: string;
21
+ };
22
+ neutral: {
23
+ stroke: string;
24
+ fill: string;
25
+ };
26
+ blue: {
27
+ stroke: string;
28
+ fill: string;
29
+ };
30
+ purple: {
31
+ stroke: string;
32
+ fill: string;
33
+ };
34
+ orange: {
35
+ stroke: string;
36
+ fill: string;
37
+ };
38
+ };
39
+ export declare function getSparklineColors(trend?: 'up' | 'down' | 'neutral', color?: string): {
40
+ stroke: string;
41
+ fill: string;
42
+ };
43
+ export default Sparkline;
44
+ //# sourceMappingURL=Sparkline.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Sparkline.d.ts","sourceRoot":"","sources":["../../../src/components/Analytics/Sparkline.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAkB,MAAM,OAAO,CAAC;AAEvC,UAAU,cAAc;IACtB,IAAI,EAAE,MAAM,EAAE,CAAC;IACf,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,MAAM,CAAC,EAAE,MAAM,CAAC;IAChB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,SAAS,CAAC,EACxB,IAAI,EACJ,KAAW,EACX,MAAW,EACX,WAAuB,EACvB,SAAuB,EACvB,WAAe,EACf,YAAmB,EACnB,SAAc,GACf,EAAE,cAAc,qBAoGhB;AAGD,eAAO,MAAM,gBAAgB;;;;;;;;;;;;;;;;;;;;;;;;;CAyB5B,CAAC;AAGF,wBAAgB,kBAAkB,CAAC,KAAK,CAAC,EAAE,IAAI,GAAG,MAAM,GAAG,SAAS,EAAE,KAAK,CAAC,EAAE,MAAM;;;EAOnF;AAED,eAAe,SAAS,CAAC"}
@@ -0,0 +1,90 @@
1
+ 'use client';
2
+ import React, { useMemo } from 'react';
3
+ export function Sparkline({ data, width = 100, height = 32, strokeColor = '#3b82f6', fillColor = '#3b82f680', strokeWidth = 2, showGradient = true, className = '', }) {
4
+ const pathData = useMemo(() => {
5
+ if (!data || data.length < 2)
6
+ return { line: '', area: '' };
7
+ const min = Math.min(...data);
8
+ const max = Math.max(...data);
9
+ const range = max - min || 1;
10
+ const padding = 2;
11
+ const points = data.map((value, index) => {
12
+ const x = padding + (index / (data.length - 1)) * (width - padding * 2);
13
+ const y = height - padding - ((value - min) / range) * (height - padding * 2);
14
+ return { x, y };
15
+ });
16
+ // Create smooth line path using cubic bezier curves
17
+ let linePath = `M ${points[0].x} ${points[0].y}`;
18
+ for (let i = 1; i < points.length; i++) {
19
+ const prev = points[i - 1];
20
+ const curr = points[i];
21
+ const tension = 0.3;
22
+ const cp1x = prev.x + (curr.x - prev.x) * tension;
23
+ const cp1y = prev.y;
24
+ const cp2x = curr.x - (curr.x - prev.x) * tension;
25
+ const cp2y = curr.y;
26
+ linePath += ` C ${cp1x} ${cp1y}, ${cp2x} ${cp2y}, ${curr.x} ${curr.y}`;
27
+ }
28
+ // Create area path for gradient fill
29
+ const areaPath = `${linePath} L ${points[points.length - 1].x} ${height} L ${points[0].x} ${height} Z`;
30
+ return { line: linePath, area: areaPath };
31
+ }, [data, width, height]);
32
+ // Generate unique ID for gradient
33
+ const gradientId = useMemo(() => `sparkline-gradient-${Math.random().toString(36).substr(2, 9)}`, []);
34
+ if (!data || data.length < 2) {
35
+ return (React.createElement("div", { className: `flex items-center justify-center ${className}`, style: { width, height } },
36
+ React.createElement("div", { className: "h-0.5 w-full bg-gray-200 dark:bg-gray-700 rounded" })));
37
+ }
38
+ return (React.createElement("svg", { width: width, height: height, className: className, viewBox: `0 0 ${width} ${height}`, preserveAspectRatio: "none" },
39
+ showGradient && (React.createElement("defs", null,
40
+ React.createElement("linearGradient", { id: gradientId, x1: "0%", y1: "0%", x2: "0%", y2: "100%" },
41
+ React.createElement("stop", { offset: "0%", stopColor: fillColor, stopOpacity: "0.4" }),
42
+ React.createElement("stop", { offset: "100%", stopColor: fillColor, stopOpacity: "0" })))),
43
+ showGradient && (React.createElement("path", { d: pathData.area, fill: `url(#${gradientId})` })),
44
+ React.createElement("path", { d: pathData.line, fill: "none", stroke: strokeColor, strokeWidth: strokeWidth, strokeLinecap: "round", strokeLinejoin: "round" }),
45
+ data.length > 0 && (React.createElement("circle", { cx: width - 2, cy: height -
46
+ 2 -
47
+ ((data[data.length - 1] - Math.min(...data)) /
48
+ (Math.max(...data) - Math.min(...data) || 1)) *
49
+ (height - 4), r: 3, fill: strokeColor }))));
50
+ }
51
+ // Preset color configurations for different trends
52
+ export const SPARKLINE_COLORS = {
53
+ positive: {
54
+ stroke: '#10b981',
55
+ fill: '#10b98180',
56
+ },
57
+ negative: {
58
+ stroke: '#ef4444',
59
+ fill: '#ef444480',
60
+ },
61
+ neutral: {
62
+ stroke: '#6b7280',
63
+ fill: '#6b728080',
64
+ },
65
+ blue: {
66
+ stroke: '#3b82f6',
67
+ fill: '#3b82f680',
68
+ },
69
+ purple: {
70
+ stroke: '#8b5cf6',
71
+ fill: '#8b5cf680',
72
+ },
73
+ orange: {
74
+ stroke: '#f97316',
75
+ fill: '#f9731680',
76
+ },
77
+ };
78
+ // Helper to determine sparkline color based on trend
79
+ export function getSparklineColors(trend, color) {
80
+ if (trend === 'up')
81
+ return SPARKLINE_COLORS.positive;
82
+ if (trend === 'down')
83
+ return SPARKLINE_COLORS.negative;
84
+ if (color && SPARKLINE_COLORS[color]) {
85
+ return SPARKLINE_COLORS[color];
86
+ }
87
+ return SPARKLINE_COLORS.blue;
88
+ }
89
+ export default Sparkline;
90
+ //# sourceMappingURL=Sparkline.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Sparkline.js","sourceRoot":"","sources":["../../../src/components/Analytics/Sparkline.tsx"],"names":[],"mappings":"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"}
@@ -7,6 +7,8 @@ export { AnalyticsCard } from './AnalyticsCard';
7
7
  export { ChartContainer } from './ChartContainer';
8
8
  export { DataTable } from './DataTable';
9
9
  export { MetricDisplay } from './MetricDisplay';
10
+ export { Sparkline, SPARKLINE_COLORS, getSparklineColors } from './Sparkline';
11
+ export { EnhancedKPICard } from './EnhancedKPICard';
10
12
  export type { AnalyticsCardProps } from './AnalyticsCard';
11
13
  export type { ChartContainerProps, ChartAction } from './ChartContainer';
12
14
  export type { DataTableProps, DataTableColumn } from './DataTable';
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Analytics/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAE/C,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AACzD,YAAY,EAAE,mBAAmB,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AACxE,YAAY,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAClE,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Analytics/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAEnD,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA;AACzD,YAAY,EAAE,mBAAmB,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAA;AACxE,YAAY,EAAE,cAAc,EAAE,eAAe,EAAE,MAAM,aAAa,CAAA;AAClE,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAA"}
@@ -7,4 +7,6 @@ export { AnalyticsCard } from './AnalyticsCard';
7
7
  export { ChartContainer } from './ChartContainer';
8
8
  export { DataTable } from './DataTable';
9
9
  export { MetricDisplay } from './MetricDisplay';
10
+ export { Sparkline, SPARKLINE_COLORS, getSparklineColors } from './Sparkline';
11
+ export { EnhancedKPICard } from './EnhancedKPICard';
10
12
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Analytics/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Analytics/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,cAAc,EAAE,MAAM,kBAAkB,CAAA;AACjD,OAAO,EAAE,SAAS,EAAE,MAAM,aAAa,CAAA;AACvC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAA;AAC/C,OAAO,EAAE,SAAS,EAAE,gBAAgB,EAAE,kBAAkB,EAAE,MAAM,aAAa,CAAA;AAC7E,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA"}
@@ -1 +1 @@
1
- {"version":3,"file":"DashboardFooter.d.ts","sourceRoot":"","sources":["../../../src/components/Dashboard/DashboardFooter.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,WAAW,oBAAoB;IACnC,8BAA8B;IAC9B,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,0DAA0D;IAC1D,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,8BAA8B;IAC9B,KAAK,CAAC,EAAE,UAAU,EAAE,CAAA;CACrB;AAED,MAAM,WAAW,UAAU;IACzB,iBAAiB;IACjB,KAAK,EAAE,MAAM,CAAA;IACb,eAAe;IACf,GAAG,EAAE,MAAM,CAAA;IACX,sBAAsB;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED;;;;;GAKG;AACH,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAqG1D,CAAA"}
1
+ {"version":3,"file":"DashboardFooter.d.ts","sourceRoot":"","sources":["../../../src/components/Dashboard/DashboardFooter.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAA;AAEzB,MAAM,WAAW,oBAAoB;IACnC,8BAA8B;IAC9B,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,0DAA0D;IAC1D,eAAe,CAAC,EAAE,OAAO,CAAA;IACzB,8BAA8B;IAC9B,KAAK,CAAC,EAAE,UAAU,EAAE,CAAA;CACrB;AAED,MAAM,WAAW,UAAU;IACzB,iBAAiB;IACjB,KAAK,EAAE,MAAM,CAAA;IACb,eAAe;IACf,GAAG,EAAE,MAAM,CAAA;IACX,sBAAsB;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB;AAED;;;;;GAKG;AACH,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CA6H1D,CAAA"}
@@ -50,19 +50,35 @@ links = [] }) => {
50
50
  fontSize: '13px'
51
51
  } },
52
52
  React.createElement("span", { style: { color: 'var(--varity-text-secondary, #757575)' } }, "Powered by"),
53
- React.createElement("a", { href: "https://varity.com?utm_source=dashboard&utm_medium=footer", target: "_blank", rel: "noopener noreferrer", style: {
53
+ React.createElement("a", { href: "https://developer.store.varity.so", target: "_blank", rel: "noopener noreferrer", style: {
54
54
  color: 'var(--varity-primary-color, #1976d2)',
55
55
  textDecoration: 'none',
56
56
  fontWeight: 600,
57
57
  display: 'flex',
58
58
  alignItems: 'center',
59
- gap: '4px'
59
+ gap: '6px'
60
60
  }, onMouseEnter: (e) => {
61
- e.currentTarget.style.textDecoration = 'underline';
61
+ e.currentTarget.style.opacity = '0.8';
62
62
  }, onMouseLeave: (e) => {
63
- e.currentTarget.style.textDecoration = 'none';
63
+ e.currentTarget.style.opacity = '1';
64
64
  } },
65
- React.createElement("span", { style: { fontSize: '16px' } }, "\uD83D\uDE80"),
66
- "Varity")))));
65
+ React.createElement("svg", { width: "20", height: "20", viewBox: "0 0 64 64", xmlns: "http://www.w3.org/2000/svg", style: { display: 'block' } },
66
+ React.createElement("defs", null,
67
+ React.createElement("linearGradient", { id: "varity-ft-f1", x1: "0%", y1: "0%", x2: "100%", y2: "100%" },
68
+ React.createElement("stop", { offset: "0%", stopColor: "#5EEAD4" }),
69
+ React.createElement("stop", { offset: "100%", stopColor: "#0D9488" })),
70
+ React.createElement("linearGradient", { id: "varity-ft-f2", x1: "100%", y1: "0%", x2: "0%", y2: "100%" },
71
+ React.createElement("stop", { offset: "0%", stopColor: "#60A5FA" }),
72
+ React.createElement("stop", { offset: "100%", stopColor: "#1D4ED8" })),
73
+ React.createElement("linearGradient", { id: "varity-ft-f4", x1: "0%", y1: "100%", x2: "100%", y2: "0%" },
74
+ React.createElement("stop", { offset: "0%", stopColor: "#14B8A6" }),
75
+ React.createElement("stop", { offset: "100%", stopColor: "#2DD4BF" }))),
76
+ React.createElement("path", { d: "M32 6 L48 22 L32 32 L16 22 Z", fill: "url(#varity-ft-f4)" }),
77
+ React.createElement("path", { d: "M16 22 L32 32 L32 58 L8 36 Z", fill: "url(#varity-ft-f1)" }),
78
+ React.createElement("path", { d: "M48 22 L56 36 L32 58 L32 32 Z", fill: "url(#varity-ft-f2)" }),
79
+ React.createElement("path", { d: "M8 36 L32 58 L20 58 Z", fill: "url(#varity-ft-f1)", opacity: "0.7" }),
80
+ React.createElement("path", { d: "M56 36 L44 58 L32 58 Z", fill: "url(#varity-ft-f2)", opacity: "0.7" }),
81
+ React.createElement("path", { d: "M32 12 L40 22 L32 28 L24 22 Z", fill: "white", opacity: "0.25" })),
82
+ React.createElement("span", null, "Varity"))))));
67
83
  };
68
84
  //# sourceMappingURL=DashboardFooter.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"DashboardFooter.js","sourceRoot":"","sources":["../../../src/components/Dashboard/DashboardFooter.tsx"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"DashboardFooter.js","sourceRoot":"","sources":["../../../src/components/Dashboard/DashboardFooter.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAA;AAoBzB;;;;;GAKG;AACH,MAAM,CAAC,MAAM,eAAe,GAAmC,CAAC,EAC9D,WAAW,EACX,eAAe,GAAG,IAAI,EAAE,6BAA6B;AACrD,KAAK,GAAG,EAAE,EACX,EAAE,EAAE;IACH,MAAM,WAAW,GAAG,IAAI,IAAI,EAAE,CAAC,WAAW,EAAE,CAAA;IAE5C,OAAO,CACL,gCACE,SAAS,EAAC,yBAAyB,EACnC,KAAK,EAAE;YACL,OAAO,EAAE,WAAW;YACpB,eAAe,EAAE,kCAAkC;YACnD,SAAS,EAAE,+CAA+C;YAC1D,OAAO,EAAE,MAAM;YACf,cAAc,EAAE,eAAe;YAC/B,UAAU,EAAE,QAAQ;YACpB,QAAQ,EAAE,MAAM;YAChB,GAAG,EAAE,MAAM;YACX,QAAQ,EAAE,MAAM;YAChB,KAAK,EAAE,uCAAuC;SAC/C;QAGD,6BAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,UAAU,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE;YAC/D,WAAW,IAAI,CACd;;gBACK,WAAW;;gBAAG,WAAW;yCACvB,CACR;YAGA,KAAK,CAAC,MAAM,GAAG,CAAC,IAAI,CACnB,6BAAK,KAAK,EAAE,EAAE,OAAO,EAAE,MAAM,EAAE,GAAG,EAAE,MAAM,EAAE,IACzC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE,CAAC,CAC1B,2BACE,GAAG,EAAE,KAAK,EACV,IAAI,EAAE,IAAI,CAAC,GAAG,EACd,MAAM,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,EAC5C,GAAG,EAAE,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,qBAAqB,CAAC,CAAC,CAAC,SAAS,EACtD,KAAK,EAAE;oBACL,KAAK,EAAE,uCAAuC;oBAC9C,cAAc,EAAE,MAAM;iBACvB,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;oBAClB,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,sCAAsC,CAAA;gBACtE,CAAC,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;oBAClB,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,KAAK,GAAG,uCAAuC,CAAA;gBACvE,CAAC,IAEA,IAAI,CAAC,KAAK,CACT,CACL,CAAC,CACE,CACP,CACG;QAGL,eAAe,IAAI,CAClB,6BACE,SAAS,EAAC,oBAAoB,EAC9B,KAAK,EAAE;gBACL,OAAO,EAAE,MAAM;gBACf,UAAU,EAAE,QAAQ;gBACpB,GAAG,EAAE,KAAK;gBACV,OAAO,EAAE,UAAU;gBACnB,eAAe,EAAE,qCAAqC;gBACtD,YAAY,EAAE,KAAK;gBACnB,QAAQ,EAAE,MAAM;aACjB;YAED,8BAAM,KAAK,EAAE,EAAE,KAAK,EAAE,uCAAuC,EAAE,iBAExD;YACP,2BACE,IAAI,EAAC,mCAAmC,EACxC,MAAM,EAAC,QAAQ,EACf,GAAG,EAAC,qBAAqB,EACzB,KAAK,EAAE;oBACL,KAAK,EAAE,sCAAsC;oBAC7C,cAAc,EAAE,MAAM;oBACtB,UAAU,EAAE,GAAG;oBACf,OAAO,EAAE,MAAM;oBACf,UAAU,EAAE,QAAQ;oBACpB,GAAG,EAAE,KAAK;iBACX,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;oBAClB,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,KAAK,CAAA;gBACvC,CAAC,EACD,YAAY,EAAE,CAAC,CAAC,EAAE,EAAE;oBAClB,CAAC,CAAC,aAAa,CAAC,KAAK,CAAC,OAAO,GAAG,GAAG,CAAA;gBACrC,CAAC;gBAED,6BACE,KAAK,EAAC,IAAI,EACV,MAAM,EAAC,IAAI,EACX,OAAO,EAAC,WAAW,EACnB,KAAK,EAAC,4BAA4B,EAClC,KAAK,EAAE,EAAE,OAAO,EAAE,OAAO,EAAE;oBAE3B;wBACE,wCAAgB,EAAE,EAAC,cAAc,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,MAAM,EAAC,EAAE,EAAC,MAAM;4BACnE,8BAAM,MAAM,EAAC,IAAI,EAAC,SAAS,EAAC,SAAS,GAAE;4BAAA,8BAAM,MAAM,EAAC,MAAM,EAAC,SAAS,EAAC,SAAS,GAAE,CACjE;wBACjB,wCAAgB,EAAE,EAAC,cAAc,EAAC,EAAE,EAAC,MAAM,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,MAAM;4BACnE,8BAAM,MAAM,EAAC,IAAI,EAAC,SAAS,EAAC,SAAS,GAAE;4BAAA,8BAAM,MAAM,EAAC,MAAM,EAAC,SAAS,EAAC,SAAS,GAAE,CACjE;wBACjB,wCAAgB,EAAE,EAAC,cAAc,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,MAAM,EAAC,EAAE,EAAC,MAAM,EAAC,EAAE,EAAC,IAAI;4BACnE,8BAAM,MAAM,EAAC,IAAI,EAAC,SAAS,EAAC,SAAS,GAAE;4BAAA,8BAAM,MAAM,EAAC,MAAM,EAAC,SAAS,EAAC,SAAS,GAAE,CACjE,CACZ;oBACP,8BAAM,CAAC,EAAC,8BAA8B,EAAC,IAAI,EAAC,oBAAoB,GAAE;oBAClE,8BAAM,CAAC,EAAC,8BAA8B,EAAC,IAAI,EAAC,oBAAoB,GAAE;oBAClE,8BAAM,CAAC,EAAC,+BAA+B,EAAC,IAAI,EAAC,oBAAoB,GAAE;oBACnE,8BAAM,CAAC,EAAC,uBAAuB,EAAC,IAAI,EAAC,oBAAoB,EAAC,OAAO,EAAC,KAAK,GAAE;oBACzE,8BAAM,CAAC,EAAC,wBAAwB,EAAC,IAAI,EAAC,oBAAoB,EAAC,OAAO,EAAC,KAAK,GAAE;oBAC1E,8BAAM,CAAC,EAAC,+BAA+B,EAAC,IAAI,EAAC,OAAO,EAAC,OAAO,EAAC,MAAM,GAAE,CACjE;gBACN,2CAAmB,CACjB,CACA,CACP,CACM,CACV,CAAA;AACH,CAAC,CAAA"}
@@ -8,6 +8,8 @@ import { UserInfo } from './DashboardLayout';
8
8
  export interface DashboardHeaderProps {
9
9
  /** Header height in pixels */
10
10
  height?: number;
11
+ /** Sidebar width in pixels (used to offset header from left) */
12
+ sidebarWidth?: number;
11
13
  /** User information */
12
14
  user?: UserInfo;
13
15
  /** Callback when user clicks logout */
@@ -16,6 +18,14 @@ export interface DashboardHeaderProps {
16
18
  showNotifications?: boolean;
17
19
  /** Number of unread notifications */
18
20
  notificationCount?: number;
21
+ /** Callback when user navigates to profile */
22
+ onNavigateToProfile?: () => void;
23
+ /** Callback when user navigates to settings */
24
+ onNavigateToSettings?: () => void;
25
+ /** Callback when search bar is clicked */
26
+ onSearchClick?: () => void;
27
+ /** Placeholder text for search bar */
28
+ searchPlaceholder?: string;
19
29
  }
20
30
  /**
21
31
  * DashboardHeader Component
@@ -1 +1 @@
1
- {"version":3,"file":"DashboardHeader.d.ts","sourceRoot":"","sources":["../../../src/components/Dashboard/DashboardHeader.tsx"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAA;AACzB,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE5C,MAAM,WAAW,oBAAoB;IACnC,8BAA8B;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,uBAAuB;IACvB,IAAI,CAAC,EAAE,QAAQ,CAAA;IACf,uCAAuC;IACvC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAA;IACrB,8BAA8B;IAC9B,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,qCAAqC;IACrC,iBAAiB,CAAC,EAAE,MAAM,CAAA;CAC3B;AAED;;GAEG;AACH,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAsI1D,CAAA"}
1
+ {"version":3,"file":"DashboardHeader.d.ts","sourceRoot":"","sources":["../../../src/components/Dashboard/DashboardHeader.tsx"],"names":[],"mappings":"AAEA;;;;GAIG;AAEH,OAAO,KAAsC,MAAM,OAAO,CAAA;AAC1D,OAAO,EAAE,QAAQ,EAAE,MAAM,mBAAmB,CAAA;AAE5C,MAAM,WAAW,oBAAoB;IACnC,8BAA8B;IAC9B,MAAM,CAAC,EAAE,MAAM,CAAA;IACf,gEAAgE;IAChE,YAAY,CAAC,EAAE,MAAM,CAAA;IACrB,uBAAuB;IACvB,IAAI,CAAC,EAAE,QAAQ,CAAA;IACf,uCAAuC;IACvC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAA;IACrB,8BAA8B;IAC9B,iBAAiB,CAAC,EAAE,OAAO,CAAA;IAC3B,qCAAqC;IACrC,iBAAiB,CAAC,EAAE,MAAM,CAAA;IAC1B,8CAA8C;IAC9C,mBAAmB,CAAC,EAAE,MAAM,IAAI,CAAA;IAChC,+CAA+C;IAC/C,oBAAoB,CAAC,EAAE,MAAM,IAAI,CAAA;IACjC,0CAA0C;IAC1C,aAAa,CAAC,EAAE,MAAM,IAAI,CAAA;IAC1B,sCAAsC;IACtC,iBAAiB,CAAC,EAAE,MAAM,CAAA;CAC3B;AAED;;GAEG;AACH,eAAO,MAAM,eAAe,EAAE,KAAK,CAAC,EAAE,CAAC,oBAAoB,CAuU1D,CAAA"}