@stigg/react-sdk 4.3.0-beta.0 → 4.3.0-beta.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (31) hide show
  1. package/dist/components/checkout/CheckoutContainer.style.d.ts +0 -3
  2. package/dist/components/checkout/CheckoutProvider.d.ts +2 -0
  3. package/dist/components/checkout/hooks/useLoadCheckout.d.ts +1 -3
  4. package/dist/components/checkout/index.d.ts +1 -1
  5. package/dist/components/checkout/theme.d.ts +6 -2
  6. package/dist/components/common/mapExternalTheme.d.ts +2 -3
  7. package/dist/index.d.ts +1 -1
  8. package/dist/react-sdk.cjs.development.js +111 -85
  9. package/dist/react-sdk.cjs.development.js.map +1 -1
  10. package/dist/react-sdk.cjs.production.min.js +1 -1
  11. package/dist/react-sdk.cjs.production.min.js.map +1 -1
  12. package/dist/react-sdk.esm.js +113 -90
  13. package/dist/react-sdk.esm.js.map +1 -1
  14. package/dist/stories/CustomerPortal.stories.d.ts +1 -1
  15. package/package.json +2 -2
  16. package/src/components/checkout/CheckoutContainer.style.ts +3 -3
  17. package/src/components/checkout/CheckoutContainer.tsx +3 -7
  18. package/src/components/checkout/CheckoutProvider.tsx +9 -4
  19. package/src/components/checkout/CheckoutSummary.tsx +1 -1
  20. package/src/components/checkout/components/InputField.tsx +1 -2
  21. package/src/components/checkout/hooks/useLoadCheckout.ts +1 -1
  22. package/src/components/checkout/index.ts +1 -1
  23. package/src/components/checkout/steps/payment/stripe/StripePaymentForm.tsx +2 -2
  24. package/src/components/checkout/steps/plan/BillingPeriodPicker.style.tsx +1 -1
  25. package/src/components/checkout/theme.ts +31 -14
  26. package/src/components/common/mapExternalTheme.ts +22 -12
  27. package/src/index.ts +1 -1
  28. package/src/stories/Checkout.stories.tsx +4 -1
  29. package/src/stories/CustomerPortal.stories.tsx +1 -1
  30. package/dist/components/checkout/types.d.ts +0 -7
  31. package/src/components/checkout/types.ts +0 -7
@@ -2953,10 +2953,9 @@ function mapFontWeight$1(defaultValue, fontWeight) {
2953
2953
  }
2954
2954
  }
2955
2955
 
