@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,238 @@
|
|
|
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, { createContext, useContext, useState, useCallback, useEffect } from 'react';
|
|
15
|
+
import { ThirdwebProvider } from 'thirdweb/react';
|
|
16
|
+
import { useActiveAccount, useConnect } from 'thirdweb/react';
|
|
17
|
+
import { inAppWallet, preAuthenticate } from 'thirdweb/wallets';
|
|
18
|
+
import { createThirdwebClient } from 'thirdweb';
|
|
19
|
+
import toast from 'react-hot-toast';
|
|
20
|
+
import { getErrorMessage } from '@varity-labs/types';
|
|
21
|
+
const InAppWalletContext = createContext(undefined);
|
|
22
|
+
/**
|
|
23
|
+
* Internal component that uses Thirdweb hooks
|
|
24
|
+
*/
|
|
25
|
+
function InAppWalletManager({ children, onLoginSuccess, onLoginError, onLogout, client }) {
|
|
26
|
+
const [user, setUser] = useState(null);
|
|
27
|
+
const [wallet, setWallet] = useState(null);
|
|
28
|
+
const [isLoading, setIsLoading] = useState(false);
|
|
29
|
+
const [emailPending, setEmailPending] = useState(null);
|
|
30
|
+
const { connect } = useConnect();
|
|
31
|
+
const activeAccount = useActiveAccount();
|
|
32
|
+
const isAuthenticated = !!activeAccount;
|
|
33
|
+
// Update user when account changes
|
|
34
|
+
useEffect(() => {
|
|
35
|
+
if (activeAccount) {
|
|
36
|
+
const walletAddress = activeAccount.address;
|
|
37
|
+
const userData = {
|
|
38
|
+
walletAddress,
|
|
39
|
+
userId: walletAddress,
|
|
40
|
+
authMethod: 'email', // Default, will be updated based on actual method
|
|
41
|
+
};
|
|
42
|
+
setUser(userData);
|
|
43
|
+
onLoginSuccess?.(userData);
|
|
44
|
+
}
|
|
45
|
+
else {
|
|
46
|
+
setUser(null);
|
|
47
|
+
}
|
|
48
|
+
}, [activeAccount, onLoginSuccess]);
|
|
49
|
+
// Step 1: Send verification code to email
|
|
50
|
+
const sendEmailVerificationCode = useCallback(async (email) => {
|
|
51
|
+
setIsLoading(true);
|
|
52
|
+
try {
|
|
53
|
+
await preAuthenticate({
|
|
54
|
+
client,
|
|
55
|
+
strategy: 'email',
|
|
56
|
+
email,
|
|
57
|
+
});
|
|
58
|
+
setEmailPending(email);
|
|
59
|
+
toast.success(`Verification code sent to ${email}`);
|
|
60
|
+
}
|
|
61
|
+
catch (error) {
|
|
62
|
+
const errorMessage = getErrorMessage(error);
|
|
63
|
+
console.error('Failed to send verification code:', errorMessage);
|
|
64
|
+
const errorObj = error instanceof Error ? error : new Error(errorMessage);
|
|
65
|
+
onLoginError?.(errorObj);
|
|
66
|
+
toast.error('Failed to send verification code');
|
|
67
|
+
}
|
|
68
|
+
finally {
|
|
69
|
+
setIsLoading(false);
|
|
70
|
+
}
|
|
71
|
+
}, [client, onLoginError]);
|
|
72
|
+
// Step 2: Complete login with verification code
|
|
73
|
+
const verifyEmailAndConnect = useCallback(async (verificationCode) => {
|
|
74
|
+
if (!emailPending) {
|
|
75
|
+
toast.error('No email pending verification');
|
|
76
|
+
return;
|
|
77
|
+
}
|
|
78
|
+
setIsLoading(true);
|
|
79
|
+
try {
|
|
80
|
+
const newWallet = inAppWallet();
|
|
81
|
+
setWallet(newWallet);
|
|
82
|
+
await connect(async () => {
|
|
83
|
+
await newWallet.connect({
|
|
84
|
+
client,
|
|
85
|
+
strategy: 'email',
|
|
86
|
+
email: emailPending,
|
|
87
|
+
verificationCode,
|
|
88
|
+
});
|
|
89
|
+
return newWallet;
|
|
90
|
+
});
|
|
91
|
+
setEmailPending(null);
|
|
92
|
+
toast.success('Successfully logged in!');
|
|
93
|
+
}
|
|
94
|
+
catch (error) {
|
|
95
|
+
const errorMessage = getErrorMessage(error);
|
|
96
|
+
console.error('Email verification failed:', errorMessage);
|
|
97
|
+
const errorObj = error instanceof Error ? error : new Error(errorMessage);
|
|
98
|
+
onLoginError?.(errorObj);
|
|
99
|
+
toast.error('Invalid verification code');
|
|
100
|
+
}
|
|
101
|
+
finally {
|
|
102
|
+
setIsLoading(false);
|
|
103
|
+
}
|
|
104
|
+
}, [connect, client, emailPending, onLoginError]);
|
|
105
|
+
// Legacy convenience method - initiates the 2-step flow
|
|
106
|
+
const loginWithEmail = useCallback(async (email) => {
|
|
107
|
+
await sendEmailVerificationCode(email);
|
|
108
|
+
}, [sendEmailVerificationCode]);
|
|
109
|
+
const loginWithGoogle = useCallback(async () => {
|
|
110
|
+
setIsLoading(true);
|
|
111
|
+
try {
|
|
112
|
+
const wallet = inAppWallet();
|
|
113
|
+
setWallet(wallet);
|
|
114
|
+
await connect(async () => {
|
|
115
|
+
await wallet.connect({
|
|
116
|
+
client,
|
|
117
|
+
strategy: 'google',
|
|
118
|
+
});
|
|
119
|
+
return wallet;
|
|
120
|
+
});
|
|
121
|
+
toast.success('Successfully logged in with Google!');
|
|
122
|
+
}
|
|
123
|
+
catch (error) {
|
|
124
|
+
const errorMessage = getErrorMessage(error);
|
|
125
|
+
console.error('Google login error:', errorMessage);
|
|
126
|
+
const errorObj = error instanceof Error ? error : new Error(errorMessage);
|
|
127
|
+
onLoginError?.(errorObj);
|
|
128
|
+
toast.error('Failed to login with Google');
|
|
129
|
+
}
|
|
130
|
+
finally {
|
|
131
|
+
setIsLoading(false);
|
|
132
|
+
}
|
|
133
|
+
}, [connect, client, onLoginError]);
|
|
134
|
+
const loginWithApple = useCallback(async () => {
|
|
135
|
+
setIsLoading(true);
|
|
136
|
+
try {
|
|
137
|
+
const wallet = inAppWallet();
|
|
138
|
+
setWallet(wallet);
|
|
139
|
+
await connect(async () => {
|
|
140
|
+
await wallet.connect({
|
|
141
|
+
client,
|
|
142
|
+
strategy: 'apple',
|
|
143
|
+
});
|
|
144
|
+
return wallet;
|
|
145
|
+
});
|
|
146
|
+
toast.success('Successfully logged in with Apple!');
|
|
147
|
+
}
|
|
148
|
+
catch (error) {
|
|
149
|
+
const errorMessage = getErrorMessage(error);
|
|
150
|
+
console.error('Apple login error:', errorMessage);
|
|
151
|
+
const errorObj = error instanceof Error ? error : new Error(errorMessage);
|
|
152
|
+
onLoginError?.(errorObj);
|
|
153
|
+
toast.error('Failed to login with Apple');
|
|
154
|
+
}
|
|
155
|
+
finally {
|
|
156
|
+
setIsLoading(false);
|
|
157
|
+
}
|
|
158
|
+
}, [connect, client, onLoginError]);
|
|
159
|
+
const loginWithFacebook = useCallback(async () => {
|
|
160
|
+
setIsLoading(true);
|
|
161
|
+
try {
|
|
162
|
+
const wallet = inAppWallet();
|
|
163
|
+
setWallet(wallet);
|
|
164
|
+
await connect(async () => {
|
|
165
|
+
await wallet.connect({
|
|
166
|
+
client,
|
|
167
|
+
strategy: 'facebook',
|
|
168
|
+
});
|
|
169
|
+
return wallet;
|
|
170
|
+
});
|
|
171
|
+
toast.success('Successfully logged in with Facebook!');
|
|
172
|
+
}
|
|
173
|
+
catch (error) {
|
|
174
|
+
const errorMessage = getErrorMessage(error);
|
|
175
|
+
console.error('Facebook login error:', errorMessage);
|
|
176
|
+
const errorObj = error instanceof Error ? error : new Error(errorMessage);
|
|
177
|
+
onLoginError?.(errorObj);
|
|
178
|
+
toast.error('Failed to login with Facebook');
|
|
179
|
+
}
|
|
180
|
+
finally {
|
|
181
|
+
setIsLoading(false);
|
|
182
|
+
}
|
|
183
|
+
}, [connect, client, onLoginError]);
|
|
184
|
+
const logout = useCallback(async () => {
|
|
185
|
+
setIsLoading(true);
|
|
186
|
+
try {
|
|
187
|
+
if (wallet) {
|
|
188
|
+
await wallet.disconnect();
|
|
189
|
+
}
|
|
190
|
+
setUser(null);
|
|
191
|
+
setWallet(null);
|
|
192
|
+
onLogout?.();
|
|
193
|
+
toast.success('Logged out successfully');
|
|
194
|
+
}
|
|
195
|
+
catch (error) {
|
|
196
|
+
const errorMessage = getErrorMessage(error);
|
|
197
|
+
console.error('Logout error:', errorMessage);
|
|
198
|
+
toast.error('Failed to logout');
|
|
199
|
+
}
|
|
200
|
+
finally {
|
|
201
|
+
setIsLoading(false);
|
|
202
|
+
}
|
|
203
|
+
}, [wallet, onLogout]);
|
|
204
|
+
const value = {
|
|
205
|
+
user,
|
|
206
|
+
isAuthenticated,
|
|
207
|
+
isLoading,
|
|
208
|
+
emailPending,
|
|
209
|
+
sendEmailVerificationCode,
|
|
210
|
+
verifyEmailAndConnect,
|
|
211
|
+
loginWithEmail,
|
|
212
|
+
loginWithGoogle,
|
|
213
|
+
loginWithApple,
|
|
214
|
+
loginWithFacebook,
|
|
215
|
+
logout,
|
|
216
|
+
wallet,
|
|
217
|
+
};
|
|
218
|
+
return (React.createElement(InAppWalletContext.Provider, { value: value }, children));
|
|
219
|
+
}
|
|
220
|
+
/**
|
|
221
|
+
* Main provider component
|
|
222
|
+
*/
|
|
223
|
+
export function InAppWalletProvider({ children, clientId, onLoginSuccess, onLoginError, onLogout }) {
|
|
224
|
+
const client = React.useMemo(() => createThirdwebClient({ clientId }), [clientId]);
|
|
225
|
+
return (React.createElement(ThirdwebProvider, null,
|
|
226
|
+
React.createElement(InAppWalletManager, { client: client, onLoginSuccess: onLoginSuccess, onLoginError: onLoginError, onLogout: onLogout }, children)));
|
|
227
|
+
}
|
|
228
|
+
/**
|
|
229
|
+
* Hook to use In-App Wallet context
|
|
230
|
+
*/
|
|
231
|
+
export function useInAppWallet() {
|
|
232
|
+
const context = useContext(InAppWalletContext);
|
|
233
|
+
if (context === undefined) {
|
|
234
|
+
throw new Error('useInAppWallet must be used within InAppWalletProvider');
|
|
235
|
+
}
|
|
236
|
+
return context;
|
|
237
|
+
}
|
|
238
|
+
//# sourceMappingURL=InAppWalletProvider.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"InAppWalletProvider.js","sourceRoot":"","sources":["../../../src/components/InAppWallet/InAppWalletProvider.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,25 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* OnboardingFlow - Complete User Onboarding Wizard
|
|
3
|
+
*
|
|
4
|
+
* Multi-step wizard for onboarding users to Varity L3
|
|
5
|
+
* Steps: Welcome -> Auth -> Wallet Created -> Buy USDC (optional) -> Dashboard
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```tsx
|
|
9
|
+
* <OnboardingFlow
|
|
10
|
+
* onComplete={(user) => router.push('/dashboard')}
|
|
11
|
+
* skipBuyUSDC={false}
|
|
12
|
+
* />
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
15
|
+
import React from 'react';
|
|
16
|
+
interface OnboardingFlowProps {
|
|
17
|
+
onComplete?: (user: any) => void;
|
|
18
|
+
onSkip?: () => void;
|
|
19
|
+
skipBuyUSDC?: boolean;
|
|
20
|
+
companyName?: string;
|
|
21
|
+
companyLogo?: string;
|
|
22
|
+
}
|
|
23
|
+
export declare function OnboardingFlow({ onComplete, onSkip, skipBuyUSDC, companyName, companyLogo }: OnboardingFlowProps): React.JSX.Element;
|
|
24
|
+
export {};
|
|
25
|
+
//# sourceMappingURL=OnboardingFlow.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OnboardingFlow.d.ts","sourceRoot":"","sources":["../../../src/components/InAppWallet/OnboardingFlow.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,KAAmB,MAAM,OAAO,CAAC;AAKxC,UAAU,mBAAmB;IAC3B,UAAU,CAAC,EAAE,CAAC,IAAI,EAAE,GAAG,KAAK,IAAI,CAAC;IACjC,MAAM,CAAC,EAAE,MAAM,IAAI,CAAC;IACpB,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB;AAID,wBAAgB,cAAc,CAAC,EAC7B,UAAU,EACV,MAAM,EACN,WAAmB,EACnB,WAAsB,EACtB,WAAW,EACZ,EAAE,mBAAmB,qBAsRrB"}
|
|
@@ -0,0 +1,159 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* OnboardingFlow - Complete User Onboarding Wizard
|
|
3
|
+
*
|
|
4
|
+
* Multi-step wizard for onboarding users to Varity L3
|
|
5
|
+
* Steps: Welcome -> Auth -> Wallet Created -> Buy USDC (optional) -> Dashboard
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```tsx
|
|
9
|
+
* <OnboardingFlow
|
|
10
|
+
* onComplete={(user) => router.push('/dashboard')}
|
|
11
|
+
* skipBuyUSDC={false}
|
|
12
|
+
* />
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
15
|
+
import React, { useState } from 'react';
|
|
16
|
+
import { useInAppWallet } from './InAppWalletProvider';
|
|
17
|
+
import { EmailLoginButton } from './EmailLoginButton';
|
|
18
|
+
import { SocialLoginButtons } from './SocialLoginButtons';
|
|
19
|
+
export function OnboardingFlow({ onComplete, onSkip, skipBuyUSDC = false, companyName = 'Varity', companyLogo }) {
|
|
20
|
+
const { user, isAuthenticated } = useInAppWallet();
|
|
21
|
+
const [currentStep, setCurrentStep] = useState('welcome');
|
|
22
|
+
const showBuyUSDC = !skipBuyUSDC;
|
|
23
|
+
const handleComplete = React.useCallback(() => {
|
|
24
|
+
setCurrentStep('complete');
|
|
25
|
+
onComplete?.(user);
|
|
26
|
+
}, [user, onComplete]);
|
|
27
|
+
// Auto-advance to wallet-created when authenticated
|
|
28
|
+
React.useEffect(() => {
|
|
29
|
+
if (isAuthenticated && user && currentStep === 'auth') {
|
|
30
|
+
setCurrentStep('wallet-created');
|
|
31
|
+
setTimeout(() => {
|
|
32
|
+
if (showBuyUSDC) {
|
|
33
|
+
setCurrentStep('buy-usdc');
|
|
34
|
+
}
|
|
35
|
+
else {
|
|
36
|
+
handleComplete();
|
|
37
|
+
}
|
|
38
|
+
}, 3000); // Show success for 3 seconds
|
|
39
|
+
}
|
|
40
|
+
}, [isAuthenticated, user, currentStep, showBuyUSDC, handleComplete]);
|
|
41
|
+
const handleSkipOnboarding = () => {
|
|
42
|
+
onSkip?.();
|
|
43
|
+
};
|
|
44
|
+
const renderStep = () => {
|
|
45
|
+
switch (currentStep) {
|
|
46
|
+
case 'welcome':
|
|
47
|
+
return (React.createElement("div", { className: "text-center space-y-6" },
|
|
48
|
+
companyLogo && (React.createElement("img", { src: companyLogo, alt: companyName, className: "h-16 mx-auto" })),
|
|
49
|
+
React.createElement("div", { className: "space-y-2" },
|
|
50
|
+
React.createElement("h1", { className: "text-3xl font-bold text-gray-900" },
|
|
51
|
+
"Welcome to ",
|
|
52
|
+
companyName),
|
|
53
|
+
React.createElement("p", { className: "text-lg text-gray-600" }, "Get started in 2 minutes - No crypto knowledge required")),
|
|
54
|
+
React.createElement("div", { className: "bg-gradient-to-br from-indigo-50 to-purple-50 rounded-xl p-6 space-y-4" },
|
|
55
|
+
React.createElement("h3", { className: "font-semibold text-gray-900" }, "What you'll get:"),
|
|
56
|
+
React.createElement("ul", { className: "text-left space-y-3" },
|
|
57
|
+
React.createElement("li", { className: "flex items-start gap-3" },
|
|
58
|
+
React.createElement("svg", { className: "w-6 h-6 text-green-500 flex-shrink-0", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24" },
|
|
59
|
+
React.createElement("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" })),
|
|
60
|
+
React.createElement("span", { className: "text-gray-700" },
|
|
61
|
+
React.createElement("strong", null, "Your own wallet"),
|
|
62
|
+
" - Automatically created with email/social login")),
|
|
63
|
+
React.createElement("li", { className: "flex items-start gap-3" },
|
|
64
|
+
React.createElement("svg", { className: "w-6 h-6 text-green-500 flex-shrink-0", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24" },
|
|
65
|
+
React.createElement("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" })),
|
|
66
|
+
React.createElement("span", { className: "text-gray-700" },
|
|
67
|
+
React.createElement("strong", null, "Free transactions"),
|
|
68
|
+
" - USDC as gas token means low fees")),
|
|
69
|
+
React.createElement("li", { className: "flex items-start gap-3" },
|
|
70
|
+
React.createElement("svg", { className: "w-6 h-6 text-green-500 flex-shrink-0", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24" },
|
|
71
|
+
React.createElement("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" })),
|
|
72
|
+
React.createElement("span", { className: "text-gray-700" },
|
|
73
|
+
React.createElement("strong", null, "Buy crypto with card"),
|
|
74
|
+
" - Use credit card, Apple Pay, or Google Pay")))),
|
|
75
|
+
React.createElement("button", { onClick: () => setCurrentStep('auth'), className: "w-full bg-gradient-to-r from-indigo-600 to-purple-600 hover:from-indigo-700 hover:to-purple-700 text-white font-semibold py-4 px-6 rounded-xl transition-all shadow-lg hover:shadow-xl" }, "Get Started"),
|
|
76
|
+
React.createElement("button", { onClick: handleSkipOnboarding, className: "text-sm text-gray-500 hover:text-gray-700" }, "Skip for now")));
|
|
77
|
+
case 'auth':
|
|
78
|
+
return (React.createElement("div", { className: "space-y-6" },
|
|
79
|
+
React.createElement("div", { className: "text-center space-y-2" },
|
|
80
|
+
React.createElement("h2", { className: "text-2xl font-bold text-gray-900" }, "Create Your Wallet"),
|
|
81
|
+
React.createElement("p", { className: "text-gray-600" }, "Choose how you'd like to sign in - your wallet will be created automatically")),
|
|
82
|
+
React.createElement("div", { className: "space-y-4" },
|
|
83
|
+
React.createElement(SocialLoginButtons, { providers: ['google', 'apple', 'facebook'], layout: "vertical", showDivider: false }),
|
|
84
|
+
React.createElement("div", { className: "relative my-6" },
|
|
85
|
+
React.createElement("div", { className: "absolute inset-0 flex items-center" },
|
|
86
|
+
React.createElement("div", { className: "w-full border-t border-gray-300" })),
|
|
87
|
+
React.createElement("div", { className: "relative flex justify-center text-sm" },
|
|
88
|
+
React.createElement("span", { className: "bg-white px-4 text-gray-500" }, "or use email"))),
|
|
89
|
+
React.createElement(EmailLoginButton, null)),
|
|
90
|
+
React.createElement("button", { onClick: () => setCurrentStep('welcome'), className: "w-full text-gray-600 hover:text-gray-900 font-medium" }, "\u2190 Back")));
|
|
91
|
+
case 'wallet-created':
|
|
92
|
+
return (React.createElement("div", { className: "text-center space-y-6" },
|
|
93
|
+
React.createElement("div", { className: "flex justify-center" },
|
|
94
|
+
React.createElement("div", { className: "relative" },
|
|
95
|
+
React.createElement("div", { className: "w-24 h-24 bg-gradient-to-br from-green-400 to-green-600 rounded-full flex items-center justify-center animate-pulse" },
|
|
96
|
+
React.createElement("svg", { className: "w-12 h-12 text-white", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24" },
|
|
97
|
+
React.createElement("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M5 13l4 4L19 7" }))),
|
|
98
|
+
React.createElement("div", { className: "absolute -top-2 -right-2 w-8 h-8 bg-yellow-400 rounded-full flex items-center justify-center animate-bounce" },
|
|
99
|
+
React.createElement("span", { className: "text-xl" }, "\uD83C\uDF89")))),
|
|
100
|
+
React.createElement("div", { className: "space-y-2" },
|
|
101
|
+
React.createElement("h2", { className: "text-2xl font-bold text-gray-900" }, "Wallet Created Successfully!"),
|
|
102
|
+
React.createElement("p", { className: "text-gray-600" }, "Your wallet is ready to use")),
|
|
103
|
+
React.createElement("div", { className: "bg-gray-50 rounded-xl p-4 space-y-2" },
|
|
104
|
+
React.createElement("div", { className: "flex justify-between items-center" },
|
|
105
|
+
React.createElement("span", { className: "text-sm text-gray-600" }, "Wallet Address:"),
|
|
106
|
+
React.createElement("code", { className: "text-xs font-mono bg-white px-2 py-1 rounded" },
|
|
107
|
+
user?.walletAddress?.slice(0, 6),
|
|
108
|
+
"...",
|
|
109
|
+
user?.walletAddress?.slice(-4))),
|
|
110
|
+
user?.email && (React.createElement("div", { className: "flex justify-between items-center" },
|
|
111
|
+
React.createElement("span", { className: "text-sm text-gray-600" }, "Email:"),
|
|
112
|
+
React.createElement("span", { className: "text-sm font-medium" }, user.email)))),
|
|
113
|
+
React.createElement("div", { className: "text-sm text-gray-500" }, "Redirecting to next step...")));
|
|
114
|
+
case 'buy-usdc':
|
|
115
|
+
return (React.createElement("div", { className: "space-y-6" },
|
|
116
|
+
React.createElement("div", { className: "text-center space-y-2" },
|
|
117
|
+
React.createElement("h2", { className: "text-2xl font-bold text-gray-900" }, "Add Funds to Your Wallet"),
|
|
118
|
+
React.createElement("p", { className: "text-gray-600" }, "Buy USDC with your credit card to start using the platform")),
|
|
119
|
+
React.createElement("div", { className: "bg-gradient-to-br from-blue-50 to-indigo-50 rounded-xl p-6 space-y-4" },
|
|
120
|
+
React.createElement("div", { className: "flex items-center gap-3" },
|
|
121
|
+
React.createElement("svg", { className: "w-8 h-8 text-blue-600", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24" },
|
|
122
|
+
React.createElement("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M3 10h18M7 15h1m4 0h1m-7 4h12a3 3 0 003-3V8a3 3 0 00-3-3H6a3 3 0 00-3 3v8a3 3 0 003 3z" })),
|
|
123
|
+
React.createElement("div", null,
|
|
124
|
+
React.createElement("h3", { className: "font-semibold text-gray-900" }, "Payment Methods"),
|
|
125
|
+
React.createElement("p", { className: "text-sm text-gray-600" }, "Credit card, Apple Pay, Google Pay")))),
|
|
126
|
+
React.createElement("div", { className: "flex gap-3" },
|
|
127
|
+
React.createElement("button", { onClick: handleComplete, className: "flex-1 border-2 border-gray-300 text-gray-700 font-medium py-3 px-6 rounded-xl hover:bg-gray-50 transition-all" }, "Skip for now"),
|
|
128
|
+
React.createElement("button", { onClick: () => {
|
|
129
|
+
// This will be replaced with actual Onramp widget
|
|
130
|
+
console.log('Opening Onramp...');
|
|
131
|
+
handleComplete();
|
|
132
|
+
}, className: "flex-1 bg-gradient-to-r from-indigo-600 to-purple-600 hover:from-indigo-700 hover:to-purple-700 text-white font-semibold py-3 px-6 rounded-xl transition-all shadow-lg hover:shadow-xl" }, "Buy USDC"))));
|
|
133
|
+
case 'complete':
|
|
134
|
+
return (React.createElement("div", { className: "text-center space-y-6" },
|
|
135
|
+
React.createElement("div", { className: "flex justify-center" },
|
|
136
|
+
React.createElement("div", { className: "w-24 h-24 bg-gradient-to-br from-purple-400 to-indigo-600 rounded-full flex items-center justify-center" },
|
|
137
|
+
React.createElement("svg", { className: "w-12 h-12 text-white", fill: "none", stroke: "currentColor", viewBox: "0 0 24 24" },
|
|
138
|
+
React.createElement("path", { strokeLinecap: "round", strokeLinejoin: "round", strokeWidth: 2, d: "M14 10h4.764a2 2 0 011.789 2.894l-3.5 7A2 2 0 0115.263 21h-4.017c-.163 0-.326-.02-.485-.06L7 20m7-10V5a2 2 0 00-2-2h-.095c-.5 0-.905.405-.905.905 0 .714-.211 1.412-.608 2.006L7 11v9m7-10h-2M7 20H5a2 2 0 01-2-2v-6a2 2 0 012-2h2.5" })))),
|
|
139
|
+
React.createElement("div", { className: "space-y-2" },
|
|
140
|
+
React.createElement("h2", { className: "text-2xl font-bold text-gray-900" }, "You're All Set!"),
|
|
141
|
+
React.createElement("p", { className: "text-gray-600" },
|
|
142
|
+
"Welcome to ",
|
|
143
|
+
companyName,
|
|
144
|
+
". Let's get started!"))));
|
|
145
|
+
default:
|
|
146
|
+
return null;
|
|
147
|
+
}
|
|
148
|
+
};
|
|
149
|
+
return (React.createElement("div", { className: "min-h-screen bg-gradient-to-br from-indigo-50 via-white to-purple-50 flex items-center justify-center p-4" },
|
|
150
|
+
React.createElement("div", { className: "w-full max-w-md" },
|
|
151
|
+
React.createElement("div", { className: "bg-white rounded-2xl shadow-2xl p-8" },
|
|
152
|
+
React.createElement("div", { className: "mb-8" },
|
|
153
|
+
React.createElement("div", { className: "flex justify-between mb-2" }, ['welcome', 'auth', 'wallet-created', ...(showBuyUSDC ? ['buy-usdc'] : []), 'complete'].map((step, index) => (React.createElement("div", { key: step, className: `h-2 flex-1 mx-1 rounded-full transition-all ${['welcome', 'auth', 'wallet-created', ...(showBuyUSDC ? ['buy-usdc'] : []), 'complete'].indexOf(currentStep) >= index
|
|
154
|
+
? 'bg-gradient-to-r from-indigo-600 to-purple-600'
|
|
155
|
+
: 'bg-gray-200'}` }))))),
|
|
156
|
+
renderStep()),
|
|
157
|
+
React.createElement("p", { className: "text-center text-xs text-gray-500 mt-6" }, "Powered by Varity \u2022 Secure \u2022 Decentralized"))));
|
|
158
|
+
}
|
|
159
|
+
//# sourceMappingURL=OnboardingFlow.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"OnboardingFlow.js","sourceRoot":"","sources":["../../../src/components/InAppWallet/OnboardingFlow.tsx"],"names":[],"mappings":"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"}
|
|
@@ -0,0 +1,28 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SocialLoginButtons - Social OAuth Authentication Buttons
|
|
3
|
+
*
|
|
4
|
+
* Provides one-click social login via Google, Apple, Facebook
|
|
5
|
+
* Automatically creates custodial wallets for users
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```tsx
|
|
9
|
+
* <SocialLoginButtons
|
|
10
|
+
* providers={['google', 'apple', 'facebook']}
|
|
11
|
+
* onSuccess={(user) => console.log('Logged in:', user)}
|
|
12
|
+
* />
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
15
|
+
import React from 'react';
|
|
16
|
+
type SocialProvider = 'google' | 'apple' | 'facebook' | 'discord' | 'twitter';
|
|
17
|
+
interface SocialLoginButtonsProps {
|
|
18
|
+
providers?: SocialProvider[];
|
|
19
|
+
onSuccess?: (provider: SocialProvider) => void;
|
|
20
|
+
onError?: (error: Error) => void;
|
|
21
|
+
layout?: 'horizontal' | 'vertical' | 'grid';
|
|
22
|
+
showDivider?: boolean;
|
|
23
|
+
dividerText?: string;
|
|
24
|
+
size?: 'sm' | 'md' | 'lg';
|
|
25
|
+
}
|
|
26
|
+
export declare function SocialLoginButtons({ providers, onSuccess, onError, layout, showDivider, dividerText, size, }: SocialLoginButtonsProps): React.JSX.Element;
|
|
27
|
+
export {};
|
|
28
|
+
//# sourceMappingURL=SocialLoginButtons.d.ts.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SocialLoginButtons.d.ts","sourceRoot":"","sources":["../../../src/components/InAppWallet/SocialLoginButtons.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;GAaG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,KAAK,cAAc,GAAG,QAAQ,GAAG,OAAO,GAAG,UAAU,GAAG,SAAS,GAAG,SAAS,CAAC;AAE9E,UAAU,uBAAuB;IAC/B,SAAS,CAAC,EAAE,cAAc,EAAE,CAAC;IAC7B,SAAS,CAAC,EAAE,CAAC,QAAQ,EAAE,cAAc,KAAK,IAAI,CAAC;IAC/C,OAAO,CAAC,EAAE,CAAC,KAAK,EAAE,KAAK,KAAK,IAAI,CAAC;IACjC,MAAM,CAAC,EAAE,YAAY,GAAG,UAAU,GAAG,MAAM,CAAC;IAC5C,WAAW,CAAC,EAAE,OAAO,CAAC;IACtB,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,IAAI,CAAC,EAAE,IAAI,GAAG,IAAI,GAAG,IAAI,CAAC;CAC3B;AA2ED,wBAAgB,kBAAkB,CAAC,EACjC,SAA2C,EAC3C,SAAS,EACT,OAAO,EACP,MAAmB,EACnB,WAAkB,EAClB,WAAgC,EAChC,IAAW,GACZ,EAAE,uBAAuB,qBAwGzB"}
|
|
@@ -0,0 +1,128 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* SocialLoginButtons - Social OAuth Authentication Buttons
|
|
3
|
+
*
|
|
4
|
+
* Provides one-click social login via Google, Apple, Facebook
|
|
5
|
+
* Automatically creates custodial wallets for users
|
|
6
|
+
*
|
|
7
|
+
* @example
|
|
8
|
+
* ```tsx
|
|
9
|
+
* <SocialLoginButtons
|
|
10
|
+
* providers={['google', 'apple', 'facebook']}
|
|
11
|
+
* onSuccess={(user) => console.log('Logged in:', user)}
|
|
12
|
+
* />
|
|
13
|
+
* ```
|
|
14
|
+
*/
|
|
15
|
+
import React from 'react';
|
|
16
|
+
import { useInAppWallet } from './InAppWalletProvider';
|
|
17
|
+
import { getErrorMessage } from '@varity-labs/types';
|
|
18
|
+
const providerConfig = {
|
|
19
|
+
google: {
|
|
20
|
+
name: 'Google',
|
|
21
|
+
icon: (React.createElement("svg", { className: "w-5 h-5", viewBox: "0 0 24 24" },
|
|
22
|
+
React.createElement("path", { fill: "currentColor", d: "M22.56 12.25c0-.78-.07-1.53-.2-2.25H12v4.26h5.92c-.26 1.37-1.04 2.53-2.21 3.31v2.77h3.57c2.08-1.92 3.28-4.74 3.28-8.09z" }),
|
|
23
|
+
React.createElement("path", { fill: "currentColor", d: "M12 23c2.97 0 5.46-.98 7.28-2.66l-3.57-2.77c-.98.66-2.23 1.06-3.71 1.06-2.86 0-5.29-1.93-6.16-4.53H2.18v2.84C3.99 20.53 7.7 23 12 23z" }),
|
|
24
|
+
React.createElement("path", { fill: "currentColor", d: "M5.84 14.09c-.22-.66-.35-1.36-.35-2.09s.13-1.43.35-2.09V7.07H2.18C1.43 8.55 1 10.22 1 12s.43 3.45 1.18 4.93l2.85-2.22.81-.62z" }),
|
|
25
|
+
React.createElement("path", { fill: "currentColor", d: "M12 5.38c1.62 0 3.06.56 4.21 1.64l3.15-3.15C17.45 2.09 14.97 1 12 1 7.7 1 3.99 3.47 2.18 7.07l3.66 2.84c.87-2.6 3.3-4.53 6.16-4.53z" }))),
|
|
26
|
+
bgColor: 'bg-white hover:bg-gray-50',
|
|
27
|
+
textColor: 'text-gray-700',
|
|
28
|
+
borderColor: 'border-gray-300',
|
|
29
|
+
},
|
|
30
|
+
apple: {
|
|
31
|
+
name: 'Apple',
|
|
32
|
+
icon: (React.createElement("svg", { className: "w-5 h-5", fill: "currentColor", viewBox: "0 0 24 24" },
|
|
33
|
+
React.createElement("path", { d: "M17.05 20.28c-.98.95-2.05.8-3.08.35-1.09-.46-2.09-.48-3.24 0-1.44.62-2.2.44-3.06-.35C2.79 15.25 3.51 7.59 9.05 7.31c1.35.07 2.29.74 3.08.8 1.18-.24 2.31-.93 3.57-.84 1.51.12 2.65.72 3.4 1.8-3.12 1.87-2.38 5.98.48 7.13-.57 1.5-1.31 2.99-2.54 4.09l.01-.01zM12.03 7.25c-.15-2.23 1.66-4.07 3.74-4.25.29 2.58-2.34 4.5-3.74 4.25z" }))),
|
|
34
|
+
bgColor: 'bg-black hover:bg-gray-900',
|
|
35
|
+
textColor: 'text-white',
|
|
36
|
+
borderColor: 'border-black',
|
|
37
|
+
},
|
|
38
|
+
facebook: {
|
|
39
|
+
name: 'Facebook',
|
|
40
|
+
icon: (React.createElement("svg", { className: "w-5 h-5", fill: "currentColor", viewBox: "0 0 24 24" },
|
|
41
|
+
React.createElement("path", { d: "M24 12.073c0-6.627-5.373-12-12-12s-12 5.373-12 12c0 5.99 4.388 10.954 10.125 11.854v-8.385H7.078v-3.47h3.047V9.43c0-3.007 1.792-4.669 4.533-4.669 1.312 0 2.686.235 2.686.235v2.953H15.83c-1.491 0-1.956.925-1.956 1.874v2.25h3.328l-.532 3.47h-2.796v8.385C19.612 23.027 24 18.062 24 12.073z" }))),
|
|
42
|
+
bgColor: 'bg-[#1877F2] hover:bg-[#166FE5]',
|
|
43
|
+
textColor: 'text-white',
|
|
44
|
+
borderColor: 'border-[#1877F2]',
|
|
45
|
+
},
|
|
46
|
+
discord: {
|
|
47
|
+
name: 'Discord',
|
|
48
|
+
icon: (React.createElement("svg", { className: "w-5 h-5", fill: "currentColor", viewBox: "0 0 24 24" },
|
|
49
|
+
React.createElement("path", { d: "M20.317 4.492c-1.53-.69-3.17-1.2-4.885-1.49a.075.075 0 0 0-.079.036c-.21.369-.444.85-.608 1.23a18.566 18.566 0 0 0-5.487 0 12.36 12.36 0 0 0-.617-1.23A.077.077 0 0 0 8.562 3c-1.714.29-3.354.8-4.885 1.491a.07.07 0 0 0-.032.027C.533 9.093-.32 13.555.099 17.961a.08.08 0 0 0 .031.055 20.03 20.03 0 0 0 5.993 2.98.078.078 0 0 0 .084-.026 13.83 13.83 0 0 0 1.226-1.963.074.074 0 0 0-.041-.104 13.201 13.201 0 0 1-1.872-.878.075.075 0 0 1-.008-.125c.126-.093.252-.19.372-.287a.075.075 0 0 1 .078-.01c3.927 1.764 8.18 1.764 12.061 0a.075.075 0 0 1 .079.009c.12.098.245.195.372.288a.075.075 0 0 1-.006.125c-.598.344-1.22.635-1.873.877a.075.075 0 0 0-.041.105c.36.687.772 1.341 1.225 1.962a.077.077 0 0 0 .084.028 19.963 19.963 0 0 0 6.002-2.981.076.076 0 0 0 .032-.054c.5-5.094-.838-9.52-3.549-13.442a.06.06 0 0 0-.031-.028zM8.02 15.278c-1.182 0-2.157-1.069-2.157-2.38 0-1.312.956-2.38 2.157-2.38 1.21 0 2.176 1.077 2.157 2.38 0 1.312-.956 2.38-2.157 2.38zm7.975 0c-1.183 0-2.157-1.069-2.157-2.38 0-1.312.955-2.38 2.157-2.38 1.21 0 2.176 1.077 2.157 2.38 0 1.312-.946 2.38-2.157 2.38z" }))),
|
|
50
|
+
bgColor: 'bg-[#5865F2] hover:bg-[#4752C4]',
|
|
51
|
+
textColor: 'text-white',
|
|
52
|
+
borderColor: 'border-[#5865F2]',
|
|
53
|
+
},
|
|
54
|
+
twitter: {
|
|
55
|
+
name: 'Twitter',
|
|
56
|
+
icon: (React.createElement("svg", { className: "w-5 h-5", fill: "currentColor", viewBox: "0 0 24 24" },
|
|
57
|
+
React.createElement("path", { d: "M23.953 4.57a10 10 0 01-2.825.775 4.958 4.958 0 002.163-2.723c-.951.555-2.005.959-3.127 1.184a4.92 4.92 0 00-8.384 4.482C7.69 8.095 4.067 6.13 1.64 3.162a4.822 4.822 0 00-.666 2.475c0 1.71.87 3.213 2.188 4.096a4.904 4.904 0 01-2.228-.616v.06a4.923 4.923 0 003.946 4.827 4.996 4.996 0 01-2.212.085 4.936 4.936 0 004.604 3.417 9.867 9.867 0 01-6.102 2.105c-.39 0-.779-.023-1.17-.067a13.995 13.995 0 007.557 2.209c9.053 0 13.998-7.496 13.998-13.985 0-.21 0-.42-.015-.63A9.935 9.935 0 0024 4.59z" }))),
|
|
58
|
+
bgColor: 'bg-[#1DA1F2] hover:bg-[#1A8CD8]',
|
|
59
|
+
textColor: 'text-white',
|
|
60
|
+
borderColor: 'border-[#1DA1F2]',
|
|
61
|
+
},
|
|
62
|
+
};
|
|
63
|
+
export function SocialLoginButtons({ providers = ['google', 'apple', 'facebook'], onSuccess, onError, layout = 'vertical', showDivider = true, dividerText = 'or continue with', size = 'md', }) {
|
|
64
|
+
const { loginWithGoogle, loginWithApple, loginWithFacebook, isLoading } = useInAppWallet();
|
|
65
|
+
const handleLogin = async (provider) => {
|
|
66
|
+
try {
|
|
67
|
+
switch (provider) {
|
|
68
|
+
case 'google':
|
|
69
|
+
await loginWithGoogle();
|
|
70
|
+
break;
|
|
71
|
+
case 'apple':
|
|
72
|
+
await loginWithApple();
|
|
73
|
+
break;
|
|
74
|
+
case 'facebook':
|
|
75
|
+
await loginWithFacebook();
|
|
76
|
+
break;
|
|
77
|
+
default:
|
|
78
|
+
throw new Error(`Provider ${provider} not implemented`);
|
|
79
|
+
}
|
|
80
|
+
onSuccess?.(provider);
|
|
81
|
+
}
|
|
82
|
+
catch (error) {
|
|
83
|
+
const errorMessage = getErrorMessage(error);
|
|
84
|
+
console.error(`${provider} login error:`, errorMessage);
|
|
85
|
+
const errorObj = error instanceof Error ? error : new Error(errorMessage);
|
|
86
|
+
onError?.(errorObj);
|
|
87
|
+
}
|
|
88
|
+
};
|
|
89
|
+
const sizeClasses = {
|
|
90
|
+
sm: 'px-4 py-2 text-sm',
|
|
91
|
+
md: 'px-6 py-3 text-base',
|
|
92
|
+
lg: 'px-8 py-4 text-lg',
|
|
93
|
+
};
|
|
94
|
+
const layoutClasses = {
|
|
95
|
+
horizontal: 'flex flex-row gap-3',
|
|
96
|
+
vertical: 'flex flex-col gap-3',
|
|
97
|
+
grid: 'grid grid-cols-2 gap-3',
|
|
98
|
+
};
|
|
99
|
+
return (React.createElement("div", { className: "w-full" },
|
|
100
|
+
showDivider && (React.createElement("div", { className: "relative my-6" },
|
|
101
|
+
React.createElement("div", { className: "absolute inset-0 flex items-center" },
|
|
102
|
+
React.createElement("div", { className: "w-full border-t border-gray-300" })),
|
|
103
|
+
React.createElement("div", { className: "relative flex justify-center text-sm" },
|
|
104
|
+
React.createElement("span", { className: "bg-white px-4 text-gray-500" }, dividerText)))),
|
|
105
|
+
React.createElement("div", { className: layoutClasses[layout] }, providers.map((provider) => {
|
|
106
|
+
const config = providerConfig[provider];
|
|
107
|
+
if (!config)
|
|
108
|
+
return null;
|
|
109
|
+
return (React.createElement("button", { key: provider, onClick: () => handleLogin(provider), disabled: isLoading, className: `
|
|
110
|
+
${config.bgColor}
|
|
111
|
+
${config.textColor}
|
|
112
|
+
${sizeClasses[size]}
|
|
113
|
+
border ${config.borderColor}
|
|
114
|
+
rounded-lg font-medium
|
|
115
|
+
flex items-center justify-center gap-2
|
|
116
|
+
transition-all duration-200
|
|
117
|
+
disabled:opacity-50 disabled:cursor-not-allowed
|
|
118
|
+
shadow-sm hover:shadow-md
|
|
119
|
+
` },
|
|
120
|
+
isLoading ? (React.createElement("svg", { className: "animate-spin h-5 w-5", fill: "none", viewBox: "0 0 24 24" },
|
|
121
|
+
React.createElement("circle", { className: "opacity-25", cx: "12", cy: "12", r: "10", stroke: "currentColor", strokeWidth: "4" }),
|
|
122
|
+
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" }))) : (config.icon),
|
|
123
|
+
React.createElement("span", null,
|
|
124
|
+
"Continue with ",
|
|
125
|
+
config.name)));
|
|
126
|
+
}))));
|
|
127
|
+
}
|
|
128
|
+
//# sourceMappingURL=SocialLoginButtons.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"SocialLoginButtons.js","sourceRoot":"","sources":["../../../src/components/InAppWallet/SocialLoginButtons.tsx"],"names":[],"mappings":"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"}
|