@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.
- package/dist/components/checkout/CheckoutContainer.style.d.ts +0 -3
- package/dist/components/checkout/CheckoutProvider.d.ts +2 -0
- package/dist/components/checkout/hooks/useLoadCheckout.d.ts +1 -3
- package/dist/components/checkout/index.d.ts +1 -1
- package/dist/components/checkout/theme.d.ts +6 -2
- package/dist/components/common/mapExternalTheme.d.ts +2 -3
- package/dist/index.d.ts +1 -1
- package/dist/react-sdk.cjs.development.js +111 -85
- package/dist/react-sdk.cjs.development.js.map +1 -1
- package/dist/react-sdk.cjs.production.min.js +1 -1
- package/dist/react-sdk.cjs.production.min.js.map +1 -1
- package/dist/react-sdk.esm.js +113 -90
- package/dist/react-sdk.esm.js.map +1 -1
- package/dist/stories/CustomerPortal.stories.d.ts +1 -1
- package/package.json +2 -2
- package/src/components/checkout/CheckoutContainer.style.ts +3 -3
- package/src/components/checkout/CheckoutContainer.tsx +3 -7
- package/src/components/checkout/CheckoutProvider.tsx +9 -4
- package/src/components/checkout/CheckoutSummary.tsx +1 -1
- package/src/components/checkout/components/InputField.tsx +1 -2
- package/src/components/checkout/hooks/useLoadCheckout.ts +1 -1
- package/src/components/checkout/index.ts +1 -1
- package/src/components/checkout/steps/payment/stripe/StripePaymentForm.tsx +2 -2
- package/src/components/checkout/steps/plan/BillingPeriodPicker.style.tsx +1 -1
- package/src/components/checkout/theme.ts +31 -14
- package/src/components/common/mapExternalTheme.ts +22 -12
- package/src/index.ts +1 -1
- package/src/stories/Checkout.stories.tsx +4 -1
- package/src/stories/CustomerPortal.stories.tsx +1 -1
- package/dist/components/checkout/types.d.ts +0 -7
- 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(
|
|
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(
|
|
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(
|
|
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(
|
|
3041
|
-
|
|
3042
|
-
|
|
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
|
-
|
|
6859
|
-
|
|
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
|
-
|
|
6862
|
-
|
|
6863
|
-
|
|
6864
|
-
|
|
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
|
|
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
|
|
6981
|
-
return
|
|
7006
|
+
var theme = _ref.theme;
|
|
7007
|
+
return theme.stigg.palette.backgroundPaper;
|
|
6982
7008
|
}, ";border:", function (_ref2) {
|
|
6983
|
-
var
|
|
6984
|
-
return "1px solid " +
|
|
6985
|
-
}, ";& *{box-sizing:border-box;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
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,
|
|
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,
|
|
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
|
-
|
|
8031
|
-
|
|
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(
|
|
8101
|
-
var amountPerMonth =
|
|
8102
|
-
price =
|
|
8103
|
-
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(
|
|
8120
|
-
var label =
|
|
8121
|
-
quantity =
|
|
8122
|
-
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(
|
|
8164
|
-
var subscriptionPreview =
|
|
8165
|
-
isFetchingSubscriptionPreview =
|
|
8189
|
+
var DiscountLineItem = function DiscountLineItem(_ref4) {
|
|
8190
|
+
var subscriptionPreview = _ref4.subscriptionPreview,
|
|
8191
|
+
isFetchingSubscriptionPreview = _ref4.isFetchingSubscriptionPreview;
|
|
8166
8192
|
|
|
8167
|
-
var
|
|
8168
|
-
subTotal =
|
|
8169
|
-
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(
|
|
8199
|
-
var subscriptionPreview =
|
|
8200
|
-
isFetchingSubscriptionPreview =
|
|
8224
|
+
var TaxLineItem = function TaxLineItem(_ref6) {
|
|
8225
|
+
var subscriptionPreview = _ref6.subscriptionPreview,
|
|
8226
|
+
isFetchingSubscriptionPreview = _ref6.isFetchingSubscriptionPreview;
|
|
8201
8227
|
|
|
8202
|
-
var
|
|
8203
|
-
tax =
|
|
8204
|
-
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(
|
|
8251
|
+
var CheckoutSummary = function CheckoutSummary(_ref8) {
|
|
8226
8252
|
var _plan$pricePoints, _subscription$addons;
|
|
8227
8253
|
|
|
8228
|
-
var onCheckout =
|
|
8229
|
-
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
|
|
8242
|
-
plan =
|
|
8243
|
-
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
|
|
8256
|
-
baseCharge =
|
|
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
|
|
8271
|
-
var
|
|
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
|
-
|
|
8292
|
-
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
|
|
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+
|
|
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
|
|
8857
|
-
|
|
8858
|
-
|
|
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,
|
|
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
|
|
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
|