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

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (269) hide show
  1. package/LICENSE +1 -1
  2. package/README.md +227 -203
  3. package/dist/components/Analytics/DataTable.js +1 -1
  4. package/dist/components/Analytics/DataTable.js.map +1 -1
  5. package/dist/components/Analytics/EnhancedKPICard.d.ts +21 -0
  6. package/dist/components/Analytics/EnhancedKPICard.d.ts.map +1 -0
  7. package/dist/components/Analytics/EnhancedKPICard.js +135 -0
  8. package/dist/components/Analytics/EnhancedKPICard.js.map +1 -0
  9. package/dist/components/Analytics/Sparkline.d.ts +44 -0
  10. package/dist/components/Analytics/Sparkline.d.ts.map +1 -0
  11. package/dist/components/Analytics/Sparkline.js +90 -0
  12. package/dist/components/Analytics/Sparkline.js.map +1 -0
  13. package/dist/components/Analytics/index.d.ts +2 -0
  14. package/dist/components/Analytics/index.d.ts.map +1 -1
  15. package/dist/components/Analytics/index.js +2 -0
  16. package/dist/components/Analytics/index.js.map +1 -1
  17. package/dist/components/Dashboard/DashboardFooter.d.ts.map +1 -1
  18. package/dist/components/Dashboard/DashboardFooter.js +22 -6
  19. package/dist/components/Dashboard/DashboardFooter.js.map +1 -1
  20. package/dist/components/Dashboard/DashboardHeader.d.ts +10 -0
  21. package/dist/components/Dashboard/DashboardHeader.d.ts.map +1 -1
  22. package/dist/components/Dashboard/DashboardHeader.js +191 -58
  23. package/dist/components/Dashboard/DashboardHeader.js.map +1 -1
  24. package/dist/components/Dashboard/DashboardLayout.d.ts +13 -3
  25. package/dist/components/Dashboard/DashboardLayout.d.ts.map +1 -1
  26. package/dist/components/Dashboard/DashboardLayout.js +9 -4
  27. package/dist/components/Dashboard/DashboardLayout.js.map +1 -1
  28. package/dist/components/Dashboard/DashboardSidebar.d.ts.map +1 -1
  29. package/dist/components/Dashboard/DashboardSidebar.js +41 -12
  30. package/dist/components/Dashboard/DashboardSidebar.js.map +1 -1
  31. package/dist/components/Dashboard/EmptyState.js +5 -5
  32. package/dist/components/Dashboard/EmptyState.js.map +1 -1
  33. package/dist/components/Dashboard/KPICard.js +5 -5
  34. package/dist/components/Dashboard/KPICard.js.map +1 -1
  35. package/dist/components/Display/Avatar.d.ts +21 -0
  36. package/dist/components/Display/Avatar.d.ts.map +1 -0
  37. package/dist/components/Display/Avatar.js +71 -0
  38. package/dist/components/Display/Avatar.js.map +1 -0
  39. package/dist/components/Display/Badge.d.ts +22 -0
  40. package/dist/components/Display/Badge.d.ts.map +1 -0
  41. package/dist/components/Display/Badge.js +60 -0
  42. package/dist/components/Display/Badge.js.map +1 -0
  43. package/dist/components/Display/ProgressBar.d.ts +12 -0
  44. package/dist/components/Display/ProgressBar.d.ts.map +1 -0
  45. package/dist/components/Display/ProgressBar.js +33 -0
  46. package/dist/components/Display/ProgressBar.js.map +1 -0
  47. package/dist/components/Display/index.d.ts +9 -0
  48. package/dist/components/Display/index.d.ts.map +1 -0
  49. package/dist/components/Display/index.js +9 -0
  50. package/dist/components/Display/index.js.map +1 -0
  51. package/dist/components/Feedback/Skeleton.d.ts +10 -0
  52. package/dist/components/Feedback/Skeleton.d.ts.map +1 -0
  53. package/dist/components/Feedback/Skeleton.js +25 -0
  54. package/dist/components/Feedback/Skeleton.js.map +1 -0
  55. package/dist/components/Feedback/Toast.d.ts +18 -0
  56. package/dist/components/Feedback/Toast.d.ts.map +1 -0
  57. package/dist/components/Feedback/Toast.js +38 -0
  58. package/dist/components/Feedback/Toast.js.map +1 -0
  59. package/dist/components/Feedback/ToastProvider.d.ts +11 -0
  60. package/dist/components/Feedback/ToastProvider.d.ts.map +1 -0
  61. package/dist/components/Feedback/ToastProvider.js +36 -0
  62. package/dist/components/Feedback/ToastProvider.js.map +1 -0
  63. package/dist/components/Feedback/index.d.ts +11 -0
  64. package/dist/components/Feedback/index.d.ts.map +1 -0
  65. package/dist/components/Feedback/index.js +9 -0
  66. package/dist/components/Feedback/index.js.map +1 -0
  67. package/dist/components/Feedback/useToast.d.ts +3 -0
  68. package/dist/components/Feedback/useToast.d.ts.map +1 -0
  69. package/dist/components/Feedback/useToast.js +10 -0
  70. package/dist/components/Feedback/useToast.js.map +1 -0
  71. package/dist/components/Form/Button.d.ts +12 -0
  72. package/dist/components/Form/Button.d.ts.map +1 -0
  73. package/dist/components/Form/Button.js +22 -0
  74. package/dist/components/Form/Button.js.map +1 -0
  75. package/dist/components/Form/Checkbox.d.ts +13 -0
  76. package/dist/components/Form/Checkbox.d.ts.map +1 -0
  77. package/dist/components/Form/Checkbox.js +36 -0
  78. package/dist/components/Form/Checkbox.js.map +1 -0
  79. package/dist/components/Form/Input.d.ts +9 -0
  80. package/dist/components/Form/Input.d.ts.map +1 -0
  81. package/dist/components/Form/Input.js +16 -0
  82. package/dist/components/Form/Input.js.map +1 -0
  83. package/dist/components/Form/RadioGroup.d.ts +20 -0
  84. package/dist/components/Form/RadioGroup.d.ts.map +1 -0
  85. package/dist/components/Form/RadioGroup.js +43 -0
  86. package/dist/components/Form/RadioGroup.js.map +1 -0
  87. package/dist/components/Form/Select.d.ts +12 -0
  88. package/dist/components/Form/Select.d.ts.map +1 -0
  89. package/dist/components/Form/Select.js +13 -0
  90. package/dist/components/Form/Select.js.map +1 -0
  91. package/dist/components/Form/Textarea.d.ts +8 -0
  92. package/dist/components/Form/Textarea.d.ts.map +1 -0
  93. package/dist/components/Form/Textarea.js +13 -0
  94. package/dist/components/Form/Textarea.js.map +1 -0
  95. package/dist/components/Form/Toggle.d.ts +12 -0
  96. package/dist/components/Form/Toggle.d.ts.map +1 -0
  97. package/dist/components/Form/Toggle.js +48 -0
  98. package/dist/components/Form/Toggle.js.map +1 -0
  99. package/dist/components/Form/index.d.ts +13 -0
  100. package/dist/components/Form/index.d.ts.map +1 -0
  101. package/dist/components/Form/index.js +13 -0
  102. package/dist/components/Form/index.js.map +1 -0
  103. package/dist/components/InAppWallet/InAppWalletProvider.d.ts +4 -4
  104. package/dist/components/InAppWallet/InAppWalletProvider.d.ts.map +1 -1
  105. package/dist/components/InAppWallet/InAppWalletProvider.js +15 -28
  106. package/dist/components/InAppWallet/InAppWalletProvider.js.map +1 -1
  107. package/dist/components/Navigation/Breadcrumb.d.ts +15 -0
  108. package/dist/components/Navigation/Breadcrumb.d.ts.map +1 -0
  109. package/dist/components/Navigation/Breadcrumb.js +28 -0
  110. package/dist/components/Navigation/Breadcrumb.js.map +1 -0
  111. package/dist/components/Navigation/CommandPalette.d.ts +26 -0
  112. package/dist/components/Navigation/CommandPalette.d.ts.map +1 -0
  113. package/dist/components/Navigation/CommandPalette.js +172 -0
  114. package/dist/components/Navigation/CommandPalette.js.map +1 -0
  115. package/dist/components/Navigation/index.d.ts +8 -0
  116. package/dist/components/Navigation/index.d.ts.map +1 -0
  117. package/dist/components/Navigation/index.js +8 -0
  118. package/dist/components/Navigation/index.js.map +1 -0
  119. package/dist/components/Onramp/BuyUSDCButton.d.ts +9 -7
  120. package/dist/components/Onramp/BuyUSDCButton.d.ts.map +1 -1
  121. package/dist/components/Onramp/BuyUSDCButton.js +37 -47
  122. package/dist/components/Onramp/BuyUSDCButton.js.map +1 -1
  123. package/dist/components/Onramp/OnrampWidget.d.ts +7 -6
  124. package/dist/components/Onramp/OnrampWidget.d.ts.map +1 -1
  125. package/dist/components/Onramp/OnrampWidget.js +58 -37
  126. package/dist/components/Onramp/OnrampWidget.js.map +1 -1
  127. package/dist/components/Onramp/index.d.ts +3 -5
  128. package/dist/components/Onramp/index.d.ts.map +1 -1
  129. package/dist/components/Onramp/index.js +3 -5
  130. package/dist/components/Onramp/index.js.map +1 -1
  131. package/dist/components/Overlay/ConfirmDialog.d.ts +14 -0
  132. package/dist/components/Overlay/ConfirmDialog.d.ts.map +1 -0
  133. package/dist/components/Overlay/ConfirmDialog.js +11 -0
  134. package/dist/components/Overlay/ConfirmDialog.js.map +1 -0
  135. package/dist/components/Overlay/Dialog.d.ts +11 -0
  136. package/dist/components/Overlay/Dialog.d.ts.map +1 -0
  137. package/dist/components/Overlay/Dialog.js +69 -0
  138. package/dist/components/Overlay/Dialog.js.map +1 -0
  139. package/dist/components/Overlay/DropdownMenu.d.ts +17 -0
  140. package/dist/components/Overlay/DropdownMenu.d.ts.map +1 -0
  141. package/dist/components/Overlay/DropdownMenu.js +123 -0
  142. package/dist/components/Overlay/DropdownMenu.js.map +1 -0
  143. package/dist/components/Overlay/index.d.ts +9 -0
  144. package/dist/components/Overlay/index.d.ts.map +1 -0
  145. package/dist/components/Overlay/index.js +9 -0
  146. package/dist/components/Overlay/index.js.map +1 -0
  147. package/dist/components/PaymentWidget/PaymentGate.d.ts +30 -0
  148. package/dist/components/PaymentWidget/PaymentGate.d.ts.map +1 -0
  149. package/dist/components/PaymentWidget/PaymentGate.js +54 -0
  150. package/dist/components/PaymentWidget/PaymentGate.js.map +1 -0
  151. package/dist/components/PaymentWidget/PaymentWidget.d.ts +40 -0
  152. package/dist/components/PaymentWidget/PaymentWidget.d.ts.map +1 -0
  153. package/dist/components/PaymentWidget/PaymentWidget.js +195 -0
  154. package/dist/components/PaymentWidget/PaymentWidget.js.map +1 -0
  155. package/dist/components/PaymentWidget/index.d.ts +30 -0
  156. package/dist/components/PaymentWidget/index.d.ts.map +1 -0
  157. package/dist/components/PaymentWidget/index.js +32 -0
  158. package/dist/components/PaymentWidget/index.js.map +1 -0
  159. package/dist/components/PaymentWidget/types.d.ts +200 -0
  160. package/dist/components/PaymentWidget/types.d.ts.map +1 -0
  161. package/dist/components/PaymentWidget/types.js +84 -0
  162. package/dist/components/PaymentWidget/types.js.map +1 -0
  163. package/dist/components/PaymentWidget/useSeamlessPayment.d.ts +51 -0
  164. package/dist/components/PaymentWidget/useSeamlessPayment.d.ts.map +1 -0
  165. package/dist/components/PaymentWidget/useSeamlessPayment.js +167 -0
  166. package/dist/components/PaymentWidget/useSeamlessPayment.js.map +1 -0
  167. package/dist/components/PaymentWidget/useVarityPayment.d.ts +20 -0
  168. package/dist/components/PaymentWidget/useVarityPayment.d.ts.map +1 -0
  169. package/dist/components/PaymentWidget/useVarityPayment.js +164 -0
  170. package/dist/components/PaymentWidget/useVarityPayment.js.map +1 -0
  171. package/dist/components/Payments/CheckoutModal.d.ts.map +1 -1
  172. package/dist/components/Payments/CheckoutModal.js +16 -5
  173. package/dist/components/Payments/CheckoutModal.js.map +1 -1
  174. package/dist/components/Payments/constants.js +1 -1
  175. package/dist/components/Payments/constants.js.map +1 -1
  176. package/dist/components/Privy/InitTimeoutScreen.d.ts.map +1 -1
  177. package/dist/components/Privy/InitTimeoutScreen.js +1 -1
  178. package/dist/components/Privy/InitTimeoutScreen.js.map +1 -1
  179. package/dist/components/Privy/InitializingScreen.d.ts +3 -3
  180. package/dist/components/Privy/InitializingScreen.d.ts.map +1 -1
  181. package/dist/components/Privy/InitializingScreen.js +6 -6
  182. package/dist/components/Privy/InitializingScreen.js.map +1 -1
  183. package/dist/components/index.d.ts +5 -2
  184. package/dist/components/index.d.ts.map +1 -1
  185. package/dist/components/index.js +20 -4
  186. package/dist/components/index.js.map +1 -1
  187. package/dist/config/chains.d.ts +5 -5
  188. package/dist/config/chains.d.ts.map +1 -1
  189. package/dist/config/chains.js +8 -8
  190. package/dist/config/chains.js.map +1 -1
  191. package/dist/hooks/index.d.ts +1 -11
  192. package/dist/hooks/index.d.ts.map +1 -1
  193. package/dist/hooks/index.js +54 -11
  194. package/dist/hooks/index.js.map +1 -1
  195. package/dist/index.d.ts +24 -42
  196. package/dist/index.d.ts.map +1 -1
  197. package/dist/index.js +180 -43
  198. package/dist/index.js.map +1 -1
  199. package/dist/providers/PrivyProvider.js +1 -1
  200. package/dist/providers/PrivyProvider.js.map +1 -1
  201. package/dist/providers/PrivyStack.d.ts +31 -73
  202. package/dist/providers/PrivyStack.d.ts.map +1 -1
  203. package/dist/providers/PrivyStack.js +32 -160
  204. package/dist/providers/PrivyStack.js.map +1 -1
  205. package/dist/providers/VarityDashboardProvider.d.ts +7 -10
  206. package/dist/providers/VarityDashboardProvider.d.ts.map +1 -1
  207. package/dist/providers/VarityDashboardProvider.js +12 -15
  208. package/dist/providers/VarityDashboardProvider.js.map +1 -1
  209. package/dist/providers/WalletSyncProvider.d.ts +17 -24
  210. package/dist/providers/WalletSyncProvider.d.ts.map +1 -1
  211. package/dist/providers/WalletSyncProvider.js +16 -27
  212. package/dist/providers/WalletSyncProvider.js.map +1 -1
  213. package/dist/providers/ZeroDevProvider.d.ts +69 -0
  214. package/dist/providers/ZeroDevProvider.d.ts.map +1 -0
  215. package/dist/providers/ZeroDevProvider.js +208 -0
  216. package/dist/providers/ZeroDevProvider.js.map +1 -0
  217. package/dist/providers/index.d.ts +1 -0
  218. package/dist/providers/index.d.ts.map +1 -1
  219. package/dist/providers/index.js +2 -0
  220. package/dist/providers/index.js.map +1 -1
  221. package/dist/wallets/SimpleSmartWallet.js +1 -1
  222. package/dist/wallets/SimpleSmartWallet.js.map +1 -1
  223. package/dist/wallets/SmartWalletProvider.js +1 -1
  224. package/dist/wallets/SmartWalletProvider.js.map +1 -1
  225. package/dist/wallets/config.d.ts +31 -8
  226. package/dist/wallets/config.d.ts.map +1 -1
  227. package/dist/wallets/config.js +33 -10
  228. package/dist/wallets/config.js.map +1 -1
  229. package/dist/wallets/index.d.ts +1 -1
  230. package/dist/wallets/index.d.ts.map +1 -1
  231. package/dist/wallets/index.js +1 -1
  232. package/dist/wallets/index.js.map +1 -1
  233. package/package.json +34 -26
  234. package/dist/core/VarityClient.d.ts +0 -76
  235. package/dist/core/VarityClient.d.ts.map +0 -1
  236. package/dist/core/VarityClient.js +0 -99
  237. package/dist/core/VarityClient.js.map +0 -1
  238. package/dist/core/config.d.ts +0 -136
  239. package/dist/core/config.d.ts.map +0 -1
  240. package/dist/core/config.js +0 -156
  241. package/dist/core/config.js.map +0 -1
  242. package/dist/hooks/useAnalytics.d.ts +0 -94
  243. package/dist/hooks/useAnalytics.d.ts.map +0 -1
  244. package/dist/hooks/useAnalytics.js +0 -116
  245. package/dist/hooks/useAnalytics.js.map +0 -1
  246. package/dist/hooks/useAuth.d.ts +0 -71
  247. package/dist/hooks/useAuth.d.ts.map +0 -1
  248. package/dist/hooks/useAuth.js +0 -198
  249. package/dist/hooks/useAuth.js.map +0 -1
  250. package/dist/hooks/useDashboard.d.ts +0 -110
  251. package/dist/hooks/useDashboard.d.ts.map +0 -1
  252. package/dist/hooks/useDashboard.js +0 -201
  253. package/dist/hooks/useDashboard.js.map +0 -1
  254. package/dist/hooks/useVarityAPI.d.ts +0 -88
  255. package/dist/hooks/useVarityAPI.d.ts.map +0 -1
  256. package/dist/hooks/useVarityAPI.js +0 -138
  257. package/dist/hooks/useVarityAPI.js.map +0 -1
  258. package/dist/hooks/useWalletAuth.d.ts +0 -108
  259. package/dist/hooks/useWalletAuth.d.ts.map +0 -1
  260. package/dist/hooks/useWalletAuth.js +0 -415
  261. package/dist/hooks/useWalletAuth.js.map +0 -1
  262. package/dist/modules/cache/index.d.ts +0 -2
  263. package/dist/modules/cache/index.d.ts.map +0 -1
  264. package/dist/modules/cache/index.js +0 -2
  265. package/dist/modules/cache/index.js.map +0 -1
  266. package/dist/types/api-extensions.d.ts +0 -92
  267. package/dist/types/api-extensions.d.ts.map +0 -1
  268. package/dist/types/api-extensions.js +0 -7
  269. package/dist/types/api-extensions.js.map +0 -1
