@stigg/react-sdk 5.23.1 → 5.24.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/common/mediaQuery.d.ts +12 -0
- package/dist/components/customerPortal/subscriptionOverview/charges/ChargeItem.d.ts +2 -1
- package/dist/components/hooks/useIsScreenWiderThan.d.ts +2 -0
- package/dist/react-sdk.cjs.development.js +159 -103
- 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 +167 -123
- package/dist/react-sdk.esm.js.map +1 -1
- package/package.json +7 -5
- package/src/components/checkout/CheckoutContainer.style.ts +18 -3
- package/src/components/checkout/progressBar/CheckoutProgressBar.tsx +24 -5
- package/src/components/checkout/steps/addons/CheckoutAddonsStep.style.tsx +11 -3
- package/src/components/checkout/steps/addons/CheckoutAddonsStep.tsx +4 -2
- package/src/components/checkout/steps/plan/CheckoutChargeList.tsx +13 -6
- package/src/components/checkout/summary/CheckoutSuccess.tsx +8 -2
- package/src/components/checkout/summary/CheckoutSummary.tsx +6 -1
- package/src/components/checkout/summary/components/LineItems.tsx +15 -4
- package/src/components/common/mediaQuery.ts +19 -0
- package/src/components/customerPortal/billing/InformationGrid.tsx +1 -0
- package/src/components/customerPortal/billing/PaymentDetailsSection.tsx +15 -3
- package/src/components/customerPortal/common/SectionContainer.tsx +12 -1
- package/src/components/customerPortal/subscriptionOverview/SubscriptionOverviewLoader.tsx +4 -1
- package/src/components/customerPortal/subscriptionOverview/SubscriptionsOverview.tsx +3 -1
- package/src/components/customerPortal/subscriptionOverview/charges/ChargeItem.tsx +4 -1
- package/src/components/customerPortal/subscriptionOverview/charges/ChargeList.tsx +2 -1
- package/src/components/customerPortal/usage/CustomerUsageData.style.tsx +4 -2
- package/src/components/customerPortal/usage/CustomerUsageData.tsx +6 -3
- package/src/components/hooks/useIsScreenWiderThan.ts +6 -0
- package/src/stories/Checkout.stories.tsx +2 -1
- package/src/stories/CustomerPortal.stories.tsx +2 -1
- package/src/stories/baseArgs.ts +4 -4
|
@@ -41,6 +41,7 @@ var Box = _interopDefault(require('@mui/material/Box'));
|
|
|
41
41
|
var Tab = _interopDefault(require('@mui/material/Tab'));
|
|
42
42
|
var isEmpty = _interopDefault(require('lodash/isEmpty'));
|
|
43
43
|
var Tabs = _interopDefault(require('@mui/material/Tabs'));
|
|
44
|
+
var material = require('@mui/material');
|
|
44
45
|
var reactFeather = require('react-feather');
|
|
45
46
|
var Link = _interopDefault(require('@mui/material/Link'));
|
|
46
47
|
var Tooltip = require('@mui/material/Tooltip');
|
|
@@ -62,7 +63,6 @@ var CircularProgress = _interopDefault(require('@mui/material/CircularProgress')
|
|
|
62
63
|
var Paper = _interopDefault(require('@mui/material/Paper'));
|
|
63
64
|
var stripeJs = require('@stripe/stripe-js');
|
|
64
65
|
var Lottie = _interopDefault(require('lottie-react'));
|
|
65
|
-
var material = require('@mui/material');
|
|
66
66
|
var Collapse = _interopDefault(require('@mui/material/Collapse'));
|
|
67
67
|
var Alert = _interopDefault(require('@mui/material/Alert'));
|
|
68
68
|
var Radio = _interopDefault(require('@mui/material/Radio'));
|
|
@@ -3103,7 +3103,7 @@ var LoggerService = /*#__PURE__*/function () {
|
|
|
3103
3103
|
|
|
3104
3104
|
var logger = /*#__PURE__*/new LoggerService();
|
|
3105
3105
|
|
|
3106
|
-
var version = "5.
|
|
3106
|
+
var version = "5.24.1";
|
|
3107
3107
|
var name = "@stigg/react-sdk";
|
|
3108
3108
|
|
|
3109
3109
|
var StiggContext = /*#__PURE__*/React__default.createContext(null);
|
|
@@ -5045,15 +5045,36 @@ function SubscriptionTabs(_ref2) {
|
|
|
5045
5045
|
}, React__default.createElement(Promotions, null)));
|
|
5046
5046
|
}
|
|
5047
5047
|
|
|
5048
|
+
var breakpoints = {
|
|
5049
|
+
xs: 320,
|
|
5050
|
+
sm: 640,
|
|
5051
|
+
md: 768,
|
|
5052
|
+
lg: 1024,
|
|
5053
|
+
xl: 1280,
|
|
5054
|
+
xxl: 1536
|
|
5055
|
+
};
|
|
5056
|
+
var mqMinWidth = function mqMinWidth(breakpoint) {
|
|
5057
|
+
return "(min-width: " + breakpoints[breakpoint] + "px)";
|
|
5058
|
+
};
|
|
5059
|
+
var mq = /*#__PURE__*/Object.keys(breakpoints).reduce(function (obj, breakpoint) {
|
|
5060
|
+
var _extends2;
|
|
5061
|
+
|
|
5062
|
+
return _extends({}, obj, (_extends2 = {}, _extends2[breakpoint] = "@media " + mqMinWidth(breakpoint), _extends2));
|
|
5063
|
+
}, {});
|
|
5064
|
+
|
|
5065
|
+
function useIsScreenWiderThan(breakpoint) {
|
|
5066
|
+
return material.useMediaQuery(mqMinWidth(breakpoint));
|
|
5067
|
+
}
|
|
5068
|
+
|
|
5048
5069
|
function _EMOTION_STRINGIFIED_CSS_ERROR__$c() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
5049
5070
|
|
|
5050
5071
|
var SkeletonLayout = /*#__PURE__*/_styled("div", {
|
|
5051
5072
|
target: "ejq3grd1",
|
|
5052
5073
|
label: "SkeletonLayout"
|
|
5053
5074
|
})( {
|
|
5054
|
-
name: "
|
|
5055
|
-
styles: "display:flex;justify-content:space-between",
|
|
5056
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5075
|
+
name: "qgg235",
|
|
5076
|
+
styles: "display:flex;justify-content:space-between;flex-wrap:wrap",
|
|
5077
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvbk92ZXJ2aWV3TG9hZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFJa0MiLCJmaWxlIjoiU3Vic2NyaXB0aW9uT3ZlcnZpZXdMb2FkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgU2tlbGV0b24gZnJvbSAncmVhY3QtbG9hZGluZy1za2VsZXRvbic7XHJcbmltcG9ydCB7IHVzZUlzU2NyZWVuV2lkZXJUaGFuIH0gZnJvbSAnLi4vLi4vaG9va3MvdXNlSXNTY3JlZW5XaWRlclRoYW4nO1xyXG5jb25zdCBTa2VsZXRvbkxheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIGZsZXgtd3JhcDogd3JhcDtcbmA7XHJcbmNvbnN0IFNrZWxldG9uTGF5b3V0TGVmdCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDMycHg7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gU3Vic2NyaXB0aW9uT3ZlcnZpZXdMb2FkZXIoKSB7XHJcbiAgICBjb25zdCBpc1NjcmVlbldpZGVyVGhhbk1kID0gdXNlSXNTY3JlZW5XaWRlclRoYW4oJ21kJyk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25MYXlvdXQsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi1vdmVydmlldy1za2VsZXRvbi1sYXlvdXRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25MYXlvdXRMZWZ0LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogaXNTY3JlZW5XaWRlclRoYW5NZCA/IDI5NSA6IDI2MCwgaGVpZ2h0OiAxOTMgfSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TdWJzY3JpcHRpb25PdmVydmlld0xvYWRlci5qcy5tYXAiXX0= */",
|
|
5057
5078
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$c
|
|
5058
5079
|
});
|
|
5059
5080
|
|
|
@@ -5063,11 +5084,12 @@ var SkeletonLayoutLeft = /*#__PURE__*/_styled("div", {
|
|
|
5063
5084
|
})( {
|
|
5064
5085
|
name: "43cxha",
|
|
5065
5086
|
styles: "display:flex;flex-direction:column;gap:32px",
|
|
5066
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5087
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvbk92ZXJ2aWV3TG9hZGVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFTc0MiLCJmaWxlIjoiU3Vic2NyaXB0aW9uT3ZlcnZpZXdMb2FkZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgU2tlbGV0b24gZnJvbSAncmVhY3QtbG9hZGluZy1za2VsZXRvbic7XHJcbmltcG9ydCB7IHVzZUlzU2NyZWVuV2lkZXJUaGFuIH0gZnJvbSAnLi4vLi4vaG9va3MvdXNlSXNTY3JlZW5XaWRlclRoYW4nO1xyXG5jb25zdCBTa2VsZXRvbkxheW91dCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gIGZsZXgtd3JhcDogd3JhcDtcbmA7XHJcbmNvbnN0IFNrZWxldG9uTGF5b3V0TGVmdCA9IHN0eWxlZC5kaXYgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDMycHg7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gU3Vic2NyaXB0aW9uT3ZlcnZpZXdMb2FkZXIoKSB7XHJcbiAgICBjb25zdCBpc1NjcmVlbldpZGVyVGhhbk1kID0gdXNlSXNTY3JlZW5XaWRlclRoYW4oJ21kJyk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25MYXlvdXQsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi1vdmVydmlldy1za2VsZXRvbi1sYXlvdXRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b25MYXlvdXRMZWZ0LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAxMjAgfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDEyMCB9KSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogaXNTY3JlZW5XaWRlclRoYW5NZCA/IDI5NSA6IDI2MCwgaGVpZ2h0OiAxOTMgfSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TdWJzY3JpcHRpb25PdmVydmlld0xvYWRlci5qcy5tYXAiXX0= */",
|
|
5067
5088
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$c
|
|
5068
5089
|
});
|
|
5069
5090
|
|
|
5070
5091
|
function SubscriptionOverviewLoader() {
|
|
5092
|
+
var isScreenWiderThanMd = useIsScreenWiderThan('md');
|
|
5071
5093
|
return React__default.createElement(SkeletonLayout, {
|
|
5072
5094
|
className: "stigg-subscription-overview-skeleton-layout"
|
|
5073
5095
|
}, React__default.createElement(SkeletonLayoutLeft, null, React__default.createElement(Skeleton$1__default, {
|
|
@@ -5075,7 +5097,7 @@ function SubscriptionOverviewLoader() {
|
|
|
5075
5097
|
}), React__default.createElement(Skeleton$1__default, {
|
|
5076
5098
|
width: 120
|
|
5077
5099
|
})), React__default.createElement(Skeleton$1__default, {
|
|
5078
|
-
width: 295,
|
|
5100
|
+
width: isScreenWiderThanMd ? 295 : 260,
|
|
5079
5101
|
height: 193
|
|
5080
5102
|
}));
|
|
5081
5103
|
}
|
|
@@ -5347,7 +5369,7 @@ var SectionContainer = /*#__PURE__*/_styled("div", {
|
|
|
5347
5369
|
}, ";border:", function (_ref2) {
|
|
5348
5370
|
var $borderColor = _ref2.$borderColor;
|
|
5349
5371
|
return "1px solid " + $borderColor;
|
|
5350
|
-
}, ";padding:64px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
5372
|
+
}, ";padding:16px;", mq.sm, "{padding:32px;}", mq.md, "{padding:48px;}", mq.lg, "{padding:64px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlNlY3Rpb25Db250YWluZXIudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUUyQyIsImZpbGUiOiJTZWN0aW9uQ29udGFpbmVyLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgbXEgfSBmcm9tICcuLi8uLi9jb21tb24vbWVkaWFRdWVyeSc7XHJcbmV4cG9ydCBjb25zdCBTZWN0aW9uQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7ICRiYWNrZ3JvdW5kQ29sb3IgfSkgPT4gJGJhY2tncm91bmRDb2xvcn07XG4gIGJvcmRlcjogJHsoeyAkYm9yZGVyQ29sb3IgfSkgPT4gYDFweCBzb2xpZCAkeyRib3JkZXJDb2xvcn1gfTtcblxuICBwYWRkaW5nOiAxNnB4O1xuICAke21xLnNtfSB7XG4gICAgcGFkZGluZzogMzJweDtcbiAgfVxuICAke21xLm1kfSB7XG4gICAgcGFkZGluZzogNDhweDtcbiAgfVxuICAke21xLmxnfSB7XG4gICAgcGFkZGluZzogNjRweDtcbiAgfVxuYDtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9U2VjdGlvbkNvbnRhaW5lci5qcy5tYXAiXX0= */"));
|
|
5351
5373
|
|
|
5352
5374
|
function NextEstimatedBill(_ref) {
|
|
5353
5375
|
var billingPeriod = _ref.billingPeriod,
|
|
@@ -5855,6 +5877,7 @@ function ChargeItem(_ref) {
|
|
|
5855
5877
|
|
|
5856
5878
|
var amount = _ref.amount,
|
|
5857
5879
|
currency = _ref.currency,
|
|
5880
|
+
blockSize = _ref.blockSize,
|
|
5858
5881
|
entitlement = _ref.entitlement,
|
|
5859
5882
|
feature = _ref.feature,
|
|
5860
5883
|
hideChargePrice = _ref.hideChargePrice,
|
|
@@ -5889,7 +5912,7 @@ function ChargeItem(_ref) {
|
|
|
5889
5912
|
}, currencyPriceFormatter({
|
|
5890
5913
|
amount: amount,
|
|
5891
5914
|
currency: currency
|
|
5892
|
-
}), " per ", feature.featureUnits)), React__default.createElement("div", {
|
|
5915
|
+
}), " per ", blockSize ? blockSize + " " : '', blockSize ? feature.featureUnitsPlural : feature.featureUnits)), React__default.createElement("div", {
|
|
5893
5916
|
style: {
|
|
5894
5917
|
display: 'flex',
|
|
5895
5918
|
gap: 12
|
|
@@ -5942,6 +5965,7 @@ function ChargeList(_ref) {
|
|
|
5942
5965
|
}, filteredSubscriptionPrices.map(function (_ref3) {
|
|
5943
5966
|
var feature = _ref3.feature,
|
|
5944
5967
|
price = _ref3.price,
|
|
5968
|
+
blockSize = _ref3.blockSize,
|
|
5945
5969
|
billingModel = _ref3.billingModel;
|
|
5946
5970
|
|
|
5947
5971
|
if (!feature || !price) {
|
|
@@ -5959,6 +5983,7 @@ function ChargeList(_ref) {
|
|
|
5959
5983
|
entitlement: entitlement,
|
|
5960
5984
|
feature: entitlement.feature,
|
|
5961
5985
|
amount: price.amount,
|
|
5986
|
+
blockSize: blockSize,
|
|
5962
5987
|
currency: price.currency,
|
|
5963
5988
|
hideChargePrice: billingModel === Stigg.BillingModel.PerUnit,
|
|
5964
5989
|
onBuyMore: onBuyMore,
|
|
@@ -6014,7 +6039,8 @@ function SubscriptionsOverview(_ref) {
|
|
|
6014
6039
|
style: {
|
|
6015
6040
|
display: 'flex',
|
|
6016
6041
|
alignItems: 'flex-start',
|
|
6017
|
-
gap: 64
|
|
6042
|
+
gap: 64,
|
|
6043
|
+
flexWrap: 'wrap'
|
|
6018
6044
|
}
|
|
6019
6045
|
}, React__default.createElement("div", {
|
|
6020
6046
|
style: {
|
|
@@ -6131,7 +6157,7 @@ var InformationGridContainer = /*#__PURE__*/_styled("div", {
|
|
|
6131
6157
|
})( {
|
|
6132
6158
|
name: "1hidw77",
|
|
6133
6159
|
styles: "display:flex;flex-direction:column;align-items:flex-start;gap:16px;flex:1 0 0",
|
|
6134
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
6160
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkluZm9ybWF0aW9uR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSW1EIiwiZmlsZSI6IkluZm9ybWF0aW9uR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEZvbnRXZWlnaHQgfSBmcm9tICdzdHlsZWQtdHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmV4cG9ydCBjb25zdCBJbmZvcm1hdGlvbkdyaWRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMTZweDtcbiAgZmxleDogMSAwIDA7XG5gO1xyXG5jb25zdCBJbmZvcm1hdGlvbkdyaWRSb3cgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMTZweDtcbiAgYWxpZ24tc2VsZjogc3RyZXRjaDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIEluZm9ybWF0aW9uR3JpZCh7IHRpdGxlLCByb3dzIH0pIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbmZvcm1hdGlvbkdyaWRDb250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIsIGZvbnRXZWlnaHQ6IEZvbnRXZWlnaHQuTWVkaXVtIH0sIHRpdGxlKSxcclxuICAgICAgICByb3dzLm1hcCgoeyBjbGFzc05hbWVQcmVmaXgsIGxhYmVsLCB2YWx1ZSwgbGFiZWxUeXBvZ3JhcGh5UHJvcHMsIHZhbHVlVHlwb2dyYXBoeVByb3BzIH0pID0+IChSZWFjdC5jcmVhdGVFbGVtZW50KEluZm9ybWF0aW9uR3JpZFJvdywgeyBrZXk6IGxhYmVsIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgT2JqZWN0LmFzc2lnbih7IGNsYXNzTmFtZTogYCR7Y2xhc3NOYW1lUHJlZml4fS1sYWJlbGAsIHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIsIHN0eWxlOiB7IHdpZHRoOiA4MCB9IH0sIGxhYmVsVHlwb2dyYXBoeVByb3BzKSwgbGFiZWwpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIE9iamVjdC5hc3NpZ24oeyBjbGFzc05hbWU6IGAke2NsYXNzTmFtZVByZWZpeH0tdGV4dGAsIHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgdmFsdWVUeXBvZ3JhcGh5UHJvcHMpLCB2YWx1ZSkpKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1JbmZvcm1hdGlvbkdyaWQuanMubWFwIl19 */",
|
|
6135
6161
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
|
|
6136
6162
|
});
|
|
6137
6163
|
|
|
@@ -6139,9 +6165,9 @@ var InformationGridRow = /*#__PURE__*/_styled("div", {
|
|
|
6139
6165
|
target: "e12mjvl50",
|
|
6140
6166
|
label: "InformationGridRow"
|
|
6141
6167
|
})( {
|
|
6142
|
-
name: "
|
|
6143
|
-
styles: "display:flex;align-items:flex-start;gap:16px;align-self:stretch",
|
|
6144
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
6168
|
+
name: "1jp5dot",
|
|
6169
|
+
styles: "display:flex;align-items:flex-start;gap:16px;align-self:stretch;flex-wrap:wrap",
|
|
6170
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkluZm9ybWF0aW9uR3JpZC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBV3NDIiwiZmlsZSI6IkluZm9ybWF0aW9uR3JpZC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IEZvbnRXZWlnaHQgfSBmcm9tICdzdHlsZWQtdHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmV4cG9ydCBjb25zdCBJbmZvcm1hdGlvbkdyaWRDb250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMTZweDtcbiAgZmxleDogMSAwIDA7XG5gO1xyXG5jb25zdCBJbmZvcm1hdGlvbkdyaWRSb3cgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMTZweDtcbiAgYWxpZ24tc2VsZjogc3RyZXRjaDtcbiAgZmxleC13cmFwOiB3cmFwO1xuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIEluZm9ybWF0aW9uR3JpZCh7IHRpdGxlLCByb3dzIH0pIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChJbmZvcm1hdGlvbkdyaWRDb250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIsIGZvbnRXZWlnaHQ6IEZvbnRXZWlnaHQuTWVkaXVtIH0sIHRpdGxlKSxcclxuICAgICAgICByb3dzLm1hcCgoeyBjbGFzc05hbWVQcmVmaXgsIGxhYmVsLCB2YWx1ZSwgbGFiZWxUeXBvZ3JhcGh5UHJvcHMsIHZhbHVlVHlwb2dyYXBoeVByb3BzIH0pID0+IChSZWFjdC5jcmVhdGVFbGVtZW50KEluZm9ybWF0aW9uR3JpZFJvdywgeyBrZXk6IGxhYmVsIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgT2JqZWN0LmFzc2lnbih7IGNsYXNzTmFtZTogYCR7Y2xhc3NOYW1lUHJlZml4fS1sYWJlbGAsIHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIsIHN0eWxlOiB7IHdpZHRoOiA4MCB9IH0sIGxhYmVsVHlwb2dyYXBoeVByb3BzKSwgbGFiZWwpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIE9iamVjdC5hc3NpZ24oeyBjbGFzc05hbWU6IGAke2NsYXNzTmFtZVByZWZpeH0tdGV4dGAsIHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgdmFsdWVUeXBvZ3JhcGh5UHJvcHMpLCB2YWx1ZSkpKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1JbmZvcm1hdGlvbkdyaWQuanMubWFwIl19 */",
|
|
6145
6171
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$i
|
|
6146
6172
|
});
|
|
6147
6173
|
|
|
@@ -6190,6 +6216,8 @@ function PaymentDetailsSection() {
|
|
|
6190
6216
|
textOverrides = _useCustomerPortalCon.textOverrides,
|
|
6191
6217
|
theme = _useCustomerPortalCon.theme;
|
|
6192
6218
|
|
|
6219
|
+
var isScreenWiderThanMd = useIsScreenWiderThan('md');
|
|
6220
|
+
|
|
6193
6221
|
var _ref = customerPortal || {},
|
|
6194
6222
|
billingInformation = _ref.billingInformation;
|
|
6195
6223
|
|
|
@@ -6212,7 +6240,8 @@ function PaymentDetailsSection() {
|
|
|
6212
6240
|
key: "information-loading-data-divider",
|
|
6213
6241
|
orientation: "vertical",
|
|
6214
6242
|
style: {
|
|
6215
|
-
minHeight: 93
|
|
6243
|
+
minHeight: 93,
|
|
6244
|
+
display: isScreenWiderThanMd ? 'block' : 'none'
|
|
6216
6245
|
}
|
|
6217
6246
|
}), React__default.createElement(InformationGridContainer, {
|
|
6218
6247
|
key: "information-loading-data-bottom"
|
|
@@ -6252,7 +6281,8 @@ function PaymentDetailsSection() {
|
|
|
6252
6281
|
key: "information-billing-data-divider",
|
|
6253
6282
|
orientation: "vertical",
|
|
6254
6283
|
style: {
|
|
6255
|
-
minHeight: 93
|
|
6284
|
+
minHeight: 93,
|
|
6285
|
+
display: isScreenWiderThanMd ? 'block' : 'none'
|
|
6256
6286
|
}
|
|
6257
6287
|
}));
|
|
6258
6288
|
items.unshift(React__default.createElement(InformationGrid, {
|
|
@@ -6294,7 +6324,8 @@ function PaymentDetailsSection() {
|
|
|
6294
6324
|
style: {
|
|
6295
6325
|
display: 'flex',
|
|
6296
6326
|
alignItems: 'stretch',
|
|
6297
|
-
gap: 64
|
|
6327
|
+
gap: isScreenWiderThanMd ? 64 : 32,
|
|
6328
|
+
flexWrap: 'wrap'
|
|
6298
6329
|
}
|
|
6299
6330
|
}, items));
|
|
6300
6331
|
}
|
|
@@ -6451,19 +6482,23 @@ var Footer = /*#__PURE__*/_styled("div", {
|
|
|
6451
6482
|
})( {
|
|
6452
6483
|
name: "3hgi0y",
|
|
6453
6484
|
styles: "margin-top:32px",
|
|
6454
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
6485
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkN1c3RvbWVyVXNhZ2VEYXRhLnN0eWxlLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNaUMiLCJmaWxlIjoiQ3VzdG9tZXJVc2FnZURhdGEuc3R5bGUudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgR3JpZCBmcm9tICdAbXVpL21hdGVyaWFsL0dyaWQnO1xyXG5pbXBvcnQgeyByYW5nZSB9IGZyb20gJ2xvZGFzaCc7XHJcbmltcG9ydCBTa2VsZXRvbiBmcm9tICdyZWFjdC1sb2FkaW5nLXNrZWxldG9uJztcclxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgdXNlSXNTY3JlZW5XaWRlclRoYW4gfSBmcm9tICcuLi8uLi9ob29rcy91c2VJc1NjcmVlbldpZGVyVGhhbic7XHJcbmV4cG9ydCBjb25zdCBGb290ZXIgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luLXRvcDogMzJweDtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBDdXN0b21lclVzYWdlTG9hZGVyKCkge1xyXG4gICAgY29uc3QgaXNNZFNjcmVlbiA9IHVzZUlzU2NyZWVuV2lkZXJUaGFuKCdtZCcpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgY29udGFpbmVyOiB0cnVlLCBzcGFjaW5nOiA0LCBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXVzYWdlLXNrZWxldG9uLWxheW91dFwiLCBzeDogeyBmbGV4V3JhcDogJ3dyYXAnIH0gfSwgcmFuZ2UoNikubWFwKChpdGVtKSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGtleTogaXRlbSwgaXRlbTogdHJ1ZSwgeHM6IGlzTWRTY3JlZW4gPyA0IDogMTIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiAyODAsIGhlaWdodDogMTIwIH0pKSkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q3VzdG9tZXJVc2FnZURhdGEuc3R5bGUuanMubWFwIl19 */",
|
|
6455
6486
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$k
|
|
6456
6487
|
});
|
|
6457
6488
|
function CustomerUsageLoader() {
|
|
6489
|
+
var isMdScreen = useIsScreenWiderThan('md');
|
|
6458
6490
|
return React__default.createElement(Grid, {
|
|
6459
6491
|
container: true,
|
|
6460
6492
|
spacing: 4,
|
|
6461
|
-
className: "stigg-subscription-usage-skeleton-layout"
|
|
6493
|
+
className: "stigg-subscription-usage-skeleton-layout",
|
|
6494
|
+
sx: {
|
|
6495
|
+
flexWrap: 'wrap'
|
|
6496
|
+
}
|
|
6462
6497
|
}, lodash.range(6).map(function (item) {
|
|
6463
6498
|
return React__default.createElement(Grid, {
|
|
6464
6499
|
key: item,
|
|
6465
6500
|
item: true,
|
|
6466
|
-
xs: 4
|
|
6501
|
+
xs: isMdScreen ? 4 : 12
|
|
6467
6502
|
}, React__default.createElement(Skeleton$1__default, {
|
|
6468
6503
|
width: 280,
|
|
6469
6504
|
height: 120
|
|
@@ -6477,9 +6512,11 @@ function CustomerUsageData(_ref) {
|
|
|
6477
6512
|
onBuyMore = _ref.onBuyMore,
|
|
6478
6513
|
filterEntitlements = _ref.filterEntitlements;
|
|
6479
6514
|
|
|
6480
|
-
var
|
|
6481
|
-
showAll =
|
|
6482
|
-
setShowAll =
|
|
6515
|
+
var _useState = React.useState(false),
|
|
6516
|
+
showAll = _useState[0],
|
|
6517
|
+
setShowAll = _useState[1];
|
|
6518
|
+
|
|
6519
|
+
var isMdScreen = useIsScreenWiderThan('md');
|
|
6483
6520
|
|
|
6484
6521
|
var _useCustomerPortalCon = useCustomerPortalContext(),
|
|
6485
6522
|
customerPortal = _useCustomerPortalCon.customerPortal,
|
|
@@ -6516,7 +6553,7 @@ function CustomerUsageData(_ref) {
|
|
|
6516
6553
|
var sortedEntitlements = [].concat(priceEntitlements, otherEntitlements);
|
|
6517
6554
|
var filteredEntitlements = filterEntitlements ? filterEntitlements(sortedEntitlements) : sortedEntitlements; // 4 -> 3 per row, 6 -> 2 per row
|
|
6518
6555
|
|
|
6519
|
-
var xs = filteredEntitlements.length > 2 ? 4 : 6;
|
|
6556
|
+
var xs = isMdScreen ? filteredEntitlements.length > 2 ? 4 : 6 : 12;
|
|
6520
6557
|
var entitlementsToShow = showAll ? filteredEntitlements : filteredEntitlements.slice(0, MAX_BOXES);
|
|
6521
6558
|
|
|
6522
6559
|
var toggleShowAll = function toggleShowAll() {
|
|
@@ -7912,35 +7949,24 @@ function CheckoutProvider(_ref2) {
|
|
|
7912
7949
|
}, children));
|
|
7913
7950
|
}
|
|
7914
7951
|
|
|
7915
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$l() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
7916
7952
|
var CheckoutLayout = /*#__PURE__*/_styled("div", {
|
|
7917
7953
|
target: "ergo9xd2",
|
|
7918
7954
|
label: "CheckoutLayout"
|
|
7919
|
-
})("margin:auto;
|
|
7955
|
+
})("margin:auto;min-height:760px;max-width:920px;display:flex;position:relative;flex-direction:column;align-items:center;background-color:", function (_ref) {
|
|
7920
7956
|
var theme = _ref.theme;
|
|
7921
7957
|
return theme.stigg.palette.backgroundPaper;
|
|
7922
7958
|
}, ";border:", function (_ref2) {
|
|
7923
7959
|
var theme = _ref2.theme;
|
|
7924
7960
|
return "1px solid " + theme.stigg.palette.outlinedBorder;
|
|
7925
|
-
}, ";& *{box-sizing:border-box;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
7961
|
+
}, ";& *{box-sizing:border-box;}padding:16px 16px;", mq.md, "{padding:32px;width:calc(100% - 64px);border-radius:10px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUd5QyIsImZpbGUiOiJDaGVja291dENvbnRhaW5lci5zdHlsZS50cyIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJveCBmcm9tICdAbXVpL21hdGVyaWFsL0JveCc7XHJcbmltcG9ydCB7IG1xIH0gZnJvbSAnLi4vY29tbW9uL21lZGlhUXVlcnknO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luOiBhdXRvO1xuICBtaW4taGVpZ2h0OiA3NjBweDtcbiAgbWF4LXdpZHRoOiA5MjBweDtcbiAgZGlzcGxheTogZmxleDtcbiAgcG9zaXRpb246IHJlbGF0aXZlO1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuXG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXJ9O1xuICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5cbiAgcGFkZGluZzogMTZweCAxNnB4O1xuICAke21xLm1kfSB7XG4gICAgcGFkZGluZzogMzJweDtcbiAgICB3aWR0aDogY2FsYygxMDAlIC0gNjRweCk7XG4gICAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0Q29udGVudCA9IHN0eWxlZChCb3gpIGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGZsZXgtc3RhcnQ7XG4gIGdhcDogMzJweDtcbiAgZmxleC13cmFwOiB3cmFwO1xuICB3aWR0aDogMTAwJTtcblxuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICAke21xLm1kfSB7XG4gICAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0UGFuZWwgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGdhcDogMDtcbiAgZmxleDogMjtcblxuICB3aWR0aDogMTAwJTtcbiAgJHttcS5tZH0ge1xuICAgIHdpZHRoOiBhdXRvO1xuICB9XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1DaGVja291dENvbnRhaW5lci5zdHlsZS5qcy5tYXAiXX0= */"));
|
|
7926
7962
|
var CheckoutContent = /*#__PURE__*/_styled(Box, {
|
|
7927
7963
|
target: "ergo9xd1",
|
|
7928
7964
|
label: "CheckoutContent"
|
|
7929
|
-
})( {
|
|
7930
|
-
name: "1pdbip7",
|
|
7931
|
-
styles: "display:flex;align-items:flex-start;gap:32px;flex-wrap:wrap;width:100%",
|
|
7932
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXFCMkMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luOiBhdXRvO1xuICB3aWR0aDogMTAwJTtcbiAgbWluLWhlaWdodDogNzYwcHg7XG4gIG1heC13aWR0aDogOTIwcHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBwYWRkaW5nOiAxNnB4IDMycHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXJ9O1xuICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRDb250ZW50ID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiAzMnB4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0UGFuZWwgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGdhcDogMDtcbiAgZmxleDogMjtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
7933
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$l
|
|
7934
|
-
});
|
|
7965
|
+
})("display:flex;align-items:flex-start;gap:32px;flex-wrap:wrap;width:100%;flex-direction:column;", mq.md, "{flex-direction:row;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTBCMkMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5pbXBvcnQgeyBtcSB9IGZyb20gJy4uL2NvbW1vbi9tZWRpYVF1ZXJ5JztcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0TGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIG1hcmdpbjogYXV0bztcbiAgbWluLWhlaWdodDogNzYwcHg7XG4gIG1heC13aWR0aDogOTIwcHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFBhcGVyfTtcbiAgYm9yZGVyOiAkeyh7IHRoZW1lIH0pID0+IGAxcHggc29saWQgJHt0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuXG4gIHBhZGRpbmc6IDE2cHggMTZweDtcbiAgJHttcS5tZH0ge1xuICAgIHBhZGRpbmc6IDMycHg7XG4gICAgd2lkdGg6IGNhbGMoMTAwJSAtIDY0cHgpO1xuICAgIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dENvbnRlbnQgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBmbGV4LXN0YXJ0O1xuICBnYXA6IDMycHg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgd2lkdGg6IDEwMCU7XG5cbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgJHttcS5tZH0ge1xuICAgIGZsZXgtZGlyZWN0aW9uOiByb3c7XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dFBhbmVsID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDA7XG4gIGZsZXg6IDI7XG5cbiAgd2lkdGg6IDEwMCU7XG4gICR7bXEubWR9IHtcbiAgICB3aWR0aDogYXV0bztcbiAgfVxuYDtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRDb250YWluZXIuc3R5bGUuanMubWFwIl19 */"));
|
|
7935
7966
|
var CheckoutPanel = /*#__PURE__*/_styled(Box, {
|
|
7936
7967
|
target: "ergo9xd0",
|
|
7937
7968
|
label: "CheckoutPanel"
|
|
7938
|
-
})( {
|
|
7939
|
-
name: "fszphw",
|
|
7940
|
-
styles: "display:flex;flex-direction:column;gap:0;flex:2",
|
|
7941
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTRCeUMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRMYXlvdXQgPSBzdHlsZWQuZGl2IGBcbiAgbWFyZ2luOiBhdXRvO1xuICB3aWR0aDogMTAwJTtcbiAgbWluLWhlaWdodDogNzYwcHg7XG4gIG1heC13aWR0aDogOTIwcHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBwYWRkaW5nOiAxNnB4IDMycHg7XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXJ9O1xuICBib3JkZXI6ICR7KHsgdGhlbWUgfSkgPT4gYDFweCBzb2xpZCAke3RoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXJ9YH07XG5cbiAgJiAqIHtcbiAgICBib3gtc2l6aW5nOiBib3JkZXItYm94O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRDb250ZW50ID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogZmxleC1zdGFydDtcbiAgZ2FwOiAzMnB4O1xuICBmbGV4LXdyYXA6IHdyYXA7XG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0UGFuZWwgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGdhcDogMDtcbiAgZmxleDogMjtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
7942
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$l
|
|
7943
|
-
});
|
|
7969
|
+
})("display:flex;flex-direction:column;gap:0;flex:2;width:100%;", mq.md, "{width:auto;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0Q29udGFpbmVyLnN0eWxlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQXNDeUMiLCJmaWxlIjoiQ2hlY2tvdXRDb250YWluZXIuc3R5bGUudHMiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5pbXBvcnQgeyBtcSB9IGZyb20gJy4uL2NvbW1vbi9tZWRpYVF1ZXJ5JztcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0TGF5b3V0ID0gc3R5bGVkLmRpdiBgXG4gIG1hcmdpbjogYXV0bztcbiAgbWluLWhlaWdodDogNzYwcHg7XG4gIG1heC13aWR0aDogOTIwcHg7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIHBvc2l0aW9uOiByZWxhdGl2ZTtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcblxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFBhcGVyfTtcbiAgYm9yZGVyOiAkeyh7IHRoZW1lIH0pID0+IGAxcHggc29saWQgJHt0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuXG4gICYgKiB7XG4gICAgYm94LXNpemluZzogYm9yZGVyLWJveDtcbiAgfVxuXG4gIHBhZGRpbmc6IDE2cHggMTZweDtcbiAgJHttcS5tZH0ge1xuICAgIHBhZGRpbmc6IDMycHg7XG4gICAgd2lkdGg6IGNhbGMoMTAwJSAtIDY0cHgpO1xuICAgIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dENvbnRlbnQgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBmbGV4LXN0YXJ0O1xuICBnYXA6IDMycHg7XG4gIGZsZXgtd3JhcDogd3JhcDtcbiAgd2lkdGg6IDEwMCU7XG5cbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgJHttcS5tZH0ge1xuICAgIGZsZXgtZGlyZWN0aW9uOiByb3c7XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dFBhbmVsID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDA7XG4gIGZsZXg6IDI7XG5cbiAgd2lkdGg6IDEwMCU7XG4gICR7bXEubWR9IHtcbiAgICB3aWR0aDogYXV0bztcbiAgfVxuYDtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRDb250YWluZXIuc3R5bGUuanMubWFwIl19 */"));
|
|
7944
7970
|
|
|
7945
7971
|
var StyledProgress = /*#__PURE__*/_styled(LinearProgress__default, {
|
|
7946
7972
|
shouldForwardProp: function shouldForwardProp(prop) {
|
|
@@ -7994,11 +8020,14 @@ var StyledIcon = /*#__PURE__*/_styled(Icon, {
|
|
|
7994
8020
|
var CheckoutProgressBar = function CheckoutProgressBar() {
|
|
7995
8021
|
var _useProgressBarModel = useProgressBarModel(),
|
|
7996
8022
|
progressBarState = _useProgressBarModel.progressBarState,
|
|
7997
|
-
setActiveStep = _useProgressBarModel.setActiveStep
|
|
8023
|
+
setActiveStep = _useProgressBarModel.setActiveStep,
|
|
8024
|
+
currentStep = _useProgressBarModel.currentStep;
|
|
7998
8025
|
|
|
7999
8026
|
var _useCheckoutModel = useCheckoutModel(),
|
|
8000
8027
|
widgetState = _useCheckoutModel.widgetState;
|
|
8001
8028
|
|
|
8029
|
+
var isScreenWiderThanMd = useIsScreenWiderThan('md');
|
|
8030
|
+
var containerRef = React.useRef();
|
|
8002
8031
|
var readOnly = widgetState.readOnly,
|
|
8003
8032
|
isLoadingCheckoutData = widgetState.isLoadingCheckoutData;
|
|
8004
8033
|
|
|
@@ -8009,6 +8038,22 @@ var CheckoutProgressBar = function CheckoutProgressBar() {
|
|
|
8009
8038
|
|
|
8010
8039
|
var progress = (activeStep + 1) * 100 / steps.length;
|
|
8011
8040
|
|
|
8041
|
+
var _React$useState = React__default.useState(currentStep),
|
|
8042
|
+
previousStep = _React$useState[0],
|
|
8043
|
+
setPreviousStep = _React$useState[1];
|
|
8044
|
+
|
|
8045
|
+
React.useEffect(function () {
|
|
8046
|
+
if (!isScreenWiderThanMd) {
|
|
8047
|
+
if (containerRef.current && currentStep !== previousStep) {
|
|
8048
|
+
containerRef.current.scrollIntoView({
|
|
8049
|
+
behavior: 'smooth'
|
|
8050
|
+
});
|
|
8051
|
+
}
|
|
8052
|
+
}
|
|
8053
|
+
|
|
8054
|
+
setPreviousStep(currentStep);
|
|
8055
|
+
}, [currentStep, isScreenWiderThanMd, previousStep, setPreviousStep]);
|
|
8056
|
+
|
|
8012
8057
|
if (progressBarState.steps.length === 1) {
|
|
8013
8058
|
return null;
|
|
8014
8059
|
}
|
|
@@ -8018,7 +8063,8 @@ var CheckoutProgressBar = function CheckoutProgressBar() {
|
|
|
8018
8063
|
sx: {
|
|
8019
8064
|
width: '100%',
|
|
8020
8065
|
mb: 3
|
|
8021
|
-
}
|
|
8066
|
+
},
|
|
8067
|
+
ref: containerRef
|
|
8022
8068
|
}, React__default.createElement(StyledProgress, {
|
|
8023
8069
|
variant: "determinate",
|
|
8024
8070
|
value: progress,
|
|
@@ -8037,7 +8083,7 @@ var CheckoutProgressBar = function CheckoutProgressBar() {
|
|
|
8037
8083
|
item: true,
|
|
8038
8084
|
display: "flex",
|
|
8039
8085
|
flexDirection: "row",
|
|
8040
|
-
flex: 1,
|
|
8086
|
+
flex: isScreenWiderThanMd ? 1 : 'auto',
|
|
8041
8087
|
justifyContent: "flex-start"
|
|
8042
8088
|
}, isLoadingCheckoutData ? React__default.createElement(Skeleton, {
|
|
8043
8089
|
width: 120,
|
|
@@ -8366,7 +8412,7 @@ var AppliedPromotionCode = function AppliedPromotionCode(_ref5) {
|
|
|
8366
8412
|
}))));
|
|
8367
8413
|
};
|
|
8368
8414
|
|
|
8369
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
8415
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$l() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
8370
8416
|
|
|
8371
8417
|
var PromotionCodeSectionContainer = /*#__PURE__*/_styled("div", {
|
|
8372
8418
|
target: "eqejwsl0",
|
|
@@ -8375,7 +8421,7 @@ var PromotionCodeSectionContainer = /*#__PURE__*/_styled("div", {
|
|
|
8375
8421
|
name: "1k6141t",
|
|
8376
8422
|
styles: "margin:16px 0",
|
|
8377
8423
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlByb21vdGlvbkNvZGVTZWN0aW9uLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFLaUQiLCJmaWxlIjoiUHJvbW90aW9uQ29kZVNlY3Rpb24udHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyB1c2VQcm9tb3Rpb25Db2RlTW9kZWwgfSBmcm9tICcuLi9ob29rcy91c2VDb3Vwb25Nb2RlbCc7XHJcbmltcG9ydCB7IEFkZFByb21vdGlvbkNvZGUgfSBmcm9tICcuL0FkZFByb21vdGlvbkNvZGUnO1xyXG5pbXBvcnQgeyBBcHBsaWVkUHJvbW90aW9uQ29kZSB9IGZyb20gJy4vQXBwbGllZFByb21vdGlvbkNvZGUnO1xyXG5jb25zdCBQcm9tb3Rpb25Db2RlU2VjdGlvbkNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICBtYXJnaW46IDE2cHggMDtcbmA7XHJcbmV4cG9ydCBjb25zdCBQcm9tb3Rpb25Db2RlU2VjdGlvbiA9ICh7IGRpc2FibGVkLCBjaGVja291dExvY2FsaXphdGlvbiwgb25Nb2NrQ2hlY2tvdXRQcmV2aWV3LCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHByb21vdGlvbkNvZGUsIHNldFByb21vdGlvbkNvZGUgfSA9IHVzZVByb21vdGlvbkNvZGVNb2RlbCgpO1xyXG4gICAgY29uc3Qgb25DbGVhclByb21vdGlvbkNvZGUgPSAoKSA9PiB7XHJcbiAgICAgICAgc2V0UHJvbW90aW9uQ29kZSgnJyk7XHJcbiAgICB9O1xyXG4gICAgY29uc3QgY29udGVudCA9IHByb21vdGlvbkNvZGUgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChBcHBsaWVkUHJvbW90aW9uQ29kZSwgeyBwcm9tb3Rpb25Db2RlOiBwcm9tb3Rpb25Db2RlLCBvbkNsZWFyUHJvbW90aW9uQ29kZTogb25DbGVhclByb21vdGlvbkNvZGUgfSkpIDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQWRkUHJvbW90aW9uQ29kZSwgeyBkaXNhYmxlZDogZGlzYWJsZWQsIGNoZWNrb3V0TG9jYWxpemF0aW9uOiBjaGVja291dExvY2FsaXphdGlvbiwgb25Nb2NrQ2hlY2tvdXRQcmV2aWV3OiBvbk1vY2tDaGVja291dFByZXZpZXcgfSkpO1xyXG4gICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJvbW90aW9uQ29kZVNlY3Rpb25Db250YWluZXIsIG51bGwsIGNvbnRlbnQpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1Qcm9tb3Rpb25Db2RlU2VjdGlvbi5qcy5tYXAiXX0= */",
|
|
8378
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
8424
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$l
|
|
8379
8425
|
});
|
|
8380
8426
|
|
|
8381
8427
|
var PromotionCodeSection = function PromotionCodeSection(_ref) {
|
|
@@ -11831,7 +11877,7 @@ var animationData = {
|
|
|
11831
11877
|
props: props
|
|
11832
11878
|
};
|
|
11833
11879
|
|
|
11834
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
11880
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$m() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
11835
11881
|
var ANIMATION_DURATION = 5000;
|
|
11836
11882
|
|
|
11837
11883
|
var CheckoutSuccessContainer = /*#__PURE__*/_styled(Box, {
|
|
@@ -11849,7 +11895,7 @@ var CheckoutSuccessContainer = /*#__PURE__*/_styled(Box, {
|
|
|
11849
11895
|
}, ";animation:blurFade 2s ease-in forwards;display:flex;flex-direction:column;justify-content:center;* rect{fill:transparent;}& path{stroke:", function (_ref4) {
|
|
11850
11896
|
var theme = _ref4.theme;
|
|
11851
11897
|
return theme.stigg.palette.primary;
|
|
11852
|
-
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
11898
|
+
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0U3VjY2Vzcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTZDIiwiZmlsZSI6IkNoZWNrb3V0U3VjY2Vzcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5pbXBvcnQgQ29sb3IgZnJvbSAnY29sb3InO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VSZWYgfSBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBMb3R0aWUgZnJvbSAnbG90dGllLXJlYWN0JztcclxuaW1wb3J0IGFuaW1hdGlvbkRhdGEgZnJvbSAnLi4vLi4vLi4vYXNzZXRzL2xvdHRpZS9jaGVja291dC1zdWNjZXNzLmpzb24nO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5leHBvcnQgY29uc3QgQU5JTUFUSU9OX0RVUkFUSU9OID0gNTAwMDtcclxuY29uc3QgQ2hlY2tvdXRTdWNjZXNzQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBAa2V5ZnJhbWVzIGJsdXJGYWRlIHtcbiAgICAwJSB7XG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IENvbG9yKHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFBhcGVyKS5hbHBoYSgwKS50b1N0cmluZygpfTtcbiAgICAgIGJhY2tkcm9wLWZpbHRlcjogYmx1cigwcHgpO1xuICAgIH1cbiAgICAxMDAlIHtcbiAgICAgIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gQ29sb3IodGhlbWUuc3RpZ2cucGFsZXR0ZS5iYWNrZ3JvdW5kUGFwZXIpLmFscGhhKDAuOSkudG9TdHJpbmcoKX07XG4gICAgICBiYWNrZHJvcC1maWx0ZXI6IGJsdXIoNi41cHgpO1xuICAgIH1cbiAgfVxuXG4gIHBvc2l0aW9uOiBhYnNvbHV0ZTtcbiAgdG9wOiAwO1xuICBsZWZ0OiAwO1xuICBib3R0b206IDA7XG4gIHJpZ2h0OiAwO1xuICB6LWluZGV4OiA1O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IENvbG9yKHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFBhcGVyKS5hbHBoYSgwLjkpLnRvU3RyaW5nKCl9O1xuICBhbmltYXRpb246IGJsdXJGYWRlIDJzIGVhc2UtaW4gZm9yd2FyZHM7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGZsZXgtZGlyZWN0aW9uOiBjb2x1bW47XG4gIGp1c3RpZnktY29udGVudDogY2VudGVyO1xuXG4gICogcmVjdCB7XG4gICAgZmlsbDogdHJhbnNwYXJlbnQ7XG4gIH1cblxuICAmIHBhdGgge1xuICAgIHN0cm9rZTogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLnByaW1hcnl9O1xuICB9XG5gO1xyXG5jb25zdCBDaGVja291dFN1Y2Nlc3NUZXh0ID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgQGtleWZyYW1lcyBmYWRlSW4ge1xuICAgIDAlIHtcbiAgICAgIG9wYWNpdHk6IDA7XG4gICAgfVxuICAgIDc1JSB7XG4gICAgICBvcGFjaXR5OiAwO1xuICAgIH1cbiAgICAxMDAlIHtcbiAgICAgIG9wYWNpdHk6IDE7XG4gICAgfVxuICB9XG5cbiAgYWxpZ24tc2VsZjogY2VudGVyO1xuICBhbmltYXRpb246IGZhZGVJbiA1cyBlYXNlLWluIGZvcndhcmRzO1xuYDtcclxuY29uc3QgU3R5bGVkTG90dGllID0gc3R5bGVkKExvdHRpZSkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcblxuICBzdmcge1xuICAgIHdpZHRoOiAzNTBweCAhaW1wb3J0YW50O1xuICAgIGhlaWdodDogYXV0byAhaW1wb3J0YW50O1xuICB9XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gQ2hlY2tvdXRTdWNjZXNzKHsgY2hlY2tvdXRMb2NhbGl6YXRpb24gfSkge1xyXG4gICAgY29uc3QgY29udGFpbmVyUmVmID0gdXNlUmVmKCk7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGlmIChjb250YWluZXJSZWYuY3VycmVudCkge1xyXG4gICAgICAgICAgICBjb250YWluZXJSZWYuY3VycmVudC5zY3JvbGxJbnRvVmlldyh7IGJlaGF2aW9yOiAnc21vb3RoJywgYmxvY2s6ICdjZW50ZXInLCBpbmxpbmU6ICdjZW50ZXInIH0pO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDaGVja291dFN1Y2Nlc3NDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LXN1Y2Nlc3MtY29udGFpbmVyXCIsIHJlZjogY29udGFpbmVyUmVmIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRMb3R0aWUsIHsgYW5pbWF0aW9uRGF0YTogYW5pbWF0aW9uRGF0YSwgbG9vcDogZmFsc2UsIGF1dG9wbGF5OiB0cnVlIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2hlY2tvdXRTdWNjZXNzVGV4dCwgeyB2YXJpYW50OiBcImgxXCIsIGNvbG9yOiBcInByaW1hcnkubWFpblwiIH0sIGNoZWNrb3V0TG9jYWxpemF0aW9uLnN1bW1hcnkuY2hlY2tvdXRTdWNjZXNzVGV4dCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1DaGVja291dFN1Y2Nlc3MuanMubWFwIl19 */"));
|
|
11853
11899
|
|
|
11854
11900
|
var CheckoutSuccessText = /*#__PURE__*/_styled(Typography, {
|
|
11855
11901
|
target: "eeyi5d31",
|
|
@@ -11857,8 +11903,8 @@ var CheckoutSuccessText = /*#__PURE__*/_styled(Typography, {
|
|
|
11857
11903
|
})( {
|
|
11858
11904
|
name: "1kkk1zv",
|
|
11859
11905
|
styles: "@keyframes fadeIn{0%{opacity:0;}75%{opacity:0;}100%{opacity:1;}}align-self:center;animation:fadeIn 5s ease-in forwards",
|
|
11860
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
11861
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
11906
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0U3VjY2Vzcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0MrQyIsImZpbGUiOiJDaGVja291dFN1Y2Nlc3MudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgQm94IGZyb20gJ0BtdWkvbWF0ZXJpYWwvQm94JztcclxuaW1wb3J0IENvbG9yIGZyb20gJ2NvbG9yJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgTG90dGllIGZyb20gJ2xvdHRpZS1yZWFjdCc7XHJcbmltcG9ydCBhbmltYXRpb25EYXRhIGZyb20gJy4uLy4uLy4uL2Fzc2V0cy9sb3R0aWUvY2hlY2tvdXQtc3VjY2Vzcy5qc29uJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uLy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuZXhwb3J0IGNvbnN0IEFOSU1BVElPTl9EVVJBVElPTiA9IDUwMDA7XHJcbmNvbnN0IENoZWNrb3V0U3VjY2Vzc0NvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgQGtleWZyYW1lcyBibHVyRmFkZSB7XG4gICAgMCUge1xuICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiBDb2xvcih0aGVtZS5zdGlnZy5wYWxldHRlLmJhY2tncm91bmRQYXBlcikuYWxwaGEoMCkudG9TdHJpbmcoKX07XG4gICAgICBiYWNrZHJvcC1maWx0ZXI6IGJsdXIoMHB4KTtcbiAgICB9XG4gICAgMTAwJSB7XG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IENvbG9yKHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFBhcGVyKS5hbHBoYSgwLjkpLnRvU3RyaW5nKCl9O1xuICAgICAgYmFja2Ryb3AtZmlsdGVyOiBibHVyKDYuNXB4KTtcbiAgICB9XG4gIH1cblxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgYm90dG9tOiAwO1xuICByaWdodDogMDtcbiAgei1pbmRleDogNTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiBDb2xvcih0aGVtZS5zdGlnZy5wYWxldHRlLmJhY2tncm91bmRQYXBlcikuYWxwaGEoMC45KS50b1N0cmluZygpfTtcbiAgYW5pbWF0aW9uOiBibHVyRmFkZSAycyBlYXNlLWluIGZvcndhcmRzO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcblxuICAqIHJlY3Qge1xuICAgIGZpbGw6IHRyYW5zcGFyZW50O1xuICB9XG5cbiAgJiBwYXRoIHtcbiAgICBzdHJva2U6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5wcmltYXJ5fTtcbiAgfVxuYDtcclxuY29uc3QgQ2hlY2tvdXRTdWNjZXNzVGV4dCA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIEBrZXlmcmFtZXMgZmFkZUluIHtcbiAgICAwJSB7XG4gICAgICBvcGFjaXR5OiAwO1xuICAgIH1cbiAgICA3NSUge1xuICAgICAgb3BhY2l0eTogMDtcbiAgICB9XG4gICAgMTAwJSB7XG4gICAgICBvcGFjaXR5OiAxO1xuICAgIH1cbiAgfVxuXG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbiAgYW5pbWF0aW9uOiBmYWRlSW4gNXMgZWFzZS1pbiBmb3J3YXJkcztcbmA7XHJcbmNvbnN0IFN0eWxlZExvdHRpZSA9IHN0eWxlZChMb3R0aWUpIGBcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cbiAgc3ZnIHtcbiAgICB3aWR0aDogMzUwcHggIWltcG9ydGFudDtcbiAgICBoZWlnaHQ6IGF1dG8gIWltcG9ydGFudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIENoZWNrb3V0U3VjY2Vzcyh7IGNoZWNrb3V0TG9jYWxpemF0aW9uIH0pIHtcclxuICAgIGNvbnN0IGNvbnRhaW5lclJlZiA9IHVzZVJlZigpO1xyXG4gICAgdXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAoY29udGFpbmVyUmVmLmN1cnJlbnQpIHtcclxuICAgICAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQuc2Nyb2xsSW50b1ZpZXcoeyBiZWhhdmlvcjogJ3Ntb290aCcsIGJsb2NrOiAnY2VudGVyJywgaW5saW5lOiAnY2VudGVyJyB9KTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbXSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2hlY2tvdXRTdWNjZXNzQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1zdWNjZXNzLWNvbnRhaW5lclwiLCByZWY6IGNvbnRhaW5lclJlZiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTG90dGllLCB7IGFuaW1hdGlvbkRhdGE6IGFuaW1hdGlvbkRhdGEsIGxvb3A6IGZhbHNlLCBhdXRvcGxheTogdHJ1ZSB9KSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENoZWNrb3V0U3VjY2Vzc1RleHQsIHsgdmFyaWFudDogXCJoMVwiLCBjb2xvcjogXCJwcmltYXJ5Lm1haW5cIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LmNoZWNrb3V0U3VjY2Vzc1RleHQpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRTdWNjZXNzLmpzLm1hcCJdfQ== */",
|
|
11907
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$m
|
|
11862
11908
|
});
|
|
11863
11909
|
|
|
11864
11910
|
var StyledLottie = /*#__PURE__*/_styled(Lottie, {
|
|
@@ -11867,14 +11913,25 @@ var StyledLottie = /*#__PURE__*/_styled(Lottie, {
|
|
|
11867
11913
|
})( {
|
|
11868
11914
|
name: "1p4tykk",
|
|
11869
11915
|
styles: "display:flex;justify-content:center;svg{width:350px!important;height:auto!important;}",
|
|
11870
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
11871
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
11916
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0U3VjY2Vzcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBd0RvQyIsImZpbGUiOiJDaGVja291dFN1Y2Nlc3MudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgQm94IGZyb20gJ0BtdWkvbWF0ZXJpYWwvQm94JztcclxuaW1wb3J0IENvbG9yIGZyb20gJ2NvbG9yJztcclxuaW1wb3J0IFJlYWN0LCB7IHVzZUVmZmVjdCwgdXNlUmVmIH0gZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgTG90dGllIGZyb20gJ2xvdHRpZS1yZWFjdCc7XHJcbmltcG9ydCBhbmltYXRpb25EYXRhIGZyb20gJy4uLy4uLy4uL2Fzc2V0cy9sb3R0aWUvY2hlY2tvdXQtc3VjY2Vzcy5qc29uJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uLy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuZXhwb3J0IGNvbnN0IEFOSU1BVElPTl9EVVJBVElPTiA9IDUwMDA7XHJcbmNvbnN0IENoZWNrb3V0U3VjY2Vzc0NvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgQGtleWZyYW1lcyBibHVyRmFkZSB7XG4gICAgMCUge1xuICAgICAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiBDb2xvcih0aGVtZS5zdGlnZy5wYWxldHRlLmJhY2tncm91bmRQYXBlcikuYWxwaGEoMCkudG9TdHJpbmcoKX07XG4gICAgICBiYWNrZHJvcC1maWx0ZXI6IGJsdXIoMHB4KTtcbiAgICB9XG4gICAgMTAwJSB7XG4gICAgICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IENvbG9yKHRoZW1lLnN0aWdnLnBhbGV0dGUuYmFja2dyb3VuZFBhcGVyKS5hbHBoYSgwLjkpLnRvU3RyaW5nKCl9O1xuICAgICAgYmFja2Ryb3AtZmlsdGVyOiBibHVyKDYuNXB4KTtcbiAgICB9XG4gIH1cblxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgYm90dG9tOiAwO1xuICByaWdodDogMDtcbiAgei1pbmRleDogNTtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiBDb2xvcih0aGVtZS5zdGlnZy5wYWxldHRlLmJhY2tncm91bmRQYXBlcikuYWxwaGEoMC45KS50b1N0cmluZygpfTtcbiAgYW5pbWF0aW9uOiBibHVyRmFkZSAycyBlYXNlLWluIGZvcndhcmRzO1xuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBqdXN0aWZ5LWNvbnRlbnQ6IGNlbnRlcjtcblxuICAqIHJlY3Qge1xuICAgIGZpbGw6IHRyYW5zcGFyZW50O1xuICB9XG5cbiAgJiBwYXRoIHtcbiAgICBzdHJva2U6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5wcmltYXJ5fTtcbiAgfVxuYDtcclxuY29uc3QgQ2hlY2tvdXRTdWNjZXNzVGV4dCA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIEBrZXlmcmFtZXMgZmFkZUluIHtcbiAgICAwJSB7XG4gICAgICBvcGFjaXR5OiAwO1xuICAgIH1cbiAgICA3NSUge1xuICAgICAgb3BhY2l0eTogMDtcbiAgICB9XG4gICAgMTAwJSB7XG4gICAgICBvcGFjaXR5OiAxO1xuICAgIH1cbiAgfVxuXG4gIGFsaWduLXNlbGY6IGNlbnRlcjtcbiAgYW5pbWF0aW9uOiBmYWRlSW4gNXMgZWFzZS1pbiBmb3J3YXJkcztcbmA7XHJcbmNvbnN0IFN0eWxlZExvdHRpZSA9IHN0eWxlZChMb3R0aWUpIGBcbiAgZGlzcGxheTogZmxleDtcbiAganVzdGlmeS1jb250ZW50OiBjZW50ZXI7XG5cbiAgc3ZnIHtcbiAgICB3aWR0aDogMzUwcHggIWltcG9ydGFudDtcbiAgICBoZWlnaHQ6IGF1dG8gIWltcG9ydGFudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIENoZWNrb3V0U3VjY2Vzcyh7IGNoZWNrb3V0TG9jYWxpemF0aW9uIH0pIHtcclxuICAgIGNvbnN0IGNvbnRhaW5lclJlZiA9IHVzZVJlZigpO1xyXG4gICAgdXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAoY29udGFpbmVyUmVmLmN1cnJlbnQpIHtcclxuICAgICAgICAgICAgY29udGFpbmVyUmVmLmN1cnJlbnQuc2Nyb2xsSW50b1ZpZXcoeyBiZWhhdmlvcjogJ3Ntb290aCcsIGJsb2NrOiAnY2VudGVyJywgaW5saW5lOiAnY2VudGVyJyB9KTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbXSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ2hlY2tvdXRTdWNjZXNzQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1zdWNjZXNzLWNvbnRhaW5lclwiLCByZWY6IGNvbnRhaW5lclJlZiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTG90dGllLCB7IGFuaW1hdGlvbkRhdGE6IGFuaW1hdGlvbkRhdGEsIGxvb3A6IGZhbHNlLCBhdXRvcGxheTogdHJ1ZSB9KSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KENoZWNrb3V0U3VjY2Vzc1RleHQsIHsgdmFyaWFudDogXCJoMVwiLCBjb2xvcjogXCJwcmltYXJ5Lm1haW5cIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LmNoZWNrb3V0U3VjY2Vzc1RleHQpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRTdWNjZXNzLmpzLm1hcCJdfQ== */",
|
|
11917
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$m
|
|
11872
11918
|
});
|
|
11873
11919
|
|
|
11874
11920
|
function CheckoutSuccess(_ref5) {
|
|
11875
11921
|
var checkoutLocalization = _ref5.checkoutLocalization;
|
|
11922
|
+
var containerRef = React.useRef();
|
|
11923
|
+
React.useEffect(function () {
|
|
11924
|
+
if (containerRef.current) {
|
|
11925
|
+
containerRef.current.scrollIntoView({
|
|
11926
|
+
behavior: 'smooth',
|
|
11927
|
+
block: 'center',
|
|
11928
|
+
inline: 'center'
|
|
11929
|
+
});
|
|
11930
|
+
}
|
|
11931
|
+
}, []);
|
|
11876
11932
|
return React__default.createElement(CheckoutSuccessContainer, {
|
|
11877
|
-
className: "stigg-checkout-success-container"
|
|
11933
|
+
className: "stigg-checkout-success-container",
|
|
11934
|
+
ref: containerRef
|
|
11878
11935
|
}, React__default.createElement(StyledLottie, {
|
|
11879
11936
|
animationData: animationData,
|
|
11880
11937
|
loop: false,
|
|
@@ -12401,15 +12458,15 @@ var CollapsableSectionIcon = /*#__PURE__*/styled$1__default(reactFeather.Chevron
|
|
|
12401
12458
|
return $isOpen && "transform: rotate(90deg)";
|
|
12402
12459
|
});
|
|
12403
12460
|
|
|
12404
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
12461
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$n() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
12405
12462
|
var LineItemContainer = /*#__PURE__*/_styled("div", {
|
|
12406
12463
|
target: "e1ultpe62",
|
|
12407
12464
|
label: "LineItemContainer"
|
|
12408
12465
|
})( {
|
|
12409
12466
|
name: "x9km8e",
|
|
12410
12467
|
styles: "&+&{margin-top:16px;}",
|
|
12411
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAmB4C","file":"LineItems.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, TiersMode, } from '@stigg/js-client-sdk';\r\nimport isEmpty from 'lodash/isEmpty';\r\nimport isNil from 'lodash/isNil';\r\nimport Link from '@mui/material/Link';\r\nimport { IconButton } from '@mui/material';\r\nimport Collapse from '@mui/material/Collapse';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nimport { getPriceBreakdownString } from './getPriceBreakdownString';\r\nimport { GraduatedPriceBreakdown } from './GraduatedPriceBreakdown';\r\nimport { CollapsableSectionIcon } from '../../../common/CollapsableSectionIcon';\r\nimport { calculateTierPrice } from '../../../utils/priceTierUtils';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 16px;\n  }\n`;\r\nexport const NestedBreakdownContainer = styled.div `\n  margin-top: 16px;\n  margin-left: 16px;\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  gap: 16px;\n`;\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const [isNestedBreakdownOpen, setIsNestedBreakdownOpen] = useState(false);\r\n    const toggleNestedBreakdown = () => setIsNestedBreakdownOpen((prev) => !prev);\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    const totalAmount = price.isTieredPrice\r\n        ? calculateTierPrice(price, quantity)\r\n        : (price.amount || 0) * Math.ceil(quantity / (price.blockSize || 1));\r\n    let nestedBreakdown;\r\n    const shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated &&\r\n        !!price.tiers &&\r\n        !isEmpty(price.tiers) &&\r\n        !isNil(price.tiers[0].upTo) &&\r\n        quantity > price.tiers[0].upTo;\r\n    if (shouldShowGraduatedPriceBreakdown) {\r\n        nestedBreakdown = React.createElement(GraduatedPriceBreakdown, { price: price, unitQuantity: quantity });\r\n    }\r\n    let title = (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label));\r\n    if (nestedBreakdown) {\r\n        title = (React.createElement(Link, { onClick: toggleNestedBreakdown, underline: \"none\", style: { cursor: 'pointer' } }, title));\r\n    }\r\n    return (React.createElement(LineItemContainer, { className: \"stigg-checkout-summary-base-charges-container\" },\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 0.5, style: { whiteSpace: 'nowrap' } },\r\n                title,\r\n                nestedBreakdown && (React.createElement(IconButton, { onClick: toggleNestedBreakdown, sx: { padding: 0 } },\r\n                    React.createElement(CollapsableSectionIcon, { \"$isOpen\": isNestedBreakdownOpen, \"$size\": 16 })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { whiteSpace: 'nowrap' } },\r\n                    getPriceBreakdownString({\r\n                        totalAmount,\r\n                        quantity,\r\n                        currency: price.currency,\r\n                        pricingModel: price.pricingModel,\r\n                        billingPeriod: price.billingPeriod,\r\n                        tiers: price.tiers,\r\n                        tiersMode: price.tiersMode,\r\n                        blockSize: price.blockSize,\r\n                        priceAmount: price.amount,\r\n                    }),\r\n                    isPayAsYouGo && ' / unit'))),\r\n        nestedBreakdown && (React.createElement(Collapse, { in: isNestedBreakdownOpen },\r\n            React.createElement(NestedBreakdownContainer, null, nestedBreakdown)))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\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: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\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\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\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\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\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\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
|
|
12412
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
12468
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAqB4C","file":"LineItems.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, TiersMode, } from '@stigg/js-client-sdk';\r\nimport isEmpty from 'lodash/isEmpty';\r\nimport isNil from 'lodash/isNil';\r\nimport Link from '@mui/material/Link';\r\nimport { IconButton } from '@mui/material';\r\nimport Collapse from '@mui/material/Collapse';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nimport { getPriceBreakdownString } from './getPriceBreakdownString';\r\nimport { GraduatedPriceBreakdown } from './GraduatedPriceBreakdown';\r\nimport { CollapsableSectionIcon } from '../../../common/CollapsableSectionIcon';\r\nimport { calculateTierPrice } from '../../../utils/priceTierUtils';\r\nimport { useIsScreenWiderThan } from '../../../hooks/useIsScreenWiderThan';\r\nimport { mq } from '../../../common/mediaQuery';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 16px;\n  }\n`;\r\nexport const NestedBreakdownContainer = styled.div `\n  margin-top: 16px;\n  margin-left: 16px;\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  flex-direction: column;\n  gap: 16px;\n\n  ${mq.lg} {\n    flex-direction: row;\n    align-items: center;\n    justify-content: space-between;\n  }\n`;\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const isScreenWiderThanLg = useIsScreenWiderThan('lg');\r\n    const [isNestedBreakdownOpen, setIsNestedBreakdownOpen] = useState(false);\r\n    const toggleNestedBreakdown = () => setIsNestedBreakdownOpen((prev) => !prev);\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    const totalAmount = price.isTieredPrice\r\n        ? calculateTierPrice(price, quantity)\r\n        : (price.amount || 0) * Math.ceil(quantity / (price.blockSize || 1));\r\n    let nestedBreakdown;\r\n    const shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated &&\r\n        !!price.tiers &&\r\n        !isEmpty(price.tiers) &&\r\n        !isNil(price.tiers[0].upTo) &&\r\n        quantity > price.tiers[0].upTo;\r\n    if (shouldShowGraduatedPriceBreakdown) {\r\n        nestedBreakdown = React.createElement(GraduatedPriceBreakdown, { price: price, unitQuantity: quantity });\r\n    }\r\n    let title = (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label));\r\n    if (nestedBreakdown) {\r\n        title = (React.createElement(Link, { onClick: toggleNestedBreakdown, underline: \"none\", style: { cursor: 'pointer' } }, title));\r\n    }\r\n    return (React.createElement(LineItemContainer, { className: \"stigg-checkout-summary-base-charges-container\" },\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 0.5, style: { whiteSpace: isScreenWiderThanLg ? 'nowrap' : 'break-spaces' } },\r\n                title,\r\n                nestedBreakdown && (React.createElement(IconButton, { onClick: toggleNestedBreakdown, sx: { padding: 0 } },\r\n                    React.createElement(CollapsableSectionIcon, { \"$isOpen\": isNestedBreakdownOpen, \"$size\": 16 })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { whiteSpace: isScreenWiderThanLg ? 'nowrap' : 'break-spaces' } },\r\n                    getPriceBreakdownString({\r\n                        totalAmount,\r\n                        quantity,\r\n                        currency: price.currency,\r\n                        pricingModel: price.pricingModel,\r\n                        billingPeriod: price.billingPeriod,\r\n                        tiers: price.tiers,\r\n                        tiersMode: price.tiersMode,\r\n                        blockSize: price.blockSize,\r\n                        priceAmount: price.amount,\r\n                    }),\r\n                    isPayAsYouGo && ' / unit'))),\r\n        nestedBreakdown && (React.createElement(Collapse, { in: isNestedBreakdownOpen },\r\n            React.createElement(NestedBreakdownContainer, null, nestedBreakdown)))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\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: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\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\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\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\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\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\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
|
|
12469
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
|
|
12413
12470
|
});
|
|
12414
12471
|
var NestedBreakdownContainer = /*#__PURE__*/_styled("div", {
|
|
12415
12472
|
target: "e1ultpe61",
|
|
@@ -12417,18 +12474,13 @@ var NestedBreakdownContainer = /*#__PURE__*/_styled("div", {
|
|
|
12417
12474
|
})( {
|
|
12418
12475
|
name: "96yaa5",
|
|
12419
12476
|
styles: "margin-top:16px;margin-left:16px",
|
|
12420
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAwBmD","file":"LineItems.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, TiersMode, } from '@stigg/js-client-sdk';\r\nimport isEmpty from 'lodash/isEmpty';\r\nimport isNil from 'lodash/isNil';\r\nimport Link from '@mui/material/Link';\r\nimport { IconButton } from '@mui/material';\r\nimport Collapse from '@mui/material/Collapse';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nimport { getPriceBreakdownString } from './getPriceBreakdownString';\r\nimport { GraduatedPriceBreakdown } from './GraduatedPriceBreakdown';\r\nimport { CollapsableSectionIcon } from '../../../common/CollapsableSectionIcon';\r\nimport { calculateTierPrice } from '../../../utils/priceTierUtils';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 16px;\n  }\n`;\r\nexport const NestedBreakdownContainer = styled.div `\n  margin-top: 16px;\n  margin-left: 16px;\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  gap: 16px;\n`;\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const [isNestedBreakdownOpen, setIsNestedBreakdownOpen] = useState(false);\r\n    const toggleNestedBreakdown = () => setIsNestedBreakdownOpen((prev) => !prev);\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    const totalAmount = price.isTieredPrice\r\n        ? calculateTierPrice(price, quantity)\r\n        : (price.amount || 0) * Math.ceil(quantity / (price.blockSize || 1));\r\n    let nestedBreakdown;\r\n    const shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated &&\r\n        !!price.tiers &&\r\n        !isEmpty(price.tiers) &&\r\n        !isNil(price.tiers[0].upTo) &&\r\n        quantity > price.tiers[0].upTo;\r\n    if (shouldShowGraduatedPriceBreakdown) {\r\n        nestedBreakdown = React.createElement(GraduatedPriceBreakdown, { price: price, unitQuantity: quantity });\r\n    }\r\n    let title = (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label));\r\n    if (nestedBreakdown) {\r\n        title = (React.createElement(Link, { onClick: toggleNestedBreakdown, underline: \"none\", style: { cursor: 'pointer' } }, title));\r\n    }\r\n    return (React.createElement(LineItemContainer, { className: \"stigg-checkout-summary-base-charges-container\" },\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 0.5, style: { whiteSpace: 'nowrap' } },\r\n                title,\r\n                nestedBreakdown && (React.createElement(IconButton, { onClick: toggleNestedBreakdown, sx: { padding: 0 } },\r\n                    React.createElement(CollapsableSectionIcon, { \"$isOpen\": isNestedBreakdownOpen, \"$size\": 16 })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { whiteSpace: 'nowrap' } },\r\n                    getPriceBreakdownString({\r\n                        totalAmount,\r\n                        quantity,\r\n                        currency: price.currency,\r\n                        pricingModel: price.pricingModel,\r\n                        billingPeriod: price.billingPeriod,\r\n                        tiers: price.tiers,\r\n                        tiersMode: price.tiersMode,\r\n                        blockSize: price.blockSize,\r\n                        priceAmount: price.amount,\r\n                    }),\r\n                    isPayAsYouGo && ' / unit'))),\r\n        nestedBreakdown && (React.createElement(Collapse, { in: isNestedBreakdownOpen },\r\n            React.createElement(NestedBreakdownContainer, null, nestedBreakdown)))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\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: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\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\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\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\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\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\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
|
|
12421
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
12477
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AA0BmD","file":"LineItems.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, TiersMode, } from '@stigg/js-client-sdk';\r\nimport isEmpty from 'lodash/isEmpty';\r\nimport isNil from 'lodash/isNil';\r\nimport Link from '@mui/material/Link';\r\nimport { IconButton } from '@mui/material';\r\nimport Collapse from '@mui/material/Collapse';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nimport { getPriceBreakdownString } from './getPriceBreakdownString';\r\nimport { GraduatedPriceBreakdown } from './GraduatedPriceBreakdown';\r\nimport { CollapsableSectionIcon } from '../../../common/CollapsableSectionIcon';\r\nimport { calculateTierPrice } from '../../../utils/priceTierUtils';\r\nimport { useIsScreenWiderThan } from '../../../hooks/useIsScreenWiderThan';\r\nimport { mq } from '../../../common/mediaQuery';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 16px;\n  }\n`;\r\nexport const NestedBreakdownContainer = styled.div `\n  margin-top: 16px;\n  margin-left: 16px;\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  flex-direction: column;\n  gap: 16px;\n\n  ${mq.lg} {\n    flex-direction: row;\n    align-items: center;\n    justify-content: space-between;\n  }\n`;\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const isScreenWiderThanLg = useIsScreenWiderThan('lg');\r\n    const [isNestedBreakdownOpen, setIsNestedBreakdownOpen] = useState(false);\r\n    const toggleNestedBreakdown = () => setIsNestedBreakdownOpen((prev) => !prev);\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    const totalAmount = price.isTieredPrice\r\n        ? calculateTierPrice(price, quantity)\r\n        : (price.amount || 0) * Math.ceil(quantity / (price.blockSize || 1));\r\n    let nestedBreakdown;\r\n    const shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated &&\r\n        !!price.tiers &&\r\n        !isEmpty(price.tiers) &&\r\n        !isNil(price.tiers[0].upTo) &&\r\n        quantity > price.tiers[0].upTo;\r\n    if (shouldShowGraduatedPriceBreakdown) {\r\n        nestedBreakdown = React.createElement(GraduatedPriceBreakdown, { price: price, unitQuantity: quantity });\r\n    }\r\n    let title = (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label));\r\n    if (nestedBreakdown) {\r\n        title = (React.createElement(Link, { onClick: toggleNestedBreakdown, underline: \"none\", style: { cursor: 'pointer' } }, title));\r\n    }\r\n    return (React.createElement(LineItemContainer, { className: \"stigg-checkout-summary-base-charges-container\" },\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 0.5, style: { whiteSpace: isScreenWiderThanLg ? 'nowrap' : 'break-spaces' } },\r\n                title,\r\n                nestedBreakdown && (React.createElement(IconButton, { onClick: toggleNestedBreakdown, sx: { padding: 0 } },\r\n                    React.createElement(CollapsableSectionIcon, { \"$isOpen\": isNestedBreakdownOpen, \"$size\": 16 })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { whiteSpace: isScreenWiderThanLg ? 'nowrap' : 'break-spaces' } },\r\n                    getPriceBreakdownString({\r\n                        totalAmount,\r\n                        quantity,\r\n                        currency: price.currency,\r\n                        pricingModel: price.pricingModel,\r\n                        billingPeriod: price.billingPeriod,\r\n                        tiers: price.tiers,\r\n                        tiersMode: price.tiersMode,\r\n                        blockSize: price.blockSize,\r\n                        priceAmount: price.amount,\r\n                    }),\r\n                    isPayAsYouGo && ' / unit'))),\r\n        nestedBreakdown && (React.createElement(Collapse, { in: isNestedBreakdownOpen },\r\n            React.createElement(NestedBreakdownContainer, null, nestedBreakdown)))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\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: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\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\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\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\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\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\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
|
|
12478
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
|
|
12422
12479
|
});
|
|
12423
12480
|
var LineItemRow = /*#__PURE__*/_styled("div", {
|
|
12424
12481
|
target: "e1ultpe60",
|
|
12425
12482
|
label: "LineItemRow"
|
|
12426
|
-
})( {
|
|
12427
|
-
name: "153q11y",
|
|
12428
|
-
styles: "display:flex;align-items:center;justify-content:space-between;gap:16px",
|
|
12429
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AA4BsC","file":"LineItems.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, TiersMode, } from '@stigg/js-client-sdk';\r\nimport isEmpty from 'lodash/isEmpty';\r\nimport isNil from 'lodash/isNil';\r\nimport Link from '@mui/material/Link';\r\nimport { IconButton } from '@mui/material';\r\nimport Collapse from '@mui/material/Collapse';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nimport { getPriceBreakdownString } from './getPriceBreakdownString';\r\nimport { GraduatedPriceBreakdown } from './GraduatedPriceBreakdown';\r\nimport { CollapsableSectionIcon } from '../../../common/CollapsableSectionIcon';\r\nimport { calculateTierPrice } from '../../../utils/priceTierUtils';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 16px;\n  }\n`;\r\nexport const NestedBreakdownContainer = styled.div `\n  margin-top: 16px;\n  margin-left: 16px;\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  gap: 16px;\n`;\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const [isNestedBreakdownOpen, setIsNestedBreakdownOpen] = useState(false);\r\n    const toggleNestedBreakdown = () => setIsNestedBreakdownOpen((prev) => !prev);\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    const totalAmount = price.isTieredPrice\r\n        ? calculateTierPrice(price, quantity)\r\n        : (price.amount || 0) * Math.ceil(quantity / (price.blockSize || 1));\r\n    let nestedBreakdown;\r\n    const shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated &&\r\n        !!price.tiers &&\r\n        !isEmpty(price.tiers) &&\r\n        !isNil(price.tiers[0].upTo) &&\r\n        quantity > price.tiers[0].upTo;\r\n    if (shouldShowGraduatedPriceBreakdown) {\r\n        nestedBreakdown = React.createElement(GraduatedPriceBreakdown, { price: price, unitQuantity: quantity });\r\n    }\r\n    let title = (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label));\r\n    if (nestedBreakdown) {\r\n        title = (React.createElement(Link, { onClick: toggleNestedBreakdown, underline: \"none\", style: { cursor: 'pointer' } }, title));\r\n    }\r\n    return (React.createElement(LineItemContainer, { className: \"stigg-checkout-summary-base-charges-container\" },\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 0.5, style: { whiteSpace: 'nowrap' } },\r\n                title,\r\n                nestedBreakdown && (React.createElement(IconButton, { onClick: toggleNestedBreakdown, sx: { padding: 0 } },\r\n                    React.createElement(CollapsableSectionIcon, { \"$isOpen\": isNestedBreakdownOpen, \"$size\": 16 })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { whiteSpace: 'nowrap' } },\r\n                    getPriceBreakdownString({\r\n                        totalAmount,\r\n                        quantity,\r\n                        currency: price.currency,\r\n                        pricingModel: price.pricingModel,\r\n                        billingPeriod: price.billingPeriod,\r\n                        tiers: price.tiers,\r\n                        tiersMode: price.tiersMode,\r\n                        blockSize: price.blockSize,\r\n                        priceAmount: price.amount,\r\n                    }),\r\n                    isPayAsYouGo && ' / unit'))),\r\n        nestedBreakdown && (React.createElement(Collapse, { in: isNestedBreakdownOpen },\r\n            React.createElement(NestedBreakdownContainer, null, nestedBreakdown)))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\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: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\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\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\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\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\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\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
|
|
12430
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12431
|
-
});
|
|
12483
|
+
})("display:flex;flex-direction:column;gap:16px;", mq.lg, "{flex-direction:row;align-items:center;justify-content:space-between;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AA8BsC","file":"LineItems.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, TiersMode, } from '@stigg/js-client-sdk';\r\nimport isEmpty from 'lodash/isEmpty';\r\nimport isNil from 'lodash/isNil';\r\nimport Link from '@mui/material/Link';\r\nimport { IconButton } from '@mui/material';\r\nimport Collapse from '@mui/material/Collapse';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nimport { getPriceBreakdownString } from './getPriceBreakdownString';\r\nimport { GraduatedPriceBreakdown } from './GraduatedPriceBreakdown';\r\nimport { CollapsableSectionIcon } from '../../../common/CollapsableSectionIcon';\r\nimport { calculateTierPrice } from '../../../utils/priceTierUtils';\r\nimport { useIsScreenWiderThan } from '../../../hooks/useIsScreenWiderThan';\r\nimport { mq } from '../../../common/mediaQuery';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 16px;\n  }\n`;\r\nexport const NestedBreakdownContainer = styled.div `\n  margin-top: 16px;\n  margin-left: 16px;\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  flex-direction: column;\n  gap: 16px;\n\n  ${mq.lg} {\n    flex-direction: row;\n    align-items: center;\n    justify-content: space-between;\n  }\n`;\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const isScreenWiderThanLg = useIsScreenWiderThan('lg');\r\n    const [isNestedBreakdownOpen, setIsNestedBreakdownOpen] = useState(false);\r\n    const toggleNestedBreakdown = () => setIsNestedBreakdownOpen((prev) => !prev);\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    const totalAmount = price.isTieredPrice\r\n        ? calculateTierPrice(price, quantity)\r\n        : (price.amount || 0) * Math.ceil(quantity / (price.blockSize || 1));\r\n    let nestedBreakdown;\r\n    const shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated &&\r\n        !!price.tiers &&\r\n        !isEmpty(price.tiers) &&\r\n        !isNil(price.tiers[0].upTo) &&\r\n        quantity > price.tiers[0].upTo;\r\n    if (shouldShowGraduatedPriceBreakdown) {\r\n        nestedBreakdown = React.createElement(GraduatedPriceBreakdown, { price: price, unitQuantity: quantity });\r\n    }\r\n    let title = (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label));\r\n    if (nestedBreakdown) {\r\n        title = (React.createElement(Link, { onClick: toggleNestedBreakdown, underline: \"none\", style: { cursor: 'pointer' } }, title));\r\n    }\r\n    return (React.createElement(LineItemContainer, { className: \"stigg-checkout-summary-base-charges-container\" },\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 0.5, style: { whiteSpace: isScreenWiderThanLg ? 'nowrap' : 'break-spaces' } },\r\n                title,\r\n                nestedBreakdown && (React.createElement(IconButton, { onClick: toggleNestedBreakdown, sx: { padding: 0 } },\r\n                    React.createElement(CollapsableSectionIcon, { \"$isOpen\": isNestedBreakdownOpen, \"$size\": 16 })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { whiteSpace: isScreenWiderThanLg ? 'nowrap' : 'break-spaces' } },\r\n                    getPriceBreakdownString({\r\n                        totalAmount,\r\n                        quantity,\r\n                        currency: price.currency,\r\n                        pricingModel: price.pricingModel,\r\n                        billingPeriod: price.billingPeriod,\r\n                        tiers: price.tiers,\r\n                        tiersMode: price.tiersMode,\r\n                        blockSize: price.blockSize,\r\n                        priceAmount: price.amount,\r\n                    }),\r\n                    isPayAsYouGo && ' / unit'))),\r\n        nestedBreakdown && (React.createElement(Collapse, { in: isNestedBreakdownOpen },\r\n            React.createElement(NestedBreakdownContainer, null, nestedBreakdown)))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\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: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\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\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\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\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\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\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */"));
|
|
12432
12484
|
|
|
12433
12485
|
var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref) {
|
|
12434
12486
|
var checkoutLocalization = _ref.checkoutLocalization;
|
|
@@ -12451,6 +12503,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
|
|
|
12451
12503
|
label = _ref2.label,
|
|
12452
12504
|
quantity = _ref2.quantity,
|
|
12453
12505
|
price = _ref2.price;
|
|
12506
|
+
var isScreenWiderThanLg = useIsScreenWiderThan('lg');
|
|
12454
12507
|
|
|
12455
12508
|
var _useState = React.useState(false),
|
|
12456
12509
|
isNestedBreakdownOpen = _useState[0],
|
|
@@ -12500,7 +12553,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
|
|
|
12500
12553
|
display: "flex",
|
|
12501
12554
|
gap: 0.5,
|
|
12502
12555
|
style: {
|
|
12503
|
-
whiteSpace: 'nowrap'
|
|
12556
|
+
whiteSpace: isScreenWiderThanLg ? 'nowrap' : 'break-spaces'
|
|
12504
12557
|
}
|
|
12505
12558
|
}, title, nestedBreakdown && React__default.createElement(material.IconButton, {
|
|
12506
12559
|
onClick: toggleNestedBreakdown,
|
|
@@ -12521,7 +12574,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
|
|
|
12521
12574
|
variant: "body1",
|
|
12522
12575
|
color: "secondary",
|
|
12523
12576
|
style: {
|
|
12524
|
-
whiteSpace: 'nowrap'
|
|
12577
|
+
whiteSpace: isScreenWiderThanLg ? 'nowrap' : 'break-spaces'
|
|
12525
12578
|
}
|
|
12526
12579
|
}, getPriceBreakdownString({
|
|
12527
12580
|
totalAmount: totalAmount,
|
|
@@ -12650,23 +12703,23 @@ var TaxLineItem = function TaxLineItem(_ref9) {
|
|
|
12650
12703
|
})))));
|
|
12651
12704
|
};
|
|
12652
12705
|
|
|
12653
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
12706
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$o() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
12654
12707
|
var SummaryContainer = /*#__PURE__*/_styled(Box, {
|
|
12655
12708
|
target: "e9ji7bp4",
|
|
12656
12709
|
label: "SummaryContainer"
|
|
12657
12710
|
})( {
|
|
12658
|
-
name: "
|
|
12659
|
-
styles: "max-width:470px;flex:1.5",
|
|
12660
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAuB4C","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const 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 SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12661
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
12711
|
+
name: "1w9aiz5",
|
|
12712
|
+
styles: "width:100%;max-width:470px;flex:1.5",
|
|
12713
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAwB4C","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12714
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12662
12715
|
});
|
|
12663
12716
|
var SummaryCard = /*#__PURE__*/_styled(Paper, {
|
|
12664
12717
|
target: "e9ji7bp3",
|
|
12665
12718
|
label: "SummaryCard"
|
|
12666
|
-
})("
|
|
12719
|
+
})("background:", function (_ref) {
|
|
12667
12720
|
var theme = _ref.theme;
|
|
12668
12721
|
return theme.stigg.palette.backgroundHighlight;
|
|
12669
|
-
}, ";padding:16px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA2ByC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const 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 SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */"));
|
|
12722
|
+
}, ";padding:16px;", mq.md, "{border-radius:10px;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA6ByC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */"));
|
|
12670
12723
|
SummaryCard.defaultProps = {
|
|
12671
12724
|
elevation: 0
|
|
12672
12725
|
};
|
|
@@ -12677,8 +12730,8 @@ var SummaryTitle = /*#__PURE__*/_styled(Typography, {
|
|
|
12677
12730
|
})( {
|
|
12678
12731
|
name: "1jcocwa",
|
|
12679
12732
|
styles: "margin-bottom:16px;font-weight:500",
|
|
12680
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAmCwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const 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 SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12681
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
12733
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAwCwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12734
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12682
12735
|
});
|
|
12683
12736
|
|
|
12684
12737
|
var StyledDivider$1 = /*#__PURE__*/_styled(Divider$1, {
|
|
@@ -12687,8 +12740,8 @@ var StyledDivider$1 = /*#__PURE__*/_styled(Divider$1, {
|
|
|
12687
12740
|
})( {
|
|
12688
12741
|
name: "1k6141t",
|
|
12689
12742
|
styles: "margin:16px 0",
|
|
12690
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAuCsC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const 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 SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12691
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
12743
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA4CsC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12744
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12692
12745
|
});
|
|
12693
12746
|
|
|
12694
12747
|
var TotalDueText = /*#__PURE__*/_styled(Typography, {
|
|
@@ -12697,8 +12750,8 @@ var TotalDueText = /*#__PURE__*/_styled(Typography, {
|
|
|
12697
12750
|
})( {
|
|
12698
12751
|
name: "5bhc30",
|
|
12699
12752
|
styles: "margin-bottom:8px",
|
|
12700
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA0CwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const 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 SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12701
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
12753
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA+CwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport Box from '@mui/material/Box';\r\nimport CircularProgress from '@mui/material/CircularProgress';\r\nimport Divider from '@mui/material/Divider';\r\nimport Grid from '@mui/material/Grid';\r\nimport Paper from '@mui/material/Paper';\r\nimport { BillingModel } 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 { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nimport { mq } from '../../common/mediaQuery';\r\nexport const SummaryContainer = styled(Box) `\n  width: 100%;\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n\n  ${mq.md} {\n    border-radius: 10px;\n  }\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\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 isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        isMocked: !!onMockCheckoutPreview,\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = 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    };\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice?.discountDetails && !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { className: \"stigg-checkout-summary-plan-title-container\", display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            React.createElement(Grid, { item: true, className: \"stigg-checkout-summary-usage-charges-container\" }, usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), 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: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\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                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: recurringInvoice?.tax, taxDetails: recurringInvoice?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...recurringInvoice?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            immediateInvoice?.proration?.hasProrations &&\r\n                immediateInvoice?.subTotal &&\r\n                immediateInvoice?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...immediateInvoice?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12754
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12702
12755
|
});
|
|
12703
12756
|
|
|
12704
12757
|
function resolveCheckoutButtonText(_ref2) {
|
|
@@ -13173,33 +13226,28 @@ var CheckoutSummarySkeleton = function CheckoutSummarySkeleton() {
|
|
|
13173
13226
|
}));
|
|
13174
13227
|
};
|
|
13175
13228
|
|
|
13176
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
13229
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$p() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
13177
13230
|
var CheckoutAddonsContainer = /*#__PURE__*/_styled(Grid, {
|
|
13178
13231
|
target: "e1o28dc92",
|
|
13179
13232
|
label: "CheckoutAddonsContainer"
|
|
13180
13233
|
})( {
|
|
13181
13234
|
name: "1wte80x",
|
|
13182
13235
|
styles: "width:100%;gap:8px",
|
|
13183
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13184
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
13236
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0QWRkb25zU3RlcC5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBSW9EIiwiZmlsZSI6IkNoZWNrb3V0QWRkb25zU3RlcC5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBHcmlkIGZyb20gJ0BtdWkvbWF0ZXJpYWwvR3JpZCc7XHJcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBtcSB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9tZWRpYVF1ZXJ5JztcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0QWRkb25zQ29udGFpbmVyID0gc3R5bGVkKEdyaWQpIGBcbiAgd2lkdGg6IDEwMCU7XG4gIGdhcDogOHB4O1xuYDtcclxuZXhwb3J0IGNvbnN0IEFkZG9uTGlzdEl0ZW1Db250YWluZXIgPSBzdHlsZWQoR3JpZCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDE2cHg7XG5cbiAgJHttcS5tZH0ge1xuICAgIGdhcDogMDtcbiAgICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICBoZWlnaHQ6IDgwcHg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IFRyYXNoQnV0dG9uID0gc3R5bGVkKEJ1dHRvbikgYFxuICBtaW4td2lkdGg6IHVuc2V0O1xuICB3aWR0aDogNDFweDtcbiAgaGVpZ2h0OiA0MXB4O1xuICBwYWRkaW5nOiAwO1xuYDtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRBZGRvbnNTdGVwLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
13237
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$p
|
|
13185
13238
|
});
|
|
13186
13239
|
var AddonListItemContainer = /*#__PURE__*/_styled(Grid, {
|
|
13187
13240
|
target: "e1o28dc91",
|
|
13188
13241
|
label: "AddonListItemContainer"
|
|
13189
|
-
})( {
|
|
13190
|
-
name: "a3p0fn",
|
|
13191
|
-
styles: "display:flex;justify-content:space-between;align-items:center;height:80px",
|
|
13192
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0QWRkb25zU3RlcC5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT21EIiwiZmlsZSI6IkNoZWNrb3V0QWRkb25zU3RlcC5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBHcmlkIGZyb20gJ0BtdWkvbWF0ZXJpYWwvR3JpZCc7XHJcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMnO1xyXG5leHBvcnQgY29uc3QgQ2hlY2tvdXRBZGRvbnNDb250YWluZXIgPSBzdHlsZWQoR3JpZCkgYFxuICB3aWR0aDogMTAwJTtcbiAgZ2FwOiA4cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgQWRkb25MaXN0SXRlbUNvbnRhaW5lciA9IHN0eWxlZChHcmlkKSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgaGVpZ2h0OiA4MHB4O1xuYDtcclxuZXhwb3J0IGNvbnN0IFRyYXNoQnV0dG9uID0gc3R5bGVkKEJ1dHRvbikgYFxuICBtaW4td2lkdGg6IHVuc2V0O1xuICB3aWR0aDogNDFweDtcbiAgaGVpZ2h0OiA0MXB4O1xuICBwYWRkaW5nOiAwO1xuYDtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRBZGRvbnNTdGVwLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
13193
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$q
|
|
13194
|
-
});
|
|
13242
|
+
})("display:flex;flex-direction:column;gap:16px;", mq.md, "{gap:0;flex-direction:row;justify-content:space-between;height:80px;align-items:center;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0QWRkb25zU3RlcC5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUW1EIiwiZmlsZSI6IkNoZWNrb3V0QWRkb25zU3RlcC5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBHcmlkIGZyb20gJ0BtdWkvbWF0ZXJpYWwvR3JpZCc7XHJcbmltcG9ydCB7IEJ1dHRvbiB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyBtcSB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9tZWRpYVF1ZXJ5JztcclxuZXhwb3J0IGNvbnN0IENoZWNrb3V0QWRkb25zQ29udGFpbmVyID0gc3R5bGVkKEdyaWQpIGBcbiAgd2lkdGg6IDEwMCU7XG4gIGdhcDogOHB4O1xuYDtcclxuZXhwb3J0IGNvbnN0IEFkZG9uTGlzdEl0ZW1Db250YWluZXIgPSBzdHlsZWQoR3JpZCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBmbGV4LWRpcmVjdGlvbjogY29sdW1uO1xuICBnYXA6IDE2cHg7XG5cbiAgJHttcS5tZH0ge1xuICAgIGdhcDogMDtcbiAgICBmbGV4LWRpcmVjdGlvbjogcm93O1xuICAgIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbiAgICBoZWlnaHQ6IDgwcHg7XG4gICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IFRyYXNoQnV0dG9uID0gc3R5bGVkKEJ1dHRvbikgYFxuICBtaW4td2lkdGg6IHVuc2V0O1xuICB3aWR0aDogNDFweDtcbiAgaGVpZ2h0OiA0MXB4O1xuICBwYWRkaW5nOiAwO1xuYDtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRBZGRvbnNTdGVwLnN0eWxlLmpzLm1hcCJdfQ== */"));
|
|
13195
13243
|
var TrashButton = /*#__PURE__*/_styled(Button, {
|
|
13196
13244
|
target: "e1o28dc90",
|
|
13197
13245
|
label: "TrashButton"
|
|
13198
13246
|
})( {
|
|
13199
13247
|
name: "156064h",
|
|
13200
13248
|
styles: "min-width:unset;width:41px;height:41px;padding:0",
|
|
13201
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
13202
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
13249
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0QWRkb25zU3RlcC5zdHlsZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBcUIwQyIsImZpbGUiOiJDaGVja291dEFkZG9uc1N0ZXAuc3R5bGUudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgR3JpZCBmcm9tICdAbXVpL21hdGVyaWFsL0dyaWQnO1xyXG5pbXBvcnQgeyBCdXR0b24gfSBmcm9tICcuLi8uLi9jb21wb25lbnRzJztcclxuaW1wb3J0IHsgbXEgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vbWVkaWFRdWVyeSc7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dEFkZG9uc0NvbnRhaW5lciA9IHN0eWxlZChHcmlkKSBgXG4gIHdpZHRoOiAxMDAlO1xuICBnYXA6IDhweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBBZGRvbkxpc3RJdGVtQ29udGFpbmVyID0gc3R5bGVkKEdyaWQpIGBcbiAgZGlzcGxheTogZmxleDtcbiAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgZ2FwOiAxNnB4O1xuXG4gICR7bXEubWR9IHtcbiAgICBnYXA6IDA7XG4gICAgZmxleC1kaXJlY3Rpb246IHJvdztcbiAgICBqdXN0aWZ5LWNvbnRlbnQ6IHNwYWNlLWJldHdlZW47XG4gICAgaGVpZ2h0OiA4MHB4O1xuICAgIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIH1cbmA7XHJcbmV4cG9ydCBjb25zdCBUcmFzaEJ1dHRvbiA9IHN0eWxlZChCdXR0b24pIGBcbiAgbWluLXdpZHRoOiB1bnNldDtcbiAgd2lkdGg6IDQxcHg7XG4gIGhlaWdodDogNDFweDtcbiAgcGFkZGluZzogMDtcbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0QWRkb25zU3RlcC5zdHlsZS5qcy5tYXAiXX0= */",
|
|
13250
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$p
|
|
13203
13251
|
});
|
|
13204
13252
|
|
|
13205
13253
|
function AddonListItem(_ref) {
|
|
@@ -13214,6 +13262,7 @@ function AddonListItem(_ref) {
|
|
|
13214
13262
|
checkoutLocalization = _ref.checkoutLocalization,
|
|
13215
13263
|
onAddonsValidationChange = _ref.onAddonsValidationChange,
|
|
13216
13264
|
isValid = _ref.isValid;
|
|
13265
|
+
var isScreenWiderThanLg = useIsScreenWiderThan('lg');
|
|
13217
13266
|
var addonPrice = addon.pricePoints.find(function (pricePoint) {
|
|
13218
13267
|
return pricePoint.billingPeriod === billingPeriod;
|
|
13219
13268
|
});
|
|
@@ -13268,7 +13317,11 @@ function AddonListItem(_ref) {
|
|
|
13268
13317
|
currency: addonPrice.currency,
|
|
13269
13318
|
minimumFractionDigits: 2
|
|
13270
13319
|
}) + "/" + (billingPeriod === Stigg.BillingPeriod.Annually ? 'year' : 'month'))), React__default.createElement(Grid, {
|
|
13271
|
-
item: true
|
|
13320
|
+
item: true,
|
|
13321
|
+
sx: {
|
|
13322
|
+
gap: '16px'
|
|
13323
|
+
},
|
|
13324
|
+
container: !isScreenWiderThanLg
|
|
13272
13325
|
}, hasChanges && React__default.createElement(Button, {
|
|
13273
13326
|
variant: "text",
|
|
13274
13327
|
size: "small",
|
|
@@ -13284,9 +13337,11 @@ function AddonListItem(_ref) {
|
|
|
13284
13337
|
id: addon.id + "-input",
|
|
13285
13338
|
type: "number",
|
|
13286
13339
|
onWheel: ON_WHEEL_BLUR,
|
|
13287
|
-
sx: {
|
|
13288
|
-
|
|
13289
|
-
|
|
13340
|
+
sx: isScreenWiderThanLg ? {
|
|
13341
|
+
marginX: 2,
|
|
13342
|
+
width: 120
|
|
13343
|
+
} : {
|
|
13344
|
+
flex: 1
|
|
13290
13345
|
},
|
|
13291
13346
|
value: (_addonState$quantity = addonState == null ? void 0 : addonState.quantity) != null ? _addonState$quantity : '',
|
|
13292
13347
|
error: !isValid,
|
|
@@ -13622,7 +13677,7 @@ function formatBillingPeriod(billingPeriod) {
|
|
|
13622
13677
|
}
|
|
13623
13678
|
}
|
|
13624
13679
|
|
|
13625
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
13680
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$q() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
13626
13681
|
var BillingPeriodPickerContainer = /*#__PURE__*/_styled(Box, {
|
|
13627
13682
|
target: "ekae5v44",
|
|
13628
13683
|
label: "BillingPeriodPickerContainer"
|
|
@@ -13630,7 +13685,7 @@ var BillingPeriodPickerContainer = /*#__PURE__*/_styled(Box, {
|
|
|
13630
13685
|
name: "1k6141t",
|
|
13631
13686
|
styles: "margin:16px 0",
|
|
13632
13687
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUl3RCIsImZpbGUiOiJCaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJveCBmcm9tICdAbXVpL21hdGVyaWFsL0JveCc7XHJcbmltcG9ydCBDaGlwIGZyb20gJ0BtdWkvbWF0ZXJpYWwvQ2hpcCc7XHJcbmltcG9ydCBDb2xvciBmcm9tICdjb2xvcic7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUGlja2VyQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBtYXJnaW46IDE2cHggMDtcbmA7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kQnV0dG9uID0gc3R5bGVkLmJ1dHRvbiBgXG4gIGN1cnNvcjogJHsoeyAkZGlzYWJsZWQsICRpc09ubHlCaWxsaW5nUGVyaW9kIH0pID0+ICRkaXNhYmxlZCA/ICdkZWZhdWx0JyA6ICRpc09ubHlCaWxsaW5nUGVyaW9kID8gJ2RlZmF1bHQnIDogJ3BvaW50ZXInfTtcbiAgZmxleDogMTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBmbGV4LXN0YXJ0O1xuICBwYWRkaW5nOiAycHggOHB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBib3JkZXI6ICR7KHsgdGhlbWUsICRpc0FjdGl2ZSwgJGlzT25seUJpbGxpbmdQZXJpb2QgfSkgPT4ge1xyXG4gICAgbGV0IGJvcmRlckNvbG9yID0gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcjtcclxuICAgIGlmICgkaXNPbmx5QmlsbGluZ1BlcmlvZCkge1xyXG4gICAgICAgIGJvcmRlckNvbG9yID0gJ3RyYW5zcGFyZW50JztcclxuICAgIH1cclxuICAgIGVsc2UgaWYgKCRpc0FjdGl2ZSkge1xyXG4gICAgICAgIGJvcmRlckNvbG9yID0gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZFJlc3RpbmdCb3JkZXI7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gYDFweCBzb2xpZCAke2JvcmRlckNvbG9yfWA7XHJcbn19O1xuICBiYWNrZ3JvdW5kOiAkeyh7IHRoZW1lLCAkaXNBY3RpdmUsICRpc09ubHlCaWxsaW5nUGVyaW9kIH0pID0+IHtcclxuICAgIGlmICgkaXNPbmx5QmlsbGluZ1BlcmlvZCkge1xyXG4gICAgICAgIHJldHVybiAndHJhbnNwYXJlbnQnO1xyXG4gICAgfVxyXG4gICAgaWYgKCRpc0FjdGl2ZSkge1xyXG4gICAgICAgIHJldHVybiBDb2xvcih0aGVtZS5zdGlnZy5wYWxldHRlLnByaW1hcnkpLmFscGhhKDAuMTUpLnRvU3RyaW5nKCk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gJ3RyYW5zcGFyZW50JztcclxufX07XG4gIHRleHQtdHJhbnNmb3JtOiBub25lO1xuICB0ZXh0LWFsaWduOiBzdGFydDtcbiAgaGVpZ2h0OiAzNnB4O1xuXG4gICYuTXVpQnV0dG9uLXJvb3Qge1xuICAgIHBhZGRpbmc6IDAgMTZweCAwIDhweDtcbiAgICAmOmhvdmVyIHtcbiAgICAgIGJhY2tncm91bmQ6IG5vbmU7XG4gICAgfVxuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZE9wdGlvbnMgPSBzdHlsZWQoQm94KSBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGdhcDogMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBCaWxsaW5nUGVyaW9kUHJpY2UgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGJhc2VsaW5lO1xuICBnYXA6IDhweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudENoaXAgPSBzdHlsZWQoQ2hpcCkgYFxuICAmIC5NdWlDaGlwLWxhYmVsIHtcbiAgICBmb250LXNpemU6IDEycHg7XG4gIH1cbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUuanMubWFwIl19 */",
|
|
13633
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
13688
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$q
|
|
13634
13689
|
});
|
|
13635
13690
|
var BillingPeriodButton = /*#__PURE__*/_styled("button", {
|
|
13636
13691
|
target: "ekae5v43",
|
|
@@ -13674,7 +13729,7 @@ var BillingPeriodOptions = /*#__PURE__*/_styled(Box, {
|
|
|
13674
13729
|
name: "1neb8ay",
|
|
13675
13730
|
styles: "display:flex;gap:16px;margin-top:16px",
|
|
13676
13731
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkJpbGxpbmdQZXJpb2RQaWNrZXIuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQTZDZ0QiLCJmaWxlIjoiQmlsbGluZ1BlcmlvZFBpY2tlci5zdHlsZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5pbXBvcnQgQ2hpcCBmcm9tICdAbXVpL21hdGVyaWFsL0NoaXAnO1xyXG5pbXBvcnQgQ29sb3IgZnJvbSAnY29sb3InO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFBpY2tlckNvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgbWFyZ2luOiAxNnB4IDA7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZEJ1dHRvbiA9IHN0eWxlZC5idXR0b24gYFxuICBjdXJzb3I6ICR7KHsgJGRpc2FibGVkLCAkaXNPbmx5QmlsbGluZ1BlcmlvZCB9KSA9PiAkZGlzYWJsZWQgPyAnZGVmYXVsdCcgOiAkaXNPbmx5QmlsbGluZ1BlcmlvZCA/ICdkZWZhdWx0JyA6ICdwb2ludGVyJ307XG4gIGZsZXg6IDE7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogZmxleC1zdGFydDtcbiAgcGFkZGluZzogMnB4IDhweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgYm9yZGVyOiAkeyh7IHRoZW1lLCAkaXNBY3RpdmUsICRpc09ubHlCaWxsaW5nUGVyaW9kIH0pID0+IHtcclxuICAgIGxldCBib3JkZXJDb2xvciA9IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRCb3JkZXI7XHJcbiAgICBpZiAoJGlzT25seUJpbGxpbmdQZXJpb2QpIHtcclxuICAgICAgICBib3JkZXJDb2xvciA9ICd0cmFuc3BhcmVudCc7XHJcbiAgICB9XHJcbiAgICBlbHNlIGlmICgkaXNBY3RpdmUpIHtcclxuICAgICAgICBib3JkZXJDb2xvciA9IHRoZW1lLnN0aWdnLnBhbGV0dGUub3V0bGluZWRSZXN0aW5nQm9yZGVyO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIGAxcHggc29saWQgJHtib3JkZXJDb2xvcn1gO1xyXG59fTtcbiAgYmFja2dyb3VuZDogJHsoeyB0aGVtZSwgJGlzQWN0aXZlLCAkaXNPbmx5QmlsbGluZ1BlcmlvZCB9KSA9PiB7XHJcbiAgICBpZiAoJGlzT25seUJpbGxpbmdQZXJpb2QpIHtcclxuICAgICAgICByZXR1cm4gJ3RyYW5zcGFyZW50JztcclxuICAgIH1cclxuICAgIGlmICgkaXNBY3RpdmUpIHtcclxuICAgICAgICByZXR1cm4gQ29sb3IodGhlbWUuc3RpZ2cucGFsZXR0ZS5wcmltYXJ5KS5hbHBoYSgwLjE1KS50b1N0cmluZygpO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuICd0cmFuc3BhcmVudCc7XHJcbn19O1xuICB0ZXh0LXRyYW5zZm9ybTogbm9uZTtcbiAgdGV4dC1hbGlnbjogc3RhcnQ7XG4gIGhlaWdodDogMzZweDtcblxuICAmLk11aUJ1dHRvbi1yb290IHtcbiAgICBwYWRkaW5nOiAwIDE2cHggMCA4cHg7XG4gICAgJjpob3ZlciB7XG4gICAgICBiYWNrZ3JvdW5kOiBub25lO1xuICAgIH1cbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEJpbGxpbmdQZXJpb2RPcHRpb25zID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuICBnYXA6IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgQmlsbGluZ1BlcmlvZFByaWNlID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBiYXNlbGluZTtcbiAgZ2FwOiA4cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgRGlzY291bnRDaGlwID0gc3R5bGVkKENoaXApIGBcbiAgJiAuTXVpQ2hpcC1sYWJlbCB7XG4gICAgZm9udC1zaXplOiAxMnB4O1xuICB9XG5gO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1CaWxsaW5nUGVyaW9kUGlja2VyLnN0eWxlLmpzLm1hcCJdfQ== */",
|
|
13677
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
13732
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$q
|
|
13678
13733
|
});
|
|
13679
13734
|
|
|
13680
13735
|
var BillingPeriodOption = function BillingPeriodOption(_ref) {
|
|
@@ -13744,7 +13799,7 @@ function BillingPeriodPicker$1(_ref2) {
|
|
|
13744
13799
|
}
|
|
13745
13800
|
|
|
13746
13801
|
var _templateObject$9;
|
|
13747
|
-
var StyledPlanCharge = /*#__PURE__*/styled.div(_templateObject$9 || (_templateObject$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n
|
|
13802
|
+
var StyledPlanCharge = /*#__PURE__*/styled.div(_templateObject$9 || (_templateObject$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n min-height: 60px;\n margin-top: 16px;\n flex-direction: column;\n\n ", " {\n flex-direction: row;\n align-items: center;\n justify-content: space-between;\n }\n"])), mq.md);
|
|
13748
13803
|
|
|
13749
13804
|
var getValidationText = function getValidationText(charge, quantity) {
|
|
13750
13805
|
var minUnitQuantity = charge.minUnitQuantity,
|
|
@@ -13769,6 +13824,7 @@ function PlanCharge(_ref) {
|
|
|
13769
13824
|
setBillableFeature = _ref.setBillableFeature,
|
|
13770
13825
|
billableFeature = _ref.billableFeature,
|
|
13771
13826
|
onValidationChange = _ref.onValidationChange;
|
|
13827
|
+
var isScreenWiderThanMd = useIsScreenWiderThan('md');
|
|
13772
13828
|
var featureId = (_charge$feature = charge.feature) == null ? void 0 : _charge$feature.featureId;
|
|
13773
13829
|
var isBaseCharge = !featureId;
|
|
13774
13830
|
var isPayAsYouGo = charge.pricingModel === Stigg.BillingModel.UsageBased;
|
|
@@ -13833,7 +13889,7 @@ function PlanCharge(_ref) {
|
|
|
13833
13889
|
|
|
13834
13890
|
chargeRow = React__default.createElement(InputField, {
|
|
13835
13891
|
sx: {
|
|
13836
|
-
width: 120
|
|
13892
|
+
width: isScreenWiderThanMd ? 120 : '100%'
|
|
13837
13893
|
},
|
|
13838
13894
|
id: featureId + "-input",
|
|
13839
13895
|
type: "number",
|
|
@@ -13902,7 +13958,7 @@ function CheckoutChargeList(_ref2) {
|
|
|
13902
13958
|
setIsDisabled(isDisabled);
|
|
13903
13959
|
setIsValid(!isDisabled);
|
|
13904
13960
|
}, [chargesValidation, setIsDisabled, setIsValid]);
|
|
13905
|
-
return React__default.createElement(
|
|
13961
|
+
return React__default.createElement(React__default.Fragment, null, planCharges == null ? void 0 : planCharges.map(function (charge) {
|
|
13906
13962
|
var _charge$feature7, _charge$feature8;
|
|
13907
13963
|
|
|
13908
13964
|
var billableFeature = billableFeatures.find(function (x) {
|
|
@@ -13929,7 +13985,7 @@ function CheckoutChargeList(_ref2) {
|
|
|
13929
13985
|
}));
|
|
13930
13986
|
}
|
|
13931
13987
|
|
|
13932
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
13988
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$r() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
13933
13989
|
var CheckoutPlanContainer = /*#__PURE__*/_styled(Box, {
|
|
13934
13990
|
target: "emtnukp0",
|
|
13935
13991
|
label: "CheckoutPlanContainer"
|
|
@@ -13937,7 +13993,7 @@ var CheckoutPlanContainer = /*#__PURE__*/_styled(Box, {
|
|
|
13937
13993
|
name: "1d3w5wq",
|
|
13938
13994
|
styles: "width:100%",
|
|
13939
13995
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0UGxhblN0ZXAuc3R5bGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUVpRCIsImZpbGUiOiJDaGVja291dFBsYW5TdGVwLnN0eWxlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IEJveCBmcm9tICdAbXVpL21hdGVyaWFsL0JveCc7XHJcbmV4cG9ydCBjb25zdCBDaGVja291dFBsYW5Db250YWluZXIgPSBzdHlsZWQoQm94KSBgXG4gIHdpZHRoOiAxMDAlO1xuYDtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9Q2hlY2tvdXRQbGFuU3RlcC5zdHlsZS5qcy5tYXAiXX0= */",
|
|
13940
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
13996
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$r
|
|
13941
13997
|
});
|
|
13942
13998
|
|
|
13943
13999
|
var CheckoutPlanStep = function CheckoutPlanStep(_ref) {
|
|
@@ -13991,7 +14047,7 @@ var StyledArrowRightIcon = /*#__PURE__*/_styled(SvgArrowRight, {
|
|
|
13991
14047
|
return theme.stigg.palette.text.secondary;
|
|
13992
14048
|
}, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN0eWxlZEFycm93LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFFMkQiLCJmaWxlIjoiU3R5bGVkQXJyb3cudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgQXJyb3dSaWdodEljb24gZnJvbSAnLi4vLi4vLi4vYXNzZXRzL2Fycm93LXJpZ2h0LnN2Zyc7XHJcbmV4cG9ydCBjb25zdCBTdHlsZWRBcnJvd1JpZ2h0SWNvbiA9IHN0eWxlZChBcnJvd1JpZ2h0SWNvbikgYFxuICBwYXRoIHtcbiAgICBzdHJva2U6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS50ZXh0LnNlY29uZGFyeX07XG4gIH1cbmA7XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVN0eWxlZEFycm93LmpzLm1hcCJdfQ== */"));
|
|
13993
14049
|
|
|
13994
|
-
function _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
14050
|
+
function _EMOTION_STRINGIFIED_CSS_ERROR__$s() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
|
|
13995
14051
|
|
|
13996
14052
|
var DowngradeToFreePlansContainer = /*#__PURE__*/_styled(Box, {
|
|
13997
14053
|
target: "eaawmuo2",
|
|
@@ -14000,7 +14056,7 @@ var DowngradeToFreePlansContainer = /*#__PURE__*/_styled(Box, {
|
|
|
14000
14056
|
name: "zjik7",
|
|
14001
14057
|
styles: "display:flex",
|
|
14002
14058
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT2tEIiwiZmlsZSI6IkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5pbXBvcnQgQWxlcnQgZnJvbSAnQG11aS9tYXRlcmlhbC9BbGVydCc7XHJcbmltcG9ydCB7IFN0eWxlZEFycm93UmlnaHRJY29uIH0gZnJvbSAnLi9TdHlsZWRBcnJvdyc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IENoYW5nZVBsYW5CdXR0b24gfSBmcm9tICcuL0NoYW5nZVBsYW5CdXR0b24nO1xyXG5jb25zdCBEb3duZ3JhZGVUb0ZyZWVQbGFuc0NvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgZGlzcGxheTogZmxleDtcbmA7XHJcbmNvbnN0IERvd25ncmFkZVRvRnJlZUFsZXJ0ID0gc3R5bGVkKEFsZXJ0KSBgXG4gIG1hcmdpbi1ib3R0b206IDE2cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgRG93bmdyYWRlVG9GcmVlUGxhbkJveCA9IHN0eWxlZChCb3gpIGBcbiAgcGFkZGluZzogMTZweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgd2lkdGg6IDEwMCU7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSB9KSA9PiBgMXB4IHNvbGlkICR7dGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn1gfTtcbmA7XHJcbmV4cG9ydCBjb25zdCBEb3duZ3JhZGVUb0ZyZWVDb250ZW50ID0gKHsgaGVhZGVyVGV4dCwgcGxhbk5hbWUsIHByaWNlVGV4dCwgfSkgPT4ge1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KERvd25ncmFkZVRvRnJlZVBsYW5Cb3gsIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LWRvd25ncmFkZS10by1mcmVlLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS10ZXh0LWhlYWRlclwiLCBzdHlsZTogeyBvcGFjaXR5OiAwLjggfSwgdmFyaWFudDogXCJjYXB0aW9uXCIsIGNvbG9yOiBcImRpc2FibGVkXCIgfSwgaGVhZGVyVGV4dCksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS1wbGFuLW5hbWVcIiwgYm9sZDogdHJ1ZSwgdmFyaWFudDogXCJoM1wiLCBjb2xvcjogXCJwcmltYXJ5XCIgfSwgcGxhbk5hbWUpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtcHJpY2UtdGV4dFwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBwcmljZVRleHQpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBEb3duZ3JhZGVUb0ZyZWVQbGFuID0gKHsgY2hlY2tvdXRMb2NhbGl6YXRpb24sIGFjdGl2ZVN1YnNjcmlwdGlvbiwgZnJlZVBsYW4sIGFsbG93Q2hhbmdlUGxhbiA9IGZhbHNlLCBvbkNoYW5nZVBsYW4sIH0pID0+IHtcclxuICAgIGxldCBhbGVydEFjdGlvbjtcclxuICAgIGlmIChhbGxvd0NoYW5nZVBsYW4gJiYgb25DaGFuZ2VQbGFuKSB7XHJcbiAgICAgICAgYWxlcnRBY3Rpb24gPSAoUmVhY3QuY3JlYXRlRWxlbWVudChDaGFuZ2VQbGFuQnV0dG9uLCB7IG9uQ2xpY2s6ICgpID0+IHtcclxuICAgICAgICAgICAgICAgIG9uQ2hhbmdlUGxhbih7IGN1cnJlbnRQbGFuOiBmcmVlUGxhbiB9KTtcclxuICAgICAgICAgICAgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb246IGNoZWNrb3V0TG9jYWxpemF0aW9uLCBzaXplOiBcInNtYWxsXCIgfSkpO1xyXG4gICAgfVxyXG4gICAgY29uc3QgcGFpZEJpbGxpbmdQZXJpb2QgPSBhY3RpdmVTdWJzY3JpcHRpb24ucHJpY2VzLmxlbmd0aCA+IDAgPyBhY3RpdmVTdWJzY3JpcHRpb24ucHJpY2VzWzBdLmJpbGxpbmdQZXJpb2QgOiB1bmRlZmluZWQ7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEb3duZ3JhZGVUb0ZyZWVBbGVydCwgeyBhY3Rpb246IGFsZXJ0QWN0aW9uLCBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtYWxlcnRcIiwgc2V2ZXJpdHk6IFwiaW5mb1wiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzcGFuOiB0cnVlLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWUuYWxlcnRUZXh0KHsgcGxhbjogYWN0aXZlU3Vic2NyaXB0aW9uLnBsYW4gfSkpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERvd25ncmFkZVRvRnJlZVBsYW5zQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS1wbGFucy1jb250YWluZXJcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERvd25ncmFkZVRvRnJlZUNvbnRlbnQsIHsgaGVhZGVyVGV4dDogY2hlY2tvdXRMb2NhbGl6YXRpb24uZG93bmdyYWRlVG9GcmVlLnBhaWRQbGFuSGVhZGVyKHsgcGxhbjogYWN0aXZlU3Vic2NyaXB0aW9uLnBsYW4gfSksIHBsYW5OYW1lOiBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWUucGFpZFBsYW5OYW1lKHsgcGxhbjogYWN0aXZlU3Vic2NyaXB0aW9uLnBsYW4gfSksIHByaWNlVGV4dDogY2hlY2tvdXRMb2NhbGl6YXRpb24uZG93bmdyYWRlVG9GcmVlLnBhaWRQbGFuUHJpY2VUZXh0KHtcclxuICAgICAgICAgICAgICAgICAgICBwbGFuOiBhY3RpdmVTdWJzY3JpcHRpb24ucGxhbixcclxuICAgICAgICAgICAgICAgICAgICBiaWxsaW5nUGVyaW9kOiBwYWlkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgICAgIH0pIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFycm93UmlnaHRJY29uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS1hcnJvd1wiLCBzdHlsZTogeyBtYXJnaW46ICdhdXRvIDE2cHgnLCBtaW5XaWR0aDogJzE2cHgnIH0gfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlQ29udGVudCwgeyBoZWFkZXJUZXh0OiBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWUuZnJlZVBsYW5IZWFkZXIoeyBwbGFuOiBmcmVlUGxhbiB9KSwgcGxhbk5hbWU6IGNoZWNrb3V0TG9jYWxpemF0aW9uLmRvd25ncmFkZVRvRnJlZS5mcmVlUGxhbk5hbWUoeyBwbGFuOiBmcmVlUGxhbiB9KSwgcHJpY2VUZXh0OiBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWUuZnJlZVBsYW5QcmljZVRleHQoeyBwbGFuOiBmcmVlUGxhbiB9KSB9KSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9RG93bmdyYWRlVG9GcmVlQ29udGFpbmVyLmpzLm1hcCJdfQ== */",
|
|
14003
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
14059
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$s
|
|
14004
14060
|
});
|
|
14005
14061
|
|
|
14006
14062
|
var DowngradeToFreeAlert = /*#__PURE__*/_styled(Alert, {
|
|
@@ -14010,7 +14066,7 @@ var DowngradeToFreeAlert = /*#__PURE__*/_styled(Alert, {
|
|
|
14010
14066
|
name: "18uqayh",
|
|
14011
14067
|
styles: "margin-bottom:16px",
|
|
14012
14068
|
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVTJDIiwiZmlsZSI6IkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBCb3ggZnJvbSAnQG11aS9tYXRlcmlhbC9Cb3gnO1xyXG5pbXBvcnQgQWxlcnQgZnJvbSAnQG11aS9tYXRlcmlhbC9BbGVydCc7XHJcbmltcG9ydCB7IFN0eWxlZEFycm93UmlnaHRJY29uIH0gZnJvbSAnLi9TdHlsZWRBcnJvdyc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IENoYW5nZVBsYW5CdXR0b24gfSBmcm9tICcuL0NoYW5nZVBsYW5CdXR0b24nO1xyXG5jb25zdCBEb3duZ3JhZGVUb0ZyZWVQbGFuc0NvbnRhaW5lciA9IHN0eWxlZChCb3gpIGBcbiAgZGlzcGxheTogZmxleDtcbmA7XHJcbmNvbnN0IERvd25ncmFkZVRvRnJlZUFsZXJ0ID0gc3R5bGVkKEFsZXJ0KSBgXG4gIG1hcmdpbi1ib3R0b206IDE2cHg7XG5gO1xyXG5leHBvcnQgY29uc3QgRG93bmdyYWRlVG9GcmVlUGxhbkJveCA9IHN0eWxlZChCb3gpIGBcbiAgcGFkZGluZzogMTZweDtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgd2lkdGg6IDEwMCU7XG4gIGJvcmRlcjogJHsoeyB0aGVtZSB9KSA9PiBgMXB4IHNvbGlkICR7dGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn1gfTtcbmA7XHJcbmV4cG9ydCBjb25zdCBEb3duZ3JhZGVUb0ZyZWVDb250ZW50ID0gKHsgaGVhZGVyVGV4dCwgcGxhbk5hbWUsIHByaWNlVGV4dCwgfSkgPT4ge1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KERvd25ncmFkZVRvRnJlZVBsYW5Cb3gsIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LWRvd25ncmFkZS10by1mcmVlLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS10ZXh0LWhlYWRlclwiLCBzdHlsZTogeyBvcGFjaXR5OiAwLjggfSwgdmFyaWFudDogXCJjYXB0aW9uXCIsIGNvbG9yOiBcImRpc2FibGVkXCIgfSwgaGVhZGVyVGV4dCksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS1wbGFuLW5hbWVcIiwgYm9sZDogdHJ1ZSwgdmFyaWFudDogXCJoM1wiLCBjb2xvcjogXCJwcmltYXJ5XCIgfSwgcGxhbk5hbWUpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtcHJpY2UtdGV4dFwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBwcmljZVRleHQpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBEb3duZ3JhZGVUb0ZyZWVQbGFuID0gKHsgY2hlY2tvdXRMb2NhbGl6YXRpb24sIGFjdGl2ZVN1YnNjcmlwdGlvbiwgZnJlZVBsYW4sIGFsbG93Q2hhbmdlUGxhbiA9IGZhbHNlLCBvbkNoYW5nZVBsYW4sIH0pID0+IHtcclxuICAgIGxldCBhbGVydEFjdGlvbjtcclxuICAgIGlmIChhbGxvd0NoYW5nZVBsYW4gJiYgb25DaGFuZ2VQbGFuKSB7XHJcbiAgICAgICAgYWxlcnRBY3Rpb24gPSAoUmVhY3QuY3JlYXRlRWxlbWVudChDaGFuZ2VQbGFuQnV0dG9uLCB7IG9uQ2xpY2s6ICgpID0+IHtcclxuICAgICAgICAgICAgICAgIG9uQ2hhbmdlUGxhbih7IGN1cnJlbnRQbGFuOiBmcmVlUGxhbiB9KTtcclxuICAgICAgICAgICAgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb246IGNoZWNrb3V0TG9jYWxpemF0aW9uLCBzaXplOiBcInNtYWxsXCIgfSkpO1xyXG4gICAgfVxyXG4gICAgY29uc3QgcGFpZEJpbGxpbmdQZXJpb2QgPSBhY3RpdmVTdWJzY3JpcHRpb24ucHJpY2VzLmxlbmd0aCA+IDAgPyBhY3RpdmVTdWJzY3JpcHRpb24ucHJpY2VzWzBdLmJpbGxpbmdQZXJpb2QgOiB1bmRlZmluZWQ7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEb3duZ3JhZGVUb0ZyZWVBbGVydCwgeyBhY3Rpb246IGFsZXJ0QWN0aW9uLCBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtYWxlcnRcIiwgc2V2ZXJpdHk6IFwiaW5mb1wiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzcGFuOiB0cnVlLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWUuYWxlcnRUZXh0KHsgcGxhbjogYWN0aXZlU3Vic2NyaXB0aW9uLnBsYW4gfSkpKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERvd25ncmFkZVRvRnJlZVBsYW5zQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS1wbGFucy1jb250YWluZXJcIiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KERvd25ncmFkZVRvRnJlZUNvbnRlbnQsIHsgaGVhZGVyVGV4dDogY2hlY2tvdXRMb2NhbGl6YXRpb24uZG93bmdyYWRlVG9GcmVlLnBhaWRQbGFuSGVhZGVyKHsgcGxhbjogYWN0aXZlU3Vic2NyaXB0aW9uLnBsYW4gfSksIHBsYW5OYW1lOiBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWUucGFpZFBsYW5OYW1lKHsgcGxhbjogYWN0aXZlU3Vic2NyaXB0aW9uLnBsYW4gfSksIHByaWNlVGV4dDogY2hlY2tvdXRMb2NhbGl6YXRpb24uZG93bmdyYWRlVG9GcmVlLnBhaWRQbGFuUHJpY2VUZXh0KHtcclxuICAgICAgICAgICAgICAgICAgICBwbGFuOiBhY3RpdmVTdWJzY3JpcHRpb24ucGxhbixcclxuICAgICAgICAgICAgICAgICAgICBiaWxsaW5nUGVyaW9kOiBwYWlkQmlsbGluZ1BlcmlvZCxcclxuICAgICAgICAgICAgICAgIH0pIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFycm93UmlnaHRJY29uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS1hcnJvd1wiLCBzdHlsZTogeyBtYXJnaW46ICdhdXRvIDE2cHgnLCBtaW5XaWR0aDogJzE2cHgnIH0gfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlQ29udGVudCwgeyBoZWFkZXJUZXh0OiBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWUuZnJlZVBsYW5IZWFkZXIoeyBwbGFuOiBmcmVlUGxhbiB9KSwgcGxhbk5hbWU6IGNoZWNrb3V0TG9jYWxpemF0aW9uLmRvd25ncmFkZVRvRnJlZS5mcmVlUGxhbk5hbWUoeyBwbGFuOiBmcmVlUGxhbiB9KSwgcHJpY2VUZXh0OiBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWUuZnJlZVBsYW5QcmljZVRleHQoeyBwbGFuOiBmcmVlUGxhbiB9KSB9KSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9RG93bmdyYWRlVG9GcmVlQ29udGFpbmVyLmpzLm1hcCJdfQ== */",
|
|
14013
|
-
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$
|
|
14069
|
+
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$s
|
|
14014
14070
|
});
|
|
14015
14071
|
|
|
14016
14072
|
var DowngradeToFreePlanBox = /*#__PURE__*/_styled(Box, {
|