@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.
- package/LICENSE +201 -0
- package/README.md +1176 -0
- package/dist/client/helpers.d.ts +17 -0
- package/dist/client/helpers.d.ts.map +1 -0
- package/dist/client/helpers.js +43 -0
- package/dist/client/helpers.js.map +1 -0
- package/dist/client/index.d.ts +1041 -0
- package/dist/client/index.d.ts.map +1 -0
- package/dist/client/index.js +1068 -0
- package/dist/client/index.js.map +1 -0
- package/dist/client/parsers.d.ts +45 -0
- package/dist/client/parsers.d.ts.map +1 -0
- package/dist/client/parsers.js +138 -0
- package/dist/client/parsers.js.map +1 -0
- package/dist/client/polyfill.d.ts +2 -0
- package/dist/client/polyfill.d.ts.map +1 -0
- package/dist/client/polyfill.js +3 -0
- package/dist/client/polyfill.js.map +1 -0
- package/dist/component/_generated/api.d.ts +36 -0
- package/dist/component/_generated/api.d.ts.map +1 -0
- package/dist/component/_generated/api.js +31 -0
- package/dist/component/_generated/api.js.map +1 -0
- package/dist/component/_generated/component.d.ts +542 -0
- package/dist/component/_generated/component.d.ts.map +1 -0
- package/dist/component/_generated/component.js +11 -0
- package/dist/component/_generated/component.js.map +1 -0
- package/dist/component/_generated/dataModel.d.ts +46 -0
- package/dist/component/_generated/dataModel.d.ts.map +1 -0
- package/dist/component/_generated/dataModel.js +11 -0
- package/dist/component/_generated/dataModel.js.map +1 -0
- package/dist/component/_generated/server.d.ts +121 -0
- package/dist/component/_generated/server.d.ts.map +1 -0
- package/dist/component/_generated/server.js +78 -0
- package/dist/component/_generated/server.js.map +1 -0
- package/dist/component/convex.config.d.ts +3 -0
- package/dist/component/convex.config.d.ts.map +1 -0
- package/dist/component/convex.config.js +3 -0
- package/dist/component/convex.config.js.map +1 -0
- package/dist/component/lib.d.ts +1005 -0
- package/dist/component/lib.d.ts.map +1 -0
- package/dist/component/lib.js +647 -0
- package/dist/component/lib.js.map +1 -0
- package/dist/component/schema.d.ts +191 -0
- package/dist/component/schema.d.ts.map +1 -0
- package/dist/component/schema.js +104 -0
- package/dist/component/schema.js.map +1 -0
- package/dist/component/util.d.ts +61 -0
- package/dist/component/util.d.ts.map +1 -0
- package/dist/component/util.js +142 -0
- package/dist/component/util.js.map +1 -0
- package/dist/core/catalog.d.ts +18 -0
- package/dist/core/catalog.d.ts.map +1 -0
- package/dist/core/catalog.js +82 -0
- package/dist/core/catalog.js.map +1 -0
- package/dist/core/index.d.ts +9 -0
- package/dist/core/index.d.ts.map +1 -0
- package/dist/core/index.js +9 -0
- package/dist/core/index.js.map +1 -0
- package/dist/core/markdown.d.ts +12 -0
- package/dist/core/markdown.d.ts.map +1 -0
- package/dist/core/markdown.js +26 -0
- package/dist/core/markdown.js.map +1 -0
- package/dist/core/payments.d.ts +11 -0
- package/dist/core/payments.d.ts.map +1 -0
- package/dist/core/payments.js +27 -0
- package/dist/core/payments.js.map +1 -0
- package/dist/core/pendingCheckout.d.ts +15 -0
- package/dist/core/pendingCheckout.d.ts.map +1 -0
- package/dist/core/pendingCheckout.js +40 -0
- package/dist/core/pendingCheckout.js.map +1 -0
- package/dist/core/resolver.d.ts +11 -0
- package/dist/core/resolver.d.ts.map +1 -0
- package/dist/core/resolver.js +106 -0
- package/dist/core/resolver.js.map +1 -0
- package/dist/core/selectors.d.ts +12 -0
- package/dist/core/selectors.d.ts.map +1 -0
- package/dist/core/selectors.js +18 -0
- package/dist/core/selectors.js.map +1 -0
- package/dist/core/subscriptionUpdate.d.ts +20 -0
- package/dist/core/subscriptionUpdate.d.ts.map +1 -0
- package/dist/core/subscriptionUpdate.js +64 -0
- package/dist/core/subscriptionUpdate.js.map +1 -0
- package/dist/core/types.d.ts +170 -0
- package/dist/core/types.d.ts.map +1 -0
- package/dist/core/types.js +15 -0
- package/dist/core/types.js.map +1 -0
- package/dist/design-system/colors/color-utils.d.ts +10 -0
- package/dist/design-system/colors/color-utils.d.ts.map +1 -0
- package/dist/design-system/colors/color-utils.js +91 -0
- package/dist/design-system/colors/color-utils.js.map +1 -0
- package/dist/design-system/colors/config.d.ts +33 -0
- package/dist/design-system/colors/config.d.ts.map +1 -0
- package/dist/design-system/colors/config.js +224 -0
- package/dist/design-system/colors/config.js.map +1 -0
- package/dist/design-system/colors/index.d.ts +3 -0
- package/dist/design-system/colors/index.d.ts.map +1 -0
- package/dist/design-system/colors/index.js +3 -0
- package/dist/design-system/colors/index.js.map +1 -0
- package/dist/design-system/rounded/config.d.ts +31 -0
- package/dist/design-system/rounded/config.d.ts.map +1 -0
- package/dist/design-system/rounded/config.js +76 -0
- package/dist/design-system/rounded/config.js.map +1 -0
- package/dist/design-system/rounded/index.d.ts +2 -0
- package/dist/design-system/rounded/index.d.ts.map +1 -0
- package/dist/design-system/rounded/index.js +2 -0
- package/dist/design-system/rounded/index.js.map +1 -0
- package/dist/design-system/typography/config.d.ts +55 -0
- package/dist/design-system/typography/config.d.ts.map +1 -0
- package/dist/design-system/typography/config.js +308 -0
- package/dist/design-system/typography/config.js.map +1 -0
- package/dist/design-system/typography/index.d.ts +3 -0
- package/dist/design-system/typography/index.d.ts.map +1 -0
- package/dist/design-system/typography/index.js +3 -0
- package/dist/design-system/typography/index.js.map +1 -0
- package/dist/design-system/typography/tokens.d.ts +23 -0
- package/dist/design-system/typography/tokens.d.ts.map +1 -0
- package/dist/design-system/typography/tokens.js +99 -0
- package/dist/design-system/typography/tokens.js.map +1 -0
- package/dist/react/hooks/useCheckoutSuccessParams.d.ts +2 -0
- package/dist/react/hooks/useCheckoutSuccessParams.d.ts.map +1 -0
- package/dist/react/hooks/useCheckoutSuccessParams.js +5 -0
- package/dist/react/hooks/useCheckoutSuccessParams.js.map +1 -0
- package/dist/react/index.d.ts +25 -0
- package/dist/react/index.d.ts.map +1 -0
- package/dist/react/index.js +22 -0
- package/dist/react/index.js.map +1 -0
- package/dist/react/primitives/BillingGate.d.ts +8 -0
- package/dist/react/primitives/BillingGate.d.ts.map +1 -0
- package/dist/react/primitives/BillingGate.js +13 -0
- package/dist/react/primitives/BillingGate.js.map +1 -0
- package/dist/react/primitives/BillingToggle.d.ts +8 -0
- package/dist/react/primitives/BillingToggle.d.ts.map +1 -0
- package/dist/react/primitives/BillingToggle.js +12 -0
- package/dist/react/primitives/BillingToggle.js.map +1 -0
- package/dist/react/primitives/CheckoutButton.d.ts +11 -0
- package/dist/react/primitives/CheckoutButton.d.ts.map +1 -0
- package/dist/react/primitives/CheckoutButton.js +21 -0
- package/dist/react/primitives/CheckoutButton.js.map +1 -0
- package/dist/react/primitives/CheckoutSuccessSummary.d.ts +7 -0
- package/dist/react/primitives/CheckoutSuccessSummary.d.ts.map +1 -0
- package/dist/react/primitives/CheckoutSuccessSummary.js +11 -0
- package/dist/react/primitives/CheckoutSuccessSummary.js.map +1 -0
- package/dist/react/primitives/CustomerPortalButton.d.ts +8 -0
- package/dist/react/primitives/CustomerPortalButton.d.ts.map +1 -0
- package/dist/react/primitives/CustomerPortalButton.js +21 -0
- package/dist/react/primitives/CustomerPortalButton.js.map +1 -0
- package/dist/react/primitives/NumberInput.d.ts +11 -0
- package/dist/react/primitives/NumberInput.d.ts.map +1 -0
- package/dist/react/primitives/NumberInput.js +18 -0
- package/dist/react/primitives/NumberInput.js.map +1 -0
- package/dist/react/primitives/OneTimeCheckoutButton.d.ts +11 -0
- package/dist/react/primitives/OneTimeCheckoutButton.d.ts.map +1 -0
- package/dist/react/primitives/OneTimeCheckoutButton.js +4 -0
- package/dist/react/primitives/OneTimeCheckoutButton.js.map +1 -0
- package/dist/react/primitives/OneTimePaymentStatusBadge.d.ts +6 -0
- package/dist/react/primitives/OneTimePaymentStatusBadge.d.ts.map +1 -0
- package/dist/react/primitives/OneTimePaymentStatusBadge.js +11 -0
- package/dist/react/primitives/OneTimePaymentStatusBadge.js.map +1 -0
- package/dist/react/primitives/PaymentWarningBanner.d.ts +7 -0
- package/dist/react/primitives/PaymentWarningBanner.d.ts.map +1 -0
- package/dist/react/primitives/PaymentWarningBanner.js +18 -0
- package/dist/react/primitives/PaymentWarningBanner.js.map +1 -0
- package/dist/react/primitives/PricingCard.d.ts +37 -0
- package/dist/react/primitives/PricingCard.d.ts.map +1 -0
- package/dist/react/primitives/PricingCard.js +125 -0
- package/dist/react/primitives/PricingCard.js.map +1 -0
- package/dist/react/primitives/PricingSection.d.ts +39 -0
- package/dist/react/primitives/PricingSection.d.ts.map +1 -0
- package/dist/react/primitives/PricingSection.js +24 -0
- package/dist/react/primitives/PricingSection.js.map +1 -0
- package/dist/react/primitives/ScheduledChangeBanner.d.ts +8 -0
- package/dist/react/primitives/ScheduledChangeBanner.d.ts.map +1 -0
- package/dist/react/primitives/ScheduledChangeBanner.js +13 -0
- package/dist/react/primitives/ScheduledChangeBanner.js.map +1 -0
- package/dist/react/primitives/SegmentControl.d.ts +11 -0
- package/dist/react/primitives/SegmentControl.d.ts.map +1 -0
- package/dist/react/primitives/SegmentControl.js +8 -0
- package/dist/react/primitives/SegmentControl.js.map +1 -0
- package/dist/react/primitives/SegmentGroup.d.ts +14 -0
- package/dist/react/primitives/SegmentGroup.d.ts.map +1 -0
- package/dist/react/primitives/SegmentGroup.js +11 -0
- package/dist/react/primitives/SegmentGroup.js.map +1 -0
- package/dist/react/primitives/TrialLimitBanner.d.ts +7 -0
- package/dist/react/primitives/TrialLimitBanner.d.ts.map +1 -0
- package/dist/react/primitives/TrialLimitBanner.js +14 -0
- package/dist/react/primitives/TrialLimitBanner.js.map +1 -0
- package/dist/react/shared.d.ts +28 -0
- package/dist/react/shared.d.ts.map +1 -0
- package/dist/react/shared.js +109 -0
- package/dist/react/shared.js.map +1 -0
- package/dist/react/widgets/BillingPortal.d.ts +9 -0
- package/dist/react/widgets/BillingPortal.d.ts.map +1 -0
- package/dist/react/widgets/BillingPortal.js +30 -0
- package/dist/react/widgets/BillingPortal.js.map +1 -0
- package/dist/react/widgets/ProductItem.d.ts +8 -0
- package/dist/react/widgets/ProductItem.d.ts.map +1 -0
- package/dist/react/widgets/ProductItem.js +14 -0
- package/dist/react/widgets/ProductItem.js.map +1 -0
- package/dist/react/widgets/ProductRoot.d.ts +16 -0
- package/dist/react/widgets/ProductRoot.d.ts.map +1 -0
- package/dist/react/widgets/ProductRoot.js +171 -0
- package/dist/react/widgets/ProductRoot.js.map +1 -0
- package/dist/react/widgets/SubscriptionItem.d.ts +27 -0
- package/dist/react/widgets/SubscriptionItem.d.ts.map +1 -0
- package/dist/react/widgets/SubscriptionItem.js +32 -0
- package/dist/react/widgets/SubscriptionItem.js.map +1 -0
- package/dist/react/widgets/SubscriptionRoot.d.ts +16 -0
- package/dist/react/widgets/SubscriptionRoot.d.ts.map +1 -0
- package/dist/react/widgets/SubscriptionRoot.js +405 -0
- package/dist/react/widgets/SubscriptionRoot.js.map +1 -0
- package/dist/react/widgets/index.d.ts +19 -0
- package/dist/react/widgets/index.d.ts.map +1 -0
- package/dist/react/widgets/index.js +16 -0
- package/dist/react/widgets/index.js.map +1 -0
- package/dist/react/widgets/productGroupContext.d.ts +6 -0
- package/dist/react/widgets/productGroupContext.d.ts.map +1 -0
- package/dist/react/widgets/productGroupContext.js +3 -0
- package/dist/react/widgets/productGroupContext.js.map +1 -0
- package/dist/react/widgets/subscriptionContext.d.ts +6 -0
- package/dist/react/widgets/subscriptionContext.d.ts.map +1 -0
- package/dist/react/widgets/subscriptionContext.js +3 -0
- package/dist/react/widgets/subscriptionContext.js.map +1 -0
- package/dist/react/widgets/types.d.ts +171 -0
- package/dist/react/widgets/types.d.ts.map +1 -0
- package/dist/react/widgets/types.js +2 -0
- package/dist/react/widgets/types.js.map +1 -0
- package/dist/svelte/index.d.ts +22 -0
- package/dist/svelte/index.d.ts.map +1 -0
- package/dist/svelte/index.js +20 -0
- package/dist/svelte/index.js.map +1 -0
- package/dist/svelte/primitives/BillingGate.svelte +28 -0
- package/dist/svelte/primitives/BillingToggle.svelte +27 -0
- package/dist/svelte/primitives/CheckoutButton.svelte +60 -0
- package/dist/svelte/primitives/CheckoutSuccessSummary.svelte +34 -0
- package/dist/svelte/primitives/CustomerPortalButton.svelte +60 -0
- package/dist/svelte/primitives/NumberInput.svelte +71 -0
- package/dist/svelte/primitives/OneTimeCheckoutButton.svelte +37 -0
- package/dist/svelte/primitives/OneTimePaymentStatusBadge.svelte +20 -0
- package/dist/svelte/primitives/PaymentWarningBanner.svelte +30 -0
- package/dist/svelte/primitives/PricingCard.svelte +356 -0
- package/dist/svelte/primitives/PricingSection.svelte +121 -0
- package/dist/svelte/primitives/ScheduledChangeBanner.svelte +46 -0
- package/dist/svelte/primitives/SegmentControl.svelte +38 -0
- package/dist/svelte/primitives/SegmentGroup.svelte +52 -0
- package/dist/svelte/primitives/TrialLimitBanner.svelte +32 -0
- package/dist/svelte/primitives/shared.d.ts +13 -0
- package/dist/svelte/primitives/shared.d.ts.map +1 -0
- package/dist/svelte/primitives/shared.js +87 -0
- package/dist/svelte/primitives/shared.js.map +1 -0
- package/dist/svelte/widgets/BillingPortal.svelte +55 -0
- package/dist/svelte/widgets/Product.svelte +35 -0
- package/dist/svelte/widgets/ProductRoot.svelte +428 -0
- package/dist/svelte/widgets/Subscription.svelte +52 -0
- package/dist/svelte/widgets/SubscriptionRoot.svelte +690 -0
- package/dist/svelte/widgets/index.d.ts +19 -0
- package/dist/svelte/widgets/index.d.ts.map +1 -0
- package/dist/svelte/widgets/index.js +16 -0
- package/dist/svelte/widgets/index.js.map +1 -0
- package/dist/svelte/widgets/productGroupContext.d.ts +6 -0
- package/dist/svelte/widgets/productGroupContext.d.ts.map +1 -0
- package/dist/svelte/widgets/productGroupContext.js +2 -0
- package/dist/svelte/widgets/productGroupContext.js.map +1 -0
- package/dist/svelte/widgets/subscriptionContext.d.ts +6 -0
- package/dist/svelte/widgets/subscriptionContext.d.ts.map +1 -0
- package/dist/svelte/widgets/subscriptionContext.js +2 -0
- package/dist/svelte/widgets/subscriptionContext.js.map +1 -0
- package/dist/svelte/widgets/types.d.ts +171 -0
- package/dist/svelte/widgets/types.d.ts.map +1 -0
- package/dist/svelte/widgets/types.js +2 -0
- package/dist/svelte/widgets/types.js.map +1 -0
- package/package.json +182 -0
- package/src/client/helpers.test.ts +139 -0
- package/src/client/helpers.ts +51 -0
- package/src/client/index.test.ts +1554 -0
- package/src/client/index.ts +1504 -0
- package/src/client/parsers.test.ts +1017 -0
- package/src/client/parsers.ts +182 -0
- package/src/client/polyfill.ts +2 -0
- package/src/component/_generated/api.ts +52 -0
- package/src/component/_generated/component.ts +619 -0
- package/src/component/_generated/dataModel.ts +60 -0
- package/src/component/_generated/server.ts +156 -0
- package/src/component/convex.config.ts +3 -0
- package/src/component/lib.test.ts +1359 -0
- package/src/component/lib.ts +726 -0
- package/src/component/schema.ts +112 -0
- package/src/component/util.test.ts +281 -0
- package/src/component/util.ts +228 -0
- package/src/core/catalog.test.ts +212 -0
- package/src/core/catalog.ts +119 -0
- package/src/core/index.ts +8 -0
- package/src/core/markdown.test.ts +43 -0
- package/src/core/markdown.ts +26 -0
- package/src/core/payments.test.ts +69 -0
- package/src/core/payments.ts +33 -0
- package/src/core/pendingCheckout.test.ts +44 -0
- package/src/core/pendingCheckout.ts +40 -0
- package/src/core/resolver.test.ts +283 -0
- package/src/core/resolver.ts +160 -0
- package/src/core/selectors.test.ts +119 -0
- package/src/core/selectors.ts +35 -0
- package/src/core/subscriptionUpdate.test.ts +164 -0
- package/src/core/subscriptionUpdate.ts +102 -0
- package/src/core/types.ts +220 -0
- package/src/design-system/README.md +40 -0
- package/src/design-system/base.css +27 -0
- package/src/design-system/colors/color-utils.ts +110 -0
- package/src/design-system/colors/config.ts +282 -0
- package/src/design-system/colors/index.ts +2 -0
- package/src/design-system/colors/utilities.css +2328 -0
- package/src/design-system/components/badges.css +65 -0
- package/src/design-system/components/buttons.css +256 -0
- package/src/design-system/components/dialog.css +218 -0
- package/src/design-system/components/icon-buttons.css +115 -0
- package/src/design-system/components/inputs.css +94 -0
- package/src/design-system/components/links.css +53 -0
- package/src/design-system/components/prose.css +67 -0
- package/src/design-system/components/segment-control.css +303 -0
- package/src/design-system/index.css +21 -0
- package/src/design-system/rounded/config.ts +91 -0
- package/src/design-system/rounded/index.ts +1 -0
- package/src/design-system/rounded/utilities.css +37 -0
- package/src/design-system/typography/config.ts +340 -0
- package/src/design-system/typography/index.ts +2 -0
- package/src/design-system/typography/tokens.ts +148 -0
- package/src/design-system/typography/utilities.css +728 -0
- package/src/library.css +20 -0
- package/src/react/hooks/useCheckoutSuccessParams.ts +7 -0
- package/src/react/index.tsx +47 -0
- package/src/react/primitives/BillingGate.tsx +26 -0
- package/src/react/primitives/BillingToggle.tsx +29 -0
- package/src/react/primitives/CheckoutButton.tsx +47 -0
- package/src/react/primitives/CheckoutSuccessSummary.tsx +36 -0
- package/src/react/primitives/CustomerPortalButton.tsx +50 -0
- package/src/react/primitives/NumberInput.tsx +83 -0
- package/src/react/primitives/OneTimeCheckoutButton.tsx +27 -0
- package/src/react/primitives/OneTimePaymentStatusBadge.tsx +18 -0
- package/src/react/primitives/PaymentWarningBanner.tsx +33 -0
- package/src/react/primitives/PricingCard.tsx +421 -0
- package/src/react/primitives/PricingSection.tsx +129 -0
- package/src/react/primitives/ScheduledChangeBanner.tsx +52 -0
- package/src/react/primitives/SegmentControl.tsx +32 -0
- package/src/react/primitives/SegmentGroup.tsx +53 -0
- package/src/react/primitives/TrialLimitBanner.tsx +32 -0
- package/src/react/shared.ts +138 -0
- package/src/react/widgets/BillingPortal.tsx +56 -0
- package/src/react/widgets/ProductItem.tsx +26 -0
- package/src/react/widgets/ProductRoot.tsx +441 -0
- package/src/react/widgets/SubscriptionItem.tsx +71 -0
- package/src/react/widgets/SubscriptionRoot.tsx +759 -0
- package/src/react/widgets/index.ts +36 -0
- package/src/react/widgets/productGroupContext.ts +10 -0
- package/src/react/widgets/subscriptionContext.ts +10 -0
- package/src/react/widgets/types.ts +179 -0
- package/src/svelte/index.ts +43 -0
- package/src/svelte/primitives/BillingGate.svelte +28 -0
- package/src/svelte/primitives/BillingToggle.svelte +27 -0
- package/src/svelte/primitives/CheckoutButton.svelte +60 -0
- package/src/svelte/primitives/CheckoutSuccessSummary.svelte +34 -0
- package/src/svelte/primitives/CustomerPortalButton.svelte +60 -0
- package/src/svelte/primitives/NumberInput.svelte +71 -0
- package/src/svelte/primitives/OneTimeCheckoutButton.svelte +37 -0
- package/src/svelte/primitives/OneTimePaymentStatusBadge.svelte +20 -0
- package/src/svelte/primitives/PaymentWarningBanner.svelte +30 -0
- package/src/svelte/primitives/PricingCard.svelte +356 -0
- package/src/svelte/primitives/PricingSection.svelte +121 -0
- package/src/svelte/primitives/ScheduledChangeBanner.svelte +46 -0
- package/src/svelte/primitives/SegmentControl.svelte +38 -0
- package/src/svelte/primitives/SegmentGroup.svelte +52 -0
- package/src/svelte/primitives/TrialLimitBanner.svelte +32 -0
- package/src/svelte/primitives/shared.ts +113 -0
- package/src/svelte/svelte.d.ts +6 -0
- package/src/svelte/widgets/BillingPortal.svelte +55 -0
- package/src/svelte/widgets/Product.svelte +35 -0
- package/src/svelte/widgets/ProductRoot.svelte +428 -0
- package/src/svelte/widgets/Subscription.svelte +52 -0
- package/src/svelte/widgets/SubscriptionRoot.svelte +690 -0
- package/src/svelte/widgets/index.ts +36 -0
- package/src/svelte/widgets/productGroupContext.ts +7 -0
- package/src/svelte/widgets/subscriptionContext.ts +7 -0
- package/src/svelte/widgets/types.ts +179 -0
- package/src/tailwind.css +6 -0
- 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"}
|