2956
- function mapTypography(configuration) {
2956
+ function mapTypography(typography) {
2957
2957
  var _typography$h, _typography$h2, _typography$h3, _typography$h4, _typography$h5, _typography$h6, _typography$body, _typography$body2;
2958
2958
 
2959
- var typography = configuration.typography;
2960
2959
  return {
2961
2960
  fontFamilyUrl: (typography == null ? void 0 : typography.fontFamily) || undefined,
2962
2961
  h1: {
@@ -2996,7 +2995,8 @@ function mapAlignment(alignment) {
2996
2995
  }
2997
2996
 
2998
2997
  function mapCustomerPortalConfiguration(configuration) {
2999
- var palette = configuration.palette;
2998
+ var palette = configuration.palette,
2999
+ typography = configuration.typography;
3000
3000
  return {
3001
3001
  palette: {
3002
3002
  primary: (palette == null ? void 0 : palette.primary) || undefined,
@@ -3007,13 +3007,14 @@ function mapCustomerPortalConfiguration(configuration) {
3007
3007
  primary: (palette == null ? void 0 : palette.textColor) || undefined
3008
3008
  }
3009
3009
  },
3010
- typography: mapTypography(configuration)
3010
+ typography: mapTypography(typography)
3011
3011
  };
3012
3012
  }
3013
3013
  function mapPaywallConfiguration(paywallConfiguration) {
3014
3014
  var palette = paywallConfiguration.palette,
3015
3015
  layout = paywallConfiguration.layout,
3016
- customCss = paywallConfiguration.customCss;
3016
+ customCss = paywallConfiguration.customCss,
3017
+ typography = paywallConfiguration.typography;
3017
3018
  return {
3018
3019
  customCss: customCss || undefined,
3019
3020
  palette: {
@@ -3025,7 +3026,7 @@ function mapPaywallConfiguration(paywallConfiguration) {
3025
3026
  primary: (palette == null ? void 0 : palette.textColor) || undefined
3026
3027
  }
3027
3028
  },
3028
- typography: mapTypography(paywallConfiguration),
3029
+ typography: mapTypography(typography),
3029
3030
  layout: {
3030
3031
  ctaAlignment: mapAlignment(layout == null ? void 0 : layout.alignment),
3031
3032
  headerAlignment: mapAlignment(layout == null ? void 0 : layout.alignment),
@@ -3037,9 +3038,22 @@ function mapPaywallConfiguration(paywallConfiguration) {
3037
3038
  }
3038
3039
  };
3039
3040
  }
3040
- function mapCheckoutConfiguration(_configuration) {
3041
- // TODO: configuration should be of type CustomerPortalConfiguration
3042
- return {};
3041
+ function mapCheckoutConfiguration(configuration) {
3042
+ var palette = configuration.palette,
3043
+ typography = configuration.typography;
3044
+ return {
3045
+ palette: {
3046
+ primary: (palette == null ? void 0 : palette.primary) || undefined,
3047
+ backgroundPaper: (palette == null ? void 0 : palette.backgroundColor) || undefined,
3048
+ outlinedBorder: (palette == null ? void 0 : palette.borderColor) || undefined,
3049
+ text: {
3050
+ primary: (palette == null ? void 0 : palette.textColor) || undefined
3051
+ },
3052
+ backgroundHighlight: (palette == null ? void 0 : palette.selectionColor) || undefined,
3053
+ backgroundSection: (palette == null ? void 0 : palette.summaryBackgroundColor) || undefined
3054
+ },
3055
+ typography: mapTypography(typography)
3056
+ };
3043
3057
  }
3044
3058
 
3045
3059
  function getCustomerSubscriptionDetails(activeSubscriptions) {
@@ -6855,15 +6869,26 @@ function getResolvedCheckoutLocalize(localizeOverride) {
6855
6869
  return merge(checkoutDefaultLocalization, localizeOverride);
6856
6870
  }
6857
6871
 
6858
- function getResolvedCheckoutTheme(_globalTheme, themeOverride, remoteConfiguration) {
6859
- var _remoteConfiguration$, _remoteConfiguration$2;
6872
+ var defaultCheckoutTheme = {
6873
+ primary: 'rgb(50, 126, 238)',
6874
+ textColor: 'rgb(0, 30, 108)',
6875
+ backgroundColor: 'rgb(255, 255, 255)',
6876
+ borderColor: 'rgb(235, 237, 243)',
6877
+ selectionColor: 'rgb(229, 242, 255)',
6878
+ summaryBackgroundColor: 'rgb(109, 121, 144)'
6879
+ };
6880
+ function getResolvedCheckoutTheme(globalTheme, themeOverride, _remoteConfiguration) {
6881
+ var _ref = globalTheme || {},
6882
+ globalPalette = _ref.palette;
6860
6883
 
6861
- // todo: implement theme customization
6862
- var checkoutDefaultTheme = {
6863
- backgroundColor: (themeOverride == null ? void 0 : themeOverride.backgroundColor) || (remoteConfiguration == null ? void 0 : (_remoteConfiguration$ = remoteConfiguration.palette) == null ? void 0 : _remoteConfiguration$.backgroundColor) || 'white',
6864
- borderColor: (themeOverride == null ? void 0 : themeOverride.borderColor) || (remoteConfiguration == null ? void 0 : (_remoteConfiguration$2 = remoteConfiguration.palette) == null ? void 0 : _remoteConfiguration$2.borderColor) || 'rgba(0, 30, 108, 0.15)'
6884
+ return {
6885
+ primary: (themeOverride == null ? void 0 : themeOverride.primary) || (globalPalette == null ? void 0 : globalPalette.primary) || defaultCheckoutTheme.primary,
6886
+ textColor: (themeOverride == null ? void 0 : themeOverride.textColor) || (globalPalette == null ? void 0 : globalPalette.text.primary) || defaultCheckoutTheme.textColor,
6887
+ backgroundColor: (themeOverride == null ? void 0 : themeOverride.backgroundColor) || (globalPalette == null ? void 0 : globalPalette.backgroundPaper) || defaultCheckoutTheme.backgroundColor,
6888
+ borderColor: (themeOverride == null ? void 0 : themeOverride.borderColor) || (globalPalette == null ? void 0 : globalPalette.outlinedBorder) || defaultCheckoutTheme.borderColor,
6889
+ selectionColor: (themeOverride == null ? void 0 : themeOverride.selectionColor) || (globalPalette == null ? void 0 : globalPalette.backgroundSection) || defaultCheckoutTheme.selectionColor,
6890
+ summaryBackgroundColor: (themeOverride == null ? void 0 : themeOverride.summaryBackgroundColor) || (globalPalette == null ? void 0 : globalPalette.backgroundHighlight) || defaultCheckoutTheme.summaryBackgroundColor
6865
6891
  };
6866
- return checkoutDefaultTheme;
6867
6892
  }
6868
6893
 
6869
6894
  var CheckoutContext = /*#__PURE__*/React__default.createContext(null);
@@ -6923,9 +6948,9 @@ function CheckoutProvider(_ref2) {
6923
6948
  checkout = _useLoadCheckout.checkout,
6924
6949
  isLoading = _useLoadCheckout.isLoading;
6925
6950
 
6926
- var configuration = checkout != null && checkout.configuration ? mapCheckoutConfiguration() : undefined;
6951
+ var configuration = checkout != null && checkout.configuration ? mapCheckoutConfiguration(checkout.configuration) : undefined;
6927
6952
  var globalTheme = useStiggTheme(configuration);
6928
- var checkoutTheme = getResolvedCheckoutTheme(globalTheme, theme, checkout == null ? void 0 : checkout.configuration);
6953
+ var checkoutTheme = getResolvedCheckoutTheme(globalTheme, theme);
6929
6954
  var checkoutLocalization = getResolvedCheckoutLocalize(textOverrides);
6930
6955
  var initialState = React.useMemo(function () {
6931
6956
  var _checkout$resource;
@@ -6952,6 +6977,7 @@ function CheckoutProvider(_ref2) {
6952
6977
  checkout: checkout,
6953
6978
  isLoading: isLoading,
6954
6979
  checkoutLocalization: checkoutLocalization,
6980
+ stiggTheme: globalTheme,
6955
6981
  theme: checkoutTheme,
6956
6982
  progressBar: progressBar,
6957
6983
  planStep: planStep,
@@ -6963,7 +6989,7 @@ function CheckoutProvider(_ref2) {
6963
6989
  }
6964
6990
  };
6965
6991
  return initialState;
6966
- }, [billingCountryCode, preferredBillingPeriod, checkout]);
6992
+ }, [theme, globalTheme, billingCountryCode, preferredBillingPeriod, checkout]);
6967
6993
  return React__default.createElement(SdkThemeProvider, {
6968
6994
  key: checkout == null ? void 0 : checkout.plan.id,
6969
6995
  componentTheme: configuration
@@ -6977,19 +7003,19 @@ var CheckoutLayout = /*#__PURE__*/_styled("div", {
6977
7003
  target: "ergo9xd2",
6978
7004
  label: "CheckoutLayout"
6979
7005
  })("margin:auto;width:100%;max-width:920px;display:flex;flex-direction:column;align-items:center;padding:16px 32px;border-radius:10px;background-color:", function (_ref) {
6980
- var $backgroundColor = _ref.$backgroundColor;
6981
- return $backgroundColor;
7006
+ var theme = _ref.theme;
7007
+ return theme.stigg.palette.backgroundPaper;
6982
7008
  }, ";border:", function (_ref2) {
6983
- var $borderColor = _ref2.$borderColor;
6984
- return "1px solid " + $borderColor;
6985
- }, ";& *{box-sizing:border-box;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUV5QyIsImZpbGUiOiJDaGVja291dENvbnRhaW5lci5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJveCBmcm9tICdAbXVpL21hdGVyaWFsL0JveCc7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBtYXJnaW46IGF1dG87XG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6IDkyMHB4O1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gIHBhZGRpbmc6IDE2cHggMzJweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyAkYmFja2dyb3VuZENvbG9yIH0pID0+ICRiYWNrZ3JvdW5kQ29sb3J9O1xuICBib3JkZXI6ICR7KHsgJGJvcmRlckNvbG9yIH0pID0+IGAxcHggc29saWQgJHskYm9yZGVyQ29sb3J9YH07XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRDb250ZW50ID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiAzMnB4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0UGFuZWwgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGdhcDogMDtcbiAgZmxleDogMjtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLmpzLm1hcCJdfQ== */"));
7009
+ var theme = _ref2.theme;
7010
+ return "1px solid " + theme.stigg.palette.outlinedBorder;
7011
+ }, ";& *{box-sizing:border-box;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUV5QyIsImZpbGUiOiJDaGVja291dENvbnRhaW5lci5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJveCBmcm9tICdAbXVpL21hdGVyaWFsL0JveCc7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBtYXJnaW46IGF1dG87XG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6IDkyMHB4O1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gIHBhZGRpbmc6IDE2cHggMzJweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLmJhY2tncm91bmRQYXBlcn07XG4gIGJvcmRlcjogJHsoeyB0aGVtZSB9KSA9PiBgMXB4IHNvbGlkICR7dGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn1gfTtcblxuICAmICoge1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dENvbnRlbnQgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBmbGV4LXN0YXJ0O1xuICBnYXA6IDMycHg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRQYW5lbCA9IHN0eWxlZChCb3gpIGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgZ2FwOiAwO1xuICBmbGV4OiAyO1xuYDtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRDb250YWluZXIuc3R5bGUuanMubWFwIl19 */"));
6986
7012
  var CheckoutContent = /*#__PURE__*/_styled(Box, {
6987
7013
  target: "ergo9xd1",
6988
7014
  label: "CheckoutContent"
6989
7015
  })( {
6990
7016
  name: "1pdbip7",
6991
7017
  styles: "display:flex;align-items:flex-start;gap:32px;flex-wrap:wrap;width:100%",
6992
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1CMkMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luOiBhdXRvO1xuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA5MjBweDtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBwYWRkaW5nOiAxNnB4IDMycHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgJGJhY2tncm91bmRDb2xvciB9KSA9PiAkYmFja2dyb3VuZENvbG9yfTtcbiAgYm9yZGVyOiAkeyh7ICRib3JkZXJDb2xvciB9KSA9PiBgMXB4IHNvbGlkICR7JGJvcmRlckNvbG9yfWB9O1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0Q29udGVudCA9IHN0eWxlZChCb3gpIGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMzJweDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dFBhbmVsID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDA7XG4gIGZsZXg6IDI7XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1DaGVja291dENvbnRhaW5lci5zdHlsZS5qcy5tYXAiXX0= */",
7018
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1CMkMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luOiBhdXRvO1xuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA5MjBweDtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBwYWRkaW5nOiAxNnB4IDMycHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXJ9O1xuICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRDb250ZW50ID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiAzMnB4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0UGFuZWwgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGdhcDogMDtcbiAgZmxleDogMjtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLmpzLm1hcCJdfQ== */",
6993
7019
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
6994
7020
  });
6995
7021
  var CheckoutPanel = /*#__PURE__*/_styled(Box, {
@@ -6998,7 +7024,7 @@ var CheckoutPanel = /*#__PURE__*/_styled(Box, {
6998
7024
  })( {
6999
7025
  name: "fszphw",
7000
7026
  styles: "display:flex;flex-direction:column;gap:0;flex:2",
7001
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBCeUMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luOiBhdXRvO1xuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA5MjBweDtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBwYWRkaW5nOiAxNnB4IDMycHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgJGJhY2tncm91bmRDb2xvciB9KSA9PiAkYmFja2dyb3VuZENvbG9yfTtcbiAgYm9yZGVyOiAkeyh7ICRib3JkZXJDb2xvciB9KSA9PiBgMXB4IHNvbGlkICR7JGJvcmRlckNvbG9yfWB9O1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0Q29udGVudCA9IHN0eWxlZChCb3gpIGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMzJweDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dFBhbmVsID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDA7XG4gIGZsZXg6IDI7XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1DaGVja291dENvbnRhaW5lci5zdHlsZS5qcy5tYXAiXX0= */",
7027
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBCeUMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luOiBhdXRvO1xuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA5MjBweDtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBwYWRkaW5nOiAxNnB4IDMycHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXJ9O1xuICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRDb250ZW50ID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiAzMnB4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0UGFuZWwgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGdhcDogMDtcbiAgZmxleDogMjtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLmpzLm1hcCJdfQ== */",
7002
7028
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
7003
7029
  });
7004
7030
 
@@ -7149,6 +7175,7 @@ var InputField = /*#__PURE__*/styled$1(material.TextField)(function (_ref) {
7149
7175
  var theme = _ref.theme;
7150
7176
  return {
7151
7177
  '& .MuiOutlinedInput-root': {
7178
+ height: '42px',
7152
7179
  borderRadius: theme.stigg.border.radius,
7153
7180
  fieldset: {
7154
7181
  borderColor: theme.stigg.palette.outlinedBorder
@@ -7162,9 +7189,7 @@ var InputField = /*#__PURE__*/styled$1(material.TextField)(function (_ref) {
7162
7189
  borderRadius: theme.stigg.border.radius,
7163
7190
  fontFamily: theme.stigg.typography.fontFamily,
7164
7191
  color: theme.stigg.palette.text.primary
7165
- }, theme.stigg.typography.body, {
7166
- height: '42px'
7167
- })
7192
+ }, theme.stigg.typography.body)
7168
7193
  };
7169
7194
  });
7170
7195
 
@@ -7443,12 +7468,15 @@ var PromotionCodeSection = function PromotionCodeSection(_ref) {
7443
7468
  };
7444
7469
 
7445
7470
  function StripePaymentForm() {
7471
+ var _configuration$conten;
7472
+
7446
7473
  var _useCheckoutModel = useCheckoutModel(),
7447
7474
  checkoutState = _useCheckoutModel.checkoutState,
7448
7475
  checkoutLocalization = _useCheckoutModel.checkoutLocalization;
7449
7476
 
7450
7477
  var _ref = checkoutState || {},
7451
- customer = _ref.customer;
7478
+ customer = _ref.customer,
7479
+ configuration = _ref.configuration;
7452
7480
 
7453
7481
  return React__default.createElement(material.Grid, {
7454
7482
  flexDirection: "column",
@@ -7465,7 +7493,7 @@ function StripePaymentForm() {
7465
7493
  options: {
7466
7494
  mode: 'billing',
7467
7495
  fields: {
7468
- phone: 'always'
7496
+ phone: !!(configuration != null && (_configuration$conten = configuration.content) != null && _configuration$conten.collectPhoneNumber) ? 'always' : 'auto'
7469
7497
  },
7470
7498
  defaultValues: _extends({}, (customer == null ? void 0 : customer.name) && {
7471
7499
  name: customer.name
@@ -8026,12 +8054,10 @@ function _EMOTION_STRINGIFIED_CSS_ERROR__$k() { return "You have tried to string
8026
8054
  var SummaryCard = /*#__PURE__*/_styled(material.Paper, {
8027
8055
  target: "e164dmji6",
8028
8056
  label: "SummaryCard"
8029
- })( {
8030
- name: "1qvn0za",
8031
- styles: "border-radius:10px;background:#f8f9fb;padding:16px",
8032
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAckC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: #f8f9fb;\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8033
- toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
8034
- });
8057
+ })("border-radius:10px;background:", function (_ref) {
8058
+ var theme = _ref.theme;
8059
+ return theme.stigg.palette.backgroundHighlight;
8060
+ }, ";padding:16px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAckC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */"));
8035
8061
 
8036
8062
  SummaryCard.defaultProps = {
8037
8063
  elevation: 0
@@ -8043,7 +8069,7 @@ var PlanName = /*#__PURE__*/_styled(Typography, {
8043
8069
  })( {
8044
8070
  name: "18uqayh",
8045
8071
  styles: "margin-bottom:16px",
8046
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAsBoC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: #f8f9fb;\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8072
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAsBoC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8047
8073
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
8048
8074
  });
8049
8075
 
@@ -8053,7 +8079,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", {
8053
8079
  })( {
8054
8080
  name: "rdmn2i",
8055
8081
  styles: "&+&{margin-top:8px;}",
8056
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAyBqC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: #f8f9fb;\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8082
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAyBqC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8057
8083
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
8058
8084
  });
8059
8085
 
@@ -8063,7 +8089,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", {
8063
8089
  })( {
8064
8090
  name: "bcffy2",
8065
8091
  styles: "display:flex;align-items:center;justify-content:space-between",
8066
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA8B+B","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: #f8f9fb;\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8092
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA8B+B","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8067
8093
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
8068
8094
  });
8069
8095
 
@@ -8073,7 +8099,7 @@ var StyledDivider$1 = /*#__PURE__*/_styled(material.Divider, {
8073
8099
  })( {
8074
8100
  name: "1k6141t",
8075
8101
  styles: "margin:16px 0",
8076
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAmCsC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: #f8f9fb;\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8102
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAmCsC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8077
8103
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
8078
8104
  });
8079
8105
 
@@ -8083,7 +8109,7 @@ var SubtotalText = /*#__PURE__*/_styled(Typography, {
8083
8109
  })( {
8084
8110
  name: "1d0nbku",
8085
8111
  styles: "margin-top:24px",
8086
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAsCwC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: #f8f9fb;\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8112
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAsCwC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8087
8113
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
8088
8114
  });
8089
8115
 
@@ -8093,14 +8119,14 @@ var TotalDueText = /*#__PURE__*/_styled(Typography, {
8093
8119
  })( {
8094
8120
  name: "5bhc30",
8095
8121
  styles: "margin-bottom:8px",
8096
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAyCwC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: #f8f9fb;\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8122
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAyCwC","file":"CheckoutSummary.tsx","sourcesContent":["import partition from 'lodash/partition';\r\nimport React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper, Skeleton } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, DiscountType } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../common/PoweredByStigg';\r\nimport { Typography } from '../common/Typography';\r\nimport { useChargesSort } from '../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../utils/currencyUtils';\r\nimport { Button } from './components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from './hooks';\r\nimport { PromotionCodeSection } from './promotionCode';\r\nimport { useSubmit } from './steps/payment/stripe';\r\nimport { getTierByQuantity } from '../utils/priceTierUtils';\r\nconst SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nconst LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nexport const getPriceString = ({ amountPerMonth, price, quantity, }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amountPerMonth = amountPerMonth / 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount: amountPerMonth, currency: price.currency });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst BilledPriceLineItem = ({ label, quantity, price }) => {\r\n    const { billingPeriod } = price;\r\n    let amountPerMonth;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amountPerMonth = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amountPerMonth = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amountPerMonth, price, quantity })))),\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, currencyPriceFormatter({ amount: quantity * amountPerMonth, currency: price.currency }))))));\r\n};\r\nconst DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { subTotal, discount } = subscriptionPreview || {};\r\n    if (!subTotal || !discount) {\r\n        return null;\r\n    }\r\n    let discountAmount;\r\n    if (discount.type === DiscountType.Percentage) {\r\n        discountAmount = -1 * Math.abs((discount.value / 100) * subTotal.amount);\r\n    }\r\n    else {\r\n        discountAmount = -1 * Math.abs(discount.value);\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `Discount${discount.type === DiscountType.Percentage ? ` (${discount.value}% off)` : ''}`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: discountAmount, currency: subTotal.currency }))))));\r\n};\r\nconst TaxLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, }) => {\r\n    const { tax, taxDetails } = subscriptionPreview || {};\r\n    if (!taxDetails || !tax) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, `${taxDetails.displayName} (${taxDetails?.percentage}%)`),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency }))))));\r\n};\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter(price => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, price => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({ onCheckout, onCheckoutCompleted });\r\n    const handleCheckout = async (e) => {\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            return;\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map(price => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find(billableFeature => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map(addon => {\r\n                    const addonPrice = addon.addon.pricePoints?.find(price => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            !!subscriptionPreview?.hasScheduledUpdates && activeSubscription?.currentBillingPeriodEnd && (React.createElement(Typography, { variant: \"caption\" }, typeof checkoutLocalization.changesWillApplyAtEndOfBillingPeriod === 'function'\r\n                ? checkoutLocalization.changesWillApplyAtEndOfBillingPeriod({\r\n                    billingPeriodEnd: activeSubscription.currentBillingPeriodEnd,\r\n                })\r\n                : checkoutLocalization.changesWillApplyAtEndOfBillingPeriod)),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, variant: \"contained\", size: \"medium\", onClick: async (e) => {\r\n                    if (isLoading) {\r\n                        return;\r\n                    }\r\n                    if (isLastStep) {\r\n                        await handleCheckout(e);\r\n                    }\r\n                    else {\r\n                        progressBar.goNext();\r\n                    }\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } },\r\n                    isLoading && React.createElement(CircularProgress, { size: 20 }),\r\n                    !isLoading &&\r\n                        (isLastStep\r\n                            ? checkoutLocalization.checkoutButton.purchaseText\r\n                            : checkoutLocalization.checkoutButton.nextText)))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } })));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
8097
8123
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
8098
8124
  });
8099
8125
 
8100
- var getPriceString = function getPriceString(_ref) {
8101
- var amountPerMonth = _ref.amountPerMonth,
8102
- price = _ref.price,
8103
- quantity = _ref.quantity;
8126
+ var getPriceString = function getPriceString(_ref2) {
8127
+ var amountPerMonth = _ref2.amountPerMonth,
8128
+ price = _ref2.price,
8129
+ quantity = _ref2.quantity;
8104
8130
  var billingPeriod = price.billingPeriod;
8105
8131
  var billingPeriodString = null;
8106
8132
 
@@ -8116,10 +8142,10 @@ var getPriceString = function getPriceString(_ref) {
8116
8142
  return "" + (quantity > 1 ? quantity + " x " + addonPriceFormat + " each" : addonPriceFormat) + (billingPeriodString ? " x " + billingPeriodString : '');
8117
8143
  };
8118
8144
 
8119
- var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
8120
- var label = _ref2.label,
8121
- quantity = _ref2.quantity,
8122
- price = _ref2.price;
8145
+ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
8146
+ var label = _ref3.label,
8147
+ quantity = _ref3.quantity,
8148
+ price = _ref3.price;
8123
8149
  var billingPeriod = price.billingPeriod;
8124
8150
  var amountPerMonth;
8125
8151
 
@@ -8160,13 +8186,13 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
8160
8186
  })))));
8161
8187
  };
8162
8188
 
8163
- var DiscountLineItem = function DiscountLineItem(_ref3) {
8164
- var subscriptionPreview = _ref3.subscriptionPreview,
8165
- isFetchingSubscriptionPreview = _ref3.isFetchingSubscriptionPreview;
8189
+ var DiscountLineItem = function DiscountLineItem(_ref4) {
8190
+ var subscriptionPreview = _ref4.subscriptionPreview,
8191
+ isFetchingSubscriptionPreview = _ref4.isFetchingSubscriptionPreview;
8166
8192
 
8167
- var _ref4 = subscriptionPreview || {},
8168
- subTotal = _ref4.subTotal,
8169
- discount = _ref4.discount;
8193
+ var _ref5 = subscriptionPreview || {},
8194
+ subTotal = _ref5.subTotal,
8195
+ discount = _ref5.discount;
8170
8196
 
8171
8197
  if (!subTotal || !discount) {
8172
8198
  return null;
@@ -8195,13 +8221,13 @@ var DiscountLineItem = function DiscountLineItem(_ref3) {
8195
8221
  }))));
8196
8222
  };
8197
8223
 
8198
- var TaxLineItem = function TaxLineItem(_ref5) {
8199
- var subscriptionPreview = _ref5.subscriptionPreview,
8200
- isFetchingSubscriptionPreview = _ref5.isFetchingSubscriptionPreview;
8224
+ var TaxLineItem = function TaxLineItem(_ref6) {
8225
+ var subscriptionPreview = _ref6.subscriptionPreview,
8226
+ isFetchingSubscriptionPreview = _ref6.isFetchingSubscriptionPreview;
8201
8227
 
8202
- var _ref6 = subscriptionPreview || {},
8203
- tax = _ref6.tax,
8204
- taxDetails = _ref6.taxDetails;
8228
+ var _ref7 = subscriptionPreview || {},
8229
+ tax = _ref7.tax,
8230
+ taxDetails = _ref7.taxDetails;
8205
8231
 
8206
8232
  if (!taxDetails || !tax) {
8207
8233
  return null;
@@ -8222,11 +8248,11 @@ var TaxLineItem = function TaxLineItem(_ref5) {
8222
8248
  }))));
