@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.
Files changed (495) hide show
  1. package/LICENSE +31 -0
  2. package/README.md +248 -0
  3. package/dist/components/AI/ChatbotWidget.d.ts +53 -0
  4. package/dist/components/AI/ChatbotWidget.d.ts.map +1 -0
  5. package/dist/components/AI/ChatbotWidget.js +126 -0
  6. package/dist/components/AI/ChatbotWidget.js.map +1 -0
  7. package/dist/components/AI/InputBar.d.ts +25 -0
  8. package/dist/components/AI/InputBar.d.ts.map +1 -0
  9. package/dist/components/AI/InputBar.js +126 -0
  10. package/dist/components/AI/InputBar.js.map +1 -0
  11. package/dist/components/AI/MessageBubble.d.ts +37 -0
  12. package/dist/components/AI/MessageBubble.d.ts.map +1 -0
  13. package/dist/components/AI/MessageBubble.js +124 -0
  14. package/dist/components/AI/MessageBubble.js.map +1 -0
  15. package/dist/components/AI/index.d.ts +12 -0
  16. package/dist/components/AI/index.d.ts.map +1 -0
  17. package/dist/components/AI/index.js +9 -0
  18. package/dist/components/AI/index.js.map +1 -0
  19. package/dist/components/Analytics/AnalyticsCard.d.ts +48 -0
  20. package/dist/components/Analytics/AnalyticsCard.d.ts.map +1 -0
  21. package/dist/components/Analytics/AnalyticsCard.js +156 -0
  22. package/dist/components/Analytics/AnalyticsCard.js.map +1 -0
  23. package/dist/components/Analytics/ChartContainer.d.ts +53 -0
  24. package/dist/components/Analytics/ChartContainer.d.ts.map +1 -0
  25. package/dist/components/Analytics/ChartContainer.js +128 -0
  26. package/dist/components/Analytics/ChartContainer.js.map +1 -0
  27. package/dist/components/Analytics/DataTable.d.ts +62 -0
  28. package/dist/components/Analytics/DataTable.d.ts.map +1 -0
  29. package/dist/components/Analytics/DataTable.js +165 -0
  30. package/dist/components/Analytics/DataTable.js.map +1 -0
  31. package/dist/components/Analytics/MetricDisplay.d.ts +42 -0
  32. package/dist/components/Analytics/MetricDisplay.d.ts.map +1 -0
  33. package/dist/components/Analytics/MetricDisplay.js +110 -0
  34. package/dist/components/Analytics/MetricDisplay.js.map +1 -0
  35. package/dist/components/Analytics/index.d.ts +14 -0
  36. package/dist/components/Analytics/index.d.ts.map +1 -0
  37. package/dist/components/Analytics/index.js +10 -0
  38. package/dist/components/Analytics/index.js.map +1 -0
  39. package/dist/components/Branding/Attribution.d.ts +39 -0
  40. package/dist/components/Branding/Attribution.d.ts.map +1 -0
  41. package/dist/components/Branding/Attribution.js +124 -0
  42. package/dist/components/Branding/Attribution.js.map +1 -0
  43. package/dist/components/Branding/Logo.d.ts +39 -0
  44. package/dist/components/Branding/Logo.d.ts.map +1 -0
  45. package/dist/components/Branding/Logo.js +67 -0
  46. package/dist/components/Branding/Logo.js.map +1 -0
  47. package/dist/components/Branding/ThemeProvider.d.ts +85 -0
  48. package/dist/components/Branding/ThemeProvider.d.ts.map +1 -0
  49. package/dist/components/Branding/ThemeProvider.js +186 -0
  50. package/dist/components/Branding/ThemeProvider.js.map +1 -0
  51. package/dist/components/Branding/index.d.ts +12 -0
  52. package/dist/components/Branding/index.d.ts.map +1 -0
  53. package/dist/components/Branding/index.js +9 -0
  54. package/dist/components/Branding/index.js.map +1 -0
  55. package/dist/components/Dashboard/DashboardFooter.d.ts +30 -0
  56. package/dist/components/Dashboard/DashboardFooter.d.ts.map +1 -0
  57. package/dist/components/Dashboard/DashboardFooter.js +68 -0
  58. package/dist/components/Dashboard/DashboardFooter.js.map +1 -0
  59. package/dist/components/Dashboard/DashboardHeader.d.ts +24 -0
  60. package/dist/components/Dashboard/DashboardHeader.d.ts.map +1 -0
  61. package/dist/components/Dashboard/DashboardHeader.js +87 -0
  62. package/dist/components/Dashboard/DashboardHeader.js.map +1 -0
  63. package/dist/components/Dashboard/DashboardLayout.d.ts +71 -0
  64. package/dist/components/Dashboard/DashboardLayout.d.ts.map +1 -0
  65. package/dist/components/Dashboard/DashboardLayout.js +52 -0
  66. package/dist/components/Dashboard/DashboardLayout.js.map +1 -0
  67. package/dist/components/Dashboard/DashboardSidebar.d.ts +26 -0
  68. package/dist/components/Dashboard/DashboardSidebar.d.ts.map +1 -0
  69. package/dist/components/Dashboard/DashboardSidebar.js +146 -0
  70. package/dist/components/Dashboard/DashboardSidebar.js.map +1 -0
  71. package/dist/components/Dashboard/EmptyState.d.ts +84 -0
  72. package/dist/components/Dashboard/EmptyState.d.ts.map +1 -0
  73. package/dist/components/Dashboard/EmptyState.js +99 -0
  74. package/dist/components/Dashboard/EmptyState.js.map +1 -0
  75. package/dist/components/Dashboard/KPICard.d.ts +58 -0
  76. package/dist/components/Dashboard/KPICard.d.ts.map +1 -0
  77. package/dist/components/Dashboard/KPICard.js +82 -0
  78. package/dist/components/Dashboard/KPICard.js.map +1 -0
  79. package/dist/components/Dashboard/LoadingSkeleton.d.ts +58 -0
  80. package/dist/components/Dashboard/LoadingSkeleton.d.ts.map +1 -0
  81. package/dist/components/Dashboard/LoadingSkeleton.js +105 -0
  82. package/dist/components/Dashboard/LoadingSkeleton.js.map +1 -0
  83. package/dist/components/Dashboard/StatusBadge.d.ts +57 -0
  84. package/dist/components/Dashboard/StatusBadge.d.ts.map +1 -0
  85. package/dist/components/Dashboard/StatusBadge.js +149 -0
  86. package/dist/components/Dashboard/StatusBadge.js.map +1 -0
  87. package/dist/components/Dashboard/index.d.ts +19 -0
  88. package/dist/components/Dashboard/index.d.ts.map +1 -0
  89. package/dist/components/Dashboard/index.js +18 -0
  90. package/dist/components/Dashboard/index.js.map +1 -0
  91. package/dist/components/InAppWallet/EmailLoginButton.d.ts +27 -0
  92. package/dist/components/InAppWallet/EmailLoginButton.d.ts.map +1 -0
  93. package/dist/components/InAppWallet/EmailLoginButton.js +84 -0
  94. package/dist/components/InAppWallet/EmailLoginButton.js.map +1 -0
  95. package/dist/components/InAppWallet/InAppWalletProvider.d.ts +54 -0
  96. package/dist/components/InAppWallet/InAppWalletProvider.d.ts.map +1 -0
  97. package/dist/components/InAppWallet/InAppWalletProvider.js +238 -0
  98. package/dist/components/InAppWallet/InAppWalletProvider.js.map +1 -0
  99. package/dist/components/InAppWallet/OnboardingFlow.d.ts +25 -0
  100. package/dist/components/InAppWallet/OnboardingFlow.d.ts.map +1 -0
  101. package/dist/components/InAppWallet/OnboardingFlow.js +159 -0
  102. package/dist/components/InAppWallet/OnboardingFlow.js.map +1 -0
  103. package/dist/components/InAppWallet/SocialLoginButtons.d.ts +28 -0
  104. package/dist/components/InAppWallet/SocialLoginButtons.d.ts.map +1 -0
  105. package/dist/components/InAppWallet/SocialLoginButtons.js +128 -0
  106. package/dist/components/InAppWallet/SocialLoginButtons.js.map +1 -0
  107. package/dist/components/InAppWallet/index.d.ts +15 -0
  108. package/dist/components/InAppWallet/index.d.ts.map +1 -0
  109. package/dist/components/InAppWallet/index.js +14 -0
  110. package/dist/components/InAppWallet/index.js.map +1 -0
  111. package/dist/components/Onramp/BuyUSDCButton.d.ts +27 -0
  112. package/dist/components/Onramp/BuyUSDCButton.d.ts.map +1 -0
  113. package/dist/components/Onramp/BuyUSDCButton.js +70 -0
  114. package/dist/components/Onramp/BuyUSDCButton.js.map +1 -0
  115. package/dist/components/Onramp/OnrampWidget.d.ts +38 -0
  116. package/dist/components/Onramp/OnrampWidget.d.ts.map +1 -0
  117. package/dist/components/Onramp/OnrampWidget.js +105 -0
  118. package/dist/components/Onramp/OnrampWidget.js.map +1 -0
  119. package/dist/components/Onramp/index.d.ts +14 -0
  120. package/dist/components/Onramp/index.d.ts.map +1 -0
  121. package/dist/components/Onramp/index.js +12 -0
  122. package/dist/components/Onramp/index.js.map +1 -0
  123. package/dist/components/Payments/CheckoutModal.d.ts +19 -0
  124. package/dist/components/Payments/CheckoutModal.d.ts.map +1 -0
  125. package/dist/components/Payments/CheckoutModal.js +183 -0
  126. package/dist/components/Payments/CheckoutModal.js.map +1 -0
  127. package/dist/components/Payments/SubscriptionWidget.d.ts +17 -0
  128. package/dist/components/Payments/SubscriptionWidget.d.ts.map +1 -0
  129. package/dist/components/Payments/SubscriptionWidget.js +89 -0
  130. package/dist/components/Payments/SubscriptionWidget.js.map +1 -0
  131. package/dist/components/Payments/constants.d.ts +59 -0
  132. package/dist/components/Payments/constants.d.ts.map +1 -0
  133. package/dist/components/Payments/constants.js +145 -0
  134. package/dist/components/Payments/constants.js.map +1 -0
  135. package/dist/components/Payments/index.d.ts +10 -0
  136. package/dist/components/Payments/index.d.ts.map +1 -0
  137. package/dist/components/Payments/index.js +12 -0
  138. package/dist/components/Payments/index.js.map +1 -0
  139. package/dist/components/Payments/types.d.ts +119 -0
  140. package/dist/components/Payments/types.d.ts.map +1 -0
  141. package/dist/components/Payments/types.js +27 -0
  142. package/dist/components/Payments/types.js.map +1 -0
  143. package/dist/components/Payments/usePayments.d.ts +33 -0
  144. package/dist/components/Payments/usePayments.d.ts.map +1 -0
  145. package/dist/components/Payments/usePayments.js +249 -0
  146. package/dist/components/Payments/usePayments.js.map +1 -0
  147. package/dist/components/Privy/InitTimeoutScreen.d.ts +62 -0
  148. package/dist/components/Privy/InitTimeoutScreen.d.ts.map +1 -0
  149. package/dist/components/Privy/InitTimeoutScreen.js +64 -0
  150. package/dist/components/Privy/InitTimeoutScreen.js.map +1 -0
  151. package/dist/components/Privy/InitializingScreen.d.ts +56 -0
  152. package/dist/components/Privy/InitializingScreen.d.ts.map +1 -0
  153. package/dist/components/Privy/InitializingScreen.js +60 -0
  154. package/dist/components/Privy/InitializingScreen.js.map +1 -0
  155. package/dist/components/Privy/PrivyLoginButton.d.ts +27 -0
  156. package/dist/components/Privy/PrivyLoginButton.d.ts.map +1 -0
  157. package/dist/components/Privy/PrivyLoginButton.js +48 -0
  158. package/dist/components/Privy/PrivyLoginButton.js.map +1 -0
  159. package/dist/components/Privy/PrivyProtectedRoute.d.ts +22 -0
  160. package/dist/components/Privy/PrivyProtectedRoute.d.ts.map +1 -0
  161. package/dist/components/Privy/PrivyProtectedRoute.js +46 -0
  162. package/dist/components/Privy/PrivyProtectedRoute.js.map +1 -0
  163. package/dist/components/Privy/PrivyReadyGate.d.ts +69 -0
  164. package/dist/components/Privy/PrivyReadyGate.d.ts.map +1 -0
  165. package/dist/components/Privy/PrivyReadyGate.js +83 -0
  166. package/dist/components/Privy/PrivyReadyGate.js.map +1 -0
  167. package/dist/components/Privy/PrivyUserProfile.d.ts +25 -0
  168. package/dist/components/Privy/PrivyUserProfile.d.ts.map +1 -0
  169. package/dist/components/Privy/PrivyUserProfile.js +98 -0
  170. package/dist/components/Privy/PrivyUserProfile.js.map +1 -0
  171. package/dist/components/Privy/index.d.ts +21 -0
  172. package/dist/components/Privy/index.d.ts.map +1 -0
  173. package/dist/components/Privy/index.js +16 -0
  174. package/dist/components/Privy/index.js.map +1 -0
  175. package/dist/components/SIWE/AuthStatus.d.ts +15 -0
  176. package/dist/components/SIWE/AuthStatus.d.ts.map +1 -0
  177. package/dist/components/SIWE/AuthStatus.js +47 -0
  178. package/dist/components/SIWE/AuthStatus.js.map +1 -0
  179. package/dist/components/SIWE/ProtectedRoute.d.ts +17 -0
  180. package/dist/components/SIWE/ProtectedRoute.d.ts.map +1 -0
  181. package/dist/components/SIWE/ProtectedRoute.js +52 -0
  182. package/dist/components/SIWE/ProtectedRoute.js.map +1 -0
  183. package/dist/components/SIWE/SIWEButton.d.ts +22 -0
  184. package/dist/components/SIWE/SIWEButton.d.ts.map +1 -0
  185. package/dist/components/SIWE/SIWEButton.js +106 -0
  186. package/dist/components/SIWE/SIWEButton.js.map +1 -0
  187. package/dist/components/SIWE/SIWEModal.d.ts +19 -0
  188. package/dist/components/SIWE/SIWEModal.d.ts.map +1 -0
  189. package/dist/components/SIWE/SIWEModal.js +75 -0
  190. package/dist/components/SIWE/SIWEModal.js.map +1 -0
  191. package/dist/components/SIWE/SIWEProvider.d.ts +38 -0
  192. package/dist/components/SIWE/SIWEProvider.d.ts.map +1 -0
  193. package/dist/components/SIWE/SIWEProvider.js +227 -0
  194. package/dist/components/SIWE/SIWEProvider.js.map +1 -0
  195. package/dist/components/SIWE/index.d.ts +15 -0
  196. package/dist/components/SIWE/index.d.ts.map +1 -0
  197. package/dist/components/SIWE/index.js +10 -0
  198. package/dist/components/SIWE/index.js.map +1 -0
  199. package/dist/components/index.d.ts +11 -0
  200. package/dist/components/index.d.ts.map +1 -0
  201. package/dist/components/index.js +16 -0
  202. package/dist/components/index.js.map +1 -0
  203. package/dist/components/templates/Finance/FinanceDashboard.d.ts +15 -0
  204. package/dist/components/templates/Finance/FinanceDashboard.d.ts.map +1 -0
  205. package/dist/components/templates/Finance/FinanceDashboard.js +112 -0
  206. package/dist/components/templates/Finance/FinanceDashboard.js.map +1 -0
  207. package/dist/components/templates/Healthcare/HealthcareDashboard.d.ts +15 -0
  208. package/dist/components/templates/Healthcare/HealthcareDashboard.d.ts.map +1 -0
  209. package/dist/components/templates/Healthcare/HealthcareDashboard.js +121 -0
  210. package/dist/components/templates/Healthcare/HealthcareDashboard.js.map +1 -0
  211. package/dist/components/templates/ISO/ISODashboard.d.ts +15 -0
  212. package/dist/components/templates/ISO/ISODashboard.d.ts.map +1 -0
  213. package/dist/components/templates/ISO/ISODashboard.js +184 -0
  214. package/dist/components/templates/ISO/ISODashboard.js.map +1 -0
  215. package/dist/components/templates/Retail/RetailDashboard.d.ts +15 -0
  216. package/dist/components/templates/Retail/RetailDashboard.d.ts.map +1 -0
  217. package/dist/components/templates/Retail/RetailDashboard.js +151 -0
  218. package/dist/components/templates/Retail/RetailDashboard.js.map +1 -0
  219. package/dist/components/templates/index.d.ts +14 -0
  220. package/dist/components/templates/index.d.ts.map +1 -0
  221. package/dist/components/templates/index.js +14 -0
  222. package/dist/components/templates/index.js.map +1 -0
  223. package/dist/config/chains.d.ts +23 -0
  224. package/dist/config/chains.d.ts.map +1 -0
  225. package/dist/config/chains.js +55 -0
  226. package/dist/config/chains.js.map +1 -0
  227. package/dist/core/VarityClient.d.ts +76 -0
  228. package/dist/core/VarityClient.d.ts.map +1 -0
  229. package/dist/core/VarityClient.js +99 -0
  230. package/dist/core/VarityClient.js.map +1 -0
  231. package/dist/core/config.d.ts +136 -0
  232. package/dist/core/config.d.ts.map +1 -0
  233. package/dist/core/config.js +156 -0
  234. package/dist/core/config.js.map +1 -0
  235. package/dist/hooks/index.d.ts +17 -0
  236. package/dist/hooks/index.d.ts.map +1 -0
  237. package/dist/hooks/index.js +18 -0
  238. package/dist/hooks/index.js.map +1 -0
  239. package/dist/hooks/useAnalytics.d.ts +94 -0
  240. package/dist/hooks/useAnalytics.d.ts.map +1 -0
  241. package/dist/hooks/useAnalytics.js +116 -0
  242. package/dist/hooks/useAnalytics.js.map +1 -0
  243. package/dist/hooks/useAuth.d.ts +71 -0
  244. package/dist/hooks/useAuth.d.ts.map +1 -0
  245. package/dist/hooks/useAuth.js +198 -0
  246. package/dist/hooks/useAuth.js.map +1 -0
  247. package/dist/hooks/useDashboard.d.ts +110 -0
  248. package/dist/hooks/useDashboard.d.ts.map +1 -0
  249. package/dist/hooks/useDashboard.js +201 -0
  250. package/dist/hooks/useDashboard.js.map +1 -0
  251. package/dist/hooks/useVarityAPI.d.ts +88 -0
  252. package/dist/hooks/useVarityAPI.d.ts.map +1 -0
  253. package/dist/hooks/useVarityAPI.js +138 -0
  254. package/dist/hooks/useVarityAPI.js.map +1 -0
  255. package/dist/hooks/useWalletAuth.d.ts +108 -0
  256. package/dist/hooks/useWalletAuth.d.ts.map +1 -0
  257. package/dist/hooks/useWalletAuth.js +415 -0
  258. package/dist/hooks/useWalletAuth.js.map +1 -0
  259. package/dist/hooks/web3/index.d.ts +5 -0
  260. package/dist/hooks/web3/index.d.ts.map +1 -0
  261. package/dist/hooks/web3/index.js +6 -0
  262. package/dist/hooks/web3/index.js.map +1 -0
  263. package/dist/hooks/web3/useAddressValidation.d.ts +37 -0
  264. package/dist/hooks/web3/useAddressValidation.d.ts.map +1 -0
  265. package/dist/hooks/web3/useAddressValidation.js +59 -0
  266. package/dist/hooks/web3/useAddressValidation.js.map +1 -0
  267. package/dist/hooks/web3/useBlockExplorer.d.ts +37 -0
  268. package/dist/hooks/web3/useBlockExplorer.d.ts.map +1 -0
  269. package/dist/hooks/web3/useBlockExplorer.js +59 -0
  270. package/dist/hooks/web3/useBlockExplorer.js.map +1 -0
  271. package/dist/hooks/web3/useUSDCFormat.d.ts +34 -0
  272. package/dist/hooks/web3/useUSDCFormat.d.ts.map +1 -0
  273. package/dist/hooks/web3/useUSDCFormat.js +43 -0
  274. package/dist/hooks/web3/useUSDCFormat.js.map +1 -0
  275. package/dist/hooks/web3/useVarityWallet.d.ts +48 -0
  276. package/dist/hooks/web3/useVarityWallet.d.ts.map +1 -0
  277. package/dist/hooks/web3/useVarityWallet.js +70 -0
  278. package/dist/hooks/web3/useVarityWallet.js.map +1 -0
  279. package/dist/index.d.ts +55 -0
  280. package/dist/index.d.ts.map +1 -0
  281. package/dist/index.js +68 -0
  282. package/dist/index.js.map +1 -0
  283. package/dist/modules/analytics/AnalyticsClient.d.ts +72 -0
  284. package/dist/modules/analytics/AnalyticsClient.d.ts.map +1 -0
  285. package/dist/modules/analytics/AnalyticsClient.js +56 -0
  286. package/dist/modules/analytics/AnalyticsClient.js.map +1 -0
  287. package/dist/modules/analytics/index.d.ts +2 -0
  288. package/dist/modules/analytics/index.d.ts.map +1 -0
  289. package/dist/modules/analytics/index.js +2 -0
  290. package/dist/modules/analytics/index.js.map +1 -0
  291. package/dist/modules/auth/AuthClient.d.ts +41 -0
  292. package/dist/modules/auth/AuthClient.d.ts.map +1 -0
  293. package/dist/modules/auth/AuthClient.js +36 -0
  294. package/dist/modules/auth/AuthClient.js.map +1 -0
  295. package/dist/modules/auth/index.d.ts +2 -0
  296. package/dist/modules/auth/index.d.ts.map +1 -0
  297. package/dist/modules/auth/index.js +2 -0
  298. package/dist/modules/auth/index.js.map +1 -0
  299. package/dist/modules/cache/CacheClient.d.ts +48 -0
  300. package/dist/modules/cache/CacheClient.d.ts.map +1 -0
  301. package/dist/modules/cache/CacheClient.js +59 -0
  302. package/dist/modules/cache/CacheClient.js.map +1 -0
  303. package/dist/modules/cache/index.d.ts +2 -0
  304. package/dist/modules/cache/index.d.ts.map +1 -0
  305. package/dist/modules/cache/index.js +2 -0
  306. package/dist/modules/cache/index.js.map +1 -0
  307. package/dist/modules/compute/ComputeClient.d.ts +54 -0
  308. package/dist/modules/compute/ComputeClient.d.ts.map +1 -0
  309. package/dist/modules/compute/ComputeClient.js +39 -0
  310. package/dist/modules/compute/ComputeClient.js.map +1 -0
  311. package/dist/modules/compute/index.d.ts +2 -0
  312. package/dist/modules/compute/index.d.ts.map +1 -0
  313. package/dist/modules/compute/index.js +2 -0
  314. package/dist/modules/compute/index.js.map +1 -0
  315. package/dist/modules/export/ExportClient.d.ts +56 -0
  316. package/dist/modules/export/ExportClient.d.ts.map +1 -0
  317. package/dist/modules/export/ExportClient.js +42 -0
  318. package/dist/modules/export/ExportClient.js.map +1 -0
  319. package/dist/modules/export/index.d.ts +2 -0
  320. package/dist/modules/export/index.d.ts.map +1 -0
  321. package/dist/modules/export/index.js +2 -0
  322. package/dist/modules/export/index.js.map +1 -0
  323. package/dist/modules/forecasting/ForecastingClient.d.ts +112 -0
  324. package/dist/modules/forecasting/ForecastingClient.d.ts.map +1 -0
  325. package/dist/modules/forecasting/ForecastingClient.js +48 -0
  326. package/dist/modules/forecasting/ForecastingClient.js.map +1 -0
  327. package/dist/modules/forecasting/index.d.ts +2 -0
  328. package/dist/modules/forecasting/index.d.ts.map +1 -0
  329. package/dist/modules/forecasting/index.js +2 -0
  330. package/dist/modules/forecasting/index.js.map +1 -0
  331. package/dist/modules/monitoring/MonitoringClient.d.ts +67 -0
  332. package/dist/modules/monitoring/MonitoringClient.d.ts.map +1 -0
  333. package/dist/modules/monitoring/MonitoringClient.js +48 -0
  334. package/dist/modules/monitoring/MonitoringClient.js.map +1 -0
  335. package/dist/modules/monitoring/index.d.ts +2 -0
  336. package/dist/modules/monitoring/index.d.ts.map +1 -0
  337. package/dist/modules/monitoring/index.js +2 -0
  338. package/dist/modules/monitoring/index.js.map +1 -0
  339. package/dist/modules/notifications/NotificationsClient.d.ts +68 -0
  340. package/dist/modules/notifications/NotificationsClient.d.ts.map +1 -0
  341. package/dist/modules/notifications/NotificationsClient.js +50 -0
  342. package/dist/modules/notifications/NotificationsClient.js.map +1 -0
  343. package/dist/modules/notifications/index.d.ts +2 -0
  344. package/dist/modules/notifications/index.d.ts.map +1 -0
  345. package/dist/modules/notifications/index.js +2 -0
  346. package/dist/modules/notifications/index.js.map +1 -0
  347. package/dist/modules/oracle/OracleClient.d.ts +48 -0
  348. package/dist/modules/oracle/OracleClient.d.ts.map +1 -0
  349. package/dist/modules/oracle/OracleClient.js +34 -0
  350. package/dist/modules/oracle/OracleClient.js.map +1 -0
  351. package/dist/modules/oracle/index.d.ts +2 -0
  352. package/dist/modules/oracle/index.d.ts.map +1 -0
  353. package/dist/modules/oracle/index.js +2 -0
  354. package/dist/modules/oracle/index.js.map +1 -0
  355. package/dist/modules/storage/StorageClient.d.ts +44 -0
  356. package/dist/modules/storage/StorageClient.d.ts.map +1 -0
  357. package/dist/modules/storage/StorageClient.js +43 -0
  358. package/dist/modules/storage/StorageClient.js.map +1 -0
  359. package/dist/modules/storage/index.d.ts +2 -0
  360. package/dist/modules/storage/index.d.ts.map +1 -0
  361. package/dist/modules/storage/index.js +2 -0
  362. package/dist/modules/storage/index.js.map +1 -0
  363. package/dist/modules/templates/TemplateDeploymentClient.d.ts +208 -0
  364. package/dist/modules/templates/TemplateDeploymentClient.d.ts.map +1 -0
  365. package/dist/modules/templates/TemplateDeploymentClient.js +101 -0
  366. package/dist/modules/templates/TemplateDeploymentClient.js.map +1 -0
  367. package/dist/modules/templates/index.d.ts +8 -0
  368. package/dist/modules/templates/index.d.ts.map +1 -0
  369. package/dist/modules/templates/index.js +7 -0
  370. package/dist/modules/templates/index.js.map +1 -0
  371. package/dist/modules/webhooks/WebhooksClient.d.ts +85 -0
  372. package/dist/modules/webhooks/WebhooksClient.d.ts.map +1 -0
  373. package/dist/modules/webhooks/WebhooksClient.js +68 -0
  374. package/dist/modules/webhooks/WebhooksClient.js.map +1 -0
  375. package/dist/modules/webhooks/index.d.ts +2 -0
  376. package/dist/modules/webhooks/index.d.ts.map +1 -0
  377. package/dist/modules/webhooks/index.js +2 -0
  378. package/dist/modules/webhooks/index.js.map +1 -0
  379. package/dist/modules/zk/ZKClient.d.ts +67 -0
  380. package/dist/modules/zk/ZKClient.d.ts.map +1 -0
  381. package/dist/modules/zk/ZKClient.js +36 -0
  382. package/dist/modules/zk/ZKClient.js.map +1 -0
  383. package/dist/modules/zk/index.d.ts +2 -0
  384. package/dist/modules/zk/index.d.ts.map +1 -0
  385. package/dist/modules/zk/index.js +2 -0
  386. package/dist/modules/zk/index.js.map +1 -0
  387. package/dist/providers/ChainContext.d.ts +65 -0
  388. package/dist/providers/ChainContext.d.ts.map +1 -0
  389. package/dist/providers/ChainContext.js +92 -0
  390. package/dist/providers/ChainContext.js.map +1 -0
  391. package/dist/providers/PrivyProvider.d.ts +42 -0
  392. package/dist/providers/PrivyProvider.d.ts.map +1 -0
  393. package/dist/providers/PrivyProvider.js +131 -0
  394. package/dist/providers/PrivyProvider.js.map +1 -0
  395. package/dist/providers/PrivyStack.d.ts +165 -0
  396. package/dist/providers/PrivyStack.d.ts.map +1 -0
  397. package/dist/providers/PrivyStack.js +295 -0
  398. package/dist/providers/PrivyStack.js.map +1 -0
  399. package/dist/providers/VarityDashboardProvider.d.ts +90 -0
  400. package/dist/providers/VarityDashboardProvider.d.ts.map +1 -0
  401. package/dist/providers/VarityDashboardProvider.js +242 -0
  402. package/dist/providers/VarityDashboardProvider.js.map +1 -0
  403. package/dist/providers/VarityProvider.d.ts +32 -0
  404. package/dist/providers/VarityProvider.d.ts.map +1 -0
  405. package/dist/providers/VarityProvider.js +56 -0
  406. package/dist/providers/VarityProvider.js.map +1 -0
  407. package/dist/providers/WalletContext.d.ts +68 -0
  408. package/dist/providers/WalletContext.d.ts.map +1 -0
  409. package/dist/providers/WalletContext.js +98 -0
  410. package/dist/providers/WalletContext.js.map +1 -0
  411. package/dist/providers/WalletSyncProvider.d.ts +84 -0
  412. package/dist/providers/WalletSyncProvider.d.ts.map +1 -0
  413. package/dist/providers/WalletSyncProvider.js +132 -0
  414. package/dist/providers/WalletSyncProvider.js.map +1 -0
  415. package/dist/providers/index.d.ts +47 -0
  416. package/dist/providers/index.d.ts.map +1 -0
  417. package/dist/providers/index.js +51 -0
  418. package/dist/providers/index.js.map +1 -0
  419. package/dist/tests/mocks/httpClient.mock.d.ts +62 -0
  420. package/dist/tests/mocks/httpClient.mock.d.ts.map +1 -0
  421. package/dist/tests/mocks/httpClient.mock.js +108 -0
  422. package/dist/tests/mocks/httpClient.mock.js.map +1 -0
  423. package/dist/tests/setup.d.ts +6 -0
  424. package/dist/tests/setup.d.ts.map +1 -0
  425. package/dist/tests/setup.js +51 -0
  426. package/dist/tests/setup.js.map +1 -0
  427. package/dist/types/api-extensions.d.ts +92 -0
  428. package/dist/types/api-extensions.d.ts.map +1 -0
  429. package/dist/types/api-extensions.js +7 -0
  430. package/dist/types/api-extensions.js.map +1 -0
  431. package/dist/utils/http.d.ts +51 -0
  432. package/dist/utils/http.d.ts.map +1 -0
  433. package/dist/utils/http.js +104 -0
  434. package/dist/utils/http.js.map +1 -0
  435. package/dist/wallets/SimpleSmartWallet.d.ts +68 -0
  436. package/dist/wallets/SimpleSmartWallet.d.ts.map +1 -0
  437. package/dist/wallets/SimpleSmartWallet.js +74 -0
  438. package/dist/wallets/SimpleSmartWallet.js.map +1 -0
  439. package/dist/wallets/SmartWalletProvider.d.ts +217 -0
  440. package/dist/wallets/SmartWalletProvider.d.ts.map +1 -0
  441. package/dist/wallets/SmartWalletProvider.js +366 -0
  442. package/dist/wallets/SmartWalletProvider.js.map +1 -0
  443. package/dist/wallets/config.d.ts +199 -0
  444. package/dist/wallets/config.d.ts.map +1 -0
  445. package/dist/wallets/config.js +183 -0
  446. package/dist/wallets/config.js.map +1 -0
  447. package/dist/wallets/index.d.ts +9 -0
  448. package/dist/wallets/index.d.ts.map +1 -0
  449. package/dist/wallets/index.js +9 -0
  450. package/dist/wallets/index.js.map +1 -0
  451. package/dist/web3/AddressDisplay/AddressDisplay.d.ts +33 -0
  452. package/dist/web3/AddressDisplay/AddressDisplay.d.ts.map +1 -0
  453. package/dist/web3/AddressDisplay/AddressDisplay.js +42 -0
  454. package/dist/web3/AddressDisplay/AddressDisplay.js.map +1 -0
  455. package/dist/web3/AddressInput/AddressInput.d.ts +36 -0
  456. package/dist/web3/AddressInput/AddressInput.d.ts.map +1 -0
  457. package/dist/web3/AddressInput/AddressInput.js +54 -0
  458. package/dist/web3/AddressInput/AddressInput.js.map +1 -0
  459. package/dist/web3/AmountInput/AmountInput.d.ts +41 -0
  460. package/dist/web3/AmountInput/AmountInput.d.ts.map +1 -0
  461. package/dist/web3/AmountInput/AmountInput.js +74 -0
  462. package/dist/web3/AmountInput/AmountInput.js.map +1 -0
  463. package/dist/web3/BalanceDisplay/BalanceDisplay.d.ts +30 -0
  464. package/dist/web3/BalanceDisplay/BalanceDisplay.d.ts.map +1 -0
  465. package/dist/web3/BalanceDisplay/BalanceDisplay.js +35 -0
  466. package/dist/web3/BalanceDisplay/BalanceDisplay.js.map +1 -0
  467. package/dist/web3/BlockExplorerLink/BlockExplorerLink.d.ts +41 -0
  468. package/dist/web3/BlockExplorerLink/BlockExplorerLink.d.ts.map +1 -0
  469. package/dist/web3/BlockExplorerLink/BlockExplorerLink.js +46 -0
  470. package/dist/web3/BlockExplorerLink/BlockExplorerLink.js.map +1 -0
  471. package/dist/web3/ConnectWallet/ConnectWallet.d.ts +35 -0
  472. package/dist/web3/ConnectWallet/ConnectWallet.d.ts.map +1 -0
  473. package/dist/web3/ConnectWallet/ConnectWallet.js +58 -0
  474. package/dist/web3/ConnectWallet/ConnectWallet.js.map +1 -0
  475. package/dist/web3/DisconnectButton/DisconnectButton.d.ts +30 -0
  476. package/dist/web3/DisconnectButton/DisconnectButton.d.ts.map +1 -0
  477. package/dist/web3/DisconnectButton/DisconnectButton.js +48 -0
  478. package/dist/web3/DisconnectButton/DisconnectButton.js.map +1 -0
  479. package/dist/web3/WalletBalance/WalletBalance.d.ts +27 -0
  480. package/dist/web3/WalletBalance/WalletBalance.d.ts.map +1 -0
  481. package/dist/web3/WalletBalance/WalletBalance.js +49 -0
  482. package/dist/web3/WalletBalance/WalletBalance.js.map +1 -0
  483. package/dist/web3/WalletDropdown/WalletDropdown.d.ts +29 -0
  484. package/dist/web3/WalletDropdown/WalletDropdown.d.ts.map +1 -0
  485. package/dist/web3/WalletDropdown/WalletDropdown.js +93 -0
  486. package/dist/web3/WalletDropdown/WalletDropdown.js.map +1 -0
  487. package/dist/web3/WalletInfo/WalletInfo.d.ts +31 -0
  488. package/dist/web3/WalletInfo/WalletInfo.d.ts.map +1 -0
  489. package/dist/web3/WalletInfo/WalletInfo.js +41 -0
  490. package/dist/web3/WalletInfo/WalletInfo.js.map +1 -0
  491. package/dist/web3/index.d.ts +11 -0
  492. package/dist/web3/index.d.ts.map +1 -0
  493. package/dist/web3/index.js +14 -0
  494. package/dist/web3/index.js.map +1 -0
  495. 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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"}