@mmailaender/convex-creem 0.1.0

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 (383) hide show
  1. package/LICENSE +201 -0
  2. package/README.md +1176 -0
  3. package/dist/client/helpers.d.ts +17 -0
  4. package/dist/client/helpers.d.ts.map +1 -0
  5. package/dist/client/helpers.js +43 -0
  6. package/dist/client/helpers.js.map +1 -0
  7. package/dist/client/index.d.ts +1041 -0
  8. package/dist/client/index.d.ts.map +1 -0
  9. package/dist/client/index.js +1068 -0
  10. package/dist/client/index.js.map +1 -0
  11. package/dist/client/parsers.d.ts +45 -0
  12. package/dist/client/parsers.d.ts.map +1 -0
  13. package/dist/client/parsers.js +138 -0
  14. package/dist/client/parsers.js.map +1 -0
  15. package/dist/client/polyfill.d.ts +2 -0
  16. package/dist/client/polyfill.d.ts.map +1 -0
  17. package/dist/client/polyfill.js +3 -0
  18. package/dist/client/polyfill.js.map +1 -0
  19. package/dist/component/_generated/api.d.ts +36 -0
  20. package/dist/component/_generated/api.d.ts.map +1 -0
  21. package/dist/component/_generated/api.js +31 -0
  22. package/dist/component/_generated/api.js.map +1 -0
  23. package/dist/component/_generated/component.d.ts +542 -0
  24. package/dist/component/_generated/component.d.ts.map +1 -0
  25. package/dist/component/_generated/component.js +11 -0
  26. package/dist/component/_generated/component.js.map +1 -0
  27. package/dist/component/_generated/dataModel.d.ts +46 -0
  28. package/dist/component/_generated/dataModel.d.ts.map +1 -0
  29. package/dist/component/_generated/dataModel.js +11 -0
  30. package/dist/component/_generated/dataModel.js.map +1 -0
  31. package/dist/component/_generated/server.d.ts +121 -0
  32. package/dist/component/_generated/server.d.ts.map +1 -0
  33. package/dist/component/_generated/server.js +78 -0
  34. package/dist/component/_generated/server.js.map +1 -0
  35. package/dist/component/convex.config.d.ts +3 -0
  36. package/dist/component/convex.config.d.ts.map +1 -0
  37. package/dist/component/convex.config.js +3 -0
  38. package/dist/component/convex.config.js.map +1 -0
  39. package/dist/component/lib.d.ts +1005 -0
  40. package/dist/component/lib.d.ts.map +1 -0
  41. package/dist/component/lib.js +647 -0
  42. package/dist/component/lib.js.map +1 -0
  43. package/dist/component/schema.d.ts +191 -0
  44. package/dist/component/schema.d.ts.map +1 -0
  45. package/dist/component/schema.js +104 -0
  46. package/dist/component/schema.js.map +1 -0
  47. package/dist/component/util.d.ts +61 -0
  48. package/dist/component/util.d.ts.map +1 -0
  49. package/dist/component/util.js +142 -0
  50. package/dist/component/util.js.map +1 -0
  51. package/dist/core/catalog.d.ts +18 -0
  52. package/dist/core/catalog.d.ts.map +1 -0
  53. package/dist/core/catalog.js +82 -0
  54. package/dist/core/catalog.js.map +1 -0
  55. package/dist/core/index.d.ts +9 -0
  56. package/dist/core/index.d.ts.map +1 -0
  57. package/dist/core/index.js +9 -0
  58. package/dist/core/index.js.map +1 -0
  59. package/dist/core/markdown.d.ts +12 -0
  60. package/dist/core/markdown.d.ts.map +1 -0
  61. package/dist/core/markdown.js +26 -0
  62. package/dist/core/markdown.js.map +1 -0
  63. package/dist/core/payments.d.ts +11 -0
  64. package/dist/core/payments.d.ts.map +1 -0
  65. package/dist/core/payments.js +27 -0
  66. package/dist/core/payments.js.map +1 -0
  67. package/dist/core/pendingCheckout.d.ts +15 -0
  68. package/dist/core/pendingCheckout.d.ts.map +1 -0
  69. package/dist/core/pendingCheckout.js +40 -0
  70. package/dist/core/pendingCheckout.js.map +1 -0
  71. package/dist/core/resolver.d.ts +11 -0
  72. package/dist/core/resolver.d.ts.map +1 -0
  73. package/dist/core/resolver.js +106 -0
  74. package/dist/core/resolver.js.map +1 -0
  75. package/dist/core/selectors.d.ts +12 -0
  76. package/dist/core/selectors.d.ts.map +1 -0
  77. package/dist/core/selectors.js +18 -0
  78. package/dist/core/selectors.js.map +1 -0
  79. package/dist/core/subscriptionUpdate.d.ts +20 -0
  80. package/dist/core/subscriptionUpdate.d.ts.map +1 -0
  81. package/dist/core/subscriptionUpdate.js +64 -0
  82. package/dist/core/subscriptionUpdate.js.map +1 -0
  83. package/dist/core/types.d.ts +170 -0
  84. package/dist/core/types.d.ts.map +1 -0
  85. package/dist/core/types.js +15 -0
  86. package/dist/core/types.js.map +1 -0
  87. package/dist/design-system/colors/color-utils.d.ts +10 -0
  88. package/dist/design-system/colors/color-utils.d.ts.map +1 -0
  89. package/dist/design-system/colors/color-utils.js +91 -0
  90. package/dist/design-system/colors/color-utils.js.map +1 -0
  91. package/dist/design-system/colors/config.d.ts +33 -0
  92. package/dist/design-system/colors/config.d.ts.map +1 -0
  93. package/dist/design-system/colors/config.js +224 -0
  94. package/dist/design-system/colors/config.js.map +1 -0
  95. package/dist/design-system/colors/index.d.ts +3 -0
  96. package/dist/design-system/colors/index.d.ts.map +1 -0
  97. package/dist/design-system/colors/index.js +3 -0
  98. package/dist/design-system/colors/index.js.map +1 -0
  99. package/dist/design-system/rounded/config.d.ts +31 -0
  100. package/dist/design-system/rounded/config.d.ts.map +1 -0
  101. package/dist/design-system/rounded/config.js +76 -0
  102. package/dist/design-system/rounded/config.js.map +1 -0
  103. package/dist/design-system/rounded/index.d.ts +2 -0
  104. package/dist/design-system/rounded/index.d.ts.map +1 -0
  105. package/dist/design-system/rounded/index.js +2 -0
  106. package/dist/design-system/rounded/index.js.map +1 -0
  107. package/dist/design-system/typography/config.d.ts +55 -0
  108. package/dist/design-system/typography/config.d.ts.map +1 -0
  109. package/dist/design-system/typography/config.js +308 -0
  110. package/dist/design-system/typography/config.js.map +1 -0
  111. package/dist/design-system/typography/index.d.ts +3 -0
  112. package/dist/design-system/typography/index.d.ts.map +1 -0
  113. package/dist/design-system/typography/index.js +3 -0
  114. package/dist/design-system/typography/index.js.map +1 -0
  115. package/dist/design-system/typography/tokens.d.ts +23 -0
  116. package/dist/design-system/typography/tokens.d.ts.map +1 -0
  117. package/dist/design-system/typography/tokens.js +99 -0
  118. package/dist/design-system/typography/tokens.js.map +1 -0
  119. package/dist/react/hooks/useCheckoutSuccessParams.d.ts +2 -0
  120. package/dist/react/hooks/useCheckoutSuccessParams.d.ts.map +1 -0
  121. package/dist/react/hooks/useCheckoutSuccessParams.js +5 -0
  122. package/dist/react/hooks/useCheckoutSuccessParams.js.map +1 -0
  123. package/dist/react/index.d.ts +25 -0
  124. package/dist/react/index.d.ts.map +1 -0
  125. package/dist/react/index.js +22 -0
  126. package/dist/react/index.js.map +1 -0
  127. package/dist/react/primitives/BillingGate.d.ts +8 -0
  128. package/dist/react/primitives/BillingGate.d.ts.map +1 -0
  129. package/dist/react/primitives/BillingGate.js +13 -0
  130. package/dist/react/primitives/BillingGate.js.map +1 -0
  131. package/dist/react/primitives/BillingToggle.d.ts +8 -0
  132. package/dist/react/primitives/BillingToggle.d.ts.map +1 -0
  133. package/dist/react/primitives/BillingToggle.js +12 -0
  134. package/dist/react/primitives/BillingToggle.js.map +1 -0
  135. package/dist/react/primitives/CheckoutButton.d.ts +11 -0
  136. package/dist/react/primitives/CheckoutButton.d.ts.map +1 -0
  137. package/dist/react/primitives/CheckoutButton.js +21 -0
  138. package/dist/react/primitives/CheckoutButton.js.map +1 -0
  139. package/dist/react/primitives/CheckoutSuccessSummary.d.ts +7 -0
  140. package/dist/react/primitives/CheckoutSuccessSummary.d.ts.map +1 -0
  141. package/dist/react/primitives/CheckoutSuccessSummary.js +11 -0
  142. package/dist/react/primitives/CheckoutSuccessSummary.js.map +1 -0
  143. package/dist/react/primitives/CustomerPortalButton.d.ts +8 -0
  144. package/dist/react/primitives/CustomerPortalButton.d.ts.map +1 -0
  145. package/dist/react/primitives/CustomerPortalButton.js +21 -0
  146. package/dist/react/primitives/CustomerPortalButton.js.map +1 -0
  147. package/dist/react/primitives/NumberInput.d.ts +11 -0
  148. package/dist/react/primitives/NumberInput.d.ts.map +1 -0
  149. package/dist/react/primitives/NumberInput.js +18 -0
  150. package/dist/react/primitives/NumberInput.js.map +1 -0
  151. package/dist/react/primitives/OneTimeCheckoutButton.d.ts +11 -0
  152. package/dist/react/primitives/OneTimeCheckoutButton.d.ts.map +1 -0
  153. package/dist/react/primitives/OneTimeCheckoutButton.js +4 -0
  154. package/dist/react/primitives/OneTimeCheckoutButton.js.map +1 -0
  155. package/dist/react/primitives/OneTimePaymentStatusBadge.d.ts +6 -0
  156. package/dist/react/primitives/OneTimePaymentStatusBadge.d.ts.map +1 -0
  157. package/dist/react/primitives/OneTimePaymentStatusBadge.js +11 -0
  158. package/dist/react/primitives/OneTimePaymentStatusBadge.js.map +1 -0
  159. package/dist/react/primitives/PaymentWarningBanner.d.ts +7 -0
  160. package/dist/react/primitives/PaymentWarningBanner.d.ts.map +1 -0
  161. package/dist/react/primitives/PaymentWarningBanner.js +18 -0
  162. package/dist/react/primitives/PaymentWarningBanner.js.map +1 -0
  163. package/dist/react/primitives/PricingCard.d.ts +37 -0
  164. package/dist/react/primitives/PricingCard.d.ts.map +1 -0
  165. package/dist/react/primitives/PricingCard.js +125 -0
  166. package/dist/react/primitives/PricingCard.js.map +1 -0
  167. package/dist/react/primitives/PricingSection.d.ts +39 -0
  168. package/dist/react/primitives/PricingSection.d.ts.map +1 -0
  169. package/dist/react/primitives/PricingSection.js +24 -0
  170. package/dist/react/primitives/PricingSection.js.map +1 -0
  171. package/dist/react/primitives/ScheduledChangeBanner.d.ts +8 -0
  172. package/dist/react/primitives/ScheduledChangeBanner.d.ts.map +1 -0
  173. package/dist/react/primitives/ScheduledChangeBanner.js +13 -0
  174. package/dist/react/primitives/ScheduledChangeBanner.js.map +1 -0
  175. package/dist/react/primitives/SegmentControl.d.ts +11 -0
  176. package/dist/react/primitives/SegmentControl.d.ts.map +1 -0
  177. package/dist/react/primitives/SegmentControl.js +8 -0
  178. package/dist/react/primitives/SegmentControl.js.map +1 -0
  179. package/dist/react/primitives/SegmentGroup.d.ts +14 -0
  180. package/dist/react/primitives/SegmentGroup.d.ts.map +1 -0
  181. package/dist/react/primitives/SegmentGroup.js +11 -0
  182. package/dist/react/primitives/SegmentGroup.js.map +1 -0
  183. package/dist/react/primitives/TrialLimitBanner.d.ts +7 -0
  184. package/dist/react/primitives/TrialLimitBanner.d.ts.map +1 -0
  185. package/dist/react/primitives/TrialLimitBanner.js +14 -0
  186. package/dist/react/primitives/TrialLimitBanner.js.map +1 -0
  187. package/dist/react/shared.d.ts +28 -0
  188. package/dist/react/shared.d.ts.map +1 -0
  189. package/dist/react/shared.js +109 -0
  190. package/dist/react/shared.js.map +1 -0
  191. package/dist/react/widgets/BillingPortal.d.ts +9 -0
  192. package/dist/react/widgets/BillingPortal.d.ts.map +1 -0
  193. package/dist/react/widgets/BillingPortal.js +30 -0
  194. package/dist/react/widgets/BillingPortal.js.map +1 -0
  195. package/dist/react/widgets/ProductItem.d.ts +8 -0
  196. package/dist/react/widgets/ProductItem.d.ts.map +1 -0
  197. package/dist/react/widgets/ProductItem.js +14 -0
  198. package/dist/react/widgets/ProductItem.js.map +1 -0
  199. package/dist/react/widgets/ProductRoot.d.ts +16 -0
  200. package/dist/react/widgets/ProductRoot.d.ts.map +1 -0
  201. package/dist/react/widgets/ProductRoot.js +171 -0
  202. package/dist/react/widgets/ProductRoot.js.map +1 -0
  203. package/dist/react/widgets/SubscriptionItem.d.ts +27 -0
  204. package/dist/react/widgets/SubscriptionItem.d.ts.map +1 -0
  205. package/dist/react/widgets/SubscriptionItem.js +32 -0
  206. package/dist/react/widgets/SubscriptionItem.js.map +1 -0
  207. package/dist/react/widgets/SubscriptionRoot.d.ts +16 -0
  208. package/dist/react/widgets/SubscriptionRoot.d.ts.map +1 -0
  209. package/dist/react/widgets/SubscriptionRoot.js +405 -0
  210. package/dist/react/widgets/SubscriptionRoot.js.map +1 -0
  211. package/dist/react/widgets/index.d.ts +19 -0
  212. package/dist/react/widgets/index.d.ts.map +1 -0
  213. package/dist/react/widgets/index.js +16 -0
  214. package/dist/react/widgets/index.js.map +1 -0
  215. package/dist/react/widgets/productGroupContext.d.ts +6 -0
  216. package/dist/react/widgets/productGroupContext.d.ts.map +1 -0
  217. package/dist/react/widgets/productGroupContext.js +3 -0
  218. package/dist/react/widgets/productGroupContext.js.map +1 -0
  219. package/dist/react/widgets/subscriptionContext.d.ts +6 -0
  220. package/dist/react/widgets/subscriptionContext.d.ts.map +1 -0
  221. package/dist/react/widgets/subscriptionContext.js +3 -0
  222. package/dist/react/widgets/subscriptionContext.js.map +1 -0
  223. package/dist/react/widgets/types.d.ts +171 -0
  224. package/dist/react/widgets/types.d.ts.map +1 -0
  225. package/dist/react/widgets/types.js +2 -0
  226. package/dist/react/widgets/types.js.map +1 -0
  227. package/dist/svelte/index.d.ts +22 -0
  228. package/dist/svelte/index.d.ts.map +1 -0
  229. package/dist/svelte/index.js +20 -0
  230. package/dist/svelte/index.js.map +1 -0
  231. package/dist/svelte/primitives/BillingGate.svelte +28 -0
  232. package/dist/svelte/primitives/BillingToggle.svelte +27 -0
  233. package/dist/svelte/primitives/CheckoutButton.svelte +60 -0
  234. package/dist/svelte/primitives/CheckoutSuccessSummary.svelte +34 -0
  235. package/dist/svelte/primitives/CustomerPortalButton.svelte +60 -0
  236. package/dist/svelte/primitives/NumberInput.svelte +71 -0
  237. package/dist/svelte/primitives/OneTimeCheckoutButton.svelte +37 -0
  238. package/dist/svelte/primitives/OneTimePaymentStatusBadge.svelte +20 -0
  239. package/dist/svelte/primitives/PaymentWarningBanner.svelte +30 -0
  240. package/dist/svelte/primitives/PricingCard.svelte +356 -0
  241. package/dist/svelte/primitives/PricingSection.svelte +121 -0
  242. package/dist/svelte/primitives/ScheduledChangeBanner.svelte +46 -0
  243. package/dist/svelte/primitives/SegmentControl.svelte +38 -0
  244. package/dist/svelte/primitives/SegmentGroup.svelte +52 -0
  245. package/dist/svelte/primitives/TrialLimitBanner.svelte +32 -0
  246. package/dist/svelte/primitives/shared.d.ts +13 -0
  247. package/dist/svelte/primitives/shared.d.ts.map +1 -0
  248. package/dist/svelte/primitives/shared.js +87 -0
  249. package/dist/svelte/primitives/shared.js.map +1 -0
  250. package/dist/svelte/widgets/BillingPortal.svelte +55 -0
  251. package/dist/svelte/widgets/Product.svelte +35 -0
  252. package/dist/svelte/widgets/ProductRoot.svelte +428 -0
  253. package/dist/svelte/widgets/Subscription.svelte +52 -0
  254. package/dist/svelte/widgets/SubscriptionRoot.svelte +690 -0
  255. package/dist/svelte/widgets/index.d.ts +19 -0
  256. package/dist/svelte/widgets/index.d.ts.map +1 -0
  257. package/dist/svelte/widgets/index.js +16 -0
  258. package/dist/svelte/widgets/index.js.map +1 -0
  259. package/dist/svelte/widgets/productGroupContext.d.ts +6 -0
  260. package/dist/svelte/widgets/productGroupContext.d.ts.map +1 -0
  261. package/dist/svelte/widgets/productGroupContext.js +2 -0
  262. package/dist/svelte/widgets/productGroupContext.js.map +1 -0
  263. package/dist/svelte/widgets/subscriptionContext.d.ts +6 -0
  264. package/dist/svelte/widgets/subscriptionContext.d.ts.map +1 -0
  265. package/dist/svelte/widgets/subscriptionContext.js +2 -0
  266. package/dist/svelte/widgets/subscriptionContext.js.map +1 -0
  267. package/dist/svelte/widgets/types.d.ts +171 -0
  268. package/dist/svelte/widgets/types.d.ts.map +1 -0
  269. package/dist/svelte/widgets/types.js +2 -0
  270. package/dist/svelte/widgets/types.js.map +1 -0
  271. package/package.json +182 -0
  272. package/src/client/helpers.test.ts +139 -0
  273. package/src/client/helpers.ts +51 -0
  274. package/src/client/index.test.ts +1554 -0
  275. package/src/client/index.ts +1504 -0
  276. package/src/client/parsers.test.ts +1017 -0
  277. package/src/client/parsers.ts +182 -0
  278. package/src/client/polyfill.ts +2 -0
  279. package/src/component/_generated/api.ts +52 -0
  280. package/src/component/_generated/component.ts +619 -0
  281. package/src/component/_generated/dataModel.ts +60 -0
  282. package/src/component/_generated/server.ts +156 -0
  283. package/src/component/convex.config.ts +3 -0
  284. package/src/component/lib.test.ts +1359 -0
  285. package/src/component/lib.ts +726 -0
  286. package/src/component/schema.ts +112 -0
  287. package/src/component/util.test.ts +281 -0
  288. package/src/component/util.ts +228 -0
  289. package/src/core/catalog.test.ts +212 -0
  290. package/src/core/catalog.ts +119 -0
  291. package/src/core/index.ts +8 -0
  292. package/src/core/markdown.test.ts +43 -0
  293. package/src/core/markdown.ts +26 -0
  294. package/src/core/payments.test.ts +69 -0
  295. package/src/core/payments.ts +33 -0
  296. package/src/core/pendingCheckout.test.ts +44 -0
  297. package/src/core/pendingCheckout.ts +40 -0
  298. package/src/core/resolver.test.ts +283 -0
  299. package/src/core/resolver.ts +160 -0
  300. package/src/core/selectors.test.ts +119 -0
  301. package/src/core/selectors.ts +35 -0
  302. package/src/core/subscriptionUpdate.test.ts +164 -0
  303. package/src/core/subscriptionUpdate.ts +102 -0
  304. package/src/core/types.ts +220 -0
  305. package/src/design-system/README.md +40 -0
  306. package/src/design-system/base.css +27 -0
  307. package/src/design-system/colors/color-utils.ts +110 -0
  308. package/src/design-system/colors/config.ts +282 -0
  309. package/src/design-system/colors/index.ts +2 -0
  310. package/src/design-system/colors/utilities.css +2328 -0
  311. package/src/design-system/components/badges.css +65 -0
  312. package/src/design-system/components/buttons.css +256 -0
  313. package/src/design-system/components/dialog.css +218 -0
  314. package/src/design-system/components/icon-buttons.css +115 -0
  315. package/src/design-system/components/inputs.css +94 -0
  316. package/src/design-system/components/links.css +53 -0
  317. package/src/design-system/components/prose.css +67 -0
  318. package/src/design-system/components/segment-control.css +303 -0
  319. package/src/design-system/index.css +21 -0
  320. package/src/design-system/rounded/config.ts +91 -0
  321. package/src/design-system/rounded/index.ts +1 -0
  322. package/src/design-system/rounded/utilities.css +37 -0
  323. package/src/design-system/typography/config.ts +340 -0
  324. package/src/design-system/typography/index.ts +2 -0
  325. package/src/design-system/typography/tokens.ts +148 -0
  326. package/src/design-system/typography/utilities.css +728 -0
  327. package/src/library.css +20 -0
  328. package/src/react/hooks/useCheckoutSuccessParams.ts +7 -0
  329. package/src/react/index.tsx +47 -0
  330. package/src/react/primitives/BillingGate.tsx +26 -0
  331. package/src/react/primitives/BillingToggle.tsx +29 -0
  332. package/src/react/primitives/CheckoutButton.tsx +47 -0
  333. package/src/react/primitives/CheckoutSuccessSummary.tsx +36 -0
  334. package/src/react/primitives/CustomerPortalButton.tsx +50 -0
  335. package/src/react/primitives/NumberInput.tsx +83 -0
  336. package/src/react/primitives/OneTimeCheckoutButton.tsx +27 -0
  337. package/src/react/primitives/OneTimePaymentStatusBadge.tsx +18 -0
  338. package/src/react/primitives/PaymentWarningBanner.tsx +33 -0
  339. package/src/react/primitives/PricingCard.tsx +421 -0
  340. package/src/react/primitives/PricingSection.tsx +129 -0
  341. package/src/react/primitives/ScheduledChangeBanner.tsx +52 -0
  342. package/src/react/primitives/SegmentControl.tsx +32 -0
  343. package/src/react/primitives/SegmentGroup.tsx +53 -0
  344. package/src/react/primitives/TrialLimitBanner.tsx +32 -0
  345. package/src/react/shared.ts +138 -0
  346. package/src/react/widgets/BillingPortal.tsx +56 -0
  347. package/src/react/widgets/ProductItem.tsx +26 -0
  348. package/src/react/widgets/ProductRoot.tsx +441 -0
  349. package/src/react/widgets/SubscriptionItem.tsx +71 -0
  350. package/src/react/widgets/SubscriptionRoot.tsx +759 -0
  351. package/src/react/widgets/index.ts +36 -0
  352. package/src/react/widgets/productGroupContext.ts +10 -0
  353. package/src/react/widgets/subscriptionContext.ts +10 -0
  354. package/src/react/widgets/types.ts +179 -0
  355. package/src/svelte/index.ts +43 -0
  356. package/src/svelte/primitives/BillingGate.svelte +28 -0
  357. package/src/svelte/primitives/BillingToggle.svelte +27 -0
  358. package/src/svelte/primitives/CheckoutButton.svelte +60 -0
  359. package/src/svelte/primitives/CheckoutSuccessSummary.svelte +34 -0
  360. package/src/svelte/primitives/CustomerPortalButton.svelte +60 -0
  361. package/src/svelte/primitives/NumberInput.svelte +71 -0
  362. package/src/svelte/primitives/OneTimeCheckoutButton.svelte +37 -0
  363. package/src/svelte/primitives/OneTimePaymentStatusBadge.svelte +20 -0
  364. package/src/svelte/primitives/PaymentWarningBanner.svelte +30 -0
  365. package/src/svelte/primitives/PricingCard.svelte +356 -0
  366. package/src/svelte/primitives/PricingSection.svelte +121 -0
  367. package/src/svelte/primitives/ScheduledChangeBanner.svelte +46 -0
  368. package/src/svelte/primitives/SegmentControl.svelte +38 -0
  369. package/src/svelte/primitives/SegmentGroup.svelte +52 -0
  370. package/src/svelte/primitives/TrialLimitBanner.svelte +32 -0
  371. package/src/svelte/primitives/shared.ts +113 -0
  372. package/src/svelte/svelte.d.ts +6 -0
  373. package/src/svelte/widgets/BillingPortal.svelte +55 -0
  374. package/src/svelte/widgets/Product.svelte +35 -0
  375. package/src/svelte/widgets/ProductRoot.svelte +428 -0
  376. package/src/svelte/widgets/Subscription.svelte +52 -0
  377. package/src/svelte/widgets/SubscriptionRoot.svelte +690 -0
  378. package/src/svelte/widgets/index.ts +36 -0
  379. package/src/svelte/widgets/productGroupContext.ts +7 -0
  380. package/src/svelte/widgets/subscriptionContext.ts +7 -0
  381. package/src/svelte/widgets/types.ts +179 -0
  382. package/src/tailwind.css +6 -0
  383. package/src/test.ts +18 -0
