@varity-labs/ui-kit 2.0.0-alpha.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/LICENSE +31 -0
- package/README.md +248 -0
- package/dist/components/AI/ChatbotWidget.d.ts +53 -0
- package/dist/components/AI/ChatbotWidget.d.ts.map +1 -0
- package/dist/components/AI/ChatbotWidget.js +126 -0
- package/dist/components/AI/ChatbotWidget.js.map +1 -0
- package/dist/components/AI/InputBar.d.ts +25 -0
- package/dist/components/AI/InputBar.d.ts.map +1 -0
- package/dist/components/AI/InputBar.js +126 -0
- package/dist/components/AI/InputBar.js.map +1 -0
- package/dist/components/AI/MessageBubble.d.ts +37 -0
- package/dist/components/AI/MessageBubble.d.ts.map +1 -0
- package/dist/components/AI/MessageBubble.js +124 -0
- package/dist/components/AI/MessageBubble.js.map +1 -0
- package/dist/components/AI/index.d.ts +12 -0
- package/dist/components/AI/index.d.ts.map +1 -0
- package/dist/components/AI/index.js +9 -0
- package/dist/components/AI/index.js.map +1 -0
- package/dist/components/Analytics/AnalyticsCard.d.ts +48 -0
- package/dist/components/Analytics/AnalyticsCard.d.ts.map +1 -0
- package/dist/components/Analytics/AnalyticsCard.js +156 -0
- package/dist/components/Analytics/AnalyticsCard.js.map +1 -0
- package/dist/components/Analytics/ChartContainer.d.ts +53 -0
- package/dist/components/Analytics/ChartContainer.d.ts.map +1 -0
- package/dist/components/Analytics/ChartContainer.js +128 -0
- package/dist/components/Analytics/ChartContainer.js.map +1 -0
- package/dist/components/Analytics/DataTable.d.ts +62 -0
- package/dist/components/Analytics/DataTable.d.ts.map +1 -0
- package/dist/components/Analytics/DataTable.js +165 -0
- package/dist/components/Analytics/DataTable.js.map +1 -0
- package/dist/components/Analytics/MetricDisplay.d.ts +42 -0
- package/dist/components/Analytics/MetricDisplay.d.ts.map +1 -0
- package/dist/components/Analytics/MetricDisplay.js +110 -0
- package/dist/components/Analytics/MetricDisplay.js.map +1 -0
- package/dist/components/Analytics/index.d.ts +14 -0
- package/dist/components/Analytics/index.d.ts.map +1 -0
- package/dist/components/Analytics/index.js +10 -0
- package/dist/components/Analytics/index.js.map +1 -0
- package/dist/components/Branding/Attribution.d.ts +39 -0
- package/dist/components/Branding/Attribution.d.ts.map +1 -0
- package/dist/components/Branding/Attribution.js +124 -0
- package/dist/components/Branding/Attribution.js.map +1 -0
- package/dist/components/Branding/Logo.d.ts +39 -0
- package/dist/components/Branding/Logo.d.ts.map +1 -0
- package/dist/components/Branding/Logo.js +67 -0
- package/dist/components/Branding/Logo.js.map +1 -0
- package/dist/components/Branding/ThemeProvider.d.ts +85 -0
- package/dist/components/Branding/ThemeProvider.d.ts.map +1 -0
- package/dist/components/Branding/ThemeProvider.js +186 -0
- package/dist/components/Branding/ThemeProvider.js.map +1 -0
- package/dist/components/Branding/index.d.ts +12 -0
- package/dist/components/Branding/index.d.ts.map +1 -0
- package/dist/components/Branding/index.js +9 -0
- package/dist/components/Branding/index.js.map +1 -0
- package/dist/components/Dashboard/DashboardFooter.d.ts +30 -0
- package/dist/components/Dashboard/DashboardFooter.d.ts.map +1 -0
- package/dist/components/Dashboard/DashboardFooter.js +68 -0
- package/dist/components/Dashboard/DashboardFooter.js.map +1 -0
- package/dist/components/Dashboard/DashboardHeader.d.ts +24 -0
- package/dist/components/Dashboard/DashboardHeader.d.ts.map +1 -0
- package/dist/components/Dashboard/DashboardHeader.js +87 -0
- package/dist/components/Dashboard/DashboardHeader.js.map +1 -0
- package/dist/components/Dashboard/DashboardLayout.d.ts +71 -0
- package/dist/components/Dashboard/DashboardLayout.d.ts.map +1 -0
- package/dist/components/Dashboard/DashboardLayout.js +52 -0
- package/dist/components/Dashboard/DashboardLayout.js.map +1 -0
- package/dist/components/Dashboard/DashboardSidebar.d.ts +26 -0
- package/dist/components/Dashboard/DashboardSidebar.d.ts.map +1 -0
- package/dist/components/Dashboard/DashboardSidebar.js +146 -0
- package/dist/components/Dashboard/DashboardSidebar.js.map +1 -0
- package/dist/components/Dashboard/EmptyState.d.ts +84 -0
- package/dist/components/Dashboard/EmptyState.d.ts.map +1 -0
- package/dist/components/Dashboard/EmptyState.js +99 -0
- package/dist/components/Dashboard/EmptyState.js.map +1 -0
- package/dist/components/Dashboard/KPICard.d.ts +58 -0
- package/dist/components/Dashboard/KPICard.d.ts.map +1 -0
- package/dist/components/Dashboard/KPICard.js +82 -0
- package/dist/components/Dashboard/KPICard.js.map +1 -0
- package/dist/components/Dashboard/LoadingSkeleton.d.ts +58 -0
- package/dist/components/Dashboard/LoadingSkeleton.d.ts.map +1 -0
- package/dist/components/Dashboard/LoadingSkeleton.js +105 -0
- package/dist/components/Dashboard/LoadingSkeleton.js.map +1 -0
- package/dist/components/Dashboard/StatusBadge.d.ts +57 -0
- package/dist/components/Dashboard/StatusBadge.d.ts.map +1 -0
- package/dist/components/Dashboard/StatusBadge.js +149 -0
- package/dist/components/Dashboard/StatusBadge.js.map +1 -0
- package/dist/components/Dashboard/index.d.ts +19 -0
- package/dist/components/Dashboard/index.d.ts.map +1 -0
- package/dist/components/Dashboard/index.js +18 -0
- package/dist/components/Dashboard/index.js.map +1 -0
- package/dist/components/InAppWallet/EmailLoginButton.d.ts +27 -0
- package/dist/components/InAppWallet/EmailLoginButton.d.ts.map +1 -0
- package/dist/components/InAppWallet/EmailLoginButton.js +84 -0
- package/dist/components/InAppWallet/EmailLoginButton.js.map +1 -0
- package/dist/components/InAppWallet/InAppWalletProvider.d.ts +54 -0
- package/dist/components/InAppWallet/InAppWalletProvider.d.ts.map +1 -0
- package/dist/components/InAppWallet/InAppWalletProvider.js +238 -0
- package/dist/components/InAppWallet/InAppWalletProvider.js.map +1 -0
- package/dist/components/InAppWallet/OnboardingFlow.d.ts +25 -0
- package/dist/components/InAppWallet/OnboardingFlow.d.ts.map +1 -0
- package/dist/components/InAppWallet/OnboardingFlow.js +159 -0
- package/dist/components/InAppWallet/OnboardingFlow.js.map +1 -0
- package/dist/components/InAppWallet/SocialLoginButtons.d.ts +28 -0
- package/dist/components/InAppWallet/SocialLoginButtons.d.ts.map +1 -0
- package/dist/components/InAppWallet/SocialLoginButtons.js +128 -0
- package/dist/components/InAppWallet/SocialLoginButtons.js.map +1 -0
- package/dist/components/InAppWallet/index.d.ts +15 -0
- package/dist/components/InAppWallet/index.d.ts.map +1 -0
- package/dist/components/InAppWallet/index.js +14 -0
- package/dist/components/InAppWallet/index.js.map +1 -0
- package/dist/components/Onramp/BuyUSDCButton.d.ts +27 -0
- package/dist/components/Onramp/BuyUSDCButton.d.ts.map +1 -0
- package/dist/components/Onramp/BuyUSDCButton.js +70 -0
- package/dist/components/Onramp/BuyUSDCButton.js.map +1 -0
- package/dist/components/Onramp/OnrampWidget.d.ts +38 -0
- package/dist/components/Onramp/OnrampWidget.d.ts.map +1 -0
- package/dist/components/Onramp/OnrampWidget.js +105 -0
- package/dist/components/Onramp/OnrampWidget.js.map +1 -0
- package/dist/components/Onramp/index.d.ts +14 -0
- package/dist/components/Onramp/index.d.ts.map +1 -0
- package/dist/components/Onramp/index.js +12 -0
- package/dist/components/Onramp/index.js.map +1 -0
- package/dist/components/Payments/CheckoutModal.d.ts +19 -0
- package/dist/components/Payments/CheckoutModal.d.ts.map +1 -0
- package/dist/components/Payments/CheckoutModal.js +183 -0
- package/dist/components/Payments/CheckoutModal.js.map +1 -0
- package/dist/components/Payments/SubscriptionWidget.d.ts +17 -0
- package/dist/components/Payments/SubscriptionWidget.d.ts.map +1 -0
- package/dist/components/Payments/SubscriptionWidget.js +89 -0
- package/dist/components/Payments/SubscriptionWidget.js.map +1 -0
- package/dist/components/Payments/constants.d.ts +59 -0
- package/dist/components/Payments/constants.d.ts.map +1 -0
- package/dist/components/Payments/constants.js +145 -0
- package/dist/components/Payments/constants.js.map +1 -0
- package/dist/components/Payments/index.d.ts +10 -0
- package/dist/components/Payments/index.d.ts.map +1 -0
- package/dist/components/Payments/index.js +12 -0
- package/dist/components/Payments/index.js.map +1 -0
- package/dist/components/Payments/types.d.ts +119 -0
- package/dist/components/Payments/types.d.ts.map +1 -0
- package/dist/components/Payments/types.js +27 -0
- package/dist/components/Payments/types.js.map +1 -0
- package/dist/components/Payments/usePayments.d.ts +33 -0
- package/dist/components/Payments/usePayments.d.ts.map +1 -0
- package/dist/components/Payments/usePayments.js +249 -0
- package/dist/components/Payments/usePayments.js.map +1 -0
- package/dist/components/Privy/InitTimeoutScreen.d.ts +62 -0
- package/dist/components/Privy/InitTimeoutScreen.d.ts.map +1 -0
- package/dist/components/Privy/InitTimeoutScreen.js +64 -0
- package/dist/components/Privy/InitTimeoutScreen.js.map +1 -0
- package/dist/components/Privy/InitializingScreen.d.ts +56 -0
- package/dist/components/Privy/InitializingScreen.d.ts.map +1 -0
- package/dist/components/Privy/InitializingScreen.js +60 -0
- package/dist/components/Privy/InitializingScreen.js.map +1 -0
- package/dist/components/Privy/PrivyLoginButton.d.ts +27 -0
- package/dist/components/Privy/PrivyLoginButton.d.ts.map +1 -0
- package/dist/components/Privy/PrivyLoginButton.js +48 -0
- package/dist/components/Privy/PrivyLoginButton.js.map +1 -0
- package/dist/components/Privy/PrivyProtectedRoute.d.ts +22 -0
- package/dist/components/Privy/PrivyProtectedRoute.d.ts.map +1 -0
- package/dist/components/Privy/PrivyProtectedRoute.js +46 -0
- package/dist/components/Privy/PrivyProtectedRoute.js.map +1 -0
- package/dist/components/Privy/PrivyReadyGate.d.ts +69 -0
- package/dist/components/Privy/PrivyReadyGate.d.ts.map +1 -0
- package/dist/components/Privy/PrivyReadyGate.js +83 -0
- package/dist/components/Privy/PrivyReadyGate.js.map +1 -0
- package/dist/components/Privy/PrivyUserProfile.d.ts +25 -0
- package/dist/components/Privy/PrivyUserProfile.d.ts.map +1 -0
- package/dist/components/Privy/PrivyUserProfile.js +98 -0
- package/dist/components/Privy/PrivyUserProfile.js.map +1 -0
- package/dist/components/Privy/index.d.ts +21 -0
- package/dist/components/Privy/index.d.ts.map +1 -0
- package/dist/components/Privy/index.js +16 -0
- package/dist/components/Privy/index.js.map +1 -0
- package/dist/components/SIWE/AuthStatus.d.ts +15 -0
- package/dist/components/SIWE/AuthStatus.d.ts.map +1 -0
- package/dist/components/SIWE/AuthStatus.js +47 -0
- package/dist/components/SIWE/AuthStatus.js.map +1 -0
- package/dist/components/SIWE/ProtectedRoute.d.ts +17 -0
- package/dist/components/SIWE/ProtectedRoute.d.ts.map +1 -0
- package/dist/components/SIWE/ProtectedRoute.js +52 -0
- package/dist/components/SIWE/ProtectedRoute.js.map +1 -0
- package/dist/components/SIWE/SIWEButton.d.ts +22 -0
- package/dist/components/SIWE/SIWEButton.d.ts.map +1 -0
- package/dist/components/SIWE/SIWEButton.js +106 -0
- package/dist/components/SIWE/SIWEButton.js.map +1 -0
- package/dist/components/SIWE/SIWEModal.d.ts +19 -0
- package/dist/components/SIWE/SIWEModal.d.ts.map +1 -0
- package/dist/components/SIWE/SIWEModal.js +75 -0
- package/dist/components/SIWE/SIWEModal.js.map +1 -0
- package/dist/components/SIWE/SIWEProvider.d.ts +38 -0
- package/dist/components/SIWE/SIWEProvider.d.ts.map +1 -0
- package/dist/components/SIWE/SIWEProvider.js +227 -0
- package/dist/components/SIWE/SIWEProvider.js.map +1 -0
- package/dist/components/SIWE/index.d.ts +15 -0
- package/dist/components/SIWE/index.d.ts.map +1 -0
- package/dist/components/SIWE/index.js +10 -0
- package/dist/components/SIWE/index.js.map +1 -0
- package/dist/components/index.d.ts +11 -0
- package/dist/components/index.d.ts.map +1 -0
- package/dist/components/index.js +16 -0
- package/dist/components/index.js.map +1 -0
- package/dist/components/templates/Finance/FinanceDashboard.d.ts +15 -0
- package/dist/components/templates/Finance/FinanceDashboard.d.ts.map +1 -0
- package/dist/components/templates/Finance/FinanceDashboard.js +112 -0
- package/dist/components/templates/Finance/FinanceDashboard.js.map +1 -0
- package/dist/components/templates/Healthcare/HealthcareDashboard.d.ts +15 -0
- package/dist/components/templates/Healthcare/HealthcareDashboard.d.ts.map +1 -0
- package/dist/components/templates/Healthcare/HealthcareDashboard.js +121 -0
- package/dist/components/templates/Healthcare/HealthcareDashboard.js.map +1 -0
- package/dist/components/templates/ISO/ISODashboard.d.ts +15 -0
- package/dist/components/templates/ISO/ISODashboard.d.ts.map +1 -0
- package/dist/components/templates/ISO/ISODashboard.js +184 -0
- package/dist/components/templates/ISO/ISODashboard.js.map +1 -0
- package/dist/components/templates/Retail/RetailDashboard.d.ts +15 -0
- package/dist/components/templates/Retail/RetailDashboard.d.ts.map +1 -0
- package/dist/components/templates/Retail/RetailDashboard.js +151 -0
- package/dist/components/templates/Retail/RetailDashboard.js.map +1 -0
- package/dist/components/templates/index.d.ts +14 -0
- package/dist/components/templates/index.d.ts.map +1 -0
- package/dist/components/templates/index.js +14 -0
- package/dist/components/templates/index.js.map +1 -0
- package/dist/config/chains.d.ts +23 -0
- package/dist/config/chains.d.ts.map +1 -0
- package/dist/config/chains.js +55 -0
- package/dist/config/chains.js.map +1 -0
- package/dist/core/VarityClient.d.ts +76 -0
- package/dist/core/VarityClient.d.ts.map +1 -0
- package/dist/core/VarityClient.js +99 -0
- package/dist/core/VarityClient.js.map +1 -0
- package/dist/core/config.d.ts +136 -0
- package/dist/core/config.d.ts.map +1 -0
- package/dist/core/config.js +156 -0
- package/dist/core/config.js.map +1 -0
- package/dist/hooks/index.d.ts +17 -0
- package/dist/hooks/index.d.ts.map +1 -0
- package/dist/hooks/index.js +18 -0
- package/dist/hooks/index.js.map +1 -0
- package/dist/hooks/useAnalytics.d.ts +94 -0
- package/dist/hooks/useAnalytics.d.ts.map +1 -0
- package/dist/hooks/useAnalytics.js +116 -0
- package/dist/hooks/useAnalytics.js.map +1 -0
- package/dist/hooks/useAuth.d.ts +71 -0
- package/dist/hooks/useAuth.d.ts.map +1 -0
- package/dist/hooks/useAuth.js +198 -0
- package/dist/hooks/useAuth.js.map +1 -0
- package/dist/hooks/useDashboard.d.ts +110 -0
- package/dist/hooks/useDashboard.d.ts.map +1 -0
- package/dist/hooks/useDashboard.js +201 -0
- package/dist/hooks/useDashboard.js.map +1 -0
- package/dist/hooks/useVarityAPI.d.ts +88 -0
- package/dist/hooks/useVarityAPI.d.ts.map +1 -0
- package/dist/hooks/useVarityAPI.js +138 -0
- package/dist/hooks/useVarityAPI.js.map +1 -0
- package/dist/hooks/useWalletAuth.d.ts +108 -0
- package/dist/hooks/useWalletAuth.d.ts.map +1 -0
- package/dist/hooks/useWalletAuth.js +415 -0
- package/dist/hooks/useWalletAuth.js.map +1 -0
- package/dist/hooks/web3/index.d.ts +5 -0
- package/dist/hooks/web3/index.d.ts.map +1 -0
- package/dist/hooks/web3/index.js +6 -0
- package/dist/hooks/web3/index.js.map +1 -0
- package/dist/hooks/web3/useAddressValidation.d.ts +37 -0
- package/dist/hooks/web3/useAddressValidation.d.ts.map +1 -0
- package/dist/hooks/web3/useAddressValidation.js +59 -0
- package/dist/hooks/web3/useAddressValidation.js.map +1 -0
- package/dist/hooks/web3/useBlockExplorer.d.ts +37 -0
- package/dist/hooks/web3/useBlockExplorer.d.ts.map +1 -0
- package/dist/hooks/web3/useBlockExplorer.js +59 -0
- package/dist/hooks/web3/useBlockExplorer.js.map +1 -0
- package/dist/hooks/web3/useUSDCFormat.d.ts +34 -0
- package/dist/hooks/web3/useUSDCFormat.d.ts.map +1 -0
- package/dist/hooks/web3/useUSDCFormat.js +43 -0
- package/dist/hooks/web3/useUSDCFormat.js.map +1 -0
- package/dist/hooks/web3/useVarityWallet.d.ts +48 -0
- package/dist/hooks/web3/useVarityWallet.d.ts.map +1 -0
- package/dist/hooks/web3/useVarityWallet.js +70 -0
- package/dist/hooks/web3/useVarityWallet.js.map +1 -0
- package/dist/index.d.ts +55 -0
- package/dist/index.d.ts.map +1 -0
- package/dist/index.js +68 -0
- package/dist/index.js.map +1 -0
- package/dist/modules/analytics/AnalyticsClient.d.ts +72 -0
- package/dist/modules/analytics/AnalyticsClient.d.ts.map +1 -0
- package/dist/modules/analytics/AnalyticsClient.js +56 -0
- package/dist/modules/analytics/AnalyticsClient.js.map +1 -0
- package/dist/modules/analytics/index.d.ts +2 -0
- package/dist/modules/analytics/index.d.ts.map +1 -0
- package/dist/modules/analytics/index.js +2 -0
- package/dist/modules/analytics/index.js.map +1 -0
- package/dist/modules/auth/AuthClient.d.ts +41 -0
- package/dist/modules/auth/AuthClient.d.ts.map +1 -0
- package/dist/modules/auth/AuthClient.js +36 -0
- package/dist/modules/auth/AuthClient.js.map +1 -0
- package/dist/modules/auth/index.d.ts +2 -0
- package/dist/modules/auth/index.d.ts.map +1 -0
- package/dist/modules/auth/index.js +2 -0
- package/dist/modules/auth/index.js.map +1 -0
- package/dist/modules/cache/CacheClient.d.ts +48 -0
- package/dist/modules/cache/CacheClient.d.ts.map +1 -0
- package/dist/modules/cache/CacheClient.js +59 -0
- package/dist/modules/cache/CacheClient.js.map +1 -0
- package/dist/modules/cache/index.d.ts +2 -0
- package/dist/modules/cache/index.d.ts.map +1 -0
- package/dist/modules/cache/index.js +2 -0
- package/dist/modules/cache/index.js.map +1 -0
- package/dist/modules/compute/ComputeClient.d.ts +54 -0
- package/dist/modules/compute/ComputeClient.d.ts.map +1 -0
- package/dist/modules/compute/ComputeClient.js +39 -0
- package/dist/modules/compute/ComputeClient.js.map +1 -0
- package/dist/modules/compute/index.d.ts +2 -0
- package/dist/modules/compute/index.d.ts.map +1 -0
- package/dist/modules/compute/index.js +2 -0
- package/dist/modules/compute/index.js.map +1 -0
- package/dist/modules/export/ExportClient.d.ts +56 -0
- package/dist/modules/export/ExportClient.d.ts.map +1 -0
- package/dist/modules/export/ExportClient.js +42 -0
- package/dist/modules/export/ExportClient.js.map +1 -0
- package/dist/modules/export/index.d.ts +2 -0
- package/dist/modules/export/index.d.ts.map +1 -0
- package/dist/modules/export/index.js +2 -0
- package/dist/modules/export/index.js.map +1 -0
- package/dist/modules/forecasting/ForecastingClient.d.ts +112 -0
- package/dist/modules/forecasting/ForecastingClient.d.ts.map +1 -0
- package/dist/modules/forecasting/ForecastingClient.js +48 -0
- package/dist/modules/forecasting/ForecastingClient.js.map +1 -0
- package/dist/modules/forecasting/index.d.ts +2 -0
- package/dist/modules/forecasting/index.d.ts.map +1 -0
- package/dist/modules/forecasting/index.js +2 -0
- package/dist/modules/forecasting/index.js.map +1 -0
- package/dist/modules/monitoring/MonitoringClient.d.ts +67 -0
- package/dist/modules/monitoring/MonitoringClient.d.ts.map +1 -0
- package/dist/modules/monitoring/MonitoringClient.js +48 -0
- package/dist/modules/monitoring/MonitoringClient.js.map +1 -0
- package/dist/modules/monitoring/index.d.ts +2 -0
- package/dist/modules/monitoring/index.d.ts.map +1 -0
- package/dist/modules/monitoring/index.js +2 -0
- package/dist/modules/monitoring/index.js.map +1 -0
- package/dist/modules/notifications/NotificationsClient.d.ts +68 -0
- package/dist/modules/notifications/NotificationsClient.d.ts.map +1 -0
- package/dist/modules/notifications/NotificationsClient.js +50 -0
- package/dist/modules/notifications/NotificationsClient.js.map +1 -0
- package/dist/modules/notifications/index.d.ts +2 -0
- package/dist/modules/notifications/index.d.ts.map +1 -0
- package/dist/modules/notifications/index.js +2 -0
- package/dist/modules/notifications/index.js.map +1 -0
- package/dist/modules/oracle/OracleClient.d.ts +48 -0
- package/dist/modules/oracle/OracleClient.d.ts.map +1 -0
- package/dist/modules/oracle/OracleClient.js +34 -0
- package/dist/modules/oracle/OracleClient.js.map +1 -0
- package/dist/modules/oracle/index.d.ts +2 -0
- package/dist/modules/oracle/index.d.ts.map +1 -0
- package/dist/modules/oracle/index.js +2 -0
- package/dist/modules/oracle/index.js.map +1 -0
- package/dist/modules/storage/StorageClient.d.ts +44 -0
- package/dist/modules/storage/StorageClient.d.ts.map +1 -0
- package/dist/modules/storage/StorageClient.js +43 -0
- package/dist/modules/storage/StorageClient.js.map +1 -0
- package/dist/modules/storage/index.d.ts +2 -0
- package/dist/modules/storage/index.d.ts.map +1 -0
- package/dist/modules/storage/index.js +2 -0
- package/dist/modules/storage/index.js.map +1 -0
- package/dist/modules/templates/TemplateDeploymentClient.d.ts +208 -0
- package/dist/modules/templates/TemplateDeploymentClient.d.ts.map +1 -0
- package/dist/modules/templates/TemplateDeploymentClient.js +101 -0
- package/dist/modules/templates/TemplateDeploymentClient.js.map +1 -0
- package/dist/modules/templates/index.d.ts +8 -0
- package/dist/modules/templates/index.d.ts.map +1 -0
- package/dist/modules/templates/index.js +7 -0
- package/dist/modules/templates/index.js.map +1 -0
- package/dist/modules/webhooks/WebhooksClient.d.ts +85 -0
- package/dist/modules/webhooks/WebhooksClient.d.ts.map +1 -0
- package/dist/modules/webhooks/WebhooksClient.js +68 -0
- package/dist/modules/webhooks/WebhooksClient.js.map +1 -0
- package/dist/modules/webhooks/index.d.ts +2 -0
- package/dist/modules/webhooks/index.d.ts.map +1 -0
- package/dist/modules/webhooks/index.js +2 -0
- package/dist/modules/webhooks/index.js.map +1 -0
- package/dist/modules/zk/ZKClient.d.ts +67 -0
- package/dist/modules/zk/ZKClient.d.ts.map +1 -0
- package/dist/modules/zk/ZKClient.js +36 -0
- package/dist/modules/zk/ZKClient.js.map +1 -0
- package/dist/modules/zk/index.d.ts +2 -0
- package/dist/modules/zk/index.d.ts.map +1 -0
- package/dist/modules/zk/index.js +2 -0
- package/dist/modules/zk/index.js.map +1 -0
- package/dist/providers/ChainContext.d.ts +65 -0
- package/dist/providers/ChainContext.d.ts.map +1 -0
- package/dist/providers/ChainContext.js +92 -0
- package/dist/providers/ChainContext.js.map +1 -0
- package/dist/providers/PrivyProvider.d.ts +42 -0
- package/dist/providers/PrivyProvider.d.ts.map +1 -0
- package/dist/providers/PrivyProvider.js +131 -0
- package/dist/providers/PrivyProvider.js.map +1 -0
- package/dist/providers/PrivyStack.d.ts +165 -0
- package/dist/providers/PrivyStack.d.ts.map +1 -0
- package/dist/providers/PrivyStack.js +295 -0
- package/dist/providers/PrivyStack.js.map +1 -0
- package/dist/providers/VarityDashboardProvider.d.ts +90 -0
- package/dist/providers/VarityDashboardProvider.d.ts.map +1 -0
- package/dist/providers/VarityDashboardProvider.js +242 -0
- package/dist/providers/VarityDashboardProvider.js.map +1 -0
- package/dist/providers/VarityProvider.d.ts +32 -0
- package/dist/providers/VarityProvider.d.ts.map +1 -0
- package/dist/providers/VarityProvider.js +56 -0
- package/dist/providers/VarityProvider.js.map +1 -0
- package/dist/providers/WalletContext.d.ts +68 -0
- package/dist/providers/WalletContext.d.ts.map +1 -0
- package/dist/providers/WalletContext.js +98 -0
- package/dist/providers/WalletContext.js.map +1 -0
- package/dist/providers/WalletSyncProvider.d.ts +84 -0
- package/dist/providers/WalletSyncProvider.d.ts.map +1 -0
- package/dist/providers/WalletSyncProvider.js +132 -0
- package/dist/providers/WalletSyncProvider.js.map +1 -0
- package/dist/providers/index.d.ts +47 -0
- package/dist/providers/index.d.ts.map +1 -0
- package/dist/providers/index.js +51 -0
- package/dist/providers/index.js.map +1 -0
- package/dist/tests/mocks/httpClient.mock.d.ts +62 -0
- package/dist/tests/mocks/httpClient.mock.d.ts.map +1 -0
- package/dist/tests/mocks/httpClient.mock.js +108 -0
- package/dist/tests/mocks/httpClient.mock.js.map +1 -0
- package/dist/tests/setup.d.ts +6 -0
- package/dist/tests/setup.d.ts.map +1 -0
- package/dist/tests/setup.js +51 -0
- package/dist/tests/setup.js.map +1 -0
- package/dist/types/api-extensions.d.ts +92 -0
- package/dist/types/api-extensions.d.ts.map +1 -0
- package/dist/types/api-extensions.js +7 -0
- package/dist/types/api-extensions.js.map +1 -0
- package/dist/utils/http.d.ts +51 -0
- package/dist/utils/http.d.ts.map +1 -0
- package/dist/utils/http.js +104 -0
- package/dist/utils/http.js.map +1 -0
- package/dist/wallets/SimpleSmartWallet.d.ts +68 -0
- package/dist/wallets/SimpleSmartWallet.d.ts.map +1 -0
- package/dist/wallets/SimpleSmartWallet.js +74 -0
- package/dist/wallets/SimpleSmartWallet.js.map +1 -0
- package/dist/wallets/SmartWalletProvider.d.ts +217 -0
- package/dist/wallets/SmartWalletProvider.d.ts.map +1 -0
- package/dist/wallets/SmartWalletProvider.js +366 -0
- package/dist/wallets/SmartWalletProvider.js.map +1 -0
- package/dist/wallets/config.d.ts +199 -0
- package/dist/wallets/config.d.ts.map +1 -0
- package/dist/wallets/config.js +183 -0
- package/dist/wallets/config.js.map +1 -0
- package/dist/wallets/index.d.ts +9 -0
- package/dist/wallets/index.d.ts.map +1 -0
- package/dist/wallets/index.js +9 -0
- package/dist/wallets/index.js.map +1 -0
- package/dist/web3/AddressDisplay/AddressDisplay.d.ts +33 -0
- package/dist/web3/AddressDisplay/AddressDisplay.d.ts.map +1 -0
- package/dist/web3/AddressDisplay/AddressDisplay.js +42 -0
- package/dist/web3/AddressDisplay/AddressDisplay.js.map +1 -0
- package/dist/web3/AddressInput/AddressInput.d.ts +36 -0
- package/dist/web3/AddressInput/AddressInput.d.ts.map +1 -0
- package/dist/web3/AddressInput/AddressInput.js +54 -0
- package/dist/web3/AddressInput/AddressInput.js.map +1 -0
- package/dist/web3/AmountInput/AmountInput.d.ts +41 -0
- package/dist/web3/AmountInput/AmountInput.d.ts.map +1 -0
- package/dist/web3/AmountInput/AmountInput.js +74 -0
- package/dist/web3/AmountInput/AmountInput.js.map +1 -0
- package/dist/web3/BalanceDisplay/BalanceDisplay.d.ts +30 -0
- package/dist/web3/BalanceDisplay/BalanceDisplay.d.ts.map +1 -0
- package/dist/web3/BalanceDisplay/BalanceDisplay.js +35 -0
- package/dist/web3/BalanceDisplay/BalanceDisplay.js.map +1 -0
- package/dist/web3/BlockExplorerLink/BlockExplorerLink.d.ts +41 -0
- package/dist/web3/BlockExplorerLink/BlockExplorerLink.d.ts.map +1 -0
- package/dist/web3/BlockExplorerLink/BlockExplorerLink.js +46 -0
- package/dist/web3/BlockExplorerLink/BlockExplorerLink.js.map +1 -0
- package/dist/web3/ConnectWallet/ConnectWallet.d.ts +35 -0
- package/dist/web3/ConnectWallet/ConnectWallet.d.ts.map +1 -0
- package/dist/web3/ConnectWallet/ConnectWallet.js +58 -0
- package/dist/web3/ConnectWallet/ConnectWallet.js.map +1 -0
- package/dist/web3/DisconnectButton/DisconnectButton.d.ts +30 -0
- package/dist/web3/DisconnectButton/DisconnectButton.d.ts.map +1 -0
- package/dist/web3/DisconnectButton/DisconnectButton.js +48 -0
- package/dist/web3/DisconnectButton/DisconnectButton.js.map +1 -0
- package/dist/web3/WalletBalance/WalletBalance.d.ts +27 -0
- package/dist/web3/WalletBalance/WalletBalance.d.ts.map +1 -0
- package/dist/web3/WalletBalance/WalletBalance.js +49 -0
- package/dist/web3/WalletBalance/WalletBalance.js.map +1 -0
- package/dist/web3/WalletDropdown/WalletDropdown.d.ts +29 -0
- package/dist/web3/WalletDropdown/WalletDropdown.d.ts.map +1 -0
- package/dist/web3/WalletDropdown/WalletDropdown.js +93 -0
- package/dist/web3/WalletDropdown/WalletDropdown.js.map +1 -0
- package/dist/web3/WalletInfo/WalletInfo.d.ts +31 -0
- package/dist/web3/WalletInfo/WalletInfo.d.ts.map +1 -0
- package/dist/web3/WalletInfo/WalletInfo.js +41 -0
- package/dist/web3/WalletInfo/WalletInfo.js.map +1 -0
- package/dist/web3/index.d.ts +11 -0
- package/dist/web3/index.d.ts.map +1 -0
- package/dist/web3/index.js +14 -0
- package/dist/web3/index.js.map +1 -0
- package/package.json +105 -0
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"KPICard.js","sourceRoot":"","sources":["../../../src/components/Dashboard/KPICard.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AA2BzC;;;;;;;;;;;;;;;;;;;;;;;;;;;;;GA6BG;AACH,MAAM,UAAU,OAAO,CAAC,EACtB,KAAK,EACL,KAAK,EACL,QAAQ,EACR,IAAI,EACJ,KAAK,EACL,UAAU,EACV,OAAO,GAAG,KAAK,EACf,OAAO,EACP,SAAS,GAAG,EAAE,EACd,OAAO,GAAG,SAAS,EACnB,IAAI,GAAG,IAAI,GACE;IACb,MAAM,UAAU,GAAG,wCAAwC,CAAC;IAE5D,MAAM,aAAa,GAAG;QACpB,OAAO,EAAE,2CAA2C;QACpD,QAAQ,EAAE,yCAAyC;QACnD,MAAM,EAAE,mCAAmC;KAC5C,CAAC;IAEF,MAAM,UAAU,GAAG;QACjB,EAAE,EAAE,KAAK;QACT,EAAE,EAAE,KAAK;QACT,EAAE,EAAE,KAAK;KACV,CAAC;IAEF,MAAM,eAAe,GAAG;QACtB,EAAE,EAAE,SAAS;QACb,EAAE,EAAE,UAAU;QACd,EAAE,EAAE,UAAU;KACf,CAAC;IAEF,MAAM,WAAW,GAAG;QAClB,EAAE,EAAE,4BAA4B;QAChC,IAAI,EAAE,wBAAwB;QAC9B,OAAO,EAAE,2BAA2B;KACrC,CAAC;IAEF,MAAM,UAAU,GAAG;QACjB,EAAE,EAAE,GAAG;QACP,IAAI,EAAE,GAAG;QACT,OAAO,EAAE,GAAG;KACb,CAAC;IAEF,MAAM,iBAAiB,GAAG,OAAO;QAC/B,CAAC,CAAC,0EAA0E;QAC5E,CAAC,CAAC,EAAE,CAAC;IAEP,IAAI,OAAO,EAAE,CAAC;QACZ,OAAO,CACL,6BACE,SAAS,EAAE,GAAG,UAAU,IAAI,aAAa,CAAC,OAAO,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,IAAI,SAAS,gBAAgB;YAEnG,6BAAK,SAAS,EAAC,wCAAwC;gBACrD,6BAAK,SAAS,EAAC,8BAA8B,GAAO;gBACnD,IAAI,IAAI,6BAAK,SAAS,EAAC,6BAA6B,GAAO,CACxD;YACN,6BAAK,SAAS,EAAC,mCAAmC,GAAO;YACxD,QAAQ,IAAI,6BAAK,SAAS,EAAC,8BAA8B,GAAO,CAC7D,CACP,CAAC;IACJ,CAAC;IAED,OAAO,CACL,6BACE,SAAS,EAAE,GAAG,UAAU,IAAI,aAAa,CAAC,OAAO,CAAC,IAAI,UAAU,CAAC,IAAI,CAAC,IAAI,iBAAiB,IAAI,SAAS,EAAE,EAC1G,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,SAAS,EACpC,QAAQ,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,SAAS;QAEjC,6BAAK,SAAS,EAAC,wCAAwC;YACrD,4BAAI,SAAS,EAAC,mCAAmC,IAAE,KAAK,CAAM;YAC7D,IAAI,IAAI,6BAAK,SAAS,EAAC,eAAe,IAAE,IAAI,CAAO,CAChD;QAEN,6BAAK,SAAS,EAAC,2BAA2B;YACxC,8BAAM,SAAS,EAAE,2BAA2B,eAAe,CAAC,IAAI,CAAC,EAAE,IAChE,KAAK,CACD;YACN,KAAK,IAAI,UAAU,IAAI,CACtB,8BACE,SAAS,EAAE,8EAA8E,WAAW,CAAC,KAAK,CAAC,EAAE;gBAE7G,kCAAO,UAAU,CAAC,KAAK,CAAC,CAAQ;gBAChC,kCAAO,UAAU,CAAQ,CACpB,CACR,CACG;QAEL,QAAQ,IAAI,CACX,2BAAG,SAAS,EAAC,4BAA4B,IAAE,QAAQ,CAAK,CACzD,CACG,CACP,CAAC;AACJ,CAAC;AAED,eAAe,OAAO,CAAC"}
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
export interface LoadingSkeletonProps {
|
|
3
|
+
/** Type of skeleton to display */
|
|
4
|
+
type?: 'text' | 'circle' | 'rect' | 'card' | 'table' | 'list';
|
|
5
|
+
/** Width (CSS value or number for pixels) */
|
|
6
|
+
width?: string | number;
|
|
7
|
+
/** Height (CSS value or number for pixels) */
|
|
8
|
+
height?: string | number;
|
|
9
|
+
/** Number of lines for text skeleton */
|
|
10
|
+
lines?: number;
|
|
11
|
+
/** Number of items for list skeleton */
|
|
12
|
+
items?: number;
|
|
13
|
+
/** Whether to show animation */
|
|
14
|
+
animate?: boolean;
|
|
15
|
+
/** Additional CSS class names */
|
|
16
|
+
className?: string;
|
|
17
|
+
}
|
|
18
|
+
/**
|
|
19
|
+
* LoadingSkeleton - Placeholder loading states
|
|
20
|
+
*
|
|
21
|
+
* A component for displaying loading placeholders with animated
|
|
22
|
+
* shimmer effect. Supports various types including text, cards,
|
|
23
|
+
* tables, and lists.
|
|
24
|
+
*
|
|
25
|
+
* @example
|
|
26
|
+
* ```tsx
|
|
27
|
+
* import { LoadingSkeleton } from '@varity-labs/ui-kit';
|
|
28
|
+
*
|
|
29
|
+
* function MyComponent() {
|
|
30
|
+
* const { loading, data } = useData();
|
|
31
|
+
*
|
|
32
|
+
* if (loading) {
|
|
33
|
+
* return <LoadingSkeleton type="card" />;
|
|
34
|
+
* }
|
|
35
|
+
*
|
|
36
|
+
* return <DataDisplay data={data} />;
|
|
37
|
+
* }
|
|
38
|
+
* ```
|
|
39
|
+
*/
|
|
40
|
+
export declare function LoadingSkeleton({ type, width, height, lines, items, animate, className, }: LoadingSkeletonProps): React.JSX.Element;
|
|
41
|
+
/**
|
|
42
|
+
* SkeletonText - Shorthand for text skeleton
|
|
43
|
+
*/
|
|
44
|
+
export declare function SkeletonText({ lines, ...props }: Omit<LoadingSkeletonProps, 'type'>): React.JSX.Element;
|
|
45
|
+
/**
|
|
46
|
+
* SkeletonCard - Shorthand for card skeleton
|
|
47
|
+
*/
|
|
48
|
+
export declare function SkeletonCard(props: Omit<LoadingSkeletonProps, 'type'>): React.JSX.Element;
|
|
49
|
+
/**
|
|
50
|
+
* SkeletonTable - Shorthand for table skeleton
|
|
51
|
+
*/
|
|
52
|
+
export declare function SkeletonTable({ items, ...props }: Omit<LoadingSkeletonProps, 'type'>): React.JSX.Element;
|
|
53
|
+
/**
|
|
54
|
+
* SkeletonList - Shorthand for list skeleton
|
|
55
|
+
*/
|
|
56
|
+
export declare function SkeletonList({ items, ...props }: Omit<LoadingSkeletonProps, 'type'>): React.JSX.Element;
|
|
57
|
+
export default LoadingSkeleton;
|
|
58
|
+
//# sourceMappingURL=LoadingSkeleton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoadingSkeleton.d.ts","sourceRoot":"","sources":["../../../src/components/Dashboard/LoadingSkeleton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,MAAM,WAAW,oBAAoB;IACnC,kCAAkC;IAClC,IAAI,CAAC,EAAE,MAAM,GAAG,QAAQ,GAAG,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,MAAM,CAAC;IAC9D,6CAA6C;IAC7C,KAAK,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACxB,8CAA8C;IAC9C,MAAM,CAAC,EAAE,MAAM,GAAG,MAAM,CAAC;IACzB,wCAAwC;IACxC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,wCAAwC;IACxC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,gCAAgC;IAChC,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,iCAAiC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,eAAe,CAAC,EAC9B,IAAa,EACb,KAAK,EACL,MAAM,EACN,KAAS,EACT,KAAS,EACT,OAAc,EACd,SAAc,GACf,EAAE,oBAAoB,qBA2HtB;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,EAAE,KAAS,EAAE,GAAG,KAAK,EAAE,EAAE,IAAI,CAAC,oBAAoB,EAAE,MAAM,CAAC,qBAEvF;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,oBAAoB,EAAE,MAAM,CAAC,qBAErE;AAED;;GAEG;AACH,wBAAgB,aAAa,CAAC,EAAE,KAAS,EAAE,GAAG,KAAK,EAAE,EAAE,IAAI,CAAC,oBAAoB,EAAE,MAAM,CAAC,qBAExF;AAED;;GAEG;AACH,wBAAgB,YAAY,CAAC,EAAE,KAAS,EAAE,GAAG,KAAK,EAAE,EAAE,IAAI,CAAC,oBAAoB,EAAE,MAAM,CAAC,qBAEvF;AAED,eAAe,eAAe,CAAC"}
|
|
@@ -0,0 +1,105 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* LoadingSkeleton - Placeholder loading states
|
|
4
|
+
*
|
|
5
|
+
* A component for displaying loading placeholders with animated
|
|
6
|
+
* shimmer effect. Supports various types including text, cards,
|
|
7
|
+
* tables, and lists.
|
|
8
|
+
*
|
|
9
|
+
* @example
|
|
10
|
+
* ```tsx
|
|
11
|
+
* import { LoadingSkeleton } from '@varity-labs/ui-kit';
|
|
12
|
+
*
|
|
13
|
+
* function MyComponent() {
|
|
14
|
+
* const { loading, data } = useData();
|
|
15
|
+
*
|
|
16
|
+
* if (loading) {
|
|
17
|
+
* return <LoadingSkeleton type="card" />;
|
|
18
|
+
* }
|
|
19
|
+
*
|
|
20
|
+
* return <DataDisplay data={data} />;
|
|
21
|
+
* }
|
|
22
|
+
* ```
|
|
23
|
+
*/
|
|
24
|
+
export function LoadingSkeleton({ type = 'rect', width, height, lines = 3, items = 3, animate = true, className = '', }) {
|
|
25
|
+
const baseStyles = `bg-gray-200 ${animate ? 'animate-pulse' : ''}`;
|
|
26
|
+
const getWidthStyle = () => {
|
|
27
|
+
if (width === undefined)
|
|
28
|
+
return '';
|
|
29
|
+
return typeof width === 'number' ? `${width}px` : width;
|
|
30
|
+
};
|
|
31
|
+
const getHeightStyle = () => {
|
|
32
|
+
if (height === undefined)
|
|
33
|
+
return '';
|
|
34
|
+
return typeof height === 'number' ? `${height}px` : height;
|
|
35
|
+
};
|
|
36
|
+
const style = {
|
|
37
|
+
width: getWidthStyle() || undefined,
|
|
38
|
+
height: getHeightStyle() || undefined,
|
|
39
|
+
};
|
|
40
|
+
switch (type) {
|
|
41
|
+
case 'text':
|
|
42
|
+
return (React.createElement("div", { className: `space-y-2 ${className}` }, Array.from({ length: lines }).map((_, i) => (React.createElement("div", { key: i, className: `${baseStyles} rounded h-4`, style: {
|
|
43
|
+
width: i === lines - 1 ? '60%' : '100%',
|
|
44
|
+
} })))));
|
|
45
|
+
case 'circle':
|
|
46
|
+
return (React.createElement("div", { className: `${baseStyles} rounded-full ${className}`, style: {
|
|
47
|
+
width: style.width || '48px',
|
|
48
|
+
height: style.height || '48px',
|
|
49
|
+
} }));
|
|
50
|
+
case 'rect':
|
|
51
|
+
return (React.createElement("div", { className: `${baseStyles} rounded ${className}`, style: {
|
|
52
|
+
width: style.width || '100%',
|
|
53
|
+
height: style.height || '24px',
|
|
54
|
+
} }));
|
|
55
|
+
case 'card':
|
|
56
|
+
return (React.createElement("div", { className: `bg-white border border-gray-200 rounded-lg p-4 ${className}`, style: style },
|
|
57
|
+
React.createElement("div", { className: "flex items-center gap-3 mb-4" },
|
|
58
|
+
React.createElement("div", { className: `${baseStyles} rounded-full w-10 h-10` }),
|
|
59
|
+
React.createElement("div", { className: "flex-1 space-y-2" },
|
|
60
|
+
React.createElement("div", { className: `${baseStyles} rounded h-4 w-3/4` }),
|
|
61
|
+
React.createElement("div", { className: `${baseStyles} rounded h-3 w-1/2` }))),
|
|
62
|
+
React.createElement("div", { className: "space-y-2" },
|
|
63
|
+
React.createElement("div", { className: `${baseStyles} rounded h-4` }),
|
|
64
|
+
React.createElement("div", { className: `${baseStyles} rounded h-4` }),
|
|
65
|
+
React.createElement("div", { className: `${baseStyles} rounded h-4 w-2/3` }))));
|
|
66
|
+
case 'table':
|
|
67
|
+
return (React.createElement("div", { className: `bg-white border border-gray-200 rounded-lg overflow-hidden ${className}` },
|
|
68
|
+
React.createElement("div", { className: "flex gap-4 p-4 border-b border-gray-200 bg-gray-50" }, Array.from({ length: 4 }).map((_, i) => (React.createElement("div", { key: i, className: `${baseStyles} rounded h-4 flex-1` })))),
|
|
69
|
+
Array.from({ length: items }).map((_, rowIndex) => (React.createElement("div", { key: rowIndex, className: "flex gap-4 p-4 border-b border-gray-100 last:border-b-0" }, Array.from({ length: 4 }).map((_, colIndex) => (React.createElement("div", { key: colIndex, className: `${baseStyles} rounded h-4 flex-1` }))))))));
|
|
70
|
+
case 'list':
|
|
71
|
+
return (React.createElement("div", { className: `space-y-3 ${className}` }, Array.from({ length: items }).map((_, i) => (React.createElement("div", { key: i, className: "flex items-center gap-3" },
|
|
72
|
+
React.createElement("div", { className: `${baseStyles} rounded-full w-8 h-8` }),
|
|
73
|
+
React.createElement("div", { className: "flex-1 space-y-2" },
|
|
74
|
+
React.createElement("div", { className: `${baseStyles} rounded h-4 w-3/4` }),
|
|
75
|
+
React.createElement("div", { className: `${baseStyles} rounded h-3 w-1/2` })))))));
|
|
76
|
+
default:
|
|
77
|
+
return (React.createElement("div", { className: `${baseStyles} rounded ${className}`, style: style }));
|
|
78
|
+
}
|
|
79
|
+
}
|
|
80
|
+
/**
|
|
81
|
+
* SkeletonText - Shorthand for text skeleton
|
|
82
|
+
*/
|
|
83
|
+
export function SkeletonText({ lines = 3, ...props }) {
|
|
84
|
+
return React.createElement(LoadingSkeleton, { type: "text", lines: lines, ...props });
|
|
85
|
+
}
|
|
86
|
+
/**
|
|
87
|
+
* SkeletonCard - Shorthand for card skeleton
|
|
88
|
+
*/
|
|
89
|
+
export function SkeletonCard(props) {
|
|
90
|
+
return React.createElement(LoadingSkeleton, { type: "card", ...props });
|
|
91
|
+
}
|
|
92
|
+
/**
|
|
93
|
+
* SkeletonTable - Shorthand for table skeleton
|
|
94
|
+
*/
|
|
95
|
+
export function SkeletonTable({ items = 5, ...props }) {
|
|
96
|
+
return React.createElement(LoadingSkeleton, { type: "table", items: items, ...props });
|
|
97
|
+
}
|
|
98
|
+
/**
|
|
99
|
+
* SkeletonList - Shorthand for list skeleton
|
|
100
|
+
*/
|
|
101
|
+
export function SkeletonList({ items = 3, ...props }) {
|
|
102
|
+
return React.createElement(LoadingSkeleton, { type: "list", items: items, ...props });
|
|
103
|
+
}
|
|
104
|
+
export default LoadingSkeleton;
|
|
105
|
+
//# sourceMappingURL=LoadingSkeleton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"LoadingSkeleton.js","sourceRoot":"","sources":["../../../src/components/Dashboard/LoadingSkeleton.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,MAAM,OAAO,CAAC;AAmB1B;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAM,UAAU,eAAe,CAAC,EAC9B,IAAI,GAAG,MAAM,EACb,KAAK,EACL,MAAM,EACN,KAAK,GAAG,CAAC,EACT,KAAK,GAAG,CAAC,EACT,OAAO,GAAG,IAAI,EACd,SAAS,GAAG,EAAE,GACO;IACrB,MAAM,UAAU,GAAG,eAAe,OAAO,CAAC,CAAC,CAAC,eAAe,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IAEnE,MAAM,aAAa,GAAG,GAAG,EAAE;QACzB,IAAI,KAAK,KAAK,SAAS;YAAE,OAAO,EAAE,CAAC;QACnC,OAAO,OAAO,KAAK,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,KAAK,IAAI,CAAC,CAAC,CAAC,KAAK,CAAC;IAC1D,CAAC,CAAC;IAEF,MAAM,cAAc,GAAG,GAAG,EAAE;QAC1B,IAAI,MAAM,KAAK,SAAS;YAAE,OAAO,EAAE,CAAC;QACpC,OAAO,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,MAAM,IAAI,CAAC,CAAC,CAAC,MAAM,CAAC;IAC7D,CAAC,CAAC;IAEF,MAAM,KAAK,GAAG;QACZ,KAAK,EAAE,aAAa,EAAE,IAAI,SAAS;QACnC,MAAM,EAAE,cAAc,EAAE,IAAI,SAAS;KACtC,CAAC;IAEF,QAAQ,IAAI,EAAE,CAAC;QACb,KAAK,MAAM;YACT,OAAO,CACL,6BAAK,SAAS,EAAE,aAAa,SAAS,EAAE,IACrC,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAC3C,6BACE,GAAG,EAAE,CAAC,EACN,SAAS,EAAE,GAAG,UAAU,cAAc,EACtC,KAAK,EAAE;oBACL,KAAK,EAAE,CAAC,KAAK,KAAK,GAAG,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,MAAM;iBACxC,GACD,CACH,CAAC,CACE,CACP,CAAC;QAEJ,KAAK,QAAQ;YACX,OAAO,CACL,6BACE,SAAS,EAAE,GAAG,UAAU,iBAAiB,SAAS,EAAE,EACpD,KAAK,EAAE;oBACL,KAAK,EAAE,KAAK,CAAC,KAAK,IAAI,MAAM;oBAC5B,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,MAAM;iBAC/B,GACD,CACH,CAAC;QAEJ,KAAK,MAAM;YACT,OAAO,CACL,6BACE,SAAS,EAAE,GAAG,UAAU,YAAY,SAAS,EAAE,EAC/C,KAAK,EAAE;oBACL,KAAK,EAAE,KAAK,CAAC,KAAK,IAAI,MAAM;oBAC5B,MAAM,EAAE,KAAK,CAAC,MAAM,IAAI,MAAM;iBAC/B,GACD,CACH,CAAC;QAEJ,KAAK,MAAM;YACT,OAAO,CACL,6BACE,SAAS,EAAE,kDAAkD,SAAS,EAAE,EACxE,KAAK,EAAE,KAAK;gBAEZ,6BAAK,SAAS,EAAC,8BAA8B;oBAC3C,6BAAK,SAAS,EAAE,GAAG,UAAU,yBAAyB,GAAI;oBAC1D,6BAAK,SAAS,EAAC,kBAAkB;wBAC/B,6BAAK,SAAS,EAAE,GAAG,UAAU,oBAAoB,GAAI;wBACrD,6BAAK,SAAS,EAAE,GAAG,UAAU,oBAAoB,GAAI,CACjD,CACF;gBACN,6BAAK,SAAS,EAAC,WAAW;oBACxB,6BAAK,SAAS,EAAE,GAAG,UAAU,cAAc,GAAI;oBAC/C,6BAAK,SAAS,EAAE,GAAG,UAAU,cAAc,GAAI;oBAC/C,6BAAK,SAAS,EAAE,GAAG,UAAU,oBAAoB,GAAI,CACjD,CACF,CACP,CAAC;QAEJ,KAAK,OAAO;YACV,OAAO,CACL,6BAAK,SAAS,EAAE,8DAA8D,SAAS,EAAE;gBAEvF,6BAAK,SAAS,EAAC,oDAAoD,IAChE,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CACvC,6BAAK,GAAG,EAAE,CAAC,EAAE,SAAS,EAAE,GAAG,UAAU,qBAAqB,GAAI,CAC/D,CAAC,CACE;gBAEL,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,CAAC,CAClD,6BACE,GAAG,EAAE,QAAQ,EACb,SAAS,EAAC,yDAAyD,IAElE,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,CAAC,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,CAAC,CAC9C,6BAAK,GAAG,EAAE,QAAQ,EAAE,SAAS,EAAE,GAAG,UAAU,qBAAqB,GAAI,CACtE,CAAC,CACE,CACP,CAAC,CACE,CACP,CAAC;QAEJ,KAAK,MAAM;YACT,OAAO,CACL,6BAAK,SAAS,EAAE,aAAa,SAAS,EAAE,IACrC,KAAK,CAAC,IAAI,CAAC,EAAE,MAAM,EAAE,KAAK,EAAE,CAAC,CAAC,GAAG,CAAC,CAAC,CAAC,EAAE,CAAC,EAAE,EAAE,CAAC,CAC3C,6BAAK,GAAG,EAAE,CAAC,EAAE,SAAS,EAAC,yBAAyB;gBAC9C,6BAAK,SAAS,EAAE,GAAG,UAAU,uBAAuB,GAAI;gBACxD,6BAAK,SAAS,EAAC,kBAAkB;oBAC/B,6BAAK,SAAS,EAAE,GAAG,UAAU,oBAAoB,GAAI;oBACrD,6BAAK,SAAS,EAAE,GAAG,UAAU,oBAAoB,GAAI,CACjD,CACF,CACP,CAAC,CACE,CACP,CAAC;QAEJ;YACE,OAAO,CACL,6BACE,SAAS,EAAE,GAAG,UAAU,YAAY,SAAS,EAAE,EAC/C,KAAK,EAAE,KAAK,GACZ,CACH,CAAC;IACN,CAAC;AACH,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,YAAY,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,KAAK,EAAsC;IACtF,OAAO,oBAAC,eAAe,IAAC,IAAI,EAAC,MAAM,EAAC,KAAK,EAAE,KAAK,KAAM,KAAK,GAAI,CAAC;AAClE,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,YAAY,CAAC,KAAyC;IACpE,OAAO,oBAAC,eAAe,IAAC,IAAI,EAAC,MAAM,KAAK,KAAK,GAAI,CAAC;AACpD,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,aAAa,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,KAAK,EAAsC;IACvF,OAAO,oBAAC,eAAe,IAAC,IAAI,EAAC,OAAO,EAAC,KAAK,EAAE,KAAK,KAAM,KAAK,GAAI,CAAC;AACnE,CAAC;AAED;;GAEG;AACH,MAAM,UAAU,YAAY,CAAC,EAAE,KAAK,GAAG,CAAC,EAAE,GAAG,KAAK,EAAsC;IACtF,OAAO,oBAAC,eAAe,IAAC,IAAI,EAAC,MAAM,EAAC,KAAK,EAAE,KAAK,KAAM,KAAK,GAAI,CAAC;AAClE,CAAC;AAED,eAAe,eAAe,CAAC"}
|
|
@@ -0,0 +1,57 @@
|
|
|
1
|
+
import React, { ReactNode } from 'react';
|
|
2
|
+
export type StatusType = 'connected' | 'disconnected' | 'pending' | 'syncing' | 'error' | 'warning' | 'expired' | 'active' | 'inactive';
|
|
3
|
+
export interface StatusBadgeProps {
|
|
4
|
+
/** Status type */
|
|
5
|
+
status: StatusType;
|
|
6
|
+
/** Custom label (defaults to status name) */
|
|
7
|
+
label?: string;
|
|
8
|
+
/** Show dot indicator */
|
|
9
|
+
showDot?: boolean;
|
|
10
|
+
/** Size variant */
|
|
11
|
+
size?: 'sm' | 'md' | 'lg';
|
|
12
|
+
/** Optional icon */
|
|
13
|
+
icon?: ReactNode;
|
|
14
|
+
/** Additional CSS class names */
|
|
15
|
+
className?: string;
|
|
16
|
+
}
|
|
17
|
+
/**
|
|
18
|
+
* StatusBadge - Display status indicators
|
|
19
|
+
*
|
|
20
|
+
* A badge component for displaying various status states with
|
|
21
|
+
* appropriate colors and optional animated indicators.
|
|
22
|
+
*
|
|
23
|
+
* @example
|
|
24
|
+
* ```tsx
|
|
25
|
+
* import { StatusBadge } from '@varity-labs/ui-kit';
|
|
26
|
+
*
|
|
27
|
+
* function IntegrationCard({ integration }) {
|
|
28
|
+
* return (
|
|
29
|
+
* <div className="flex items-center gap-2">
|
|
30
|
+
* <span>{integration.name}</span>
|
|
31
|
+
* <StatusBadge
|
|
32
|
+
* status={integration.isConnected ? 'connected' : 'disconnected'}
|
|
33
|
+
* />
|
|
34
|
+
* </div>
|
|
35
|
+
* );
|
|
36
|
+
* }
|
|
37
|
+
* ```
|
|
38
|
+
*/
|
|
39
|
+
export declare function StatusBadge({ status, label, showDot, size, icon, className, }: StatusBadgeProps): React.JSX.Element;
|
|
40
|
+
/**
|
|
41
|
+
* IntegrationStatus - Specialized status badge for integrations
|
|
42
|
+
*/
|
|
43
|
+
export interface IntegrationStatusProps {
|
|
44
|
+
/** Whether the integration is connected */
|
|
45
|
+
isConnected: boolean;
|
|
46
|
+
/** Whether the integration needs re-authentication */
|
|
47
|
+
needsReauth?: boolean;
|
|
48
|
+
/** Whether the integration is currently syncing */
|
|
49
|
+
isSyncing?: boolean;
|
|
50
|
+
/** Last sync time */
|
|
51
|
+
lastSyncTime?: Date;
|
|
52
|
+
/** Additional CSS class names */
|
|
53
|
+
className?: string;
|
|
54
|
+
}
|
|
55
|
+
export declare function IntegrationStatus({ isConnected, needsReauth, isSyncing, lastSyncTime, className, }: IntegrationStatusProps): React.JSX.Element;
|
|
56
|
+
export default StatusBadge;
|
|
57
|
+
//# sourceMappingURL=StatusBadge.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StatusBadge.d.ts","sourceRoot":"","sources":["../../../src/components/Dashboard/StatusBadge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAEzC,MAAM,MAAM,UAAU,GAClB,WAAW,GACX,cAAc,GACd,SAAS,GACT,SAAS,GACT,OAAO,GACP,SAAS,GACT,SAAS,GACT,QAAQ,GACR,UAAU,CAAC;AAEf,MAAM,WAAW,gBAAgB;IAC/B,kBAAkB;IAClB,MAAM,EAAE,UAAU,CAAC;IACnB,6CAA6C;IAC7C,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,yBAAyB;IACzB,OAAO,CAAC,EAAE,OAAO,CAAC;IAClB,mBAAmB;IACnB,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;IAC1B,oBAAoB;IACpB,IAAI,CAAC,EAAE,SAAS,CAAC;IACjB,iCAAiC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,wBAAgB,WAAW,CAAC,EAC1B,MAAM,EACN,KAAK,EACL,OAAc,EACd,IAAW,EACX,IAAI,EACJ,SAAc,GACf,EAAE,gBAAgB,qBAyGlB;AAED;;GAEG;AACH,MAAM,WAAW,sBAAsB;IACrC,2CAA2C;IAC3C,WAAW,EAAE,OAAO,CAAC;IACrB,sDAAsD;IACtD,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,mDAAmD;IACnD,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,qBAAqB;IACrB,YAAY,CAAC,EAAE,IAAI,CAAC;IACpB,iCAAiC;IACjC,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,iBAAiB,CAAC,EAChC,WAAW,EACX,WAAW,EACX,SAAS,EACT,YAAY,EACZ,SAAS,GACV,EAAE,sBAAsB,qBAyBxB;AAoBD,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,149 @@
|
|
|
1
|
+
import React from 'react';
|
|
2
|
+
/**
|
|
3
|
+
* StatusBadge - Display status indicators
|
|
4
|
+
*
|
|
5
|
+
* A badge component for displaying various status states with
|
|
6
|
+
* appropriate colors and optional animated indicators.
|
|
7
|
+
*
|
|
8
|
+
* @example
|
|
9
|
+
* ```tsx
|
|
10
|
+
* import { StatusBadge } from '@varity-labs/ui-kit';
|
|
11
|
+
*
|
|
12
|
+
* function IntegrationCard({ integration }) {
|
|
13
|
+
* return (
|
|
14
|
+
* <div className="flex items-center gap-2">
|
|
15
|
+
* <span>{integration.name}</span>
|
|
16
|
+
* <StatusBadge
|
|
17
|
+
* status={integration.isConnected ? 'connected' : 'disconnected'}
|
|
18
|
+
* />
|
|
19
|
+
* </div>
|
|
20
|
+
* );
|
|
21
|
+
* }
|
|
22
|
+
* ```
|
|
23
|
+
*/
|
|
24
|
+
export function StatusBadge({ status, label, showDot = true, size = 'md', icon, className = '', }) {
|
|
25
|
+
const statusConfig = {
|
|
26
|
+
connected: {
|
|
27
|
+
bg: 'bg-green-50',
|
|
28
|
+
text: 'text-green-700',
|
|
29
|
+
dot: 'bg-green-500',
|
|
30
|
+
defaultLabel: 'Connected',
|
|
31
|
+
},
|
|
32
|
+
disconnected: {
|
|
33
|
+
bg: 'bg-gray-100',
|
|
34
|
+
text: 'text-gray-600',
|
|
35
|
+
dot: 'bg-gray-400',
|
|
36
|
+
defaultLabel: 'Disconnected',
|
|
37
|
+
},
|
|
38
|
+
pending: {
|
|
39
|
+
bg: 'bg-yellow-50',
|
|
40
|
+
text: 'text-yellow-700',
|
|
41
|
+
dot: 'bg-yellow-500',
|
|
42
|
+
dotAnimate: true,
|
|
43
|
+
defaultLabel: 'Pending',
|
|
44
|
+
},
|
|
45
|
+
syncing: {
|
|
46
|
+
bg: 'bg-blue-50',
|
|
47
|
+
text: 'text-blue-700',
|
|
48
|
+
dot: 'bg-blue-500',
|
|
49
|
+
dotAnimate: true,
|
|
50
|
+
defaultLabel: 'Syncing',
|
|
51
|
+
},
|
|
52
|
+
error: {
|
|
53
|
+
bg: 'bg-red-50',
|
|
54
|
+
text: 'text-red-700',
|
|
55
|
+
dot: 'bg-red-500',
|
|
56
|
+
defaultLabel: 'Error',
|
|
57
|
+
},
|
|
58
|
+
warning: {
|
|
59
|
+
bg: 'bg-orange-50',
|
|
60
|
+
text: 'text-orange-700',
|
|
61
|
+
dot: 'bg-orange-500',
|
|
62
|
+
defaultLabel: 'Warning',
|
|
63
|
+
},
|
|
64
|
+
expired: {
|
|
65
|
+
bg: 'bg-red-50',
|
|
66
|
+
text: 'text-red-600',
|
|
67
|
+
dot: 'bg-red-400',
|
|
68
|
+
defaultLabel: 'Expired',
|
|
69
|
+
},
|
|
70
|
+
active: {
|
|
71
|
+
bg: 'bg-green-50',
|
|
72
|
+
text: 'text-green-700',
|
|
73
|
+
dot: 'bg-green-500',
|
|
74
|
+
defaultLabel: 'Active',
|
|
75
|
+
},
|
|
76
|
+
inactive: {
|
|
77
|
+
bg: 'bg-gray-100',
|
|
78
|
+
text: 'text-gray-500',
|
|
79
|
+
dot: 'bg-gray-400',
|
|
80
|
+
defaultLabel: 'Inactive',
|
|
81
|
+
},
|
|
82
|
+
};
|
|
83
|
+
const sizeStyles = {
|
|
84
|
+
sm: {
|
|
85
|
+
badge: 'px-1.5 py-0.5 text-xs',
|
|
86
|
+
dot: 'w-1.5 h-1.5',
|
|
87
|
+
},
|
|
88
|
+
md: {
|
|
89
|
+
badge: 'px-2 py-1 text-xs',
|
|
90
|
+
dot: 'w-2 h-2',
|
|
91
|
+
},
|
|
92
|
+
lg: {
|
|
93
|
+
badge: 'px-2.5 py-1.5 text-sm',
|
|
94
|
+
dot: 'w-2.5 h-2.5',
|
|
95
|
+
},
|
|
96
|
+
};
|
|
97
|
+
const config = statusConfig[status];
|
|
98
|
+
const styles = sizeStyles[size];
|
|
99
|
+
const displayLabel = label || config.defaultLabel;
|
|
100
|
+
return (React.createElement("span", { className: `inline-flex items-center gap-1.5 font-medium rounded-full ${config.bg} ${config.text} ${styles.badge} ${className}` },
|
|
101
|
+
showDot && (React.createElement("span", { className: "relative flex" },
|
|
102
|
+
React.createElement("span", { className: `${styles.dot} rounded-full ${config.dot}` }),
|
|
103
|
+
config.dotAnimate && (React.createElement("span", { className: `absolute ${styles.dot} rounded-full ${config.dot} animate-ping opacity-75` })))),
|
|
104
|
+
icon && React.createElement("span", { className: "flex-shrink-0" }, icon),
|
|
105
|
+
React.createElement("span", null, displayLabel)));
|
|
106
|
+
}
|
|
107
|
+
export function IntegrationStatus({ isConnected, needsReauth, isSyncing, lastSyncTime, className, }) {
|
|
108
|
+
let status;
|
|
109
|
+
let label;
|
|
110
|
+
if (isSyncing) {
|
|
111
|
+
status = 'syncing';
|
|
112
|
+
}
|
|
113
|
+
else if (needsReauth) {
|
|
114
|
+
status = 'expired';
|
|
115
|
+
label = 'Reconnect Required';
|
|
116
|
+
}
|
|
117
|
+
else if (isConnected) {
|
|
118
|
+
status = 'connected';
|
|
119
|
+
}
|
|
120
|
+
else {
|
|
121
|
+
status = 'disconnected';
|
|
122
|
+
}
|
|
123
|
+
return (React.createElement("div", { className: `flex flex-col gap-1 ${className || ''}` },
|
|
124
|
+
React.createElement(StatusBadge, { status: status, label: label }),
|
|
125
|
+
lastSyncTime && isConnected && !needsReauth && (React.createElement("span", { className: "text-xs text-gray-400" },
|
|
126
|
+
"Last sync: ",
|
|
127
|
+
formatRelativeTime(lastSyncTime)))));
|
|
128
|
+
}
|
|
129
|
+
/**
|
|
130
|
+
* Format relative time (e.g., "2 hours ago")
|
|
131
|
+
*/
|
|
132
|
+
function formatRelativeTime(date) {
|
|
133
|
+
const now = new Date();
|
|
134
|
+
const diffMs = now.getTime() - date.getTime();
|
|
135
|
+
const diffMins = Math.floor(diffMs / 60000);
|
|
136
|
+
const diffHours = Math.floor(diffMins / 60);
|
|
137
|
+
const diffDays = Math.floor(diffHours / 24);
|
|
138
|
+
if (diffMins < 1)
|
|
139
|
+
return 'Just now';
|
|
140
|
+
if (diffMins < 60)
|
|
141
|
+
return `${diffMins}m ago`;
|
|
142
|
+
if (diffHours < 24)
|
|
143
|
+
return `${diffHours}h ago`;
|
|
144
|
+
if (diffDays < 7)
|
|
145
|
+
return `${diffDays}d ago`;
|
|
146
|
+
return date.toLocaleDateString();
|
|
147
|
+
}
|
|
148
|
+
export default StatusBadge;
|
|
149
|
+
//# sourceMappingURL=StatusBadge.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"StatusBadge.js","sourceRoot":"","sources":["../../../src/components/Dashboard/StatusBadge.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAoB,MAAM,OAAO,CAAC;AA4BzC;;;;;;;;;;;;;;;;;;;;;GAqBG;AACH,MAAM,UAAU,WAAW,CAAC,EAC1B,MAAM,EACN,KAAK,EACL,OAAO,GAAG,IAAI,EACd,IAAI,GAAG,IAAI,EACX,IAAI,EACJ,SAAS,GAAG,EAAE,GACG;IACjB,MAAM,YAAY,GAMb;QACH,SAAS,EAAE;YACT,EAAE,EAAE,aAAa;YACjB,IAAI,EAAE,gBAAgB;YACtB,GAAG,EAAE,cAAc;YACnB,YAAY,EAAE,WAAW;SAC1B;QACD,YAAY,EAAE;YACZ,EAAE,EAAE,aAAa;YACjB,IAAI,EAAE,eAAe;YACrB,GAAG,EAAE,aAAa;YAClB,YAAY,EAAE,cAAc;SAC7B;QACD,OAAO,EAAE;YACP,EAAE,EAAE,cAAc;YAClB,IAAI,EAAE,iBAAiB;YACvB,GAAG,EAAE,eAAe;YACpB,UAAU,EAAE,IAAI;YAChB,YAAY,EAAE,SAAS;SACxB;QACD,OAAO,EAAE;YACP,EAAE,EAAE,YAAY;YAChB,IAAI,EAAE,eAAe;YACrB,GAAG,EAAE,aAAa;YAClB,UAAU,EAAE,IAAI;YAChB,YAAY,EAAE,SAAS;SACxB;QACD,KAAK,EAAE;YACL,EAAE,EAAE,WAAW;YACf,IAAI,EAAE,cAAc;YACpB,GAAG,EAAE,YAAY;YACjB,YAAY,EAAE,OAAO;SACtB;QACD,OAAO,EAAE;YACP,EAAE,EAAE,cAAc;YAClB,IAAI,EAAE,iBAAiB;YACvB,GAAG,EAAE,eAAe;YACpB,YAAY,EAAE,SAAS;SACxB;QACD,OAAO,EAAE;YACP,EAAE,EAAE,WAAW;YACf,IAAI,EAAE,cAAc;YACpB,GAAG,EAAE,YAAY;YACjB,YAAY,EAAE,SAAS;SACxB;QACD,MAAM,EAAE;YACN,EAAE,EAAE,aAAa;YACjB,IAAI,EAAE,gBAAgB;YACtB,GAAG,EAAE,cAAc;YACnB,YAAY,EAAE,QAAQ;SACvB;QACD,QAAQ,EAAE;YACR,EAAE,EAAE,aAAa;YACjB,IAAI,EAAE,eAAe;YACrB,GAAG,EAAE,aAAa;YAClB,YAAY,EAAE,UAAU;SACzB;KACF,CAAC;IAEF,MAAM,UAAU,GAAG;QACjB,EAAE,EAAE;YACF,KAAK,EAAE,uBAAuB;YAC9B,GAAG,EAAE,aAAa;SACnB;QACD,EAAE,EAAE;YACF,KAAK,EAAE,mBAAmB;YAC1B,GAAG,EAAE,SAAS;SACf;QACD,EAAE,EAAE;YACF,KAAK,EAAE,uBAAuB;YAC9B,GAAG,EAAE,aAAa;SACnB;KACF,CAAC;IAEF,MAAM,MAAM,GAAG,YAAY,CAAC,MAAM,CAAC,CAAC;IACpC,MAAM,MAAM,GAAG,UAAU,CAAC,IAAI,CAAC,CAAC;IAChC,MAAM,YAAY,GAAG,KAAK,IAAI,MAAM,CAAC,YAAY,CAAC;IAElD,OAAO,CACL,8BACE,SAAS,EAAE,6DAA6D,MAAM,CAAC,EAAE,IAAI,MAAM,CAAC,IAAI,IAAI,MAAM,CAAC,KAAK,IAAI,SAAS,EAAE;QAE9H,OAAO,IAAI,CACV,8BAAM,SAAS,EAAC,eAAe;YAC7B,8BACE,SAAS,EAAE,GAAG,MAAM,CAAC,GAAG,iBAAiB,MAAM,CAAC,GAAG,EAAE,GACrD;YACD,MAAM,CAAC,UAAU,IAAI,CACpB,8BACE,SAAS,EAAE,YAAY,MAAM,CAAC,GAAG,iBAAiB,MAAM,CAAC,GAAG,0BAA0B,GACtF,CACH,CACI,CACR;QACA,IAAI,IAAI,8BAAM,SAAS,EAAC,eAAe,IAAE,IAAI,CAAQ;QACtD,kCAAO,YAAY,CAAQ,CACtB,CACR,CAAC;AACJ,CAAC;AAkBD,MAAM,UAAU,iBAAiB,CAAC,EAChC,WAAW,EACX,WAAW,EACX,SAAS,EACT,YAAY,EACZ,SAAS,GACc;IACvB,IAAI,MAAkB,CAAC;IACvB,IAAI,KAAyB,CAAC;IAE9B,IAAI,SAAS,EAAE,CAAC;QACd,MAAM,GAAG,SAAS,CAAC;IACrB,CAAC;SAAM,IAAI,WAAW,EAAE,CAAC;QACvB,MAAM,GAAG,SAAS,CAAC;QACnB,KAAK,GAAG,oBAAoB,CAAC;IAC/B,CAAC;SAAM,IAAI,WAAW,EAAE,CAAC;QACvB,MAAM,GAAG,WAAW,CAAC;IACvB,CAAC;SAAM,CAAC;QACN,MAAM,GAAG,cAAc,CAAC;IAC1B,CAAC;IAED,OAAO,CACL,6BAAK,SAAS,EAAE,uBAAuB,SAAS,IAAI,EAAE,EAAE;QACtD,oBAAC,WAAW,IAAC,MAAM,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,GAAI;QAC5C,YAAY,IAAI,WAAW,IAAI,CAAC,WAAW,IAAI,CAC9C,8BAAM,SAAS,EAAC,uBAAuB;;YACzB,kBAAkB,CAAC,YAAY,CAAC,CACvC,CACR,CACG,CACP,CAAC;AACJ,CAAC;AAED;;GAEG;AACH,SAAS,kBAAkB,CAAC,IAAU;IACpC,MAAM,GAAG,GAAG,IAAI,IAAI,EAAE,CAAC;IACvB,MAAM,MAAM,GAAG,GAAG,CAAC,OAAO,EAAE,GAAG,IAAI,CAAC,OAAO,EAAE,CAAC;IAC9C,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,MAAM,GAAG,KAAK,CAAC,CAAC;IAC5C,MAAM,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAC,CAAC;IAC5C,MAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,SAAS,GAAG,EAAE,CAAC,CAAC;IAE5C,IAAI,QAAQ,GAAG,CAAC;QAAE,OAAO,UAAU,CAAC;IACpC,IAAI,QAAQ,GAAG,EAAE;QAAE,OAAO,GAAG,QAAQ,OAAO,CAAC;IAC7C,IAAI,SAAS,GAAG,EAAE;QAAE,OAAO,GAAG,SAAS,OAAO,CAAC;IAC/C,IAAI,QAAQ,GAAG,CAAC;QAAE,OAAO,GAAG,QAAQ,OAAO,CAAC;IAE5C,OAAO,IAAI,CAAC,kBAAkB,EAAE,CAAC;AACnC,CAAC;AAED,eAAe,WAAW,CAAC"}
|
|
@@ -0,0 +1,19 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Dashboard Components
|
|
3
|
+
*
|
|
4
|
+
* Complete dashboard layout system for Varity-powered applications.
|
|
5
|
+
* Includes layout components, data display components, and loading states.
|
|
6
|
+
*/
|
|
7
|
+
export { DashboardLayout } from './DashboardLayout';
|
|
8
|
+
export { DashboardHeader } from './DashboardHeader';
|
|
9
|
+
export { DashboardSidebar } from './DashboardSidebar';
|
|
10
|
+
export { DashboardFooter } from './DashboardFooter';
|
|
11
|
+
export { KPICard, type KPICardProps } from './KPICard';
|
|
12
|
+
export { StatusBadge, IntegrationStatus, type StatusBadgeProps, type StatusType, type IntegrationStatusProps } from './StatusBadge';
|
|
13
|
+
export { EmptyState, EmptyStatePresets, type EmptyStateProps } from './EmptyState';
|
|
14
|
+
export { LoadingSkeleton, SkeletonText, SkeletonCard, SkeletonTable, SkeletonList, type LoadingSkeletonProps, } from './LoadingSkeleton';
|
|
15
|
+
export type { DashboardLayoutProps, NavigationItem, UserInfo } from './DashboardLayout';
|
|
16
|
+
export type { DashboardHeaderProps } from './DashboardHeader';
|
|
17
|
+
export type { DashboardSidebarProps } from './DashboardSidebar';
|
|
18
|
+
export type { DashboardFooterProps, FooterLink } from './DashboardFooter';
|
|
19
|
+
//# sourceMappingURL=index.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Dashboard/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAGH,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAGnD,OAAO,EAAE,OAAO,EAAE,KAAK,YAAY,EAAE,MAAM,WAAW,CAAA;AACtD,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAE,KAAK,gBAAgB,EAAE,KAAK,UAAU,EAAE,KAAK,sBAAsB,EAAE,MAAM,eAAe,CAAA;AACnI,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAE,KAAK,eAAe,EAAE,MAAM,cAAc,CAAA;AAGlF,OAAO,EACL,eAAe,EACf,YAAY,EACZ,YAAY,EACZ,aAAa,EACb,YAAY,EACZ,KAAK,oBAAoB,GAC1B,MAAM,mBAAmB,CAAA;AAG1B,YAAY,EACV,oBAAoB,EACpB,cAAc,EACd,QAAQ,EACT,MAAM,mBAAmB,CAAA;AAE1B,YAAY,EAAE,oBAAoB,EAAE,MAAM,mBAAmB,CAAA;AAC7D,YAAY,EAAE,qBAAqB,EAAE,MAAM,oBAAoB,CAAA;AAC/D,YAAY,EAAE,oBAAoB,EAAE,UAAU,EAAE,MAAM,mBAAmB,CAAA"}
|
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Dashboard Components
|
|
3
|
+
*
|
|
4
|
+
* Complete dashboard layout system for Varity-powered applications.
|
|
5
|
+
* Includes layout components, data display components, and loading states.
|
|
6
|
+
*/
|
|
7
|
+
// Layout Components
|
|
8
|
+
export { DashboardLayout } from './DashboardLayout';
|
|
9
|
+
export { DashboardHeader } from './DashboardHeader';
|
|
10
|
+
export { DashboardSidebar } from './DashboardSidebar';
|
|
11
|
+
export { DashboardFooter } from './DashboardFooter';
|
|
12
|
+
// Data Display Components
|
|
13
|
+
export { KPICard } from './KPICard';
|
|
14
|
+
export { StatusBadge, IntegrationStatus } from './StatusBadge';
|
|
15
|
+
export { EmptyState, EmptyStatePresets } from './EmptyState';
|
|
16
|
+
// Loading States
|
|
17
|
+
export { LoadingSkeleton, SkeletonText, SkeletonCard, SkeletonTable, SkeletonList, } from './LoadingSkeleton';
|
|
18
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Dashboard/index.ts"],"names":[],"mappings":"AAAA;;;;;GAKG;AAEH,oBAAoB;AACpB,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AACnD,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAA;AACrD,OAAO,EAAE,eAAe,EAAE,MAAM,mBAAmB,CAAA;AAEnD,0BAA0B;AAC1B,OAAO,EAAE,OAAO,EAAqB,MAAM,WAAW,CAAA;AACtD,OAAO,EAAE,WAAW,EAAE,iBAAiB,EAAuE,MAAM,eAAe,CAAA;AACnI,OAAO,EAAE,UAAU,EAAE,iBAAiB,EAAwB,MAAM,cAAc,CAAA;AAElF,iBAAiB;AACjB,OAAO,EACL,eAAe,EACf,YAAY,EACZ,YAAY,EACZ,aAAa,EACb,YAAY,GAEb,MAAM,mBAAmB,CAAA"}
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* EmailLoginButton - Email OTP Authentication Button
|
|
3
|
+
*
|
|
4
|
+
* Provides email passwordless authentication using Thirdweb In-App Wallets
|
|
5
|
+
* Users receive a one-time password via email for verification
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```tsx
|
|
9
|
+
* <EmailLoginButton
|
|
10
|
+
* onSuccess={(user) => console.log('Logged in:', user)}
|
|
11
|
+
* buttonClassName="custom-button-class"
|
|
12
|
+
* />
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
15
|
+
import React from 'react';
|
|
16
|
+
interface EmailLoginButtonProps {
|
|
17
|
+
onSuccess?: (user: string) => void;
|
|
18
|
+
onError?: (error: Error) => void;
|
|
19
|
+
buttonClassName?: string;
|
|
20
|
+
inputClassName?: string;
|
|
21
|
+
placeholder?: string;
|
|
22
|
+
buttonText?: string;
|
|
23
|
+
loadingText?: string;
|
|
24
|
+
}
|
|
25
|
+
export declare function EmailLoginButton({ onSuccess, onError, buttonClassName, inputClassName, placeholder, buttonText, loadingText }: EmailLoginButtonProps): React.JSX.Element;
|
|
26
|
+
export {};
|
|
27
|
+
//# sourceMappingURL=EmailLoginButton.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmailLoginButton.d.ts","sourceRoot":"","sources":["../../../src/components/InAppWallet/EmailLoginButton.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,KAAmB,MAAM,OAAO,CAAC;AAIxC,UAAU,qBAAqB;IAC7B,SAAS,CAAC,EAAE,CAAC,IAAI,EAAE,MAAM,KAAK,IAAI,CAAC;IACnC,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IACjC,eAAe,CAAC,EAAE,MAAM,CAAC;IACzB,cAAc,CAAC,EAAE,MAAM,CAAC;IACxB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAED,wBAAgB,gBAAgB,CAAC,EAC/B,SAAS,EACT,OAAO,EACP,eAAoB,EACpB,cAAmB,EACnB,WAAgC,EAChC,UAAkC,EAClC,WAA+B,EAChC,EAAE,qBAAqB,qBA+IvB"}
|
|
@@ -0,0 +1,84 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* EmailLoginButton - Email OTP Authentication Button
|
|
3
|
+
*
|
|
4
|
+
* Provides email passwordless authentication using Thirdweb In-App Wallets
|
|
5
|
+
* Users receive a one-time password via email for verification
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```tsx
|
|
9
|
+
* <EmailLoginButton
|
|
10
|
+
* onSuccess={(user) => console.log('Logged in:', user)}
|
|
11
|
+
* buttonClassName="custom-button-class"
|
|
12
|
+
* />
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
15
|
+
import React, { useState } from 'react';
|
|
16
|
+
import { useInAppWallet } from './InAppWalletProvider';
|
|
17
|
+
import { getErrorMessage } from '@varity-labs/types';
|
|
18
|
+
export function EmailLoginButton({ onSuccess, onError, buttonClassName = '', inputClassName = '', placeholder = 'Enter your email', buttonText = 'Continue with Email', loadingText = 'Sending code...' }) {
|
|
19
|
+
const { loginWithEmail, isLoading } = useInAppWallet();
|
|
20
|
+
const [email, setEmail] = useState('');
|
|
21
|
+
const [showInput, setShowInput] = useState(false);
|
|
22
|
+
const [isValidEmail, setIsValidEmail] = useState(false);
|
|
23
|
+
const validateEmail = (email) => {
|
|
24
|
+
const emailRegex = /^[^\s@]+@[^\s@]+\.[^\s@]+$/;
|
|
25
|
+
return emailRegex.test(email);
|
|
26
|
+
};
|
|
27
|
+
const handleEmailChange = (e) => {
|
|
28
|
+
const value = e.target.value;
|
|
29
|
+
setEmail(value);
|
|
30
|
+
setIsValidEmail(validateEmail(value));
|
|
31
|
+
};
|
|
32
|
+
const handleSubmit = async (e) => {
|
|
33
|
+
e.preventDefault();
|
|
34
|
+
if (!isValidEmail) {
|
|
35
|
+
onError?.(new Error('Invalid email address'));
|
|
36
|
+
return;
|
|
37
|
+
}
|
|
38
|
+
try {
|
|
39
|
+
await loginWithEmail(email);
|
|
40
|
+
onSuccess?.(email);
|
|
41
|
+
}
|
|
42
|
+
catch (error) {
|
|
43
|
+
const errorMessage = getErrorMessage(error);
|
|
44
|
+
const errorObj = error instanceof Error ? error : new Error(errorMessage);
|
|
45
|
+
onError?.(errorObj);
|
|
46
|
+
}
|
|
47
|
+
};
|
|
48
|
+
const defaultButtonClass = `
|
|
49
|
+
w-full px-6 py-3
|
|
50
|
+
bg-gradient-to-r from-indigo-600 to-purple-600
|
|
51
|
+
hover:from-indigo-700 hover:to-purple-700
|
|
52
|
+
text-white font-medium rounded-lg
|
|
53
|
+
transition-all duration-200
|
|
54
|
+
disabled:opacity-50 disabled:cursor-not-allowed
|
|
55
|
+
flex items-center justify-center gap-2
|
|
56
|
+
shadow-lg hover:shadow-xl
|
|
57
|
+
`;
|
|
58
|
+
const defaultInputClass = `
|
|
59
|
+
w-full px-4 py-3
|
|
60
|
+
border border-gray-300 rounded-lg
|
|
61
|
+
focus:ring-2 focus:ring-indigo-500 focus:border-transparent
|
|
62
|
+
outline-none transition-all
|
|
63
|
+
`;
|
|
64
|
+
if (!showInput) {
|
|
65
|
+
return (React.createElement("button", { onClick: () => setShowInput(true), className: buttonClassName || defaultButtonClass, disabled: isLoading },
|
|
66
|
+
React.createElement("svg", { className: "w-5 h-5", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24" },
|
|
67
|
+
React.createElement("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M3 8l7.89 5.26a2 2 0 002.22 0L21 8M5 19h14a2 2 0 002-2V7a2 2 0 00-2-2H5a2 2 0 00-2 2v10a2 2 0 002 2z" })),
|
|
68
|
+
buttonText));
|
|
69
|
+
}
|
|
70
|
+
return (React.createElement("form", { onSubmit: handleSubmit, className: "w-full space-y-3" },
|
|
71
|
+
React.createElement("input", { type: "email", value: email, onChange: handleEmailChange, placeholder: placeholder, className: inputClassName || defaultInputClass, disabled: isLoading, autoFocus: true, required: true }),
|
|
72
|
+
React.createElement("div", { className: "flex gap-2" },
|
|
73
|
+
React.createElement("button", { type: "button", onClick: () => {
|
|
74
|
+
setShowInput(false);
|
|
75
|
+
setEmail('');
|
|
76
|
+
}, className: "px-4 py-3 border border-gray-300 rounded-lg hover:bg-gray-50 transition-all", disabled: isLoading }, "Back"),
|
|
77
|
+
React.createElement("button", { type: "submit", className: buttonClassName || defaultButtonClass, disabled: isLoading || !isValidEmail }, isLoading ? (React.createElement(React.Fragment, null,
|
|
78
|
+
React.createElement("svg", { className: "animate-spin h-5 w-5", fill: "none", viewBox: "0 0 24 24" },
|
|
79
|
+
React.createElement("circle", { className: "opacity-25", cx: "12", cy: "12", r: "10", stroke: "currentColor", strokeWidth: "4" }),
|
|
80
|
+
React.createElement("path", { className: "opacity-75", fill: "currentColor", d: "M4 12a8 8 0 018-8V0C5.373 0 0 5.373 0 12h4zm2 5.291A7.962 7.962 0 014 12H0c0 3.042 1.135 5.824 3 7.938l3-2.647z" })),
|
|
81
|
+
loadingText)) : ('Send Code'))),
|
|
82
|
+
React.createElement("p", { className: "text-xs text-gray-500 text-center" }, "We'll send a verification code to your email")));
|
|
83
|
+
}
|
|
84
|
+
//# sourceMappingURL=EmailLoginButton.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"EmailLoginButton.js","sourceRoot":"","sources":["../../../src/components/InAppWallet/EmailLoginButton.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,54 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* InAppWalletProvider - Thirdweb In-App Wallet Provider for Varity L3
|
|
3
|
+
*
|
|
4
|
+
* Provides email/social authentication with custodial wallet management
|
|
5
|
+
* Supports: Email OTP, Google, Apple, Facebook, Discord, Twitter
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```tsx
|
|
9
|
+
* <InAppWalletProvider clientId="your-client-id">
|
|
10
|
+
* <YourApp />
|
|
11
|
+
* </InAppWalletProvider>
|
|
12
|
+
* ```
|
|
13
|
+
*/
|
|
14
|
+
import React from 'react';
|
|
15
|
+
import { inAppWallet } from 'thirdweb/wallets';
|
|
16
|
+
interface User {
|
|
17
|
+
email?: string;
|
|
18
|
+
walletAddress?: string;
|
|
19
|
+
userId: string;
|
|
20
|
+
name?: string;
|
|
21
|
+
profileImage?: string;
|
|
22
|
+
authMethod: 'email' | 'google' | 'apple' | 'facebook' | 'discord' | 'twitter';
|
|
23
|
+
}
|
|
24
|
+
export interface InAppWalletContextType {
|
|
25
|
+
user: User | null;
|
|
26
|
+
isAuthenticated: boolean;
|
|
27
|
+
isLoading: boolean;
|
|
28
|
+
emailPending: string | null;
|
|
29
|
+
sendEmailVerificationCode: (email: string) => Promise<void>;
|
|
30
|
+
verifyEmailAndConnect: (verificationCode: string) => Promise<void>;
|
|
31
|
+
loginWithEmail: (email: string) => Promise<void>;
|
|
32
|
+
loginWithGoogle: () => Promise<void>;
|
|
33
|
+
loginWithApple: () => Promise<void>;
|
|
34
|
+
loginWithFacebook: () => Promise<void>;
|
|
35
|
+
logout: () => Promise<void>;
|
|
36
|
+
wallet: ReturnType<typeof inAppWallet> | null;
|
|
37
|
+
}
|
|
38
|
+
interface InAppWalletProviderProps {
|
|
39
|
+
children: React.ReactNode;
|
|
40
|
+
clientId: string;
|
|
41
|
+
onLoginSuccess?: (user: User) => void;
|
|
42
|
+
onLoginError?: (error: Error) => void;
|
|
43
|
+
onLogout?: () => void;
|
|
44
|
+
}
|
|
45
|
+
/**
|
|
46
|
+
* Main provider component
|
|
47
|
+
*/
|
|
48
|
+
export declare function InAppWalletProvider({ children, clientId, onLoginSuccess, onLoginError, onLogout }: InAppWalletProviderProps): React.JSX.Element;
|
|
49
|
+
/**
|
|
50
|
+
* Hook to use In-App Wallet context
|
|
51
|
+
*/
|
|
52
|
+
export declare function useInAppWallet(): InAppWalletContextType;
|
|
53
|
+
export {};
|
|
54
|
+
//# sourceMappingURL=InAppWalletProvider.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InAppWalletProvider.d.ts","sourceRoot":"","sources":["../../../src/components/InAppWallet/InAppWalletProvider.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;GAYG;AAEH,OAAO,KAAsE,MAAM,OAAO,CAAC;AAG3F,OAAO,EAAE,WAAW,EAAmB,MAAM,kBAAkB,CAAC;AAKhE,UAAU,IAAI;IACZ,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,aAAa,CAAC,EAAE,MAAM,CAAC;IACvB,MAAM,EAAE,MAAM,CAAC;IACf,IAAI,CAAC,EAAE,MAAM,CAAC;IACd,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,UAAU,EAAE,OAAO,GAAG,QAAQ,GAAG,OAAO,GAAG,UAAU,GAAG,SAAS,GAAG,SAAS,CAAC;CAC/E;AAED,MAAM,WAAW,sBAAsB;IACrC,IAAI,EAAE,IAAI,GAAG,IAAI,CAAC;IAClB,eAAe,EAAE,OAAO,CAAC;IACzB,SAAS,EAAE,OAAO,CAAC;IACnB,YAAY,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,yBAAyB,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5D,qBAAqB,EAAE,CAAC,gBAAgB,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACnE,cAAc,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,OAAO,CAAC,IAAI,CAAC,CAAC;IACjD,eAAe,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACrC,cAAc,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACpC,iBAAiB,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IACvC,MAAM,EAAE,MAAM,OAAO,CAAC,IAAI,CAAC,CAAC;IAC5B,MAAM,EAAE,UAAU,CAAC,OAAO,WAAW,CAAC,GAAG,IAAI,CAAC;CAC/C;AAID,UAAU,wBAAwB;IAChC,QAAQ,EAAE,KAAK,CAAC,SAAS,CAAC;IAC1B,QAAQ,EAAE,MAAM,CAAC;IACjB,cAAc,CAAC,EAAE,CAAC,IAAI,EAAE,IAAI,KAAK,IAAI,CAAC;IACtC,YAAY,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IACtC,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;CACvB;AA0ND;;GAEG;AACH,wBAAgB,mBAAmB,CAAC,EAClC,QAAQ,EACR,QAAQ,EACR,cAAc,EACd,YAAY,EACZ,QAAQ,EACT,EAAE,wBAAwB,qBAkB1B;AAED;;GAEG;AACH,wBAAgB,cAAc,2BAM7B"}
|