@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.
- package/LICENSE +1 -1
- package/README.md +227 -203
- package/dist/components/Analytics/DataTable.js +1 -1
- package/dist/components/Analytics/DataTable.js.map +1 -1
- package/dist/components/Analytics/EnhancedKPICard.d.ts +21 -0
- package/dist/components/Analytics/EnhancedKPICard.d.ts.map +1 -0
- package/dist/components/Analytics/EnhancedKPICard.js +135 -0
- package/dist/components/Analytics/EnhancedKPICard.js.map +1 -0
- package/dist/components/Analytics/Sparkline.d.ts +44 -0
- package/dist/components/Analytics/Sparkline.d.ts.map +1 -0
- package/dist/components/Analytics/Sparkline.js +90 -0
- package/dist/components/Analytics/Sparkline.js.map +1 -0
- package/dist/components/Analytics/index.d.ts +2 -0
- package/dist/components/Analytics/index.d.ts.map +1 -1
- package/dist/components/Analytics/index.js +2 -0
- package/dist/components/Analytics/index.js.map +1 -1
- package/dist/components/Dashboard/DashboardFooter.d.ts.map +1 -1
- package/dist/components/Dashboard/DashboardFooter.js +22 -6
- package/dist/components/Dashboard/DashboardFooter.js.map +1 -1
- package/dist/components/Dashboard/DashboardHeader.d.ts +10 -0
- package/dist/components/Dashboard/DashboardHeader.d.ts.map +1 -1
- package/dist/components/Dashboard/DashboardHeader.js +191 -58
- package/dist/components/Dashboard/DashboardHeader.js.map +1 -1
- package/dist/components/Dashboard/DashboardLayout.d.ts +13 -3
- package/dist/components/Dashboard/DashboardLayout.d.ts.map +1 -1
- package/dist/components/Dashboard/DashboardLayout.js +9 -4
- package/dist/components/Dashboard/DashboardLayout.js.map +1 -1
- package/dist/components/Dashboard/DashboardSidebar.d.ts.map +1 -1
- package/dist/components/Dashboard/DashboardSidebar.js +41 -12
- package/dist/components/Dashboard/DashboardSidebar.js.map +1 -1
- package/dist/components/Dashboard/EmptyState.js +5 -5
- package/dist/components/Dashboard/EmptyState.js.map +1 -1
- package/dist/components/Dashboard/KPICard.js +5 -5
- package/dist/components/Dashboard/KPICard.js.map +1 -1
- package/dist/components/Display/Avatar.d.ts +21 -0
- package/dist/components/Display/Avatar.d.ts.map +1 -0
- package/dist/components/Display/Avatar.js +71 -0
- package/dist/components/Display/Avatar.js.map +1 -0
- package/dist/components/Display/Badge.d.ts +22 -0
- package/dist/components/Display/Badge.d.ts.map +1 -0
- package/dist/components/Display/Badge.js +60 -0
- package/dist/components/Display/Badge.js.map +1 -0
- package/dist/components/Display/ProgressBar.d.ts +12 -0
- package/dist/components/Display/ProgressBar.d.ts.map +1 -0
- package/dist/components/Display/ProgressBar.js +33 -0
- package/dist/components/Display/ProgressBar.js.map +1 -0
- package/dist/components/Display/index.d.ts +9 -0
- package/dist/components/Display/index.d.ts.map +1 -0
- package/dist/components/Display/index.js +9 -0
- package/dist/components/Display/index.js.map +1 -0
- package/dist/components/Feedback/Skeleton.d.ts +10 -0
- package/dist/components/Feedback/Skeleton.d.ts.map +1 -0
- package/dist/components/Feedback/Skeleton.js +25 -0
- package/dist/components/Feedback/Skeleton.js.map +1 -0
- package/dist/components/Feedback/Toast.d.ts +18 -0
- package/dist/components/Feedback/Toast.d.ts.map +1 -0
- package/dist/components/Feedback/Toast.js +38 -0
- package/dist/components/Feedback/Toast.js.map +1 -0
- package/dist/components/Feedback/ToastProvider.d.ts +11 -0
- package/dist/components/Feedback/ToastProvider.d.ts.map +1 -0
- package/dist/components/Feedback/ToastProvider.js +36 -0
- package/dist/components/Feedback/ToastProvider.js.map +1 -0
- package/dist/components/Feedback/index.d.ts +11 -0
- package/dist/components/Feedback/index.d.ts.map +1 -0
- package/dist/components/Feedback/index.js +9 -0
- package/dist/components/Feedback/index.js.map +1 -0
- package/dist/components/Feedback/useToast.d.ts +3 -0
- package/dist/components/Feedback/useToast.d.ts.map +1 -0
- package/dist/components/Feedback/useToast.js +10 -0
- package/dist/components/Feedback/useToast.js.map +1 -0
- package/dist/components/Form/Button.d.ts +12 -0
- package/dist/components/Form/Button.d.ts.map +1 -0
- package/dist/components/Form/Button.js +22 -0
- package/dist/components/Form/Button.js.map +1 -0
- package/dist/components/Form/Checkbox.d.ts +13 -0
- package/dist/components/Form/Checkbox.d.ts.map +1 -0
- package/dist/components/Form/Checkbox.js +36 -0
- package/dist/components/Form/Checkbox.js.map +1 -0
- package/dist/components/Form/Input.d.ts +9 -0
- package/dist/components/Form/Input.d.ts.map +1 -0
- package/dist/components/Form/Input.js +16 -0
- package/dist/components/Form/Input.js.map +1 -0
- package/dist/components/Form/RadioGroup.d.ts +20 -0
- package/dist/components/Form/RadioGroup.d.ts.map +1 -0
- package/dist/components/Form/RadioGroup.js +43 -0
- package/dist/components/Form/RadioGroup.js.map +1 -0
- package/dist/components/Form/Select.d.ts +12 -0
- package/dist/components/Form/Select.d.ts.map +1 -0
- package/dist/components/Form/Select.js +13 -0
- package/dist/components/Form/Select.js.map +1 -0
- package/dist/components/Form/Textarea.d.ts +8 -0
- package/dist/components/Form/Textarea.d.ts.map +1 -0
- package/dist/components/Form/Textarea.js +13 -0
- package/dist/components/Form/Textarea.js.map +1 -0
- package/dist/components/Form/Toggle.d.ts +12 -0
- package/dist/components/Form/Toggle.d.ts.map +1 -0
- package/dist/components/Form/Toggle.js +48 -0
- package/dist/components/Form/Toggle.js.map +1 -0
- package/dist/components/Form/index.d.ts +13 -0
- package/dist/components/Form/index.d.ts.map +1 -0
- package/dist/components/Form/index.js +13 -0
- package/dist/components/Form/index.js.map +1 -0
- package/dist/components/InAppWallet/InAppWalletProvider.d.ts +4 -4
- package/dist/components/InAppWallet/InAppWalletProvider.d.ts.map +1 -1
- package/dist/components/InAppWallet/InAppWalletProvider.js +15 -28
- package/dist/components/InAppWallet/InAppWalletProvider.js.map +1 -1
- package/dist/components/Navigation/Breadcrumb.d.ts +15 -0
- package/dist/components/Navigation/Breadcrumb.d.ts.map +1 -0
- package/dist/components/Navigation/Breadcrumb.js +28 -0
- package/dist/components/Navigation/Breadcrumb.js.map +1 -0
- package/dist/components/Navigation/CommandPalette.d.ts +26 -0
- package/dist/components/Navigation/CommandPalette.d.ts.map +1 -0
- package/dist/components/Navigation/CommandPalette.js +172 -0
- package/dist/components/Navigation/CommandPalette.js.map +1 -0
- package/dist/components/Navigation/index.d.ts +8 -0
- package/dist/components/Navigation/index.d.ts.map +1 -0
- package/dist/components/Navigation/index.js +8 -0
- package/dist/components/Navigation/index.js.map +1 -0
- package/dist/components/Onramp/BuyUSDCButton.d.ts +9 -7
- package/dist/components/Onramp/BuyUSDCButton.d.ts.map +1 -1
- package/dist/components/Onramp/BuyUSDCButton.js +37 -47
- package/dist/components/Onramp/BuyUSDCButton.js.map +1 -1
- package/dist/components/Onramp/OnrampWidget.d.ts +7 -6
- package/dist/components/Onramp/OnrampWidget.d.ts.map +1 -1
- package/dist/components/Onramp/OnrampWidget.js +58 -37
- package/dist/components/Onramp/OnrampWidget.js.map +1 -1
- package/dist/components/Onramp/index.d.ts +3 -5
- package/dist/components/Onramp/index.d.ts.map +1 -1
- package/dist/components/Onramp/index.js +3 -5
- package/dist/components/Onramp/index.js.map +1 -1
- package/dist/components/Overlay/ConfirmDialog.d.ts +14 -0
- package/dist/components/Overlay/ConfirmDialog.d.ts.map +1 -0
- package/dist/components/Overlay/ConfirmDialog.js +11 -0
- package/dist/components/Overlay/ConfirmDialog.js.map +1 -0
- package/dist/components/Overlay/Dialog.d.ts +11 -0
- package/dist/components/Overlay/Dialog.d.ts.map +1 -0
- package/dist/components/Overlay/Dialog.js +69 -0
- package/dist/components/Overlay/Dialog.js.map +1 -0
- package/dist/components/Overlay/DropdownMenu.d.ts +17 -0
- package/dist/components/Overlay/DropdownMenu.d.ts.map +1 -0
- package/dist/components/Overlay/DropdownMenu.js +123 -0
- package/dist/components/Overlay/DropdownMenu.js.map +1 -0
- package/dist/components/Overlay/index.d.ts +9 -0
- package/dist/components/Overlay/index.d.ts.map +1 -0
- package/dist/components/Overlay/index.js +9 -0
- package/dist/components/Overlay/index.js.map +1 -0
- package/dist/components/PaymentWidget/PaymentGate.d.ts +30 -0
- package/dist/components/PaymentWidget/PaymentGate.d.ts.map +1 -0
- package/dist/components/PaymentWidget/PaymentGate.js +54 -0
- package/dist/components/PaymentWidget/PaymentGate.js.map +1 -0
- package/dist/components/PaymentWidget/PaymentWidget.d.ts +40 -0
- package/dist/components/PaymentWidget/PaymentWidget.d.ts.map +1 -0
- package/dist/components/PaymentWidget/PaymentWidget.js +195 -0
- package/dist/components/PaymentWidget/PaymentWidget.js.map +1 -0
- package/dist/components/PaymentWidget/index.d.ts +30 -0
- package/dist/components/PaymentWidget/index.d.ts.map +1 -0
- package/dist/components/PaymentWidget/index.js +32 -0
- package/dist/components/PaymentWidget/index.js.map +1 -0
- package/dist/components/PaymentWidget/types.d.ts +200 -0
- package/dist/components/PaymentWidget/types.d.ts.map +1 -0
- package/dist/components/PaymentWidget/types.js +84 -0
- package/dist/components/PaymentWidget/types.js.map +1 -0
- package/dist/components/PaymentWidget/useSeamlessPayment.d.ts +51 -0
- package/dist/components/PaymentWidget/useSeamlessPayment.d.ts.map +1 -0
- package/dist/components/PaymentWidget/useSeamlessPayment.js +167 -0
- package/dist/components/PaymentWidget/useSeamlessPayment.js.map +1 -0
- package/dist/components/PaymentWidget/useVarityPayment.d.ts +20 -0
- package/dist/components/PaymentWidget/useVarityPayment.d.ts.map +1 -0
- package/dist/components/PaymentWidget/useVarityPayment.js +164 -0
- package/dist/components/PaymentWidget/useVarityPayment.js.map +1 -0
- package/dist/components/Payments/CheckoutModal.d.ts.map +1 -1
- package/dist/components/Payments/CheckoutModal.js +16 -5
- package/dist/components/Payments/CheckoutModal.js.map +1 -1
- package/dist/components/Payments/constants.js +1 -1
- package/dist/components/Payments/constants.js.map +1 -1
- package/dist/components/Privy/InitTimeoutScreen.d.ts.map +1 -1
- package/dist/components/Privy/InitTimeoutScreen.js +1 -1
- package/dist/components/Privy/InitTimeoutScreen.js.map +1 -1
- package/dist/components/Privy/InitializingScreen.d.ts +3 -3
- package/dist/components/Privy/InitializingScreen.d.ts.map +1 -1
- package/dist/components/Privy/InitializingScreen.js +6 -6
- package/dist/components/Privy/InitializingScreen.js.map +1 -1
- package/dist/components/index.d.ts +5 -2
- package/dist/components/index.d.ts.map +1 -1
- package/dist/components/index.js +20 -4
- package/dist/components/index.js.map +1 -1
- package/dist/config/chains.d.ts +5 -5
- package/dist/config/chains.d.ts.map +1 -1
- package/dist/config/chains.js +8 -8
- package/dist/config/chains.js.map +1 -1
- package/dist/hooks/index.d.ts +1 -11
- package/dist/hooks/index.d.ts.map +1 -1
- package/dist/hooks/index.js +54 -11
- package/dist/hooks/index.js.map +1 -1
- package/dist/index.d.ts +24 -42
- package/dist/index.d.ts.map +1 -1
- package/dist/index.js +180 -43
- package/dist/index.js.map +1 -1
- package/dist/providers/PrivyProvider.js +1 -1
- package/dist/providers/PrivyProvider.js.map +1 -1
- package/dist/providers/PrivyStack.d.ts +31 -73
- package/dist/providers/PrivyStack.d.ts.map +1 -1
- package/dist/providers/PrivyStack.js +32 -160
- package/dist/providers/PrivyStack.js.map +1 -1
- package/dist/providers/VarityDashboardProvider.d.ts +7 -10
- package/dist/providers/VarityDashboardProvider.d.ts.map +1 -1
- package/dist/providers/VarityDashboardProvider.js +12 -15
- package/dist/providers/VarityDashboardProvider.js.map +1 -1
- package/dist/providers/WalletSyncProvider.d.ts +17 -24
- package/dist/providers/WalletSyncProvider.d.ts.map +1 -1
- package/dist/providers/WalletSyncProvider.js +16 -27
- package/dist/providers/WalletSyncProvider.js.map +1 -1
- package/dist/providers/ZeroDevProvider.d.ts +69 -0
- package/dist/providers/ZeroDevProvider.d.ts.map +1 -0
- package/dist/providers/ZeroDevProvider.js +208 -0
- package/dist/providers/ZeroDevProvider.js.map +1 -0
- package/dist/providers/index.d.ts +1 -0
- package/dist/providers/index.d.ts.map +1 -1
- package/dist/providers/index.js +2 -0
- package/dist/providers/index.js.map +1 -1
- package/dist/wallets/SimpleSmartWallet.js +1 -1
- package/dist/wallets/SimpleSmartWallet.js.map +1 -1
- package/dist/wallets/SmartWalletProvider.js +1 -1
- package/dist/wallets/SmartWalletProvider.js.map +1 -1
- package/dist/wallets/config.d.ts +31 -8
- package/dist/wallets/config.d.ts.map +1 -1
- package/dist/wallets/config.js +33 -10
- package/dist/wallets/config.js.map +1 -1
- package/dist/wallets/index.d.ts +1 -1
- package/dist/wallets/index.d.ts.map +1 -1
- package/dist/wallets/index.js +1 -1
- package/dist/wallets/index.js.map +1 -1
- package/package.json +34 -26
- package/dist/core/VarityClient.d.ts +0 -76
- package/dist/core/VarityClient.d.ts.map +0 -1
- package/dist/core/VarityClient.js +0 -99
- package/dist/core/VarityClient.js.map +0 -1
- package/dist/core/config.d.ts +0 -136
- package/dist/core/config.d.ts.map +0 -1
- package/dist/core/config.js +0 -156
- package/dist/core/config.js.map +0 -1
- package/dist/hooks/useAnalytics.d.ts +0 -94
- package/dist/hooks/useAnalytics.d.ts.map +0 -1
- package/dist/hooks/useAnalytics.js +0 -116
- package/dist/hooks/useAnalytics.js.map +0 -1
- package/dist/hooks/useAuth.d.ts +0 -71
- package/dist/hooks/useAuth.d.ts.map +0 -1
- package/dist/hooks/useAuth.js +0 -198
- package/dist/hooks/useAuth.js.map +0 -1
- package/dist/hooks/useDashboard.d.ts +0 -110
- package/dist/hooks/useDashboard.d.ts.map +0 -1
- package/dist/hooks/useDashboard.js +0 -201
- package/dist/hooks/useDashboard.js.map +0 -1
- package/dist/hooks/useVarityAPI.d.ts +0 -88
- package/dist/hooks/useVarityAPI.d.ts.map +0 -1
- package/dist/hooks/useVarityAPI.js +0 -138
- package/dist/hooks/useVarityAPI.js.map +0 -1
- package/dist/hooks/useWalletAuth.d.ts +0 -108
- package/dist/hooks/useWalletAuth.d.ts.map +0 -1
- package/dist/hooks/useWalletAuth.js +0 -415
- package/dist/hooks/useWalletAuth.js.map +0 -1
- package/dist/modules/cache/index.d.ts +0 -2
- package/dist/modules/cache/index.d.ts.map +0 -1
- package/dist/modules/cache/index.js +0 -2
- package/dist/modules/cache/index.js.map +0 -1
- package/dist/types/api-extensions.d.ts +0 -92
- package/dist/types/api-extensions.d.ts.map +0 -1
- package/dist/types/api-extensions.js +0 -7
- 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;
|
|
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,
|
|
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.
|
|
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: '
|
|
59
|
+
gap: '6px'
|
|
60
60
|
}, onMouseEnter: (e) => {
|
|
61
|
-
e.currentTarget.style.
|
|
61
|
+
e.currentTarget.style.opacity = '0.8';
|
|
62
62
|
}, onMouseLeave: (e) => {
|
|
63
|
-
e.currentTarget.style.
|
|
63
|
+
e.currentTarget.style.opacity = '1';
|
|
64
64
|
} },
|
|
65
|
-
React.createElement("
|
|
66
|
-
|
|
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":"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,
|
|
1
|
+
{"version":3,"file":"DashboardFooter.js","sourceRoot":"","sources":["../../../src/components/Dashboard/DashboardFooter.tsx"],"names":[],"mappings":"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"}
|
|
@@ -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":"
|
|
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"}
|