@@ -0,0 +1,39 @@
1
+ import type { BillingSnapshot, UIPlanEntry, RecurringCycle } from "../../core/types.js";
2
+ import type { ConnectedProduct } from "../widgets/types.js";
3
+ export declare const PricingSection: ({ plans, snapshot, selectedCycle, products, subscriptionProductId, subscriptionStatus, subscriptionTrialEnd, units, showSeatPicker, twoColumnLayout, subscribedSeats, isGroupSubscribed, disableCheckout, disableSwitch, disableSeats, className, onCycleChange, onCheckout, onSwitchPlan, onUpdateSeats, onContactSales, onCancelSubscription, }: {
4
+ plans?: UIPlanEntry[];
5
+ snapshot?: BillingSnapshot | null;
6
+ selectedCycle?: RecurringCycle;
7
+ products?: ConnectedProduct[];
8
+ subscriptionProductId?: string | null;
9
+ subscriptionStatus?: string | null;
10
+ subscriptionTrialEnd?: string | null;
11
+ units?: number;
12
+ showSeatPicker?: boolean;
13
+ twoColumnLayout?: boolean;
14
+ subscribedSeats?: number | null;
15
+ isGroupSubscribed?: boolean;
16
+ disableCheckout?: boolean;
17
+ disableSwitch?: boolean;
18
+ disableSeats?: boolean;
19
+ className?: string;
20
+ onCycleChange?: (cycle: RecurringCycle) => void;
21
+ onCheckout?: (payload: {
22
+ plan: UIPlanEntry;
23
+ productId: string;
24
+ units?: number;
25
+ }) => Promise<void> | void;
26
+ onSwitchPlan?: (payload: {
27
+ plan: UIPlanEntry;
28
+ productId: string;
29
+ units?: number;
30
+ }) => Promise<void> | void;
31
+ onUpdateSeats?: (payload: {
32
+ units: number;
33
+ }) => Promise<void> | void;
34
+ onContactSales?: (payload: {
35
+ plan: UIPlanEntry;
36
+ }) => Promise<void> | void;
37
+ onCancelSubscription?: () => void;
38
+ }) => import("react/jsx-runtime").JSX.Element;
39
+ //# sourceMappingURL=PricingSection.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PricingSection.d.ts","sourceRoot":"","sources":["../../../src/react/primitives/PricingSection.tsx"],"names":[],"mappings":"AAGA,OAAO,KAAK,EACV,eAAe,EACf,WAAW,EACX,cAAc,EACf,MAAM,qBAAqB,CAAC;AAC7B,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,qBAAqB,CAAC;AAE5D,eAAO,MAAM,cAAc,GAAI,mVAuB5B;IACD,KAAK,CAAC,EAAE,WAAW,EAAE,CAAC;IACtB,QAAQ,CAAC,EAAE,eAAe,GAAG,IAAI,CAAC;IAClC,aAAa,CAAC,EAAE,cAAc,CAAC;IAC/B,QAAQ,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAC9B,qBAAqB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtC,kBAAkB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACnC,oBAAoB,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACrC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,cAAc,CAAC,EAAE,OAAO,CAAC;IACzB,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,eAAe,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAChC,iBAAiB,CAAC,EAAE,OAAO,CAAC;IAC5B,eAAe,CAAC,EAAE,OAAO,CAAC;IAC1B,aAAa,CAAC,EAAE,OAAO,CAAC;IACxB,YAAY,CAAC,EAAE,OAAO,CAAC;IACvB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,cAAc,KAAK,IAAI,CAAC;IAChD,UAAU,CAAC,EAAE,CAAC,OAAO,EAAE;QACrB,IAAI,EAAE,WAAW,CAAC;QAClB,SAAS,EAAE,MAAM,CAAC;QAClB,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC3B,YAAY,CAAC,EAAE,CAAC,OAAO,EAAE;QACvB,IAAI,EAAE,WAAW,CAAC;QAClB,SAAS,EAAE,MAAM,CAAC;QAClB,KAAK,CAAC,EAAE,MAAM,CAAC;KAChB,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC3B,aAAa,CAAC,EAAE,CAAC,OAAO,EAAE;QAAE,KAAK,EAAE,MAAM,CAAA;KAAE,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IACrE,cAAc,CAAC,EAAE,CAAC,OAAO,EAAE;QAAE,IAAI,EAAE,WAAW,CAAA;KAAE,KAAK,OAAO,CAAC,IAAI,CAAC,GAAG,IAAI,CAAC;IAC1E,oBAAoB,CAAC,EAAE,MAAM,IAAI,CAAC;CACnC,4CAgEA,CAAC"}
@@ -0,0 +1,24 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { useMemo } from "react";
3
+ import { BillingToggle } from "./BillingToggle.js";
4
+ import { PricingCard } from "./PricingCard.js";
5
+ export const PricingSection = ({ plans = [], snapshot, selectedCycle, products = [], subscriptionProductId, subscriptionStatus, subscriptionTrialEnd, units, showSeatPicker = false, twoColumnLayout = false, subscribedSeats, isGroupSubscribed = false, disableCheckout = false, disableSwitch = false, disableSeats = false, className = "", onCycleChange, onCheckout, onSwitchPlan, onUpdateSeats, onContactSales, onCancelSubscription, }) => {
6
+ const availableCycles = useMemo(() => {
7
+ const set = new Set();
8
+ for (const plan of plans) {
9
+ for (const cycle of plan.billingCycles ?? []) {
10
+ set.add(cycle);
11
+ }
12
+ }
13
+ return Array.from(set);
14
+ }, [plans]);
15
+ const hasEnterprisePlan = plans.some((p) => p.category === "enterprise");
16
+ const effectiveCycle = selectedCycle ?? snapshot?.recurringCycle ?? availableCycles[0];
17
+ const showToggle = availableCycles.length > 1;
18
+ return (_jsxs("section", { className: className, children: [showToggle && (_jsx("div", { className: "mb-[6.5rem] flex justify-center", children: _jsx(BillingToggle, { cycles: availableCycles, value: effectiveCycle, onValueChange: onCycleChange }) })), _jsx("div", { className: `grid grid-cols-1 gap-1 ${showSeatPicker || twoColumnLayout
19
+ ? "md:grid-cols-2"
20
+ : hasEnterprisePlan
21
+ ? "sm:grid-cols-2 md:grid-cols-3 xl:grid-cols-4"
22
+ : "sm:grid-cols-2 md:grid-cols-3"}`, children: plans.map((plan) => (_jsx(PricingCard, { plan: plan, selectedCycle: effectiveCycle, activePlanId: snapshot?.activePlanId, subscriptionProductId: subscriptionProductId, subscriptionStatus: subscriptionStatus, subscriptionTrialEnd: subscriptionTrialEnd, products: products, units: units, showSeatPicker: showSeatPicker, subscribedSeats: subscribedSeats, isGroupSubscribed: isGroupSubscribed, disableCheckout: disableCheckout, disableSwitch: disableSwitch, disableSeats: disableSeats, onCheckout: onCheckout, onSwitchPlan: onSwitchPlan, onUpdateSeats: onUpdateSeats, onContactSales: onContactSales, onCancelSubscription: onCancelSubscription }, plan.planId))) })] }));
23
+ };
24
+ //# sourceMappingURL=PricingSection.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"PricingSection.js","sourceRoot":"","sources":["../../../src/react/primitives/PricingSection.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,OAAO,EAAE,MAAM,OAAO,CAAC;AAChC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAQ/C,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAC7B,KAAK,GAAG,EAAE,EACV,QAAQ,EACR,aAAa,EACb,QAAQ,GAAG,EAAE,EACb,qBAAqB,EACrB,kBAAkB,EAClB,oBAAoB,EACpB,KAAK,EACL,cAAc,GAAG,KAAK,EACtB,eAAe,GAAG,KAAK,EACvB,eAAe,EACf,iBAAiB,GAAG,KAAK,EACzB,eAAe,GAAG,KAAK,EACvB,aAAa,GAAG,KAAK,EACrB,YAAY,GAAG,KAAK,EACpB,SAAS,GAAG,EAAE,EACd,aAAa,EACb,UAAU,EACV,YAAY,EACZ,aAAa,EACb,cAAc,EACd,oBAAoB,GAgCrB,EAAE,EAAE;IACH,MAAM,eAAe,GAAG,OAAO,CAAC,GAAG,EAAE;QACnC,MAAM,GAAG,GAAG,IAAI,GAAG,EAAkB,CAAC;QACtC,KAAK,MAAM,IAAI,IAAI,KAAK,EAAE,CAAC;YACzB,KAAK,MAAM,KAAK,IAAI,IAAI,CAAC,aAAa,IAAI,EAAE,EAAE,CAAC;gBAC7C,GAAG,CAAC,GAAG,CAAC,KAAK,CAAC,CAAC;YACjB,CAAC;QACH,CAAC;QACD,OAAO,KAAK,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;IACzB,CAAC,EAAE,CAAC,KAAK,CAAC,CAAC,CAAC;IAEZ,MAAM,iBAAiB,GAAG,KAAK,CAAC,IAAI,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC,CAAC,CAAC,QAAQ,KAAK,YAAY,CAAC,CAAC;IACzE,MAAM,cAAc,GAClB,aAAa,IAAI,QAAQ,EAAE,cAAc,IAAI,eAAe,CAAC,CAAC,CAAC,CAAC;IAClE,MAAM,UAAU,GAAG,eAAe,CAAC,MAAM,GAAG,CAAC,CAAC;IAE9C,OAAO,CACL,mBAAS,SAAS,EAAE,SAAS,aAC1B,UAAU,IAAI,CACb,cAAK,SAAS,EAAC,iCAAiC,YAC9C,KAAC,aAAa,IACZ,MAAM,EAAE,eAAe,EACvB,KAAK,EAAE,cAAc,EACrB,aAAa,EAAE,aAAa,GAC5B,GACE,CACP,EAED,cACE,SAAS,EAAE,0BACT,cAAc,IAAI,eAAe;oBAC/B,CAAC,CAAC,gBAAgB;oBAClB,CAAC,CAAC,iBAAiB;wBACjB,CAAC,CAAC,8CAA8C;wBAChD,CAAC,CAAC,+BACR,EAAE,YAED,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACnB,KAAC,WAAW,IAEV,IAAI,EAAE,IAAI,EACV,aAAa,EAAE,cAAc,EAC7B,YAAY,EAAE,QAAQ,EAAE,YAAY,EACpC,qBAAqB,EAAE,qBAAqB,EAC5C,kBAAkB,EAAE,kBAAkB,EACtC,oBAAoB,EAAE,oBAAoB,EAC1C,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,KAAK,EACZ,cAAc,EAAE,cAAc,EAC9B,eAAe,EAAE,eAAe,EAChC,iBAAiB,EAAE,iBAAiB,EACpC,eAAe,EAAE,eAAe,EAChC,aAAa,EAAE,aAAa,EAC5B,YAAY,EAAE,YAAY,EAC1B,UAAU,EAAE,UAAU,EACtB,YAAY,EAAE,YAAY,EAC1B,aAAa,EAAE,aAAa,EAC5B,cAAc,EAAE,cAAc,EAC9B,oBAAoB,EAAE,oBAAoB,IAnBrC,IAAI,CAAC,MAAM,CAoBhB,CACH,CAAC,GACE,IACE,CACX,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { BillingSnapshot } from "../../core/types.js";
2
+ export declare const ScheduledChangeBanner: ({ snapshot, className, isLoading, onResume, }: {
3
+ snapshot?: BillingSnapshot | null;
4
+ className?: string;
5
+ isLoading?: boolean;
6
+ onResume?: () => void;
7
+ }) => import("react/jsx-runtime").JSX.Element | null;
8
+ //# sourceMappingURL=ScheduledChangeBanner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScheduledChangeBanner.d.ts","sourceRoot":"","sources":["../../../src/react/primitives/ScheduledChangeBanner.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAE3D,eAAO,MAAM,qBAAqB,GAAI,+CAKnC;IACD,QAAQ,CAAC,EAAE,eAAe,GAAG,IAAI,CAAC;IAClC,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,SAAS,CAAC,EAAE,OAAO,CAAC;IACpB,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;CACvB,mDAuCA,CAAC"}
@@ -0,0 +1,13 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ export const ScheduledChangeBanner = ({ snapshot, className = "", isLoading = false, onResume, }) => {
3
+ if (!snapshot?.metadata || snapshot.metadata.cancelAtPeriodEnd !== true) {
4
+ return null;
5
+ }
6
+ const currentPeriodEnd = typeof snapshot.metadata.currentPeriodEnd === "string"
7
+ ? snapshot.metadata.currentPeriodEnd
8
+ : undefined;
9
+ return (_jsx("div", { className: `rounded-xl bg-surface-base p-6 ${className}`, children: _jsxs("div", { className: "flex flex-col gap-6 md:flex-row md:items-start md:justify-between md:gap-4", children: [_jsxs("div", { className: "space-y-2", children: [_jsx("p", { className: "title-s text-foreground-default", children: "Cancellation scheduled" }), _jsxs("p", { className: "body-m text-foreground-muted", children: ["You will continue to have access until the end of your current billing period", currentPeriodEnd
10
+ ? ` (${new Date(currentPeriodEnd).toLocaleDateString()})`
11
+ : "", "."] })] }), onResume && (_jsx("button", { type: "button", className: "button-faded h-8 shrink-0 disabled:cursor-not-allowed disabled:opacity-50", disabled: isLoading, onClick: onResume, children: isLoading ? "Resuming…" : "Undo cancellation" }))] }) }));
12
+ };
13
+ //# sourceMappingURL=ScheduledChangeBanner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ScheduledChangeBanner.js","sourceRoot":"","sources":["../../../src/react/primitives/ScheduledChangeBanner.tsx"],"names":[],"mappings":";AAEA,MAAM,CAAC,MAAM,qBAAqB,GAAG,CAAC,EACpC,QAAQ,EACR,SAAS,GAAG,EAAE,EACd,SAAS,GAAG,KAAK,EACjB,QAAQ,GAMT,EAAE,EAAE;IACH,IAAI,CAAC,QAAQ,EAAE,QAAQ,IAAI,QAAQ,CAAC,QAAQ,CAAC,iBAAiB,KAAK,IAAI,EAAE,CAAC;QACxE,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,gBAAgB,GACpB,OAAO,QAAQ,CAAC,QAAQ,CAAC,gBAAgB,KAAK,QAAQ;QACpD,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,gBAAgB;QACpC,CAAC,CAAC,SAAS,CAAC;IAEhB,OAAO,CACL,cAAK,SAAS,EAAE,kCAAkC,SAAS,EAAE,YAC3D,eAAK,SAAS,EAAC,4EAA4E,aACzF,eAAK,SAAS,EAAC,WAAW,aACxB,YAAG,SAAS,EAAC,iCAAiC,uCAE1C,EACJ,aAAG,SAAS,EAAC,8BAA8B,8FAGxC,gBAAgB;oCACf,CAAC,CAAC,KAAK,IAAI,IAAI,CAAC,gBAAgB,CAAC,CAAC,kBAAkB,EAAE,GAAG;oCACzD,CAAC,CAAC,EAAE,SAEJ,IACA,EACL,QAAQ,IAAI,CACX,iBACE,IAAI,EAAC,QAAQ,EACb,SAAS,EAAC,2EAA2E,EACrF,QAAQ,EAAE,SAAS,EACnB,OAAO,EAAE,QAAQ,YAEhB,SAAS,CAAC,CAAC,CAAC,WAAW,CAAC,CAAC,CAAC,mBAAmB,GACvC,CACV,IACG,GACF,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { type SegmentGroupItem } from "./SegmentGroup.js";
2
+ export type SegmentControlItem = SegmentGroupItem;
3
+ export declare const SegmentControl: ({ items, value, defaultValue, disabled, className, onValueChange, }: {
4
+ items?: SegmentControlItem[];
5
+ value?: string | null;
6
+ defaultValue?: string;
7
+ disabled?: boolean;
8
+ className?: string;
9
+ onValueChange?: (value: string) => void;
10
+ }) => import("react/jsx-runtime").JSX.Element | null;
11
+ //# sourceMappingURL=SegmentControl.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SegmentControl.d.ts","sourceRoot":"","sources":["../../../src/react/primitives/SegmentControl.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAgB,KAAK,gBAAgB,EAAE,MAAM,mBAAmB,CAAC;AAExE,MAAM,MAAM,kBAAkB,GAAG,gBAAgB,CAAC;AAElD,eAAO,MAAM,cAAc,GAAI,qEAO5B;IACD,KAAK,CAAC,EAAE,kBAAkB,EAAE,CAAC;IAC7B,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACzC,mDAaA,CAAC"}
@@ -0,0 +1,8 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { SegmentGroup } from "./SegmentGroup.js";
3
+ export const SegmentControl = ({ items = [], value, defaultValue, disabled = false, className = "", onValueChange, }) => {
4
+ if (items.length <= 1)
5
+ return null;
6
+ return (_jsx(SegmentGroup, { items: items, value: value, defaultValue: defaultValue, disabled: disabled, onValueChange: onValueChange, className: className }));
7
+ };
8
+ //# sourceMappingURL=SegmentControl.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SegmentControl.js","sourceRoot":"","sources":["../../../src/react/primitives/SegmentControl.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,EAAyB,MAAM,mBAAmB,CAAC;AAIxE,MAAM,CAAC,MAAM,cAAc,GAAG,CAAC,EAC7B,KAAK,GAAG,EAAE,EACV,KAAK,EACL,YAAY,EACZ,QAAQ,GAAG,KAAK,EAChB,SAAS,GAAG,EAAE,EACd,aAAa,GAQd,EAAE,EAAE;IACH,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IAEnC,OAAO,CACL,KAAC,YAAY,IACX,KAAK,EAAE,KAAK,EACZ,KAAK,EAAE,KAAK,EACZ,YAAY,EAAE,YAAY,EAC1B,QAAQ,EAAE,QAAQ,EAClB,aAAa,EAAE,aAAa,EAC5B,SAAS,EAAE,SAAS,GACpB,CACH,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,14 @@
1
+ export type SegmentGroupItem = {
2
+ label: string;
3
+ value: string;
4
+ disabled?: boolean;
5
+ };
6
+ export declare const SegmentGroup: ({ items, value, defaultValue, disabled, className, onValueChange, }: {
7
+ items?: SegmentGroupItem[];
8
+ value?: string | null;
9
+ defaultValue?: string;
10
+ disabled?: boolean;
11
+ className?: string;
12
+ onValueChange?: (value: string) => void;
13
+ }) => import("react/jsx-runtime").JSX.Element | null;
14
+ //# sourceMappingURL=SegmentGroup.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SegmentGroup.d.ts","sourceRoot":"","sources":["../../../src/react/primitives/SegmentGroup.tsx"],"names":[],"mappings":"AAEA,MAAM,MAAM,gBAAgB,GAAG;IAC7B,KAAK,EAAE,MAAM,CAAC;IACd,KAAK,EAAE,MAAM,CAAC;IACd,QAAQ,CAAC,EAAE,OAAO,CAAC;CACpB,CAAC;AAEF,eAAO,MAAM,YAAY,GAAI,qEAO1B;IACD,KAAK,CAAC,EAAE,gBAAgB,EAAE,CAAC;IAC3B,KAAK,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IACtB,YAAY,CAAC,EAAE,MAAM,CAAC;IACtB,QAAQ,CAAC,EAAE,OAAO,CAAC;IACnB,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,aAAa,CAAC,EAAE,CAAC,KAAK,EAAE,MAAM,KAAK,IAAI,CAAC;CACzC,mDA8BA,CAAC"}
@@ -0,0 +1,11 @@
1
+ import { jsx as _jsx, jsxs as _jsxs } from "react/jsx-runtime";
2
+ import { SegmentGroup as ArkSegmentGroup } from "@ark-ui/react/segment-group";
3
+ export const SegmentGroup = ({ items = [], value, defaultValue, disabled = false, className = "", onValueChange, }) => {
4
+ if (items.length <= 1)
5
+ return null;
6
+ return (_jsxs(ArkSegmentGroup.Root, { value: value ?? undefined, defaultValue: defaultValue, disabled: disabled, className: `segment-group ${className}`, onValueChange: (details) => {
7
+ if (details.value != null)
8
+ onValueChange?.(details.value);
9
+ }, children: [_jsx(ArkSegmentGroup.Indicator, { className: "segment-group-indicator" }), items.map((item) => (_jsxs(ArkSegmentGroup.Item, { value: item.value, disabled: item.disabled, className: "segment-group-item", children: [_jsx(ArkSegmentGroup.ItemText, { className: "segment-group-item-text label-m", children: item.label }), _jsx(ArkSegmentGroup.ItemControl, { className: "segment-group-item-control" }), _jsx(ArkSegmentGroup.ItemHiddenInput, {})] }, item.value)))] }));
10
+ };
11
+ //# sourceMappingURL=SegmentGroup.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"SegmentGroup.js","sourceRoot":"","sources":["../../../src/react/primitives/SegmentGroup.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,YAAY,IAAI,eAAe,EAAE,MAAM,6BAA6B,CAAC;AAQ9E,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAC3B,KAAK,GAAG,EAAE,EACV,KAAK,EACL,YAAY,EACZ,QAAQ,GAAG,KAAK,EAChB,SAAS,GAAG,EAAE,EACd,aAAa,GAQd,EAAE,EAAE;IACH,IAAI,KAAK,CAAC,MAAM,IAAI,CAAC;QAAE,OAAO,IAAI,CAAC;IAEnC,OAAO,CACL,MAAC,eAAe,CAAC,IAAI,IACnB,KAAK,EAAE,KAAK,IAAI,SAAS,EACzB,YAAY,EAAE,YAAY,EAC1B,QAAQ,EAAE,QAAQ,EAClB,SAAS,EAAE,iBAAiB,SAAS,EAAE,EACvC,aAAa,EAAE,CAAC,OAAiC,EAAE,EAAE;YACnD,IAAI,OAAO,CAAC,KAAK,IAAI,IAAI;gBAAE,aAAa,EAAE,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC;QAC5D,CAAC,aAED,KAAC,eAAe,CAAC,SAAS,IAAC,SAAS,EAAC,yBAAyB,GAAG,EAChE,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CACnB,MAAC,eAAe,CAAC,IAAI,IAEnB,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,SAAS,EAAC,oBAAoB,aAE9B,KAAC,eAAe,CAAC,QAAQ,IAAC,SAAS,EAAC,iCAAiC,YAClE,IAAI,CAAC,KAAK,GACc,EAC3B,KAAC,eAAe,CAAC,WAAW,IAAC,SAAS,EAAC,4BAA4B,GAAG,EACtE,KAAC,eAAe,CAAC,eAAe,KAAG,KAT9B,IAAI,CAAC,KAAK,CAUM,CACxB,CAAC,IACmB,CACxB,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { BillingSnapshot } from "../../core/types.js";
2
+ export declare const TrialLimitBanner: ({ snapshot, trialEndsAt, className, }: {
3
+ snapshot?: BillingSnapshot | null;
4
+ trialEndsAt?: string | null;
5
+ className?: string;
6
+ }) => import("react/jsx-runtime").JSX.Element | null;
7
+ //# sourceMappingURL=TrialLimitBanner.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TrialLimitBanner.d.ts","sourceRoot":"","sources":["../../../src/react/primitives/TrialLimitBanner.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAE3D,eAAO,MAAM,gBAAgB,GAAI,uCAI9B;IACD,QAAQ,CAAC,EAAE,eAAe,GAAG,IAAI,CAAC;IAClC,WAAW,CAAC,EAAE,MAAM,GAAG,IAAI,CAAC;IAC5B,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,mDAqBA,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { jsxs as _jsxs } from "react/jsx-runtime";
2
+ export const TrialLimitBanner = ({ snapshot, trialEndsAt, className = "", }) => {
3
+ if (snapshot?.activeCategory !== "trial") {
4
+ return null;
5
+ }
6
+ const resolvedTrialEnd = trialEndsAt ??
7
+ (typeof snapshot.metadata?.trialEnd === "string"
8
+ ? snapshot.metadata.trialEnd
9
+ : null);
10
+ return (_jsxs("div", { className: `rounded-lg border border-sky-300 bg-sky-50 px-4 py-3 text-sm text-sky-900 dark:border-sky-800 dark:bg-sky-950/40 dark:text-sky-200 ${className}`, children: ["Trial plan active", resolvedTrialEnd
11
+ ? ` until ${new Date(resolvedTrialEnd).toLocaleDateString()}.`
12
+ : ". Upgrade before your trial ends to avoid interruptions."] }));
13
+ };
14
+ //# sourceMappingURL=TrialLimitBanner.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TrialLimitBanner.js","sourceRoot":"","sources":["../../../src/react/primitives/TrialLimitBanner.tsx"],"names":[],"mappings":";AAEA,MAAM,CAAC,MAAM,gBAAgB,GAAG,CAAC,EAC/B,QAAQ,EACR,WAAW,EACX,SAAS,GAAG,EAAE,GAKf,EAAE,EAAE;IACH,IAAI,QAAQ,EAAE,cAAc,KAAK,OAAO,EAAE,CAAC;QACzC,OAAO,IAAI,CAAC;IACd,CAAC;IAED,MAAM,gBAAgB,GACpB,WAAW;QACX,CAAC,OAAO,QAAQ,CAAC,QAAQ,EAAE,QAAQ,KAAK,QAAQ;YAC9C,CAAC,CAAC,QAAQ,CAAC,QAAQ,CAAC,QAAQ;YAC5B,CAAC,CAAC,IAAI,CAAC,CAAC;IAEZ,OAAO,CACL,eACE,SAAS,EAAE,sIAAsI,SAAS,EAAE,kCAG3J,gBAAgB;gBACf,CAAC,CAAC,UAAU,IAAI,IAAI,CAAC,gBAAgB,CAAC,CAAC,kBAAkB,EAAE,GAAG;gBAC9D,CAAC,CAAC,0DAA0D,IAC1D,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,28 @@
1
+ import type { AvailableAction, BillingSnapshot, UIPlanEntry, RecurringCycle } from "../core/types.js";
2
+ import type { ConnectedProduct } from "./widgets/types.js";
3
+ /** Format a billing cycle enum value to a human-readable label (e.g. `"every-month"` → `"Monthly"`). */
4
+ export declare const formatRecurringCycle: (cycle: RecurringCycle) => "Monthly" | "Quarterly" | "Semi-annual" | "Yearly" | "Custom";
5
+ /** Resolve the Creem product ID for a plan given the selected billing cycle. Handles cycle aliases and partial matches. */
6
+ export declare const resolveProductIdForPlan: (plan: UIPlanEntry, selectedCycle: RecurringCycle | undefined) => string | undefined;
7
+ /** Local variant of `hasBillingAction` for use in shared UI code. */
8
+ export declare const hasBillingActionLocal: (snapshot: BillingSnapshot, action: AvailableAction) => boolean;
9
+ /** Format a price amount (in cents) to a localized currency string (e.g. `999` + `"USD"` → `"$9.99"`). */
10
+ export declare const formatPrice: (amount: number, currency: string) => string;
11
+ /** Resolve the formatted price and billing interval for a product by its ID. Returns `null` if not found. */
12
+ export declare const resolveProductPrice: (productId: string | undefined, products: ConnectedProduct[]) => {
13
+ formatted: string;
14
+ interval?: string;
15
+ } | null;
16
+ /** Format the total price for a seat-based plan (e.g. `"$10/mo × 5 seats"`). Returns `null` if product not found. */
17
+ export declare const formatSeatPrice: (productId: string | undefined, products: ConnectedProduct[], seats: number) => string | null;
18
+ /** Format a product's price with its billing interval suffix (e.g. `"$10/mo"`). Returns `null` if product not found. */
19
+ export declare const formatPriceWithInterval: (productId: string | undefined, products: ConnectedProduct[]) => string | null;
20
+ /** Split a price label into main amount, interval suffix, and trailing text (e.g. `"$10/mo × 5 seats"` → `{ main: "$10", suffix: "/mo", tail: "× 5 seats" }`). */
21
+ export declare const splitPriceLabel: (value: string | null) => {
22
+ main: string;
23
+ suffix: string | null;
24
+ tail: string;
25
+ } | null;
26
+ /** Join CSS class tokens, filtering out falsy values. Lightweight alternative to `clsx`. */
27
+ export declare const cx: (...tokens: Array<string | undefined | false>) => string;
28
+ //# sourceMappingURL=shared.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shared.d.ts","sourceRoot":"","sources":["../../src/react/shared.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EACV,eAAe,EACf,eAAe,EACf,WAAW,EACX,cAAc,EACf,MAAM,kBAAkB,CAAC;AAC1B,OAAO,KAAK,EAAE,gBAAgB,EAAE,MAAM,oBAAoB,CAAC;AAU3D,wGAAwG;AACxG,eAAO,MAAM,oBAAoB,GAAI,OAAO,cAAc,kEAMzD,CAAC;AAEF,2HAA2H;AAC3H,eAAO,MAAM,uBAAuB,GAClC,MAAM,WAAW,EACjB,eAAe,cAAc,GAAG,SAAS,uBAuB1C,CAAC;AAEF,qEAAqE;AACrE,eAAO,MAAM,qBAAqB,GAChC,UAAU,eAAe,EACzB,QAAQ,eAAe,YACsB,CAAC;AAEhD,0GAA0G;AAC1G,eAAO,MAAM,WAAW,GAAI,QAAQ,MAAM,EAAE,UAAU,MAAM,KAAG,MAO9D,CAAC;AAEF,6GAA6G;AAC7G,eAAO,MAAM,mBAAmB,GAC9B,WAAW,MAAM,GAAG,SAAS,EAC7B,UAAU,gBAAgB,EAAE,KAC3B;IAAE,SAAS,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,MAAM,CAAA;CAAE,GAAG,IAO7C,CAAC;AAWF,qHAAqH;AACrH,eAAO,MAAM,eAAe,GAC1B,WAAW,MAAM,GAAG,SAAS,EAC7B,UAAU,gBAAgB,EAAE,EAC5B,OAAO,MAAM,KACZ,MAAM,GAAG,IAUX,CAAC;AAEF,wHAAwH;AACxH,eAAO,MAAM,uBAAuB,GAClC,WAAW,MAAM,GAAG,SAAS,EAC7B,UAAU,gBAAgB,EAAE,KAC3B,MAAM,GAAG,IAOX,CAAC;AAEF,kKAAkK;AAClK,eAAO,MAAM,eAAe,GAC1B,OAAO,MAAM,GAAG,IAAI,KACnB;IAAE,IAAI,EAAE,MAAM,CAAC;IAAC,MAAM,EAAE,MAAM,GAAG,IAAI,CAAC;IAAC,IAAI,EAAE,MAAM,CAAA;CAAE,GAAG,IAS1D,CAAC;AAEF,4FAA4F;AAC5F,eAAO,MAAM,EAAE,GAAI,GAAG,QAAQ,KAAK,CAAC,MAAM,GAAG,SAAS,GAAG,KAAK,CAAC,WAC7B,CAAC"}
@@ -0,0 +1,109 @@
1
+ const CYCLE_KEY_ALIASES = {
2
+ "every-month": ["every-month", "monthly", "month"],
3
+ "every-three-months": ["every-three-months", "quarterly", "every-quarter"],
4
+ "every-six-months": ["every-six-months", "semiannual", "semi-annually"],
5
+ "every-year": ["every-year", "yearly", "annual"],
6
+ custom: ["custom"],
7
+ };
8
+ /** Format a billing cycle enum value to a human-readable label (e.g. `"every-month"` → `"Monthly"`). */
9
+ export const formatRecurringCycle = (cycle) => {
10
+ if (cycle === "every-month")
11
+ return "Monthly";
12
+ if (cycle === "every-three-months")
13
+ return "Quarterly";
14
+ if (cycle === "every-six-months")
15
+ return "Semi-annual";
16
+ if (cycle === "every-year")
17
+ return "Yearly";
18
+ return "Custom";
19
+ };
20
+ /** Resolve the Creem product ID for a plan given the selected billing cycle. Handles cycle aliases and partial matches. */
21
+ export const resolveProductIdForPlan = (plan, selectedCycle) => {
22
+ const productIds = plan.creemProductIds;
23
+ if (!productIds) {
24
+ return undefined;
25
+ }
26
+ const aliases = selectedCycle
27
+ ? CYCLE_KEY_ALIASES[selectedCycle]
28
+ : CYCLE_KEY_ALIASES.custom;
29
+ for (const alias of aliases) {
30
+ if (productIds[alias]) {
31
+ return productIds[alias];
32
+ }
33
+ const partial = Object.entries(productIds).find(([key]) => key.toLowerCase().includes(alias));
34
+ if (partial) {
35
+ return partial[1];
36
+ }
37
+ }
38
+ return Object.values(productIds)[0];
39
+ };
40
+ /** Local variant of `hasBillingAction` for use in shared UI code. */
41
+ export const hasBillingActionLocal = (snapshot, action) => snapshot.availableActions.includes(action);
42
+ /** Format a price amount (in cents) to a localized currency string (e.g. `999` + `"USD"` → `"$9.99"`). */
43
+ export const formatPrice = (amount, currency) => {
44
+ return new Intl.NumberFormat(undefined, {
45
+ style: "currency",
46
+ currency,
47
+ minimumFractionDigits: 0,
48
+ maximumFractionDigits: 2,
49
+ }).format(amount / 100);
50
+ };
51
+ /** Resolve the formatted price and billing interval for a product by its ID. Returns `null` if not found. */
52
+ export const resolveProductPrice = (productId, products) => {
53
+ if (!productId || !products.length)
54
+ return null;
55
+ const product = products.find((p) => p.id === productId);
56
+ if (!product)
57
+ return null;
58
+ if (product.price == null || !product.currency)
59
+ return null;
60
+ const formatted = formatPrice(product.price, product.currency);
61
+ return { formatted, interval: product.billingPeriod ?? undefined };
62
+ };
63
+ const INTERVAL_LABELS = {
64
+ month: "/mo",
65
+ "every-month": "/mo",
66
+ "every-three-months": "/3mo",
67
+ "every-six-months": "/6mo",
68
+ year: "/yr",
69
+ "every-year": "/yr",
70
+ };
71
+ /** Format the total price for a seat-based plan (e.g. `"$10/mo × 5 seats"`). Returns `null` if product not found. */
72
+ export const formatSeatPrice = (productId, products, seats) => {
73
+ const resolved = resolveProductPrice(productId, products);
74
+ if (!resolved)
75
+ return null;
76
+ const suffix = resolved.interval
77
+ ? (INTERVAL_LABELS[resolved.interval] ?? "")
78
+ : "";
79
+ if (seats <= 1) {
80
+ return `${resolved.formatted}${suffix}`;
81
+ }
82
+ return `${resolved.formatted}${suffix} × ${seats} seats`;
83
+ };
84
+ /** Format a product's price with its billing interval suffix (e.g. `"$10/mo"`). Returns `null` if product not found. */
85
+ export const formatPriceWithInterval = (productId, products) => {
86
+ const resolved = resolveProductPrice(productId, products);
87
+ if (!resolved)
88
+ return null;
89
+ const suffix = resolved.interval
90
+ ? (INTERVAL_LABELS[resolved.interval] ?? "")
91
+ : "";
92
+ return `${resolved.formatted}${suffix}`;
93
+ };
94
+ /** Split a price label into main amount, interval suffix, and trailing text (e.g. `"$10/mo × 5 seats"` → `{ main: "$10", suffix: "/mo", tail: "× 5 seats" }`). */
95
+ export const splitPriceLabel = (value) => {
96
+ if (!value)
97
+ return null;
98
+ const match = value.match(/^(.*?)(\/[a-z0-9]+)(.*)$/i);
99
+ if (!match)
100
+ return { main: value, suffix: null, tail: "" };
101
+ return {
102
+ main: match[1]?.trim() ?? value,
103
+ suffix: match[2] ?? null,
104
+ tail: match[3]?.trim() ?? "",
105
+ };
106
+ };
107
+ /** Join CSS class tokens, filtering out falsy values. Lightweight alternative to `clsx`. */
108
+ export const cx = (...tokens) => tokens.filter(Boolean).join(" ");
109
+ //# sourceMappingURL=shared.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"shared.js","sourceRoot":"","sources":["../../src/react/shared.ts"],"names":[],"mappings":"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"}
@@ -0,0 +1,9 @@
1
+ import { type PropsWithChildren } from "react";
2
+ import type { BillingPermissions, ConnectedBillingApi } from "./types.js";
3
+ export declare const BillingPortal: ({ api, permissions, className, children, }: PropsWithChildren<{
4
+ api: ConnectedBillingApi;
5
+ permissions?: BillingPermissions;
6
+ class?: string;
7
+ className?: string;
8
+ }>) => import("react/jsx-runtime").JSX.Element | null;
9
+ //# sourceMappingURL=BillingPortal.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BillingPortal.d.ts","sourceRoot":"","sources":["../../../src/react/widgets/BillingPortal.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAY,KAAK,iBAAiB,EAAE,MAAM,OAAO,CAAC;AAGzD,OAAO,KAAK,EACV,kBAAkB,EAClB,mBAAmB,EAEpB,MAAM,YAAY,CAAC;AAEpB,eAAO,MAAM,aAAa,GAAI,4CAK3B,iBAAiB,CAAC;IACnB,GAAG,EAAE,mBAAmB,CAAC;IACzB,WAAW,CAAC,EAAE,kBAAkB,CAAC;IACjC,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;CACpB,CAAC,mDAoCD,CAAC"}
@@ -0,0 +1,30 @@
1
+ import { jsx as _jsx } from "react/jsx-runtime";
2
+ import { useState } from "react";
3
+ import { useQuery, useConvex } from "convex/react";
4
+ import { CustomerPortalButton } from "../primitives/CustomerPortalButton.js";
5
+ export const BillingPortal = ({ api, permissions, className = "", children, }) => {
6
+ const canAccess = permissions?.canAccessPortal !== false;
7
+ const client = useConvex();
8
+ const billingUiModelRef = api.uiModel;
9
+ const portalUrlRef = api.customers?.portalUrl;
10
+ const modelRaw = useQuery(billingUiModelRef, {});
11
+ const model = modelRaw;
12
+ const hasCreemCustomer = model?.hasCreemCustomer ?? false;
13
+ const [isLoading, setIsLoading] = useState(false);
14
+ const openPortal = async () => {
15
+ if (!portalUrlRef)
16
+ return;
17
+ setIsLoading(true);
18
+ try {
19
+ const { url } = await client.action(portalUrlRef, {});
20
+ window.open(url, "_blank", "noopener,noreferrer");
21
+ }
22
+ finally {
23
+ setIsLoading(false);
24
+ }
25
+ };
26
+ if (!portalUrlRef || !hasCreemCustomer || !canAccess)
27
+ return null;
28
+ return (_jsx(CustomerPortalButton, { disabled: isLoading, onOpenPortal: openPortal, className: className, children: children ?? "Manage billing" }));
29
+ };
30
+ //# sourceMappingURL=BillingPortal.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"BillingPortal.js","sourceRoot":"","sources":["../../../src/react/widgets/BillingPortal.tsx"],"names":[],"mappings":";AAAA,OAAO,EAAE,QAAQ,EAA0B,MAAM,OAAO,CAAC;AACzD,OAAO,EAAE,QAAQ,EAAE,SAAS,EAAE,MAAM,cAAc,CAAC;AACnD,OAAO,EAAE,oBAAoB,EAAE,MAAM,uCAAuC,CAAC;AAO7E,MAAM,CAAC,MAAM,aAAa,GAAG,CAAC,EAC5B,GAAG,EACH,WAAW,EACX,SAAS,GAAG,EAAE,EACd,QAAQ,GAMR,EAAE,EAAE;IACJ,MAAM,SAAS,GAAG,WAAW,EAAE,eAAe,KAAK,KAAK,CAAC;IAEzD,MAAM,MAAM,GAAG,SAAS,EAAE,CAAC;IAE3B,MAAM,iBAAiB,GAAG,GAAG,CAAC,OAAO,CAAC;IACtC,MAAM,YAAY,GAAG,GAAG,CAAC,SAAS,EAAE,SAAS,CAAC;IAE9C,MAAM,QAAQ,GAAG,QAAQ,CAAC,iBAAiB,EAAE,EAAE,CAAC,CAAC;IACjD,MAAM,KAAK,GAAG,QAA6C,CAAC;IAC5D,MAAM,gBAAgB,GAAG,KAAK,EAAE,gBAAgB,IAAI,KAAK,CAAC;IAE1D,MAAM,CAAC,SAAS,EAAE,YAAY,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAElD,MAAM,UAAU,GAAG,KAAK,IAAI,EAAE;QAC5B,IAAI,CAAC,YAAY;YAAE,OAAO;QAC1B,YAAY,CAAC,IAAI,CAAC,CAAC;QACnB,IAAI,CAAC;YACH,MAAM,EAAE,GAAG,EAAE,GAAG,MAAM,MAAM,CAAC,MAAM,CAAC,YAAY,EAAE,EAAE,CAAC,CAAC;YACtD,MAAM,CAAC,IAAI,CAAC,GAAG,EAAE,QAAQ,EAAE,qBAAqB,CAAC,CAAC;QACpD,CAAC;gBAAS,CAAC;YACT,YAAY,CAAC,KAAK,CAAC,CAAC;QACtB,CAAC;IACH,CAAC,CAAC;IAEF,IAAI,CAAC,YAAY,IAAI,CAAC,gBAAgB,IAAI,CAAC,SAAS;QAAE,OAAO,IAAI,CAAC;IAElE,OAAO,CACL,KAAC,oBAAoB,IACnB,QAAQ,EAAE,SAAS,EACnB,YAAY,EAAE,UAAU,EACxB,SAAS,EAAE,SAAS,YAEnB,QAAQ,IAAI,gBAAgB,GACR,CACxB,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,8 @@
1
+ import type { ProductType } from "./types.js";
2
+ export declare const ProductItem: ({ productId, type, title, description, }: {
3
+ productId: string;
4
+ type: ProductType;
5
+ title?: string;
6
+ description?: string;
7
+ }) => null;
8
+ //# sourceMappingURL=ProductItem.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProductItem.d.ts","sourceRoot":"","sources":["../../../src/react/widgets/ProductItem.tsx"],"names":[],"mappings":"AAEA,OAAO,KAAK,EAAE,WAAW,EAAE,MAAM,YAAY,CAAC;AAE9C,eAAO,MAAM,WAAW,GAAI,0CAKzB;IACD,SAAS,EAAE,MAAM,CAAC;IAClB,IAAI,EAAE,WAAW,CAAC;IAClB,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,WAAW,CAAC,EAAE,MAAM,CAAC;CACtB,SAWA,CAAC"}
@@ -0,0 +1,14 @@
1
+ import { useContext, useEffect } from "react";
2
+ import { ProductGroupContext } from "./productGroupContext.js";
3
+ export const ProductItem = ({ productId, type, title, description, }) => {
4
+ const rootContext = useContext(ProductGroupContext);
5
+ useEffect(() => {
6
+ if (!rootContext)
7
+ return;
8
+ const registration = { productId, type, title, description };
9
+ const unregister = rootContext.registerItem(registration);
10
+ return unregister;
11
+ }, [rootContext, productId, type, title, description]);
12
+ return null;
13
+ };
14
+ //# sourceMappingURL=ProductItem.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProductItem.js","sourceRoot":"","sources":["../../../src/react/widgets/ProductItem.tsx"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AAC9C,OAAO,EAAE,mBAAmB,EAAE,MAAM,0BAA0B,CAAC;AAG/D,MAAM,CAAC,MAAM,WAAW,GAAG,CAAC,EAC1B,SAAS,EACT,IAAI,EACJ,KAAK,EACL,WAAW,GAMZ,EAAE,EAAE;IACH,MAAM,WAAW,GAAG,UAAU,CAAC,mBAAmB,CAAC,CAAC;IAEpD,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,WAAW;YAAE,OAAO;QACzB,MAAM,YAAY,GAAG,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,EAAE,CAAC;QAC7D,MAAM,UAAU,GAAG,WAAW,CAAC,YAAY,CAAC,YAAY,CAAC,CAAC;QAC1D,OAAO,UAAU,CAAC;IACpB,CAAC,EAAE,CAAC,WAAW,EAAE,SAAS,EAAE,IAAI,EAAE,KAAK,EAAE,WAAW,CAAC,CAAC,CAAC;IAEvD,OAAO,IAAI,CAAC;AACd,CAAC,CAAC"}
@@ -0,0 +1,16 @@
1
+ import { type PropsWithChildren } from "react";
2
+ import type { BillingPermissions, CheckoutIntent, ConnectedBillingApi, Transition } from "./types.js";
3
+ export declare const ProductRoot: ({ api, permissions, transition, className, layout, styleVariant, showImages, pricingCtaVariant, successUrl, onBeforeCheckout, children, }: PropsWithChildren<{
4
+ api: ConnectedBillingApi;
5
+ permissions?: BillingPermissions;
6
+ transition?: Transition[];
7
+ class?: string;
8
+ className?: string;
9
+ layout?: "default" | "single";
10
+ styleVariant?: "legacy" | "pricing";
11
+ showImages?: boolean;
12
+ pricingCtaVariant?: "filled" | "faded";
13
+ successUrl?: string;
14
+ onBeforeCheckout?: (intent: CheckoutIntent) => Promise<boolean> | boolean;
15
+ }>) => import("react/jsx-runtime").JSX.Element;
16
+ //# sourceMappingURL=ProductRoot.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"ProductRoot.d.ts","sourceRoot":"","sources":["../../../src/react/widgets/ProductRoot.tsx"],"names":[],"mappings":"AAAA,OAAO,EAML,KAAK,iBAAiB,EACvB,MAAM,OAAO,CAAC;AASf,OAAO,KAAK,EACV,kBAAkB,EAClB,cAAc,EACd,mBAAmB,EAGnB,UAAU,EACX,MAAM,YAAY,CAAC;AAEpB,eAAO,MAAM,WAAW,GAAI,2IAYzB,iBAAiB,CAAC;IACnB,GAAG,EAAE,mBAAmB,CAAC;IACzB,WAAW,CAAC,EAAE,kBAAkB,CAAC;IACjC,UAAU,CAAC,EAAE,UAAU,EAAE,CAAC;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAC;IACf,SAAS,CAAC,EAAE,MAAM,CAAC;IACnB,MAAM,CAAC,EAAE,SAAS,GAAG,QAAQ,CAAC;IAC9B,YAAY,CAAC,EAAE,QAAQ,GAAG,SAAS,CAAC;IACpC,UAAU,CAAC,EAAE,OAAO,CAAC;IACrB,iBAAiB,CAAC,EAAE,QAAQ,GAAG,OAAO,CAAC;IACvC,UAAU,CAAC,EAAE,MAAM,CAAC;IACpB,gBAAgB,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,KAAK,OAAO,CAAC,OAAO,CAAC,GAAG,OAAO,CAAC;CAC3E,CAAC,4CAuYD,CAAC"}