@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
package/dist/react-sdk.esm.js
CHANGED
|
@@ -3059,10 +3059,9 @@ function mapFontWeight$1(defaultValue, fontWeight) {
|
|
|
3059
3059
|
}
|
|
3060
3060
|
}
|
|
3061
3061
|
|
|
3062
|
-
function mapTypography(
|
|
3062
|
+
function mapTypography(typography) {
|
|
3063
3063
|
var _typography$h, _typography$h2, _typography$h3, _typography$h4, _typography$h5, _typography$h6, _typography$body, _typography$body2;
|
|
3064
3064
|
|
|
3065
|
-
var typography = configuration.typography;
|
|
3066
3065
|
return {
|
|
3067
3066
|
fontFamilyUrl: (typography == null ? void 0 : typography.fontFamily) || undefined,
|
|
3068
3067
|
h1: {
|
|
@@ -3102,7 +3101,8 @@ function mapAlignment(alignment) {
|
|
|
3102
3101
|
}
|
|
3103
3102
|
|
|
3104
3103
|
function mapCustomerPortalConfiguration(configuration) {
|
|
3105
|
-
var palette = configuration.palette
|
|
3104
|
+
var palette = configuration.palette,
|
|
3105
|
+
typography = configuration.typography;
|
|
3106
3106
|
return {
|
|
3107
3107
|
palette: {
|
|
3108
3108
|
primary: (palette == null ? void 0 : palette.primary) || undefined,
|
|
@@ -3113,13 +3113,14 @@ function mapCustomerPortalConfiguration(configuration) {
|
|
|
3113
3113
|
primary: (palette == null ? void 0 : palette.textColor) || undefined
|
|
3114
3114
|
}
|
|
3115
3115
|
},
|
|
3116
|
-
typography: mapTypography(
|
|
3116
|
+
typography: mapTypography(typography)
|
|
3117
3117
|
};
|
|
3118
3118
|
}
|
|
3119
3119
|
function mapPaywallConfiguration(paywallConfiguration) {
|
|
3120
3120
|
var palette = paywallConfiguration.palette,
|
|
3121
3121
|
layout = paywallConfiguration.layout,
|
|
3122
|
-
customCss = paywallConfiguration.customCss
|
|
3122
|
+
customCss = paywallConfiguration.customCss,
|
|
3123
|
+
typography = paywallConfiguration.typography;
|
|
3123
3124
|
return {
|
|
3124
3125
|
customCss: customCss || undefined,
|
|
3125
3126
|
palette: {
|
|
@@ -3131,7 +3132,7 @@ function mapPaywallConfiguration(paywallConfiguration) {
|
|
|
3131
3132
|
primary: (palette == null ? void 0 : palette.textColor) || undefined
|
|
3132
3133
|
}
|
|
3133
3134
|
},
|
|
3134
|
-
typography: mapTypography(
|
|
3135
|
+
typography: mapTypography(typography),
|
|
3135
3136
|
layout: {
|
|
3136
3137
|
ctaAlignment: mapAlignment(layout == null ? void 0 : layout.alignment),
|
|
3137
3138
|
headerAlignment: mapAlignment(layout == null ? void 0 : layout.alignment),
|
|
@@ -3143,9 +3144,22 @@ function mapPaywallConfiguration(paywallConfiguration) {
|
|
|
3143
3144
|
}
|
|
3144
3145
|
};
|
|
3145
3146
|
}
|
|
3146
|
-
function mapCheckoutConfiguration(
|
|
3147
|
-
|
|
3148
|
-
|
|
3147
|
+
function mapCheckoutConfiguration(configuration) {
|
|
3148
|
+
var palette = configuration.palette,
|
|
3149
|
+
typography = configuration.typography;
|
|
3150
|
+
return {
|
|
3151
|
+
palette: {
|
|
3152
|
+
primary: (palette == null ? void 0 : palette.primary) || undefined,
|
|
3153
|
+
backgroundPaper: (palette == null ? void 0 : palette.backgroundColor) || undefined,
|
|
3154
|
+
outlinedBorder: (palette == null ? void 0 : palette.borderColor) || undefined,
|
|
3155
|
+
text: {
|
|
3156
|
+
primary: (palette == null ? void 0 : palette.textColor) || undefined
|
|
3157
|
+
},
|
|
3158
|
+
backgroundHighlight: (palette == null ? void 0 : palette.selectionColor) || undefined,
|
|
3159
|
+
backgroundSection: (palette == null ? void 0 : palette.summaryBackgroundColor) || undefined
|
|
3160
|
+
},
|
|
3161
|
+
typography: mapTypography(typography)
|
|
3162
|
+
};
|
|
3149
3163
|
}
|
|
3150
3164
|
|
|
3151
3165
|
function getCustomerSubscriptionDetails(activeSubscriptions) {
|
|
@@ -7110,15 +7124,26 @@ function getResolvedCheckoutLocalize(localizeOverride) {
|
|
|
7110
7124
|
return merge(checkoutDefaultLocalization, localizeOverride);
|
|
7111
7125
|
}
|
|
7112
7126
|
|
|
7113
|
-
|
|
7114
|
-
|
|
7127
|
+
var defaultCheckoutTheme = {
|
|
7128
|
+
primary: 'rgb(50, 126, 238)',
|
|
7129
|
+
textColor: 'rgb(0, 30, 108)',
|
|
7130
|
+
backgroundColor: 'rgb(255, 255, 255)',
|
|
7131
|
+
borderColor: 'rgb(235, 237, 243)',
|
|
7132
|
+
selectionColor: 'rgb(229, 242, 255)',
|
|
7133
|
+
summaryBackgroundColor: 'rgb(109, 121, 144)'
|
|
7134
|
+
};
|
|
7135
|
+
function getResolvedCheckoutTheme(globalTheme, themeOverride, _remoteConfiguration) {
|
|
7136
|
+
var _ref = globalTheme || {},
|
|
7137
|
+
globalPalette = _ref.palette;
|
|
7115
7138
|
|
|
7116
|
-
|
|
7117
|
-
|
|
7118
|
-
|
|
7119
|
-
|
|
7139
|
+
return {
|
|
7140
|
+
primary: (themeOverride == null ? void 0 : themeOverride.primary) || (globalPalette == null ? void 0 : globalPalette.primary) || defaultCheckoutTheme.primary,
|
|
7141
|
+
textColor: (themeOverride == null ? void 0 : themeOverride.textColor) || (globalPalette == null ? void 0 : globalPalette.text.primary) || defaultCheckoutTheme.textColor,
|
|
7142
|
+
backgroundColor: (themeOverride == null ? void 0 : themeOverride.backgroundColor) || (globalPalette == null ? void 0 : globalPalette.backgroundPaper) || defaultCheckoutTheme.backgroundColor,
|
|
7143
|
+
borderColor: (themeOverride == null ? void 0 : themeOverride.borderColor) || (globalPalette == null ? void 0 : globalPalette.outlinedBorder) || defaultCheckoutTheme.borderColor,
|
|
7144
|
+
selectionColor: (themeOverride == null ? void 0 : themeOverride.selectionColor) || (globalPalette == null ? void 0 : globalPalette.backgroundSection) || defaultCheckoutTheme.selectionColor,
|
|
7145
|
+
summaryBackgroundColor: (themeOverride == null ? void 0 : themeOverride.summaryBackgroundColor) || (globalPalette == null ? void 0 : globalPalette.backgroundHighlight) || defaultCheckoutTheme.summaryBackgroundColor
|
|
7120
7146
|
};
|
|
7121
|
-
return checkoutDefaultTheme;
|
|
7122
7147
|
}
|
|
7123
7148
|
|
|
7124
7149
|
var CheckoutContext = /*#__PURE__*/React__default.createContext(null);
|
|
@@ -7178,9 +7203,9 @@ function CheckoutProvider(_ref2) {
|
|
|
7178
7203
|
checkout = _useLoadCheckout.checkout,
|
|
7179
7204
|
isLoading = _useLoadCheckout.isLoading;
|
|
7180
7205
|
|
|
7181
|
-
var configuration = checkout != null && checkout.configuration ? mapCheckoutConfiguration() : undefined;
|
|
7206
|
+
var configuration = checkout != null && checkout.configuration ? mapCheckoutConfiguration(checkout.configuration) : undefined;
|
|
7182
7207
|
var globalTheme = useStiggTheme(configuration);
|
|
7183
|
-
var checkoutTheme = getResolvedCheckoutTheme(globalTheme, theme
|
|
7208
|
+
var checkoutTheme = getResolvedCheckoutTheme(globalTheme, theme);
|
|
7184
7209
|
var checkoutLocalization = getResolvedCheckoutLocalize(textOverrides);
|
|
7185
7210
|
var initialState = useMemo(function () {
|
|
7186
7211
|
var _checkout$resource;
|
|
@@ -7207,6 +7232,7 @@ function CheckoutProvider(_ref2) {
|
|
|
7207
7232
|
checkout: checkout,
|
|
7208
7233
|
isLoading: isLoading,
|
|
7209
7234
|
checkoutLocalization: checkoutLocalization,
|
|
7235
|
+
stiggTheme: globalTheme,
|
|
7210
7236
|
theme: checkoutTheme,
|
|
7211
7237
|
progressBar: progressBar,
|
|
7212
7238
|
planStep: planStep,
|
|
@@ -7218,7 +7244,7 @@ function CheckoutProvider(_ref2) {
|
|
|
7218
7244
|
}
|
|
7219
7245
|
};
|
|
7220
7246
|
return initialState;
|
|
7221
|
-
}, [billingCountryCode, preferredBillingPeriod, checkout]);
|
|
7247
|
+
}, [theme, globalTheme, billingCountryCode, preferredBillingPeriod, checkout]);
|
|
7222
7248
|
return React__default.createElement(SdkThemeProvider, {
|
|
7223
7249
|
key: checkout == null ? void 0 : checkout.plan.id,
|
|
7224
7250
|
componentTheme: configuration
|
|
@@ -7234,12 +7260,12 @@ var CheckoutLayout = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "produ
|
|
|
7234
7260
|
target: "ergo9xd2",
|
|
7235
7261
|
label: "CheckoutLayout"
|
|
7236
7262
|
})("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) {
|
|
7237
|
-
var
|
|
7238
|
-
return
|
|
7263
|
+
var theme = _ref.theme;
|
|
7264
|
+
return theme.stigg.palette.backgroundPaper;
|
|
7239
7265
|
}, ";border:", function (_ref2) {
|
|
7240
|
-
var
|
|
7241
|
-
return "1px solid " +
|
|
7242
|
-
}, ";& *{box-sizing:border-box;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
7266
|
+
var theme = _ref2.theme;
|
|
7267
|
+
return "1px solid " + theme.stigg.palette.outlinedBorder;
|
|
7268
|
+
}, ";& *{box-sizing:border-box;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUV5QyIsImZpbGUiOiJDaGVja291dENvbnRhaW5lci5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJveCBmcm9tICdAbXVpL21hdGVyaWFsL0JveCc7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dExheW91dCA9IHN0eWxlZC5kaXYgYFxuICBtYXJnaW46IGF1dG87XG4gIHdpZHRoOiAxMDAlO1xuICBtYXgtd2lkdGg6IDkyMHB4O1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gIHBhZGRpbmc6IDE2cHggMzJweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLmJhY2tncm91bmRQYXBlcn07XG4gIGJvcmRlcjogJHsoeyB0aGVtZSB9KSA9PiBgMXB4IHNvbGlkICR7dGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn1gfTtcblxuICAmICoge1xuICAgIGJveC1zaXppbmc6IGJvcmRlci1ib3g7XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dENvbnRlbnQgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBmbGV4LXN0YXJ0O1xuICBnYXA6IDMycHg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRQYW5lbCA9IHN0eWxlZChCb3gpIGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgZ2FwOiAwO1xuICBmbGV4OiAyO1xuYDtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRDb250YWluZXIuc3R5bGUuanMubWFwIl19 */"));
|
|
7243
7269
|
var CheckoutContent = /*#__PURE__*/_styled(Box, process.env.NODE_ENV === "production" ? {
|
|
7244
7270
|
target: "ergo9xd1"
|
|
7245
7271
|
} : {
|
|
@@ -7251,7 +7277,7 @@ var CheckoutContent = /*#__PURE__*/_styled(Box, process.env.NODE_ENV === "produc
|
|
|
7251
7277
|
} : {
|
|
7252
7278
|
name: "1pdbip7",
|
|
7253
7279
|
styles: "display:flex;align-items:flex-start;gap:32px;flex-wrap:wrap;width:100%",
|
|
7254
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
7280
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1CMkMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luOiBhdXRvO1xuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA5MjBweDtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBwYWRkaW5nOiAxNnB4IDMycHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXJ9O1xuICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRDb250ZW50ID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiAzMnB4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0UGFuZWwgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGdhcDogMDtcbiAgZmxleDogMjtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
7255
7281
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
|
|
7256
7282
|
});
|
|
7257
7283
|
var CheckoutPanel = /*#__PURE__*/_styled(Box, process.env.NODE_ENV === "production" ? {
|
|
@@ -7265,7 +7291,7 @@ var CheckoutPanel = /*#__PURE__*/_styled(Box, process.env.NODE_ENV === "producti
|
|
|
7265
7291
|
} : {
|
|
7266
7292
|
name: "fszphw",
|
|
7267
7293
|
styles: "display:flex;flex-direction:column;gap:0;flex:2",
|
|
7268
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
7294
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBCeUMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luOiBhdXRvO1xuICB3aWR0aDogMTAwJTtcbiAgbWF4LXdpZHRoOiA5MjBweDtcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBwYWRkaW5nOiAxNnB4IDMycHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXJ9O1xuICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRDb250ZW50ID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiAzMnB4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0UGFuZWwgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGdhcDogMDtcbiAgZmxleDogMjtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
7269
7295
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
|
|
7270
7296
|
});
|
|
7271
7297
|
|
|
@@ -7424,6 +7450,7 @@ var InputField = /*#__PURE__*/styled$1(TextField)(function (_ref) {
|
|
|
7424
7450
|
var theme = _ref.theme;
|
|
7425
7451
|
return {
|
|
7426
7452
|
'& .MuiOutlinedInput-root': {
|
|
7453
|
+
height: '42px',
|
|
7427
7454
|
borderRadius: theme.stigg.border.radius,
|
|
7428
7455
|
fieldset: {
|
|
7429
7456
|
borderColor: theme.stigg.palette.outlinedBorder
|
|
@@ -7437,9 +7464,7 @@ var InputField = /*#__PURE__*/styled$1(TextField)(function (_ref) {
|
|
|
7437
7464
|
borderRadius: theme.stigg.border.radius,
|
|
7438
7465
|
fontFamily: theme.stigg.typography.fontFamily,
|
|
7439
7466
|
color: theme.stigg.palette.text.primary
|
|
7440
|
-
}, theme.stigg.typography.body
|
|
7441
|
-
height: '42px'
|
|
7442
|
-
})
|
|
7467
|
+
}, theme.stigg.typography.body)
|
|
7443
7468
|
};
|
|
7444
7469
|
});
|
|
7445
7470
|
|
|
@@ -7729,12 +7754,15 @@ var PromotionCodeSection = function PromotionCodeSection(_ref) {
|
|
|
7729
7754
|
};
|
|
7730
7755
|
|
|
7731
7756
|
function StripePaymentForm() {
|
|
7757
|
+
var _configuration$conten;
|
|
7758
|
+
|
|
7732
7759
|
var _useCheckoutModel = useCheckoutModel(),
|
|
7733
7760
|
checkoutState = _useCheckoutModel.checkoutState,
|
|
7734
7761
|
checkoutLocalization = _useCheckoutModel.checkoutLocalization;
|
|
7735
7762
|
|
|
7736
7763
|
var _ref = checkoutState || {},
|
|
7737
|
-
customer = _ref.customer
|
|
7764
|
+
customer = _ref.customer,
|
|
7765
|
+
configuration = _ref.configuration;
|
|
7738
7766
|
|
|
7739
7767
|
return React__default.createElement(Grid, {
|
|
7740
7768
|
flexDirection: "column",
|
|
@@ -7751,7 +7779,7 @@ function StripePaymentForm() {
|
|
|
7751
7779
|
options: {
|
|
7752
7780
|
mode: 'billing',
|
|
7753
7781
|
fields: {
|
|
7754
|
-
phone: 'always'
|
|
7782
|
+
phone: !!(configuration != null && (_configuration$conten = configuration.content) != null && _configuration$conten.collectPhoneNumber) ? 'always' : 'auto'
|
|
7755
7783
|
},
|
|
7756
7784
|
defaultValues: _extends({}, (customer == null ? void 0 : customer.name) && {
|
|
7757
7785
|
name: customer.name
|
|
@@ -8314,15 +8342,10 @@ var SummaryCard = /*#__PURE__*/_styled(Paper, process.env.NODE_ENV === "producti
|
|
|
8314
8342
|
} : {
|
|
8315
8343
|
target: "e164dmji6",
|
|
8316
8344
|
label: "SummaryCard"
|
|
8317
|
-
})(
|
|
8318
|
-
|
|
8319
|
-
|
|
8320
|
-
} : {
|
|
8321
|
-
name: "1qvn0za",
|
|
8322
|
-
styles: "border-radius:10px;background:#f8f9fb;padding:16px",
|
|
8323
|
-
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"]} */",
|
|
8324
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
8325
|
-
});
|
|
8345
|
+
})("border-radius:10px;background:", function (_ref) {
|
|
8346
|
+
var theme = _ref.theme;
|
|
8347
|
+
return theme.stigg.palette.backgroundHighlight;
|
|
8348
|
+
}, ";padding:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# 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"]} */"));
|
|
8326
8349
|
|
|
8327
8350
|
SummaryCard.defaultProps = {
|
|
8328
8351
|
elevation: 0
|
|
@@ -8339,7 +8362,7 @@ var PlanName = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "produc
|
|
|
8339
8362
|
} : {
|
|
8340
8363
|
name: "18uqayh",
|
|
8341
8364
|
styles: "margin-bottom:16px",
|
|
8342
|
-
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"]} */",
|
|
8365
|
+
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"]} */",
|
|
8343
8366
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
8344
8367
|
});
|
|
8345
8368
|
|
|
@@ -8354,7 +8377,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
|
|
|
8354
8377
|
} : {
|
|
8355
8378
|
name: "rdmn2i",
|
|
8356
8379
|
styles: "&+&{margin-top:8px;}",
|
|
8357
|
-
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"]} */",
|
|
8380
|
+
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"]} */",
|
|
8358
8381
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
8359
8382
|
});
|
|
8360
8383
|
|
|
@@ -8369,7 +8392,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
|
|
|
8369
8392
|
} : {
|
|
8370
8393
|
name: "bcffy2",
|
|
8371
8394
|
styles: "display:flex;align-items:center;justify-content:space-between",
|
|
8372
|
-
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"]} */",
|
|
8395
|
+
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"]} */",
|
|
8373
8396
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
8374
8397
|
});
|
|
8375
8398
|
|
|
@@ -8384,7 +8407,7 @@ var StyledDivider$1 = /*#__PURE__*/_styled(Divider$1, process.env.NODE_ENV === "
|
|
|
8384
8407
|
} : {
|
|
8385
8408
|
name: "1k6141t",
|
|
8386
8409
|
styles: "margin:16px 0",
|
|
8387
|
-
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"]} */",
|
|
8410
|
+
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"]} */",
|
|
8388
8411
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
8389
8412
|
});
|
|
8390
8413
|
|
|
@@ -8399,7 +8422,7 @@ var SubtotalText = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "pr
|
|
|
8399
8422
|
} : {
|
|
8400
8423
|
name: "1d0nbku",
|
|
8401
8424
|
styles: "margin-top:24px",
|
|
8402
|
-
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"]} */",
|
|
8425
|
+
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"]} */",
|
|
8403
8426
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
8404
8427
|
});
|
|
8405
8428
|
|
|
@@ -8414,14 +8437,14 @@ var TotalDueText = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "pr
|
|
|
8414
8437
|
} : {
|
|
8415
8438
|
name: "5bhc30",
|
|
8416
8439
|
styles: "margin-bottom:8px",
|
|
8417
|
-
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"]} */",
|
|
8440
|
+
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"]} */",
|
|
8418
8441
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
8419
8442
|
});
|
|
8420
8443
|
|
|
8421
|
-
var getPriceString = function getPriceString(
|
|
8422
|
-
var amountPerMonth =
|
|
8423
|
-
price =
|
|
8424
|
-
quantity =
|
|
8444
|
+
var getPriceString = function getPriceString(_ref2) {
|
|
8445
|
+
var amountPerMonth = _ref2.amountPerMonth,
|
|
8446
|
+
price = _ref2.price,
|
|
8447
|
+
quantity = _ref2.quantity;
|
|
8425
8448
|
var billingPeriod = price.billingPeriod;
|
|
8426
8449
|
var billingPeriodString = null;
|
|
8427
8450
|
|
|
@@ -8437,10 +8460,10 @@ var getPriceString = function getPriceString(_ref) {
|
|
|
8437
8460
|
return "" + (quantity > 1 ? quantity + " x " + addonPriceFormat + " each" : addonPriceFormat) + (billingPeriodString ? " x " + billingPeriodString : '');
|
|
8438
8461
|
};
|
|
8439
8462
|
|
|
8440
|
-
var BilledPriceLineItem = function BilledPriceLineItem(
|
|
8441
|
-
var label =
|
|
8442
|
-
quantity =
|
|
8443
|
-
price =
|
|
8463
|
+
var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
|
|
8464
|
+
var label = _ref3.label,
|
|
8465
|
+
quantity = _ref3.quantity,
|
|
8466
|
+
price = _ref3.price;
|
|
8444
8467
|
var billingPeriod = price.billingPeriod;
|
|
8445
8468
|
var amountPerMonth;
|
|
8446
8469
|
|
|
@@ -8481,13 +8504,13 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
|
|
|
8481
8504
|
})))));
|
|
8482
8505
|
};
|
|
8483
8506
|
|
|
8484
|
-
var DiscountLineItem = function DiscountLineItem(
|
|
8485
|
-
var subscriptionPreview =
|
|
8486
|
-
isFetchingSubscriptionPreview =
|
|
8507
|
+
var DiscountLineItem = function DiscountLineItem(_ref4) {
|
|
8508
|
+
var subscriptionPreview = _ref4.subscriptionPreview,
|
|
8509
|
+
isFetchingSubscriptionPreview = _ref4.isFetchingSubscriptionPreview;
|
|
8487
8510
|
|
|
8488
|
-
var
|
|
8489
|
-
subTotal =
|
|
8490
|
-
discount =
|
|
8511
|
+
var _ref5 = subscriptionPreview || {},
|
|
8512
|
+
subTotal = _ref5.subTotal,
|
|
8513
|
+
discount = _ref5.discount;
|
|
8491
8514
|
|
|
8492
8515
|
if (!subTotal || !discount) {
|
|
8493
8516
|
return null;
|
|
@@ -8516,13 +8539,13 @@ var DiscountLineItem = function DiscountLineItem(_ref3) {
|
|
|
8516
8539
|
}))));
|
|
8517
8540
|
};
|
|
8518
8541
|
|
|
8519
|
-
var TaxLineItem = function TaxLineItem(
|
|
8520
|
-
var subscriptionPreview =
|
|
8521
|
-
isFetchingSubscriptionPreview =
|
|
8542
|
+
var TaxLineItem = function TaxLineItem(_ref6) {
|
|
8543
|
+
var subscriptionPreview = _ref6.subscriptionPreview,
|
|
8544
|
+
isFetchingSubscriptionPreview = _ref6.isFetchingSubscriptionPreview;
|
|
8522
8545
|
|
|
8523
|
-
var
|
|
8524
|
-
tax =
|
|
8525
|
-
taxDetails =
|
|
8546
|
+
var _ref7 = subscriptionPreview || {},
|
|
8547
|
+
tax = _ref7.tax,
|
|
8548
|
+
taxDetails = _ref7.taxDetails;
|
|
8526
8549
|
|
|
8527
8550
|
if (!taxDetails || !tax) {
|
|
8528
8551
|
return null;
|
|
@@ -8543,11 +8566,11 @@ var TaxLineItem = function TaxLineItem(_ref5) {
|
|
|
8543
8566
|
}))));
|
|
8544
8567
|
};
|
|
8545
8568
|
|
|
8546
|
-
var CheckoutSummary = function CheckoutSummary(
|
|
8569
|
+
var CheckoutSummary = function CheckoutSummary(_ref8) {
|
|
8547
8570
|
var _plan$pricePoints, _subscription$addons;
|
|
8548
8571
|
|
|
8549
|
-
var onCheckout =
|
|
8550
|
-
onCheckoutCompleted =
|
|
8572
|
+
var onCheckout = _ref8.onCheckout,
|
|
8573
|
+
onCheckoutCompleted = _ref8.onCheckoutCompleted;
|
|
8551
8574
|
|
|
8552
8575
|
var _usePaymentStepModel = usePaymentStepModel(),
|
|
8553
8576
|
setErrorMessage = _usePaymentStepModel.setErrorMessage;
|
|
@@ -8559,9 +8582,9 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
|
|
|
8559
8582
|
checkoutState = _useCheckoutModel.checkoutState,
|
|
8560
8583
|
checkoutLocalization = _useCheckoutModel.checkoutLocalization;
|
|
8561
8584
|
|
|
8562
|
-
var
|
|
8563
|
-
plan =
|
|
8564
|
-
activeSubscription =
|
|
8585
|
+
var _ref9 = checkoutState || {},
|
|
8586
|
+
plan = _ref9.plan,
|
|
8587
|
+
activeSubscription = _ref9.activeSubscription;
|
|
8565
8588
|
|
|
8566
8589
|
var planPrices = useChargesSort((plan == null ? void 0 : (_plan$pricePoints = plan.pricePoints) == null ? void 0 : _plan$pricePoints.filter(function (price) {
|
|
8567
8590
|
return price.billingPeriod === subscription.billingPeriod;
|
|
@@ -8573,8 +8596,8 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
|
|
|
8573
8596
|
baseCharges = _partition[0],
|
|
8574
8597
|
usageCharges = _partition[1];
|
|
8575
8598
|
|
|
8576
|
-
var
|
|
8577
|
-
baseCharge =
|
|
8599
|
+
var _ref10 = baseCharges || [],
|
|
8600
|
+
baseCharge = _ref10[0];
|
|
8578
8601
|
|
|
8579
8602
|
var _usePreviewSubscripti = usePreviewSubscription(),
|
|
8580
8603
|
subscriptionPreview = _usePreviewSubscripti.subscriptionPreview,
|
|
@@ -8588,8 +8611,8 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
|
|
|
8588
8611
|
isLoading = _useSubmit.isLoading;
|
|
8589
8612
|
|
|
8590
8613
|
var handleCheckout = /*#__PURE__*/function () {
|
|
8591
|
-
var
|
|
8592
|
-
var
|
|
8614
|
+
var _ref11 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee(e) {
|
|
8615
|
+
var _ref12, errorMessage;
|
|
8593
8616
|
|
|
8594
8617
|
return runtime_1.wrap(function _callee$(_context) {
|
|
8595
8618
|
while (1) {
|
|
@@ -8609,8 +8632,8 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
|
|
|
8609
8632
|
_context.t0 = {};
|
|
8610
8633
|
|
|
8611
8634
|
case 5:
|
|
8612
|
-
|
|
8613
|
-
errorMessage =
|
|
8635
|
+
_ref12 = _context.t0;
|
|
8636
|
+
errorMessage = _ref12.errorMessage;
|
|
8614
8637
|
|
|
8615
8638
|
if (!errorMessage) {
|
|
8616
8639
|
_context.next = 12;
|
|
@@ -8632,7 +8655,7 @@ var CheckoutSummary = function CheckoutSummary(_ref7) {
|
|
|
8632
8655
|
}));
|
|
8633
8656
|
|
|
8634
8657
|
return function handleCheckout(_x) {
|
|
8635
|
-
return
|
|
8658
|
+
return _ref11.apply(this, arguments);
|
|
8636
8659
|
};
|
|
8637
8660
|
}();
|
|
8638
8661
|
|
|
@@ -9192,7 +9215,7 @@ var BillingPeriodPickerContainer = /*#__PURE__*/_styled(Box$1, process.env.NODE_
|
|
|
9192
9215
|
} : {
|
|
9193
9216
|
name: "acf2e7",
|
|
9194
9217
|
styles: "padding:16px 0",
|
|
9195
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUV3RCIsImZpbGUiOiJCaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQm94LCBDaGlwIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUGlja2VyQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4IDA7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24gYFxuICBjdXJzb3I6ICR7KHsgJGRpc2FibGVkIH0pID0+ICgkZGlzYWJsZWQgPyAnZGVmYXVsdCcgOiAncG9pbnRlcicpfTtcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBoZWlnaHQ6IDgwcHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSwgJGlzQWN0aXZlIH0pID0+
|
|
9218
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUV3RCIsImZpbGUiOiJCaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQm94LCBDaGlwIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUGlja2VyQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4IDA7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24gYFxuICBjdXJzb3I6ICR7KHsgJGRpc2FibGVkIH0pID0+ICgkZGlzYWJsZWQgPyAnZGVmYXVsdCcgOiAncG9pbnRlcicpfTtcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBoZWlnaHQ6IDgwcHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSwgJGlzQWN0aXZlIH0pID0+IGAxcHggc29saWQgJHskaXNBY3RpdmUgPyB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkUmVzdGluZ0JvcmRlciA6IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSB9KSA9PiAoJGlzQWN0aXZlID8gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kU2VjdGlvbiA6ICd0cmFuc3BhcmVudCcpfTtcbiAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gIHRleHQtYWxpZ246IHN0YXJ0O1xuXG4gICYuTXVpQnV0dG9uLXJvb3Qge1xuICAgIHBhZGRpbmc6IDAgMTZweCAwIDhweDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZE9wdGlvbnMgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUHJpY2UgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGJhc2VsaW5lO1xuICBnYXA6IDhweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudENoaXAgPSBzdHlsZWQoQ2hpcCkgYFxuICAmIC5NdWlDaGlwLWxhYmVsIHtcbiAgICBmb250LXNpemU6IDEycHg7XG4gIH1cbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUuanMubWFwIl19 */",
|
|
9196
9219
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
|
|
9197
9220
|
});
|
|
9198
9221
|
var BillingPeriodButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV === "production" ? {
|
|
@@ -9208,9 +9231,10 @@ var BillingPeriodButton = /*#__PURE__*/_styled("button", process.env.NODE_ENV ==
|
|
|
9208
9231
|
$isActive = _ref2.$isActive;
|
|
9209
9232
|
return "1px solid " + ($isActive ? theme.stigg.palette.outlinedRestingBorder : theme.stigg.palette.outlinedBorder);
|
|
9210
9233
|
}, ";background:", function (_ref3) {
|
|
9211
|
-
var
|
|
9212
|
-
|
|
9213
|
-
|
|
9234
|
+
var theme = _ref3.theme,
|
|
9235
|
+
$isActive = _ref3.$isActive;
|
|
9236
|
+
return $isActive ? theme.stigg.palette.backgroundSection : 'transparent';
|
|
9237
|
+
}, ";text-transform:none;text-align:start;&.MuiButton-root{padding:0 16px 0 8px;&:hover{background:none;}}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtpRCIsImZpbGUiOiJCaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQm94LCBDaGlwIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUGlja2VyQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4IDA7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24gYFxuICBjdXJzb3I6ICR7KHsgJGRpc2FibGVkIH0pID0+ICgkZGlzYWJsZWQgPyAnZGVmYXVsdCcgOiAncG9pbnRlcicpfTtcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBoZWlnaHQ6IDgwcHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSwgJGlzQWN0aXZlIH0pID0+IGAxcHggc29saWQgJHskaXNBY3RpdmUgPyB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkUmVzdGluZ0JvcmRlciA6IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG4gIGJhY2tncm91bmQ6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSB9KSA9PiAoJGlzQWN0aXZlID8gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kU2VjdGlvbiA6ICd0cmFuc3BhcmVudCcpfTtcbiAgdGV4dC10cmFuc2Zvcm06IG5vbmU7XG4gIHRleHQtYWxpZ246IHN0YXJ0O1xuXG4gICYuTXVpQnV0dG9uLXJvb3Qge1xuICAgIHBhZGRpbmc6IDAgMTZweCAwIDhweDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZE9wdGlvbnMgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUHJpY2UgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGJhc2VsaW5lO1xuICBnYXA6IDhweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudENoaXAgPSBzdHlsZWQoQ2hpcCkgYFxuICAmIC5NdWlDaGlwLWxhYmVsIHtcbiAgICBmb250LXNpemU6IDEycHg7XG4gIH1cbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUuanMubWFwIl19 */"));
|
|
9214
9238
|
var BillingPeriodOptions = /*#__PURE__*/_styled(Box$1, process.env.NODE_ENV === "production" ? {
|
|
9215
9239
|
target: "ekae5v42"
|
|
9216
9240
|
} : {
|
|
@@ -9222,7 +9246,7 @@ var BillingPeriodOptions = /*#__PURE__*/_styled(Box$1, process.env.NODE_ENV ===
|
|
|
9222
9246
|
} : {
|
|
9223
9247
|
name: "1neb8ay",
|
|
9224
9248
|
styles: "display:flex;gap:16px;margin-top:16px",
|
|
9225
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9249
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXlCZ0QiLCJmaWxlIjoiQmlsbGluZ1BlcmlvZFBpY2tlci5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEJveCwgQ2hpcCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFBpY2tlckNvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgcGFkZGluZzogMTZweCAwO1xuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RCdXR0b24gPSBzdHlsZWQuYnV0dG9uIGBcbiAgY3Vyc29yOiAkeyh7ICRkaXNhYmxlZCB9KSA9PiAoJGRpc2FibGVkID8gJ2RlZmF1bHQnIDogJ3BvaW50ZXInKX07XG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgaGVpZ2h0OiA4MHB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBib3JkZXI6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSB9KSA9PiBgMXB4IHNvbGlkICR7JGlzQWN0aXZlID8gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZFJlc3RpbmdCb3JkZXIgOiB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lLCAkaXNBY3RpdmUgfSkgPT4gKCRpc0FjdGl2ZSA/IHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFNlY3Rpb24gOiAndHJhbnNwYXJlbnQnKX07XG4gIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICB0ZXh0LWFsaWduOiBzdGFydDtcblxuICAmLk11aUJ1dHRvbi1yb290IHtcbiAgICBwYWRkaW5nOiAwIDE2cHggMCA4cHg7XG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RPcHRpb25zID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFByaWNlID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBiYXNlbGluZTtcbiAgZ2FwOiA4cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgRGlzY291bnRDaGlwID0gc3R5bGVkKENoaXApIGBcbiAgJiAuTXVpQ2hpcC1sYWJlbCB7XG4gICAgZm9udC1zaXplOiAxMnB4O1xuICB9XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1CaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
9226
9250
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
|
|
9227
9251
|
});
|
|
9228
9252
|
var BillingPeriodPrice = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
|
|
@@ -9236,7 +9260,7 @@ var BillingPeriodPrice = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "p
|
|
|
9236
9260
|
} : {
|
|
9237
9261
|
name: "1dz2cns",
|
|
9238
9262
|
styles: "display:flex;align-items:baseline;gap:8px",
|
|
9239
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9263
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQThCNkMiLCJmaWxlIjoiQmlsbGluZ1BlcmlvZFBpY2tlci5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEJveCwgQ2hpcCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFBpY2tlckNvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgcGFkZGluZzogMTZweCAwO1xuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RCdXR0b24gPSBzdHlsZWQuYnV0dG9uIGBcbiAgY3Vyc29yOiAkeyh7ICRkaXNhYmxlZCB9KSA9PiAoJGRpc2FibGVkID8gJ2RlZmF1bHQnIDogJ3BvaW50ZXInKX07XG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgaGVpZ2h0OiA4MHB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBib3JkZXI6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSB9KSA9PiBgMXB4IHNvbGlkICR7JGlzQWN0aXZlID8gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZFJlc3RpbmdCb3JkZXIgOiB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lLCAkaXNBY3RpdmUgfSkgPT4gKCRpc0FjdGl2ZSA/IHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFNlY3Rpb24gOiAndHJhbnNwYXJlbnQnKX07XG4gIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICB0ZXh0LWFsaWduOiBzdGFydDtcblxuICAmLk11aUJ1dHRvbi1yb290IHtcbiAgICBwYWRkaW5nOiAwIDE2cHggMCA4cHg7XG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RPcHRpb25zID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFByaWNlID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBiYXNlbGluZTtcbiAgZ2FwOiA4cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgRGlzY291bnRDaGlwID0gc3R5bGVkKENoaXApIGBcbiAgJiAuTXVpQ2hpcC1sYWJlbCB7XG4gICAgZm9udC1zaXplOiAxMnB4O1xuICB9XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1CaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
9240
9264
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
|
|
9241
9265
|
});
|
|
9242
9266
|
var DiscountChip = /*#__PURE__*/_styled(Chip, process.env.NODE_ENV === "production" ? {
|
|
@@ -9250,7 +9274,7 @@ var DiscountChip = /*#__PURE__*/_styled(Chip, process.env.NODE_ENV === "producti
|
|
|
9250
9274
|
} : {
|
|
9251
9275
|
name: "dcu1sk",
|
|
9252
9276
|
styles: "& .MuiChip-label{font-size:12px;}",
|
|
9253
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
9277
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQW1DeUMiLCJmaWxlIjoiQmlsbGluZ1BlcmlvZFBpY2tlci5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEJveCwgQ2hpcCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFBpY2tlckNvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgcGFkZGluZzogMTZweCAwO1xuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RCdXR0b24gPSBzdHlsZWQuYnV0dG9uIGBcbiAgY3Vyc29yOiAkeyh7ICRkaXNhYmxlZCB9KSA9PiAoJGRpc2FibGVkID8gJ2RlZmF1bHQnIDogJ3BvaW50ZXInKX07XG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgaGVpZ2h0OiA4MHB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBib3JkZXI6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSB9KSA9PiBgMXB4IHNvbGlkICR7JGlzQWN0aXZlID8gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZFJlc3RpbmdCb3JkZXIgOiB0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lLCAkaXNBY3RpdmUgfSkgPT4gKCRpc0FjdGl2ZSA/IHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFNlY3Rpb24gOiAndHJhbnNwYXJlbnQnKX07XG4gIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICB0ZXh0LWFsaWduOiBzdGFydDtcblxuICAmLk11aUJ1dHRvbi1yb290IHtcbiAgICBwYWRkaW5nOiAwIDE2cHggMCA4cHg7XG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RPcHRpb25zID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFByaWNlID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBiYXNlbGluZTtcbiAgZ2FwOiA4cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgRGlzY291bnRDaGlwID0gc3R5bGVkKENoaXApIGBcbiAgJiAuTXVpQ2hpcC1sYWJlbCB7XG4gICAgZm9udC1zaXplOiAxMnB4O1xuICB9XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1CaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
9254
9278
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
|
|
9255
9279
|
});
|
|
9256
9280
|
|
|
@@ -9489,7 +9513,8 @@ function CheckoutContainer(_ref) {
|
|
|
9489
9513
|
stripePromise = _useStripeIntegration.stripePromise,
|
|
9490
9514
|
setupIntentClientSecret = _useStripeIntegration.setupIntentClientSecret;
|
|
9491
9515
|
|
|
9492
|
-
var
|
|
9516
|
+
var _useCheckoutContext = useCheckoutContext(),
|
|
9517
|
+
stiggTheme = _useCheckoutContext[0].stiggTheme;
|
|
9493
9518
|
|
|
9494
9519
|
var _useProgressBarModel = useProgressBarModel(),
|
|
9495
9520
|
progressBarState = _useProgressBarModel.progressBarState;
|
|
@@ -9518,9 +9543,7 @@ function CheckoutContainer(_ref) {
|
|
|
9518
9543
|
}
|
|
9519
9544
|
}
|
|
9520
9545
|
}, React__default.createElement(CheckoutLayout, {
|
|
9521
|
-
className: "stigg-checkout-layout"
|
|
9522
|
-
"$backgroundColor": stiggTheme.palette.backgroundPaper,
|
|
9523
|
-
"$borderColor": stiggTheme.palette.outlinedBorder
|
|
9546
|
+
className: "stigg-checkout-layout"
|
|
9524
9547
|
}, React__default.createElement(CheckoutProgressBar, null), React__default.createElement(CheckoutContent, null, React__default.createElement(CheckoutPanel, null, React__default.createElement(PlanHeader$1, {
|
|
9525
9548
|
allowChangePlan: allowChangePlan,
|
|
9526
9549
|
onChangePlan: onChangePlan
|