@@ -1 +1 @@
1
- {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Onramp/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAG9C,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,YAAY,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC"}
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Onramp/index.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC;AAG9C,YAAY,EAAE,kBAAkB,EAAE,MAAM,iBAAiB,CAAC;AAC1D,YAAY,EAAE,iBAAiB,EAAE,QAAQ,EAAE,MAAM,gBAAgB,CAAC"}
@@ -1,11 +1,9 @@
1
1
  /**
2
- * Onramp Components Export
2
+ * Payment Components Export
3
3
  *
4
- * Thirdweb Pay for buying crypto with fiat currency
5
- * - Credit/Debit card payments
4
+ * Seamless credit card payments for adding funds.
5
+ * - Credit/Debit card
6
6
  * - Apple Pay & Google Pay
7
- * - KYC verification handling
8
- * - Transaction status tracking
9
7
  */
10
8
  export { BuyUSDCButton } from './BuyUSDCButton';
11
9
  export { OnrampWidget } from './OnrampWidget';
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Onramp/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;GAQG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Onramp/index.ts"],"names":[],"mappings":"AAAA;;;;;;GAMG;AAEH,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
@@ -0,0 +1,14 @@
1
+ import React from 'react';
2
+ interface ConfirmDialogProps {
3
+ open: boolean;
4
+ onClose: () => void;
5
+ onConfirm: () => void;
6
+ title: string;
7
+ description: string;
8
+ confirmLabel?: string;
9
+ confirmVariant?: 'danger' | 'primary';
10
+ loading?: boolean;
11
+ }
12
+ export declare function ConfirmDialog({ open, onClose, onConfirm, title, description, confirmLabel, confirmVariant, loading, }: ConfirmDialogProps): React.JSX.Element;
13
+ export {};
14
+ //# sourceMappingURL=ConfirmDialog.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConfirmDialog.d.ts","sourceRoot":"","sources":["../../../src/components/Overlay/ConfirmDialog.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,MAAM,OAAO,CAAC;AAI1B,UAAU,kBAAkB;IAC1B,IAAI,EAAE,OAAO,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,SAAS,EAAE,MAAM,IAAI,CAAC;IACtB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,EAAE,MAAM,CAAC;IACpB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,cAAc,CAAC,EAAE,QAAQ,GAAG,SAAS,CAAC;IACtC,OAAO,CAAC,EAAE,OAAO,CAAC;CACnB;AAED,wBAAgB,aAAa,CAAC,EAC5B,IAAI,EACJ,OAAO,EACP,SAAS,EACT,KAAK,EACL,WAAW,EACX,YAAuB,EACvB,cAAyB,EACzB,OAAe,GAChB,EAAE,kBAAkB,qBAapB"}
@@ -0,0 +1,11 @@
1
+ 'use client';
2
+ import React from 'react';
3
+ import { Dialog } from './Dialog';
4
+ import { Button } from '../Form/Button';
5
+ export function ConfirmDialog({ open, onClose, onConfirm, title, description, confirmLabel = 'Delete', confirmVariant = 'danger', loading = false, }) {
6
+ return (React.createElement(Dialog, { open: open, onClose: onClose, title: title, description: description },
7
+ React.createElement("div", { className: "flex gap-2 pt-4" },
8
+ React.createElement(Button, { variant: confirmVariant, onClick: onConfirm, loading: loading }, confirmLabel),
9
+ React.createElement(Button, { variant: "secondary", onClick: onClose, disabled: loading }, "Cancel"))));
10
+ }
11
+ //# sourceMappingURL=ConfirmDialog.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ConfirmDialog.js","sourceRoot":"","sources":["../../../src/components/Overlay/ConfirmDialog.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,MAAM,EAAE,MAAM,gBAAgB,CAAC;AAaxC,MAAM,UAAU,aAAa,CAAC,EAC5B,IAAI,EACJ,OAAO,EACP,SAAS,EACT,KAAK,EACL,WAAW,EACX,YAAY,GAAG,QAAQ,EACvB,cAAc,GAAG,QAAQ,EACzB,OAAO,GAAG,KAAK,GACI;IACnB,OAAO,CACL,oBAAC,MAAM,IAAC,IAAI,EAAE,IAAI,EAAE,OAAO,EAAE,OAAO,EAAE,KAAK,EAAE,KAAK,EAAE,WAAW,EAAE,WAAW;QAC1E,6BAAK,SAAS,EAAC,iBAAiB;YAC9B,oBAAC,MAAM,IAAC,OAAO,EAAE,cAAc,EAAE,OAAO,EAAE,SAAS,EAAE,OAAO,EAAE,OAAO,IAClE,YAAY,CACN;YACT,oBAAC,MAAM,IAAC,OAAO,EAAC,WAAW,EAAC,OAAO,EAAE,OAAO,EAAE,QAAQ,EAAE,OAAO,aAEtD,CACL,CACC,CACV,CAAC;AACJ,CAAC"}
@@ -0,0 +1,11 @@
1
+ import React, { type ReactNode } from 'react';
2
+ interface DialogProps {
3
+ open: boolean;
4
+ onClose: () => void;
5
+ title: string;
6
+ description?: string;
7
+ children: ReactNode;
8
+ }
9
+ export declare function Dialog({ open, onClose, title, description, children }: DialogProps): React.JSX.Element | null;
10
+ export {};
11
+ //# sourceMappingURL=Dialog.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dialog.d.ts","sourceRoot":"","sources":["../../../src/components/Overlay/Dialog.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,EAAqB,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAGjE,UAAU,WAAW;IACnB,IAAI,EAAE,OAAO,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,KAAK,EAAE,MAAM,CAAC;IACd,WAAW,CAAC,EAAE,MAAM,CAAC;IACrB,QAAQ,EAAE,SAAS,CAAC;CACrB;AAED,wBAAgB,MAAM,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAE,EAAE,WAAW,4BAgGlF"}
@@ -0,0 +1,69 @@
1
+ 'use client';
2
+ import React, { useEffect, useRef } from 'react';
3
+ import { X } from 'lucide-react';
4
+ export function Dialog({ open, onClose, title, description, children }) {
5
+ const overlayRef = useRef(null);
6
+ const contentRef = useRef(null);
7
+ useEffect(() => {
8
+ if (!open)
9
+ return;
10
+ const handleEscape = (e) => {
11
+ if (e.key === 'Escape')
12
+ onClose();
13
+ };
14
+ // Get all focusable elements
15
+ const getFocusableElements = () => {
16
+ return contentRef.current?.querySelectorAll('button, [href], input, select, textarea, [tabindex]:not([tabindex="-1"])');
17
+ };
18
+ // Focus trap handler
19
+ const handleTabKey = (e) => {
20
+ if (e.key !== 'Tab')
21
+ return;
22
+ const focusableElements = getFocusableElements();
23
+ if (!focusableElements || focusableElements.length === 0)
24
+ return;
25
+ const firstElement = focusableElements[0];
26
+ const lastElement = focusableElements[focusableElements.length - 1];
27
+ if (e.shiftKey && document.activeElement === firstElement) {
28
+ lastElement.focus();
29
+ e.preventDefault();
30
+ }
31
+ else if (!e.shiftKey && document.activeElement === lastElement) {
32
+ firstElement.focus();
33
+ e.preventDefault();
34
+ }
35
+ };
36
+ document.addEventListener('keydown', handleEscape);
37
+ document.addEventListener('keydown', handleTabKey);
38
+ document.body.style.overflow = 'hidden';
39
+ // Focus first focusable element
40
+ const timer = setTimeout(() => {
41
+ const focusableElements = getFocusableElements();
42
+ if (focusableElements && focusableElements.length > 0) {
43
+ focusableElements[0].focus();
44
+ }
45
+ }, 50);
46
+ return () => {
47
+ document.removeEventListener('keydown', handleEscape);
48
+ document.removeEventListener('keydown', handleTabKey);
49
+ document.body.style.overflow = '';
50
+ clearTimeout(timer);
51
+ };
52
+ }, [open, onClose]);
53
+ if (!open)
54
+ return null;
55
+ return (React.createElement("div", { ref: overlayRef, className: "fixed inset-0 z-50 flex items-center justify-center p-4", onClick: (e) => {
56
+ if (e.target === overlayRef.current)
57
+ onClose();
58
+ }, role: "dialog", "aria-modal": "true", "aria-labelledby": "dialog-title" },
59
+ React.createElement("div", { className: "fixed inset-0 bg-black/50 backdrop-blur-sm" }),
60
+ React.createElement("div", { ref: contentRef, className: "relative z-10 w-full max-w-lg rounded-xl border border-gray-200 bg-white p-6 shadow-2xl" },
61
+ React.createElement("div", { className: "mb-4 flex items-start justify-between" },
62
+ React.createElement("div", null,
63
+ React.createElement("h2", { id: "dialog-title", className: "text-lg font-semibold text-gray-900" }, title),
64
+ description && (React.createElement("p", { className: "mt-1 text-sm text-gray-500" }, description))),
65
+ React.createElement("button", { onClick: onClose, className: "rounded-lg p-1 text-gray-400 hover:bg-gray-100 hover:text-gray-600 transition-colors", "aria-label": "Close dialog" },
66
+ React.createElement(X, { className: "h-5 w-5" }))),
67
+ children)));
68
+ }
69
+ //# sourceMappingURL=Dialog.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Dialog.js","sourceRoot":"","sources":["../../../src/components/Overlay/Dialog.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;AAEb,OAAO,KAAK,EAAE,EAAE,SAAS,EAAE,MAAM,EAAkB,MAAM,OAAO,CAAC;AACjE,OAAO,EAAE,CAAC,EAAE,MAAM,cAAc,CAAC;AAUjC,MAAM,UAAU,MAAM,CAAC,EAAE,IAAI,EAAE,OAAO,EAAE,KAAK,EAAE,WAAW,EAAE,QAAQ,EAAe;IACjF,MAAM,UAAU,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IAChD,MAAM,UAAU,GAAG,MAAM,CAAiB,IAAI,CAAC,CAAC;IAEhD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,IAAI;YAAE,OAAO;QAElB,MAAM,YAAY,GAAG,CAAC,CAAgB,EAAE,EAAE;YACxC,IAAI,CAAC,CAAC,GAAG,KAAK,QAAQ;gBAAE,OAAO,EAAE,CAAC;QACpC,CAAC,CAAC;QAEF,6BAA6B;QAC7B,MAAM,oBAAoB,GAAG,GAAG,EAAE;YAChC,OAAO,UAAU,CAAC,OAAO,EAAE,gBAAgB,CACzC,0EAA0E,CAC3E,CAAC;QACJ,CAAC,CAAC;QAEF,qBAAqB;QACrB,MAAM,YAAY,GAAG,CAAC,CAAgB,EAAE,EAAE;YACxC,IAAI,CAAC,CAAC,GAAG,KAAK,KAAK;gBAAE,OAAO;YAE5B,MAAM,iBAAiB,GAAG,oBAAoB,EAAE,CAAC;YACjD,IAAI,CAAC,iBAAiB,IAAI,iBAAiB,CAAC,MAAM,KAAK,CAAC;gBAAE,OAAO;YAEjE,MAAM,YAAY,GAAG,iBAAiB,CAAC,CAAC,CAAC,CAAC;YAC1C,MAAM,WAAW,GAAG,iBAAiB,CAAC,iBAAiB,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC;YAEpE,IAAI,CAAC,CAAC,QAAQ,IAAI,QAAQ,CAAC,aAAa,KAAK,YAAY,EAAE,CAAC;gBAC1D,WAAW,CAAC,KAAK,EAAE,CAAC;gBACpB,CAAC,CAAC,cAAc,EAAE,CAAC;YACrB,CAAC;iBAAM,IAAI,CAAC,CAAC,CAAC,QAAQ,IAAI,QAAQ,CAAC,aAAa,KAAK,WAAW,EAAE,CAAC;gBACjE,YAAY,CAAC,KAAK,EAAE,CAAC;gBACrB,CAAC,CAAC,cAAc,EAAE,CAAC;YACrB,CAAC;QACH,CAAC,CAAC;QAEF,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;QACnD,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;QACnD,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,QAAQ,CAAC;QAExC,gCAAgC;QAChC,MAAM,KAAK,GAAG,UAAU,CAAC,GAAG,EAAE;YAC5B,MAAM,iBAAiB,GAAG,oBAAoB,EAAE,CAAC;YACjD,IAAI,iBAAiB,IAAI,iBAAiB,CAAC,MAAM,GAAG,CAAC,EAAE,CAAC;gBACtD,iBAAiB,CAAC,CAAC,CAAC,CAAC,KAAK,EAAE,CAAC;YAC/B,CAAC;QACH,CAAC,EAAE,EAAE,CAAC,CAAC;QAEP,OAAO,GAAG,EAAE;YACV,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;YACtD,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,YAAY,CAAC,CAAC;YACtD,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,GAAG,EAAE,CAAC;YAClC,YAAY,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC,CAAC;IACJ,CAAC,EAAE,CAAC,IAAI,EAAE,OAAO,CAAC,CAAC,CAAC;IAEpB,IAAI,CAAC,IAAI;QAAE,OAAO,IAAI,CAAC;IAEvB,OAAO,CACL,6BACE,GAAG,EAAE,UAAU,EACf,SAAS,EAAC,yDAAyD,EACnE,OAAO,EAAE,CAAC,CAAC,EAAE,EAAE;YACb,IAAI,CAAC,CAAC,MAAM,KAAK,UAAU,CAAC,OAAO;gBAAE,OAAO,EAAE,CAAC;QACjD,CAAC,EACD,IAAI,EAAC,QAAQ,gBACF,MAAM,qBACD,cAAc;QAE9B,6BAAK,SAAS,EAAC,4CAA4C,GAAG;QAC9D,6BACE,GAAG,EAAE,UAAU,EACf,SAAS,EAAC,yFAAyF;YAEnG,6BAAK,SAAS,EAAC,uCAAuC;gBACpD;oBACE,4BAAI,EAAE,EAAC,cAAc,EAAC,SAAS,EAAC,qCAAqC,IAClE,KAAK,CACH;oBACJ,WAAW,IAAI,CACd,2BAAG,SAAS,EAAC,4BAA4B,IAAE,WAAW,CAAK,CAC5D,CACG;gBACN,gCACE,OAAO,EAAE,OAAO,EAChB,SAAS,EAAC,sFAAsF,gBACrF,cAAc;oBAEzB,oBAAC,CAAC,IAAC,SAAS,EAAC,SAAS,GAAG,CAClB,CACL;YACL,QAAQ,CACL,CACF,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,17 @@
1
+ import React from 'react';
2
+ import { LucideIcon } from 'lucide-react';
3
+ export interface DropdownMenuItem {
4
+ label: string;
5
+ onClick: () => void;
6
+ icon?: LucideIcon;
7
+ disabled?: boolean;
8
+ danger?: boolean;
9
+ }
10
+ export interface DropdownMenuProps {
11
+ trigger: React.ReactNode;
12
+ items: (DropdownMenuItem | 'divider')[];
13
+ align?: 'left' | 'right';
14
+ className?: string;
15
+ }
16
+ export declare function DropdownMenu({ trigger, items, align, className, }: DropdownMenuProps): React.JSX.Element;
17
+ //# sourceMappingURL=DropdownMenu.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DropdownMenu.d.ts","sourceRoot":"","sources":["../../../src/components/Overlay/DropdownMenu.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAsC,MAAM,OAAO,CAAC;AAC3D,OAAO,EAAE,UAAU,EAAE,MAAM,cAAc,CAAC;AAE1C,MAAM,WAAW,gBAAgB;IAC/B,KAAK,EAAE,MAAM,CAAC;IACd,OAAO,EAAE,MAAM,IAAI,CAAC;IACpB,IAAI,CAAC,EAAE,UAAU,CAAC;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,MAAM,CAAC,EAAE,OAAO,CAAC;CAClB;AAED,MAAM,WAAW,iBAAiB;IAChC,OAAO,EAAE,KAAK,CAAC,SAAS,CAAC;IACzB,KAAK,EAAE,CAAC,gBAAgB,GAAG,SAAS,CAAC,EAAE,CAAC;IACxC,KAAK,CAAC,EAAE,MAAM,GAAG,OAAO,CAAC;IACzB,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB;AAED,wBAAgB,YAAY,CAAC,EAC3B,OAAO,EACP,KAAK,EACL,KAAe,EACf,SAAc,GACf,EAAE,iBAAiB,qBA6KnB"}
@@ -0,0 +1,123 @@
1
+ 'use client';
2
+ import React, { useState, useRef, useEffect } from 'react';
3
+ export function DropdownMenu({ trigger, items, align = 'right', className = '', }) {
4
+ const [isOpen, setIsOpen] = useState(false);
5
+ const [focusedIndex, setFocusedIndex] = useState(-1);
6
+ const menuRef = useRef(null);
7
+ const triggerRef = useRef(null);
8
+ // Get only the actual menu items (not dividers)
9
+ const menuItems = items.filter((item) => item !== 'divider');
10
+ useEffect(() => {
11
+ const handleClickOutside = (event) => {
12
+ if (menuRef.current &&
13
+ !menuRef.current.contains(event.target) &&
14
+ triggerRef.current &&
15
+ !triggerRef.current.contains(event.target)) {
16
+ setIsOpen(false);
17
+ setFocusedIndex(-1);
18
+ }
19
+ };
20
+ if (isOpen) {
21
+ document.addEventListener('mousedown', handleClickOutside);
22
+ return () => document.removeEventListener('mousedown', handleClickOutside);
23
+ }
24
+ }, [isOpen]);
25
+ const handleKeyDown = (e) => {
26
+ if (!isOpen) {
27
+ if (e.key === 'Enter' || e.key === ' ' || e.key === 'ArrowDown') {
28
+ e.preventDefault();
29
+ setIsOpen(true);
30
+ setFocusedIndex(0);
31
+ }
32
+ return;
33
+ }
34
+ switch (e.key) {
35
+ case 'Escape':
36
+ e.preventDefault();
37
+ setIsOpen(false);
38
+ setFocusedIndex(-1);
39
+ triggerRef.current?.focus();
40
+ break;
41
+ case 'ArrowDown':
42
+ e.preventDefault();
43
+ setFocusedIndex((prev) => {
44
+ const nextIndex = prev + 1;
45
+ return nextIndex >= menuItems.length ? 0 : nextIndex;
46
+ });
47
+ break;
48
+ case 'ArrowUp':
49
+ e.preventDefault();
50
+ setFocusedIndex((prev) => {
51
+ const nextIndex = prev - 1;
52
+ return nextIndex < 0 ? menuItems.length - 1 : nextIndex;
53
+ });
54
+ break;
55
+ case 'Enter':
56
+ case ' ':
57
+ e.preventDefault();
58
+ if (focusedIndex >= 0 && focusedIndex < menuItems.length) {
59
+ const item = menuItems[focusedIndex];
60
+ if (!item.disabled) {
61
+ item.onClick();
62
+ setIsOpen(false);
63
+ setFocusedIndex(-1);
64
+ }
65
+ }
66
+ break;
67
+ case 'Tab':
68
+ // Focus trap: keep focus within menu
69
+ e.preventDefault();
70
+ if (e.shiftKey) {
71
+ // Shift+Tab: move backwards
72
+ setFocusedIndex((prev) => {
73
+ const nextIndex = prev - 1;
74
+ return nextIndex < 0 ? menuItems.length - 1 : nextIndex;
75
+ });
76
+ }
77
+ else {
78
+ // Tab: move forwards
79
+ setFocusedIndex((prev) => {
80
+ const nextIndex = prev + 1;
81
+ return nextIndex >= menuItems.length ? 0 : nextIndex;
82
+ });
83
+ }
84
+ break;
85
+ }
86
+ };
87
+ const handleItemClick = (item) => {
88
+ if (!item.disabled) {
89
+ item.onClick();
90
+ setIsOpen(false);
91
+ setFocusedIndex(-1);
92
+ }
93
+ };
94
+ return (React.createElement("div", { className: `relative inline-block ${className}` },
95
+ React.createElement("button", { ref: triggerRef, onClick: () => setIsOpen(!isOpen), onKeyDown: handleKeyDown, className: "focus:outline-none", "aria-haspopup": "true", "aria-expanded": isOpen }, trigger),
96
+ isOpen && (React.createElement("div", { ref: menuRef, className: `
97
+ absolute z-50 mt-2 w-56 rounded-md shadow-lg
98
+ bg-white dark:bg-gray-800
99
+ border border-gray-200 dark:border-gray-700
100
+ ${align === 'right' ? 'right-0' : 'left-0'}
101
+ `, role: "menu", "aria-orientation": "vertical" },
102
+ React.createElement("div", { className: "py-1" }, items.map((item, index) => {
103
+ if (item === 'divider') {
104
+ return (React.createElement("div", { key: `divider-${index}`, className: "my-1 border-t border-gray-200 dark:border-gray-700", role: "separator" }));
105
+ }
106
+ const Icon = item.icon;
107
+ const menuItemIndex = menuItems.indexOf(item);
108
+ const isFocused = menuItemIndex === focusedIndex;
109
+ return (React.createElement("button", { key: index, onClick: () => handleItemClick(item), disabled: item.disabled, role: "menuitem", className: `
110
+ w-full flex items-center gap-3 px-4 py-2 text-sm text-left
111
+ transition-colors
112
+ ${item.disabled
113
+ ? 'opacity-50 cursor-not-allowed'
114
+ : item.danger
115
+ ? 'text-red-600 dark:text-red-400 hover:bg-red-50 dark:hover:bg-red-900/20'
116
+ : 'text-gray-700 dark:text-gray-300 hover:bg-gray-100 dark:hover:bg-gray-700'}
117
+ ${isFocused ? 'bg-gray-100 dark:bg-gray-700' : ''}
118
+ ` },
119
+ Icon && React.createElement(Icon, { className: "w-4 h-4 flex-shrink-0" }),
120
+ React.createElement("span", null, item.label)));
121
+ }))))));
122
+ }
123
+ //# sourceMappingURL=DropdownMenu.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"DropdownMenu.js","sourceRoot":"","sources":["../../../src/components/Overlay/DropdownMenu.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Overlay Components
3
+ *
4
+ * Modal dialogs and overlays for Varity dashboards
5
+ */
6
+ export { Dialog } from './Dialog';
7
+ export { ConfirmDialog } from './ConfirmDialog';
8
+ export { DropdownMenu } from './DropdownMenu';
9
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../../../src/components/Overlay/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
@@ -0,0 +1,9 @@
1
+ /**
2
+ * Overlay Components
3
+ *
4
+ * Modal dialogs and overlays for Varity dashboards
5
+ */
6
+ export { Dialog } from './Dialog';
7
+ export { ConfirmDialog } from './ConfirmDialog';
8
+ export { DropdownMenu } from './DropdownMenu';
9
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Overlay/index.ts"],"names":[],"mappings":"AAAA;;;;GAIG;AAEH,OAAO,EAAE,MAAM,EAAE,MAAM,UAAU,CAAC;AAClC,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAChD,OAAO,EAAE,YAAY,EAAE,MAAM,gBAAgB,CAAC"}
@@ -0,0 +1,30 @@
1
+ /**
2
+ * PaymentGate Component
3
+ *
4
+ * A paywall component that shows premium content only to users who have purchased.
5
+ * Shows a fallback/paywall UI for non-purchasers.
6
+ *
7
+ * @example
8
+ * ```tsx
9
+ * import { PaymentGate } from '@varity/ui-kit';
10
+ *
11
+ * <PaymentGate
12
+ * appId={123}
13
+ * price={9900}
14
+ * fallback={<LockedContent />}
15
+ * >
16
+ * <PremiumContent />
17
+ * </PaymentGate>
18
+ * ```
19
+ */
20
+ import React from 'react';
21
+ import { PaymentGateProps } from './types';
22
+ /**
23
+ * PaymentGate - Paywall component for premium content
24
+ *
25
+ * Automatically shows premium content if the user has purchased,
26
+ * otherwise shows the fallback UI with a purchase option.
27
+ */
28
+ export declare const PaymentGate: React.FC<PaymentGateProps>;
29
+ export default PaymentGate;
30
+ //# sourceMappingURL=PaymentGate.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PaymentGate.d.ts","sourceRoot":"","sources":["../../../src/components/PaymentWidget/PaymentGate.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAC1B,OAAO,EAAE,gBAAgB,EAAE,MAAM,SAAS,CAAC;AAI3C;;;;;GAKG;AACH,eAAO,MAAM,WAAW,EAAE,KAAK,CAAC,EAAE,CAAC,gBAAgB,CAoDlD,CAAC;AAEF,eAAe,WAAW,CAAC"}
@@ -0,0 +1,54 @@
1
+ /**
2
+ * PaymentGate Component
3
+ *
4
+ * A paywall component that shows premium content only to users who have purchased.
5
+ * Shows a fallback/paywall UI for non-purchasers.
6
+ *
7
+ * @example
8
+ * ```tsx
9
+ * import { PaymentGate } from '@varity/ui-kit';
10
+ *
11
+ * <PaymentGate
12
+ * appId={123}
13
+ * price={9900}
14
+ * fallback={<LockedContent />}
15
+ * >
16
+ * <PremiumContent />
17
+ * </PaymentGate>
18
+ * ```
19
+ */
20
+ import React from 'react';
21
+ import { useVarityPayment } from './useVarityPayment';
22
+ import { PaymentWidget } from './PaymentWidget';
23
+ /**
24
+ * PaymentGate - Paywall component for premium content
25
+ *
26
+ * Automatically shows premium content if the user has purchased,
27
+ * otherwise shows the fallback UI with a purchase option.
28
+ */
29
+ export const PaymentGate = ({ appId, price, fallback, children, theme = 'dark', className = '', }) => {
30
+ const { hasPurchased, isLoading, pricing } = useVarityPayment({ appId });
31
+ // Loading state
32
+ if (isLoading) {
33
+ return (React.createElement("div", { className: `flex items-center justify-center p-8 ${className}` },
34
+ React.createElement("div", { className: "animate-pulse flex items-center gap-2 text-gray-500" },
35
+ React.createElement("svg", { className: "animate-spin h-5 w-5", fill: "none", viewBox: "0 0 24 24" },
36
+ React.createElement("circle", { className: "opacity-25", cx: "12", cy: "12", r: "10", stroke: "currentColor", strokeWidth: "4" }),
37
+ 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" })),
38
+ React.createElement("span", null, "Loading..."))));
39
+ }
40
+ // User has purchased - show premium content
41
+ if (hasPurchased) {
42
+ return React.createElement(React.Fragment, null, children);
43
+ }
44
+ // User has not purchased - show fallback/paywall
45
+ return (React.createElement("div", { className: className },
46
+ fallback,
47
+ pricing?.isActive && (React.createElement("div", { className: "mt-4 text-center" },
48
+ React.createElement(PaymentWidget, { appId: appId, price: price, theme: theme },
49
+ React.createElement("button", { className: "px-6 py-3 bg-blue-600 hover:bg-blue-700 text-white font-bold rounded-lg transition-colors" },
50
+ "Unlock for $",
51
+ price ? (price / 100).toFixed(2) : (Number(pricing.priceUsdc) / 1_000_000).toFixed(2)))))));
52
+ };
53
+ export default PaymentGate;
54
+ //# sourceMappingURL=PaymentGate.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PaymentGate.js","sourceRoot":"","sources":["../../../src/components/PaymentWidget/PaymentGate.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;GAkBG;AAEH,OAAO,KAAK,MAAM,OAAO,CAAC;AAE1B,OAAO,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AACtD,OAAO,EAAE,aAAa,EAAE,MAAM,iBAAiB,CAAC;AAEhD;;;;;GAKG;AACH,MAAM,CAAC,MAAM,WAAW,GAA+B,CAAC,EACtD,KAAK,EACL,KAAK,EACL,QAAQ,EACR,QAAQ,EACR,KAAK,GAAG,MAAM,EACd,SAAS,GAAG,EAAE,GACf,EAAE,EAAE;IACH,MAAM,EAAE,YAAY,EAAE,SAAS,EAAE,OAAO,EAAE,GAAG,gBAAgB,CAAC,EAAE,KAAK,EAAE,CAAC,CAAC;IAEzE,gBAAgB;IAChB,IAAI,SAAS,EAAE,CAAC;QACd,OAAO,CACL,6BAAK,SAAS,EAAE,wCAAwC,SAAS,EAAE;YACjE,6BAAK,SAAS,EAAC,qDAAqD;gBAClE,6BAAK,SAAS,EAAC,sBAAsB,EAAC,IAAI,EAAC,MAAM,EAAC,OAAO,EAAC,WAAW;oBACnE,gCAAQ,SAAS,EAAC,YAAY,EAAC,EAAE,EAAC,IAAI,EAAC,EAAE,EAAC,IAAI,EAAC,CAAC,EAAC,IAAI,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAC,GAAG,GAAG;oBAC9F,8BAAM,SAAS,EAAC,YAAY,EAAC,IAAI,EAAC,cAAc,EAAC,CAAC,EAAC,iHAAiH,GAAG,CACnK;gBACN,+CAAuB,CACnB,CACF,CACP,CAAC;IACJ,CAAC;IAED,4CAA4C;IAC5C,IAAI,YAAY,EAAE,CAAC;QACjB,OAAO,0CAAG,QAAQ,CAAI,CAAC;IACzB,CAAC;IAED,iDAAiD;IACjD,OAAO,CACL,6BAAK,SAAS,EAAE,SAAS;QAEtB,QAAQ;QAGR,OAAO,EAAE,QAAQ,IAAI,CACpB,6BAAK,SAAS,EAAC,kBAAkB;YAC/B,oBAAC,aAAa,IACZ,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK;gBAEZ,gCAAQ,SAAS,EAAC,2FAA2F;;oBAC9F,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,GAAG,GAAG,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC,SAAS,CAAC,GAAG,SAAS,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,CAC3F,CACK,CACZ,CACP,CACG,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,WAAW,CAAC"}
@@ -0,0 +1,40 @@
1
+ /**
2
+ * PaymentWidget Component
3
+ *
4
+ * REQUIRED in every Varity app that charges users.
5
+ * All payments go through the VarityPayments contract with 90/10 revenue split:
6
+ * - 90% to developer
7
+ * - 10% to Varity treasury
8
+ *
9
+ * Zero-crypto checkout: Users pay with credit card via thirdweb Pay.
10
+ * No wallets, no tokens, no blockchain terminology visible.
11
+ * The experience is identical to Stripe checkout.
12
+ *
13
+ * Flow:
14
+ * 1. User clicks purchase button
15
+ * 2. Credit card form appears (thirdweb Pay modal)
16
+ * 3. thirdweb converts USD → USDC on Arbitrum One
17
+ * 4. USDC approve + purchaseApp() execute automatically
18
+ * 5. User sees "Purchase complete" — never sees crypto
19
+ *
20
+ * @example
21
+ * ```tsx
22
+ * import { PaymentWidget } from '@varity-labs/ui-kit';
23
+ *
24
+ * <PaymentWidget appId={123} price={9900}>
25
+ * <button>Buy Premium - $99</button>
26
+ * </PaymentWidget>
27
+ * ```
28
+ */
29
+ import React from 'react';
30
+ import { PaymentWidgetProps } from './types';
31
+ /**
32
+ * PaymentWidget - Required component for app monetization
33
+ *
34
+ * Wraps a trigger element and handles the full purchase flow.
35
+ * Automatically checks USDC allowance — skips authorize step if sufficient.
36
+ * Credit card payments handled seamlessly via thirdweb Pay.
37
+ */
38
+ export declare const PaymentWidget: React.FC<PaymentWidgetProps>;
39
+ export default PaymentWidget;
40
+ //# sourceMappingURL=PaymentWidget.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PaymentWidget.d.ts","sourceRoot":"","sources":["../../../src/components/PaymentWidget/PaymentWidget.tsx"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;GA2BG;AAEH,OAAO,KAA8B,MAAM,OAAO,CAAC;AAInD,OAAO,EAAE,kBAAkB,EAAE,MAAM,SAAS,CAAC;AA6C7C;;;;;;GAMG;AACH,eAAO,MAAM,aAAa,EAAE,KAAK,CAAC,EAAE,CAAC,kBAAkB,CA4KtD,CAAC;AAEF,eAAe,aAAa,CAAC"}