8223
8249
  };
8224
8250
 
8225
- var CheckoutSummary = function CheckoutSummary(_ref7) {
8251
+ var CheckoutSummary = function CheckoutSummary(_ref8) {
8226
8252
  var _plan$pricePoints, _subscription$addons;
8227
8253
 
8228
- var onCheckout = _ref7.onCheckout,
8229
- onCheckoutCompleted = _ref7.onCheckoutCompleted;
8254
+ var onCheckout = _ref8.onCheckout,
8255
+ onCheckoutCompleted = _ref8.onCheckoutCompleted;
8230
8256
 
8231
8257
  var _usePaymentStepModel = usePaymentStepModel(),
8232
8258
  setErrorMessage = _usePaymentStepModel.setErrorMessage;
@@ -8238,9 +8264,9 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
8238
8264
  checkoutState = _useCheckoutModel.checkoutState,
8239
8265
  checkoutLocalization = _useCheckoutModel.checkoutLocalization;
8240
8266
 
8241
- var _ref8 = checkoutState || {},
8242
- plan = _ref8.plan,
8243
- activeSubscription = _ref8.activeSubscription;
8267
+ var _ref9 = checkoutState || {},
8268
+ plan = _ref9.plan,
8269
+ activeSubscription = _ref9.activeSubscription;
8244
8270
 
8245
8271
  var planPrices = useChargesSort((plan == null ? void 0 : (_plan$pricePoints = plan.pricePoints) == null ? void 0 : _plan$pricePoints.filter(function (price) {
8246
8272
  return price.billingPeriod === subscription.billingPeriod;
@@ -8252,8 +8278,8 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
8252
8278
  baseCharges = _partition[0],
8253
8279
  usageCharges = _partition[1];
8254
8280
 
8255
- var _ref9 = baseCharges || [],
8256
- baseCharge = _ref9[0];
8281
+ var _ref10 = baseCharges || [],
8282
+ baseCharge = _ref10[0];
8257
8283
 
8258
8284
  var _usePreviewSubscripti = usePreviewSubscription(),
8259
8285
  subscriptionPreview = _usePreviewSubscripti.subscriptionPreview,
@@ -8267,8 +8293,8 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
8267
8293
  isLoading = _useSubmit.isLoading;
8268
8294
 
8269
8295
  var handleCheckout = /*#__PURE__*/function () {
8270
- var _ref10 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee(e) {
8271
- var _ref11, errorMessage;
8296
+ var _ref11 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee(e) {
8297
+ var _ref12, errorMessage;
8272
8298
 
8273
8299
  return runtime_1.wrap(function _callee$(_context) {
8274
8300
  while (1) {
@@ -8288,8 +8314,8 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
8288
8314
  _context.t0 = {};
8289
8315
 
8290
8316
  case 5:
8291
- _ref11 = _context.t0;
8292
- errorMessage = _ref11.errorMessage;
8317
+ _ref12 = _context.t0;
8318
+ errorMessage = _ref12.errorMessage;
8293
8319
 
8294
8320
  if (!errorMessage) {
8295
8321
  _context.next = 12;
@@ -8311,7 +8337,7 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
8311
8337
  }));
8312
8338
 
8313
8339
  return function handleCheckout(_x) {
8314
- return _ref10.apply(this, arguments);
8340
+ return _ref11.apply(this, arguments);
8315
8341
  };
8316
8342
  }();
8317
8343
 
@@ -8839,7 +8865,7 @@ var BillingPeriodPickerContainer = /*#__PURE__*/_styled(material.Box, {
8839
8865
  })( {
8840
8866
  name: "acf2e7",
8841
8867
  styles: "padding:16px 0",
8842
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUV3RCIsImZpbGUiOiJCaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQm94LCBDaGlwIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUGlja2VyQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4IDA7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24gYFxuICBjdXJzb3I6ICR7KHsgJGRpc2FibGVkIH0pID0+ICgkZGlzYWJsZWQgPyAnZGVmYXVsdCcgOiAncG9pbnRlcicpfTtcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBoZWlnaHQ6IDgwcHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSwgJGlzQWN0aXZlIH0pID0+IGAxcHggc29saWQgJHskaXNBY3RpdmUgPyB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkUmVzdGluZ0JvcmRlciA6IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG4gIGJhY2tncm91bmQ6ICR7KHsgJGlzQWN0aXZlIH0pID0+ICgkaXNBY3RpdmUgPyAnI2U1ZjJmZicgOiAnI2ZmZicpfTtcbiAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gIHRleHQtYWxpZ246IHN0YXJ0O1xuXG4gICYuTXVpQnV0dG9uLXJvb3Qge1xuICAgIHBhZGRpbmc6IDAgMTZweCAwIDhweDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZE9wdGlvbnMgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUHJpY2UgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGJhc2VsaW5lO1xuICBnYXA6IDhweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudENoaXAgPSBzdHlsZWQoQ2hpcCkgYFxuICAmIC5NdWlDaGlwLWxhYmVsIHtcbiAgICBmb250LXNpemU6IDEycHg7XG4gIH1cbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUuanMubWFwIl19 */",
8868
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUV3RCIsImZpbGUiOiJCaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQm94LCBDaGlwIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUGlja2VyQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4IDA7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24gYFxuICBjdXJzb3I6ICR7KHsgJGRpc2FibGVkIH0pID0+ICgkZGlzYWJsZWQgPyAnZGVmYXVsdCcgOiAncG9pbnRlcicpfTtcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBoZWlnaHQ6IDgwcHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSwgJGlzQWN0aXZlIH0pID0+IGAxcHggc29saWQgJHskaXNBY3RpdmUgPyB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkUmVzdGluZ0JvcmRlciA6IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSB9KSA9PiAoJGlzQWN0aXZlID8gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kU2VjdGlvbiA6ICd0cmFuc3BhcmVudCcpfTtcbiAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gIHRleHQtYWxpZ246IHN0YXJ0O1xuXG4gICYuTXVpQnV0dG9uLXJvb3Qge1xuICAgIHBhZGRpbmc6IDAgMTZweCAwIDhweDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZE9wdGlvbnMgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUHJpY2UgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGJhc2VsaW5lO1xuICBnYXA6IDhweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudENoaXAgPSBzdHlsZWQoQ2hpcCkgYFxuICAmIC5NdWlDaGlwLWxhYmVsIHtcbiAgICBmb250LXNpemU6IDEycHg7XG4gIH1cbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUuanMubWFwIl19 */",
8843
8869
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
8844
8870
  });
8845
8871
  var BillingPeriodButton = /*#__PURE__*/_styled("button", {
@@ -8853,16 +8879,17 @@ var BillingPeriodButton = /*#__PURE__*/_styled("button", {
8853
8879
  $isActive = _ref2.$isActive;
8854
8880
  return "1px solid " + ($isActive ? theme.stigg.palette.outlinedRestingBorder : theme.stigg.palette.outlinedBorder);
8855
8881
  }, ";background:", function (_ref3) {
8856
- var $isActive = _ref3.$isActive;
8857
- return $isActive ? '#e5f2ff' : '#fff';
8858
- }, ";text-transform:none;text-align:start;&.MuiButton-root{padding:0 16px 0 8px;&:hover{background:none;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtpRCIsImZpbGUiOiJCaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQm94LCBDaGlwIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUGlja2VyQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4IDA7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24gYFxuICBjdXJzb3I6ICR7KHsgJGRpc2FibGVkIH0pID0+ICgkZGlzYWJsZWQgPyAnZGVmYXVsdCcgOiAncG9pbnRlcicpfTtcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBoZWlnaHQ6IDgwcHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSwgJGlzQWN0aXZlIH0pID0+IGAxcHggc29saWQgJHskaXNBY3RpdmUgPyB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkUmVzdGluZ0JvcmRlciA6IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG4gIGJhY2tncm91bmQ6ICR7KHsgJGlzQWN0aXZlIH0pID0+ICgkaXNBY3RpdmUgPyAnI2U1ZjJmZicgOiAnI2ZmZicpfTtcbiAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gIHRleHQtYWxpZ246IHN0YXJ0O1xuXG4gICYuTXVpQnV0dG9uLXJvb3Qge1xuICAgIHBhZGRpbmc6IDAgMTZweCAwIDhweDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZE9wdGlvbnMgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUHJpY2UgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGJhc2VsaW5lO1xuICBnYXA6IDhweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudENoaXAgPSBzdHlsZWQoQ2hpcCkgYFxuICAmIC5NdWlDaGlwLWxhYmVsIHtcbiAgICBmb250LXNpemU6IDEycHg7XG4gIH1cbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUuanMubWFwIl19 */"));
8882
+ var theme = _ref3.theme,
8883
+ $isActive = _ref3.$isActive;
8884
+ return $isActive ? theme.stigg.palette.backgroundSection : 'transparent';
8885
+ }, ";text-transform:none;text-align:start;&.MuiButton-root{padding:0 16px 0 8px;&:hover{background:none;}}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtpRCIsImZpbGUiOiJCaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQm94LCBDaGlwIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUGlja2VyQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4IDA7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24gYFxuICBjdXJzb3I6ICR7KHsgJGRpc2FibGVkIH0pID0+ICgkZGlzYWJsZWQgPyAnZGVmYXVsdCcgOiAncG9pbnRlcicpfTtcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBoZWlnaHQ6IDgwcHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSwgJGlzQWN0aXZlIH0pID0+IGAxcHggc29saWQgJHskaXNBY3RpdmUgPyB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkUmVzdGluZ0JvcmRlciA6IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSB9KSA9PiAoJGlzQWN0aXZlID8gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kU2VjdGlvbiA6ICd0cmFuc3BhcmVudCcpfTtcbiAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gIHRleHQtYWxpZ246IHN0YXJ0O1xuXG4gICYuTXVpQnV0dG9uLXJvb3Qge1xuICAgIHBhZGRpbmc6IDAgMTZweCAwIDhweDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZE9wdGlvbnMgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUHJpY2UgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGJhc2VsaW5lO1xuICBnYXA6IDhweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudENoaXAgPSBzdHlsZWQoQ2hpcCkgYFxuICAmIC5NdWlDaGlwLWxhYmVsIHtcbiAgICBmb250LXNpemU6IDEycHg7XG4gIH1cbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUuanMubWFwIl19 */"));
8859
8886
  var BillingPeriodOptions = /*#__PURE__*/_styled(material.Box, {
8860
8887
  target: "ekae5v42",
8861
8888
  label: "BillingPeriodOptions"
8862
8889
  })( {
8863
8890
  name: "1neb8ay",
8864
8891
  styles: "display:flex;gap:16px;margin-top:16px",
8865
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCZ0QiLCJmaWxlIjoiQmlsbGluZ1BlcmlvZFBpY2tlci5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEJveCwgQ2hpcCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFBpY2tlckNvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgcGFkZGluZzogMTZweCAwO1xuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RCdXR0b24gPSBzdHlsZWQuYnV0dG9uIGBcbiAgY3Vyc29yOiAkeyh7ICRkaXNhYmxlZCB9KSA9PiAoJGRpc2FibGVkID8gJ2RlZmF1bHQnIDogJ3BvaW50ZXInKX07XG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgaGVpZ2h0OiA4MHB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBib3JkZXI6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSB9KSA9PiBgMXB4IHNvbGlkICR7JGlzQWN0aXZlID8gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZFJlc3RpbmdCb3JkZXIgOiB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuICBiYWNrZ3JvdW5kOiAkeyh7ICRpc0FjdGl2ZSB9KSA9PiAoJGlzQWN0aXZlID8gJyNlNWYyZmYnIDogJyNmZmYnKX07XG4gIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICB0ZXh0LWFsaWduOiBzdGFydDtcblxuICAmLk11aUJ1dHRvbi1yb290IHtcbiAgICBwYWRkaW5nOiAwIDE2cHggMCA4cHg7XG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RPcHRpb25zID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFByaWNlID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBiYXNlbGluZTtcbiAgZ2FwOiA4cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgRGlzY291bnRDaGlwID0gc3R5bGVkKENoaXApIGBcbiAgJiAuTXVpQ2hpcC1sYWJlbCB7XG4gICAgZm9udC1zaXplOiAxMnB4O1xuICB9XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1CaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLmpzLm1hcCJdfQ== */",
8892
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCZ0QiLCJmaWxlIjoiQmlsbGluZ1BlcmlvZFBpY2tlci5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEJveCwgQ2hpcCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFBpY2tlckNvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgcGFkZGluZzogMTZweCAwO1xuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RCdXR0b24gPSBzdHlsZWQuYnV0dG9uIGBcbiAgY3Vyc29yOiAkeyh7ICRkaXNhYmxlZCB9KSA9PiAoJGRpc2FibGVkID8gJ2RlZmF1bHQnIDogJ3BvaW50ZXInKX07XG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgaGVpZ2h0OiA4MHB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBib3JkZXI6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSB9KSA9PiBgMXB4IHNvbGlkICR7JGlzQWN0aXZlID8gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZFJlc3RpbmdCb3JkZXIgOiB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lLCAkaXNBY3RpdmUgfSkgPT4gKCRpc0FjdGl2ZSA/IHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFNlY3Rpb24gOiAndHJhbnNwYXJlbnQnKX07XG4gIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICB0ZXh0LWFsaWduOiBzdGFydDtcblxuICAmLk11aUJ1dHRvbi1yb290IHtcbiAgICBwYWRkaW5nOiAwIDE2cHggMCA4cHg7XG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RPcHRpb25zID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFByaWNlID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBiYXNlbGluZTtcbiAgZ2FwOiA4cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgRGlzY291bnRDaGlwID0gc3R5bGVkKENoaXApIGBcbiAgJiAuTXVpQ2hpcC1sYWJlbCB7XG4gICAgZm9udC1zaXplOiAxMnB4O1xuICB9XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1CaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLmpzLm1hcCJdfQ== */",
8866
8893
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
8867
8894
  });
8868
8895
 
@@ -9096,7 +9123,8 @@ function CheckoutContainer(_ref) {
9096
9123
  stripePromise = _useStripeIntegration.stripePromise,
9097
9124
  setupIntentClientSecret = _useStripeIntegration.setupIntentClientSecret;
9098
9125
 
9099
- var stiggTheme = useStiggTheme();
9126
+ var _useCheckoutContext = useCheckoutContext(),
9127
+ stiggTheme = _useCheckoutContext[0].stiggTheme;
9100
9128
 
9101
9129
  var _useProgressBarModel = useProgressBarModel(),
9102
9130
  progressBarState = _useProgressBarModel.progressBarState;
@@ -9125,9 +9153,7 @@ function CheckoutContainer(_ref) {
9125
9153
  }
9126
9154
  }
9127
9155
  }, React__default.createElement(CheckoutLayout, {
9128
- className: "stigg-checkout-layout",
9129
- "$backgroundColor": stiggTheme.palette.backgroundPaper,
9130
- "$borderColor": stiggTheme.palette.outlinedBorder
9156
+ className: "stigg-checkout-layout"
9131
9157
  }, React__default.createElement(CheckoutProgressBar, null), React__default.createElement(CheckoutContent, null, React__default.createElement(CheckoutPanel, null, React__default.createElement(PlanHeader$1, {
9132
9158
  allowChangePlan: allowChangePlan,
9133
9159
  onChangePlan: onChangePlan