@stigg/react-sdk 4.4.0-beta.2 → 4.4.0-beta.4

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (60) hide show
  1. package/dist/components/checkout/Checkout.d.ts +1 -1
  2. package/dist/components/checkout/CheckoutContainer.d.ts +6 -2
  3. package/dist/components/checkout/CheckoutProvider.d.ts +3 -1
  4. package/dist/components/checkout/components/DowngradeToFreeContainer.d.ts +28 -0
  5. package/dist/components/checkout/hooks/usePaymentStepModel.d.ts +8 -2
  6. package/dist/components/checkout/hooks/useProgressBarModel.d.ts +3 -0
  7. package/dist/components/checkout/hooks/useSubscriptionModel.d.ts +2 -1
  8. package/dist/components/checkout/index.d.ts +1 -0
  9. package/dist/components/checkout/steps/payment/PaymentMethods.d.ts +3 -2
  10. package/dist/components/checkout/steps/payment/PaymentStep.d.ts +2 -1
  11. package/dist/components/checkout/steps/payment/stripe/StripePaymentForm.d.ts +2 -1
  12. package/dist/components/checkout/steps/payment/stripe/stripe.utils.d.ts +4 -0
  13. package/dist/components/checkout/steps/payment/stripe/useSubmit.d.ts +2 -1
  14. package/dist/components/checkout/steps/plan/CheckoutChargeList.d.ts +5 -1
  15. package/dist/components/checkout/summary/CheckoutSummary.d.ts +3 -1
  16. package/dist/components/checkout/summary/components/LineItems.d.ts +2 -2
  17. package/dist/components/checkout/textOverrides.d.ts +4 -1
  18. package/dist/components/checkout/types.d.ts +7 -0
  19. package/dist/components/customerPortal/subscriptionOverview/subscriptionView/SubscriptionView.style.d.ts +1 -1
  20. package/dist/components/paywall/paywallTextOverrides.d.ts +4 -0
  21. package/dist/components/utils/getPaidPriceText.d.ts +3 -1
  22. package/dist/react-sdk.cjs.development.js +583 -263
  23. package/dist/react-sdk.cjs.development.js.map +1 -1
  24. package/dist/react-sdk.cjs.production.min.js +1 -1
  25. package/dist/react-sdk.cjs.production.min.js.map +1 -1
  26. package/dist/react-sdk.esm.js +595 -263
  27. package/dist/react-sdk.esm.js.map +1 -1
  28. package/package.json +2 -2
  29. package/src/assets/payment-method.svg +3 -10
  30. package/src/components/checkout/Checkout.tsx +3 -1
  31. package/src/components/checkout/CheckoutContainer.tsx +54 -28
  32. package/src/components/checkout/CheckoutProvider.tsx +8 -4
  33. package/src/components/checkout/components/DowngradeToFreeContainer.tsx +98 -0
  34. package/src/components/checkout/hooks/usePaymentStepModel.ts +22 -3
  35. package/src/components/checkout/hooks/usePlanStepModel.ts +5 -5
  36. package/src/components/checkout/hooks/usePreviewSubscription.ts +26 -3
  37. package/src/components/checkout/hooks/useProgressBarModel.ts +18 -0
  38. package/src/components/checkout/hooks/useSubscriptionModel.ts +8 -2
  39. package/src/components/checkout/hooks/useSubscriptionState.ts +2 -1
  40. package/src/components/checkout/index.ts +1 -0
  41. package/src/components/checkout/progressBar/CheckoutProgressBar.tsx +3 -2
  42. package/src/components/checkout/steps/payment/PaymentMethods.tsx +13 -6
  43. package/src/components/checkout/steps/payment/PaymentStep.tsx +3 -1
  44. package/src/components/checkout/steps/payment/stripe/StripePaymentForm.tsx +35 -4
  45. package/src/components/checkout/steps/payment/stripe/stripe.utils.ts +4 -3
  46. package/src/components/checkout/steps/payment/stripe/useSubmit.ts +54 -45
  47. package/src/components/checkout/steps/plan/CheckoutChargeList.tsx +42 -10
  48. package/src/components/checkout/summary/CheckoutSuccess.tsx +1 -1
  49. package/src/components/checkout/summary/CheckoutSummary.tsx +24 -19
  50. package/src/components/checkout/summary/components/LineItems.tsx +8 -16
  51. package/src/components/checkout/textOverrides.ts +5 -4
  52. package/src/components/checkout/types.ts +9 -0
  53. package/src/components/paywall/PlanPrice.tsx +10 -2
  54. package/src/components/paywall/paywallTextOverrides.ts +3 -0
  55. package/src/components/utils/getPaidPriceText.ts +8 -2
  56. package/src/components/utils/getPlanPrice.ts +1 -1
  57. package/src/stories/Checkout.stories.tsx +4 -5
  58. package/dist/components/checkout/steps/surprise/SurpriseStep.d.ts +0 -2
  59. package/src/assets/nyancat.svg +0 -634
  60. package/src/components/checkout/steps/surprise/SurpriseStep.tsx +0 -27
@@ -1049,7 +1049,8 @@ function getPaidPriceText(_ref) {
1049
1049
  selectedBillingPeriod = _ref.selectedBillingPeriod,
1050
1050
  locale = _ref.locale,
1051
1051
  shouldShowMonthlyPriceAmount = _ref.shouldShowMonthlyPriceAmount,
1052
- selectedTierByFeature = _ref.selectedTierByFeature;
1052
+ selectedTierByFeature = _ref.selectedTierByFeature,
1053
+ paywallLocale = _ref.paywallLocale;
1053
1054
 
1054
1055
  var _ref2 = paywallCalculatedPrice || planPrices[0],
1055
1056
  amount = _ref2.amount,
@@ -1060,7 +1061,8 @@ function getPaidPriceText(_ref) {
1060
1061
  var priceNumber = selectedBillingPeriod === Stigg.BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? priceAmount / 12 : priceAmount;
1061
1062
  var tiers;
1062
1063
  var tierUnits;
1063
- var unit = shouldShowMonthlyPriceAmount ? '/ month' : '/ year';
1064
+ var pricePeriod = paywallLocale.price.pricePeriod(shouldShowMonthlyPriceAmount ? Stigg.BillingPeriod.Monthly : Stigg.BillingPeriod.Annually);
1065
+ var unit = pricePeriod;
1064
1066
 
1065
1067
  for (var _iterator = _createForOfIteratorHelperLoose(planPrices), _step; !(_step = _iterator()).done;) {
1066
1068
  var _price = _step.value;
@@ -1085,7 +1087,7 @@ function getPaidPriceText(_ref) {
1085
1087
  var featureUnit = ((_price$feature = price.feature) == null ? void 0 : _price$feature.units) || '';
1086
1088
 
1087
1089
  if (price.pricingModel === Stigg.BillingModel.PerUnit && !price.isTieredPrice) {
1088
- unit = shouldShowMonthlyPriceAmount ? "per " + featureUnit + " / month" : "per " + featureUnit + " / year";
1090
+ unit = shouldShowMonthlyPriceAmount ? "per " + featureUnit + " " + pricePeriod : "per " + featureUnit + " " + pricePeriod;
1089
1091
  } else if (price.pricingModel === Stigg.BillingModel.UsageBased) {
1090
1092
  unit = "per " + featureUnit;
1091
1093
  }
@@ -1144,7 +1146,8 @@ function getPlanPrice(plan, billingPeriod, paywallLocale, locale, shouldShowMont
1144
1146
  plan: plan
1145
1147
  })) : getPaidPriceText(_extends({}, paidParams, {
1146
1148
  locale: locale,
1147
- shouldShowMonthlyPriceAmount: shouldShowMonthlyPriceAmount
1149
+ shouldShowMonthlyPriceAmount: shouldShowMonthlyPriceAmount,
1150
+ paywallLocale: paywallLocale
1148
1151
  }));
1149
1152
  }
1150
1153
 
@@ -1226,7 +1229,7 @@ var PlanPriceContainer = /*#__PURE__*/_styled(Typography, {
1226
1229
  })( {
1227
1230
  name: "bfvx8c",
1228
1231
  styles: "word-break:break-word;width:100%",
1229
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTThDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBUaWVyc1NlbGVjdENvbnRhaW5lciB9IGZyb20gJy4uL2NvbW1vbi9UaWVyc1NlbGVjdENvbnRhaW5lcic7XHJcbmNvbnN0IEVNUFRZX0NIQVIgPSAn4oCOJztcclxuY29uc3QgUGxhblByaWNlQ29udGFpbmVyID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBVbml0U3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xyXG5jb25zdCBQcmljZVNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICBtaW4taGVpZ2h0OiAzOXB4O1xuYDtcclxuZnVuY3Rpb24gUHJpY2VCaWxsaW5nUGVyaW9kKHsgcGxhbiwgYmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlIH0pIHtcclxuICAgIGNvbnN0IGhhc1ByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKHByaWNlUG9pbnQgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kKTtcclxuICAgIGxldCBjb250ZW50ID0gRU1QVFlfQ0hBUjtcclxuICAgIGlmIChoYXNQcmljZSAmJiBoYXNNb250aGx5UHJpY2UgJiYgaGFzQW5udWFsbHlQcmljZSkge1xyXG4gICAgICAgIGNvbnRlbnQgPSBgLCBiaWxsZWQgJHtiaWxsaW5nUGVyaW9kLnRvTG93ZXJDYXNlKCl9YDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHNwYW46IHRydWUsIGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY29udGVudCkpO1xyXG59XHJcbmV4cG9ydCBjb25zdCBQbGFuUHJpY2UgPSAoeyBzaG93U3RhcnRpbmdBdCwgd2l0aFVuaXRQcmljZVJvdywgd2l0aFN0YXJ0aW5nQXRSb3csIHdpdGhUaWVyc1Jvdywgc2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUsIHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHByaWNlLCB1bml0LCB0aWVycywgdGllclVuaXRzIH0gPSBnZXRQbGFuUHJpY2UocGxhbiwgYmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UsIHNlbGVjdGVkVGllckJ5RmVhdHVyZSk7XHJcbiAgICBjb25zdCBbc2VsZWN0ZWRUaWVyLCBzZXRTZWxlY3RlZFRpZXJdID0gdXNlU3RhdGUoKTtcclxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgc2V0U2VsZWN0ZWRUaWVyKHNlbGVjdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdKTtcclxuICAgIH0sIFtzZWxlY3RlZFRpZXJCeUZlYXR1cmVdKTtcclxuICAgIC8vIFdlIGN1cnJlbnRseSBvbmx5IHN1cHBvcnQgcHJpY2VzIHdpdGggb25lIHRpZXIgLSBzbyB3ZSBzZWxlY3QgdGhlIGZpcnN0IG9uZVxyXG4gICAgY29uc3QgdGllcmVkUHJpY2UgPSBwbGFuLnByaWNlUG9pbnRzLmZpbmQocGxhblByaWNlID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlLmJpbGxpbmdQZXJpb2QgPT09IGJpbGxpbmdQZXJpb2QgJiYgcGxhblByaWNlLmlzVGllcmVkUHJpY2U7XHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGZlYXR1cmVJZCA9IHRpZXJlZFByaWNlID8gdGllcmVkUHJpY2UuZmVhdHVyZS5mZWF0dXJlSWQgOiB1bmRlZmluZWQ7XHJcbiAgICBjb25zdCBoYW5kbGVUaWVyQ2hhbmdlID0gKHRpZXIpID0+IHtcclxuICAgICAgICBjb25zdCB1cGRhdGVkVGllckJ5RmVhdHVyZSA9IHt9O1xyXG4gICAgICAgIHVwZGF0ZWRUaWVyQnlGZWF0dXJlW2ZlYXR1cmVJZF0gPSB0aWVyO1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllckJ5RmVhdHVyZSh1cGRhdGVkVGllckJ5RmVhdHVyZSk7XHJcbiAgICB9O1xyXG4gICAgdXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAodGllcnMpIHtcclxuICAgICAgICAgICAgaGFuZGxlVGllckNoYW5nZShzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSk7XHJcbiAgICAgICAgfVxyXG4gICAgfSwgW10pO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5QcmljZUNvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGV4dFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgd2l0aFN0YXJ0aW5nQXRSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzdHlsZTogeyBtaW5IZWlnaHQ6ICcyMHB4JyB9LCBjbGFzc05hbWU6IFwic3RpZ2ctc3RhcnRpbmctYXQtdGV4dFwiLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHNob3dTdGFydGluZ0F0ID8gcGF5d2FsbExvY2FsZS5wcmljZS5zdGFydGluZ0F0Q2FwdGlvbiA6IEVNUFRZX0NIQVIpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQcmljZVNwYW4sIHsgdmFyaWFudDogXCJoMVwiIH0sIHByaWNlKSxcclxuICAgICAgICAgICAgd2l0aFVuaXRQcmljZVJvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS11bml0LWFuZC1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHN0eWxlOiB7IG1pbkhlaWdodDogJzQ4cHgnIH0gfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVW5pdFNwYW4sIHsgc3BhbjogdHJ1ZSwgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCB1bml0KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VCaWxsaW5nUGVyaW9kLCB7IHBsYW46IHBsYW4sIGJpbGxpbmdQZXJpb2Q6IGJpbGxpbmdQZXJpb2QsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlIH0pKSksXHJcbiAgICAgICAgICAgIHdpdGhUaWVyc1JvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUaWVyc1NlbGVjdENvbnRhaW5lciwgeyBjb21wb25lbnRJZDogYCR7cGxhbi5pZH1fJHtmZWF0dXJlSWR9X3RpZXJgLCB0aWVyczogdGllcnMsIHRpZXJVbml0czogdGllclVuaXRzLCBzZWxlY3RlZFRpZXI6IHNlbGVjdGVkVGllciwgaGFuZGxlVGllckNoYW5nZTogaGFuZGxlVGllckNoYW5nZSB9KSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBsYW5QcmljZS5qcy5tYXAiXX0= */",
1232
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTThDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBUaWVyc1NlbGVjdENvbnRhaW5lciB9IGZyb20gJy4uL2NvbW1vbi9UaWVyc1NlbGVjdENvbnRhaW5lcic7XHJcbmNvbnN0IEVNUFRZX0NIQVIgPSAn4oCOJztcclxuY29uc3QgUGxhblByaWNlQ29udGFpbmVyID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBVbml0U3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xyXG5jb25zdCBQcmljZVNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICBtaW4taGVpZ2h0OiAzOXB4O1xuYDtcclxuZnVuY3Rpb24gUHJpY2VCaWxsaW5nUGVyaW9kKHsgcGxhbiwgYmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCBwYXl3YWxsTG9jYWxlLCB9KSB7XHJcbiAgICBjb25zdCBoYXNQcmljZSA9IHBsYW4ucHJpY2VQb2ludHMuZmluZChwcmljZVBvaW50ID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gYmlsbGluZ1BlcmlvZCk7XHJcbiAgICBsZXQgY29udGVudCA9IEVNUFRZX0NIQVI7XHJcbiAgICBpZiAoaGFzUHJpY2UgJiYgaGFzTW9udGhseVByaWNlICYmIGhhc0FubnVhbGx5UHJpY2UpIHtcclxuICAgICAgICBjb250ZW50ID0gcGF5d2FsbExvY2FsZS5wcmljZS5iaWxsaW5nUGVyaW9kPy4oYmlsbGluZ1BlcmlvZCkgfHwgYCwgYmlsbGVkICR7YmlsbGluZ1BlcmlvZC50b0xvd2VyQ2FzZSgpfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzcGFuOiB0cnVlLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNvbnRlbnQpKTtcclxufVxyXG5leHBvcnQgY29uc3QgUGxhblByaWNlID0gKHsgc2hvd1N0YXJ0aW5nQXQsIHdpdGhVbml0UHJpY2VSb3csIHdpdGhTdGFydGluZ0F0Um93LCB3aXRoVGllcnNSb3csIHNlbGVjdGVkVGllckJ5RmVhdHVyZSwgc2V0U2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBwbGFuLCBiaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBwcmljZSwgdW5pdCwgdGllcnMsIHRpZXJVbml0cyB9ID0gZ2V0UGxhblByaWNlKHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgY29uc3QgW3NlbGVjdGVkVGllciwgc2V0U2VsZWN0ZWRUaWVyXSA9IHVzZVN0YXRlKCk7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllcihzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRUaWVyQnlGZWF0dXJlXSk7XHJcbiAgICAvLyBXZSBjdXJyZW50bHkgb25seSBzdXBwb3J0IHByaWNlcyB3aXRoIG9uZSB0aWVyIC0gc28gd2Ugc2VsZWN0IHRoZSBmaXJzdCBvbmVcclxuICAgIGNvbnN0IHRpZXJlZFByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKHBsYW5QcmljZSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIHBsYW5QcmljZS5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kICYmIHBsYW5QcmljZS5pc1RpZXJlZFByaWNlO1xyXG4gICAgfSk7XHJcbiAgICBjb25zdCBmZWF0dXJlSWQgPSB0aWVyZWRQcmljZSA/IHRpZXJlZFByaWNlLmZlYXR1cmUuZmVhdHVyZUlkIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaGFuZGxlVGllckNoYW5nZSA9ICh0aWVyKSA9PiB7XHJcbiAgICAgICAgY29uc3QgdXBkYXRlZFRpZXJCeUZlYXR1cmUgPSB7fTtcclxuICAgICAgICB1cGRhdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdID0gdGllcjtcclxuICAgICAgICBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUodXBkYXRlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgfTtcclxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgaWYgKHRpZXJzKSB7XHJcbiAgICAgICAgICAgIGhhbmRsZVRpZXJDaGFuZ2Uoc2VsZWN0ZWRUaWVyQnlGZWF0dXJlW2ZlYXR1cmVJZF0pO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuUHJpY2VDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRleHRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgIHdpdGhTdGFydGluZ0F0Um93ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgc3R5bGU6IHsgbWluSGVpZ2h0OiAnMjBweCcgfSwgY2xhc3NOYW1lOiBcInN0aWdnLXN0YXJ0aW5nLWF0LXRleHRcIiwgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBzaG93U3RhcnRpbmdBdCA/IHBheXdhbGxMb2NhbGUucHJpY2Uuc3RhcnRpbmdBdENhcHRpb24gOiBFTVBUWV9DSEFSKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VTcGFuLCB7IHZhcmlhbnQ6IFwiaDFcIiB9LCBwcmljZSksXHJcbiAgICAgICAgICAgIHdpdGhVbml0UHJpY2VSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdW5pdC1hbmQtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCBzdHlsZTogeyBtaW5IZWlnaHQ6ICc0OHB4JyB9IH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFVuaXRTcGFuLCB7IHNwYW46IHRydWUsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgdW5pdCksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFByaWNlQmlsbGluZ1BlcmlvZCwgeyBwbGFuOiBwbGFuLCBiaWxsaW5nUGVyaW9kOiBiaWxsaW5nUGVyaW9kLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSB9KSkpLFxyXG4gICAgICAgICAgICB3aXRoVGllcnNSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllcnNTZWxlY3RDb250YWluZXIsIHsgY29tcG9uZW50SWQ6IGAke3BsYW4uaWR9XyR7ZmVhdHVyZUlkfV90aWVyYCwgdGllcnM6IHRpZXJzLCB0aWVyVW5pdHM6IHRpZXJVbml0cywgc2VsZWN0ZWRUaWVyOiBzZWxlY3RlZFRpZXIsIGhhbmRsZVRpZXJDaGFuZ2U6IGhhbmRsZVRpZXJDaGFuZ2UgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QbGFuUHJpY2UuanMubWFwIl19 */",
1230
1233
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
1231
1234
  });
1232
1235
 
@@ -1236,7 +1239,7 @@ var UnitSpan = /*#__PURE__*/_styled(Typography, {
1236
1239
  })( {
1237
1240
  name: "1bmnxg7",
1238
1241
  styles: "white-space:nowrap",
1239
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9DIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBUaWVyc1NlbGVjdENvbnRhaW5lciB9IGZyb20gJy4uL2NvbW1vbi9UaWVyc1NlbGVjdENvbnRhaW5lcic7XHJcbmNvbnN0IEVNUFRZX0NIQVIgPSAn4oCOJztcclxuY29uc3QgUGxhblByaWNlQ29udGFpbmVyID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBVbml0U3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xyXG5jb25zdCBQcmljZVNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICBtaW4taGVpZ2h0OiAzOXB4O1xuYDtcclxuZnVuY3Rpb24gUHJpY2VCaWxsaW5nUGVyaW9kKHsgcGxhbiwgYmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlIH0pIHtcclxuICAgIGNvbnN0IGhhc1ByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKHByaWNlUG9pbnQgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kKTtcclxuICAgIGxldCBjb250ZW50ID0gRU1QVFlfQ0hBUjtcclxuICAgIGlmIChoYXNQcmljZSAmJiBoYXNNb250aGx5UHJpY2UgJiYgaGFzQW5udWFsbHlQcmljZSkge1xyXG4gICAgICAgIGNvbnRlbnQgPSBgLCBiaWxsZWQgJHtiaWxsaW5nUGVyaW9kLnRvTG93ZXJDYXNlKCl9YDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHNwYW46IHRydWUsIGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY29udGVudCkpO1xyXG59XHJcbmV4cG9ydCBjb25zdCBQbGFuUHJpY2UgPSAoeyBzaG93U3RhcnRpbmdBdCwgd2l0aFVuaXRQcmljZVJvdywgd2l0aFN0YXJ0aW5nQXRSb3csIHdpdGhUaWVyc1Jvdywgc2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUsIHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHByaWNlLCB1bml0LCB0aWVycywgdGllclVuaXRzIH0gPSBnZXRQbGFuUHJpY2UocGxhbiwgYmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UsIHNlbGVjdGVkVGllckJ5RmVhdHVyZSk7XHJcbiAgICBjb25zdCBbc2VsZWN0ZWRUaWVyLCBzZXRTZWxlY3RlZFRpZXJdID0gdXNlU3RhdGUoKTtcclxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgc2V0U2VsZWN0ZWRUaWVyKHNlbGVjdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdKTtcclxuICAgIH0sIFtzZWxlY3RlZFRpZXJCeUZlYXR1cmVdKTtcclxuICAgIC8vIFdlIGN1cnJlbnRseSBvbmx5IHN1cHBvcnQgcHJpY2VzIHdpdGggb25lIHRpZXIgLSBzbyB3ZSBzZWxlY3QgdGhlIGZpcnN0IG9uZVxyXG4gICAgY29uc3QgdGllcmVkUHJpY2UgPSBwbGFuLnByaWNlUG9pbnRzLmZpbmQocGxhblByaWNlID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlLmJpbGxpbmdQZXJpb2QgPT09IGJpbGxpbmdQZXJpb2QgJiYgcGxhblByaWNlLmlzVGllcmVkUHJpY2U7XHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGZlYXR1cmVJZCA9IHRpZXJlZFByaWNlID8gdGllcmVkUHJpY2UuZmVhdHVyZS5mZWF0dXJlSWQgOiB1bmRlZmluZWQ7XHJcbiAgICBjb25zdCBoYW5kbGVUaWVyQ2hhbmdlID0gKHRpZXIpID0+IHtcclxuICAgICAgICBjb25zdCB1cGRhdGVkVGllckJ5RmVhdHVyZSA9IHt9O1xyXG4gICAgICAgIHVwZGF0ZWRUaWVyQnlGZWF0dXJlW2ZlYXR1cmVJZF0gPSB0aWVyO1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllckJ5RmVhdHVyZSh1cGRhdGVkVGllckJ5RmVhdHVyZSk7XHJcbiAgICB9O1xyXG4gICAgdXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAodGllcnMpIHtcclxuICAgICAgICAgICAgaGFuZGxlVGllckNoYW5nZShzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSk7XHJcbiAgICAgICAgfVxyXG4gICAgfSwgW10pO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5QcmljZUNvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGV4dFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgd2l0aFN0YXJ0aW5nQXRSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzdHlsZTogeyBtaW5IZWlnaHQ6ICcyMHB4JyB9LCBjbGFzc05hbWU6IFwic3RpZ2ctc3RhcnRpbmctYXQtdGV4dFwiLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHNob3dTdGFydGluZ0F0ID8gcGF5d2FsbExvY2FsZS5wcmljZS5zdGFydGluZ0F0Q2FwdGlvbiA6IEVNUFRZX0NIQVIpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQcmljZVNwYW4sIHsgdmFyaWFudDogXCJoMVwiIH0sIHByaWNlKSxcclxuICAgICAgICAgICAgd2l0aFVuaXRQcmljZVJvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS11bml0LWFuZC1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHN0eWxlOiB7IG1pbkhlaWdodDogJzQ4cHgnIH0gfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVW5pdFNwYW4sIHsgc3BhbjogdHJ1ZSwgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCB1bml0KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VCaWxsaW5nUGVyaW9kLCB7IHBsYW46IHBsYW4sIGJpbGxpbmdQZXJpb2Q6IGJpbGxpbmdQZXJpb2QsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlIH0pKSksXHJcbiAgICAgICAgICAgIHdpdGhUaWVyc1JvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUaWVyc1NlbGVjdENvbnRhaW5lciwgeyBjb21wb25lbnRJZDogYCR7cGxhbi5pZH1fJHtmZWF0dXJlSWR9X3RpZXJgLCB0aWVyczogdGllcnMsIHRpZXJVbml0czogdGllclVuaXRzLCBzZWxlY3RlZFRpZXI6IHNlbGVjdGVkVGllciwgaGFuZGxlVGllckNoYW5nZTogaGFuZGxlVGllckNoYW5nZSB9KSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBsYW5QcmljZS5qcy5tYXAiXX0= */",
1242
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9DIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBUaWVyc1NlbGVjdENvbnRhaW5lciB9IGZyb20gJy4uL2NvbW1vbi9UaWVyc1NlbGVjdENvbnRhaW5lcic7XHJcbmNvbnN0IEVNUFRZX0NIQVIgPSAn4oCOJztcclxuY29uc3QgUGxhblByaWNlQ29udGFpbmVyID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBVbml0U3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xyXG5jb25zdCBQcmljZVNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICBtaW4taGVpZ2h0OiAzOXB4O1xuYDtcclxuZnVuY3Rpb24gUHJpY2VCaWxsaW5nUGVyaW9kKHsgcGxhbiwgYmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCBwYXl3YWxsTG9jYWxlLCB9KSB7XHJcbiAgICBjb25zdCBoYXNQcmljZSA9IHBsYW4ucHJpY2VQb2ludHMuZmluZChwcmljZVBvaW50ID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gYmlsbGluZ1BlcmlvZCk7XHJcbiAgICBsZXQgY29udGVudCA9IEVNUFRZX0NIQVI7XHJcbiAgICBpZiAoaGFzUHJpY2UgJiYgaGFzTW9udGhseVByaWNlICYmIGhhc0FubnVhbGx5UHJpY2UpIHtcclxuICAgICAgICBjb250ZW50ID0gcGF5d2FsbExvY2FsZS5wcmljZS5iaWxsaW5nUGVyaW9kPy4oYmlsbGluZ1BlcmlvZCkgfHwgYCwgYmlsbGVkICR7YmlsbGluZ1BlcmlvZC50b0xvd2VyQ2FzZSgpfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzcGFuOiB0cnVlLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNvbnRlbnQpKTtcclxufVxyXG5leHBvcnQgY29uc3QgUGxhblByaWNlID0gKHsgc2hvd1N0YXJ0aW5nQXQsIHdpdGhVbml0UHJpY2VSb3csIHdpdGhTdGFydGluZ0F0Um93LCB3aXRoVGllcnNSb3csIHNlbGVjdGVkVGllckJ5RmVhdHVyZSwgc2V0U2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBwbGFuLCBiaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBwcmljZSwgdW5pdCwgdGllcnMsIHRpZXJVbml0cyB9ID0gZ2V0UGxhblByaWNlKHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgY29uc3QgW3NlbGVjdGVkVGllciwgc2V0U2VsZWN0ZWRUaWVyXSA9IHVzZVN0YXRlKCk7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllcihzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRUaWVyQnlGZWF0dXJlXSk7XHJcbiAgICAvLyBXZSBjdXJyZW50bHkgb25seSBzdXBwb3J0IHByaWNlcyB3aXRoIG9uZSB0aWVyIC0gc28gd2Ugc2VsZWN0IHRoZSBmaXJzdCBvbmVcclxuICAgIGNvbnN0IHRpZXJlZFByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKHBsYW5QcmljZSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIHBsYW5QcmljZS5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kICYmIHBsYW5QcmljZS5pc1RpZXJlZFByaWNlO1xyXG4gICAgfSk7XHJcbiAgICBjb25zdCBmZWF0dXJlSWQgPSB0aWVyZWRQcmljZSA/IHRpZXJlZFByaWNlLmZlYXR1cmUuZmVhdHVyZUlkIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaGFuZGxlVGllckNoYW5nZSA9ICh0aWVyKSA9PiB7XHJcbiAgICAgICAgY29uc3QgdXBkYXRlZFRpZXJCeUZlYXR1cmUgPSB7fTtcclxuICAgICAgICB1cGRhdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdID0gdGllcjtcclxuICAgICAgICBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUodXBkYXRlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgfTtcclxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgaWYgKHRpZXJzKSB7XHJcbiAgICAgICAgICAgIGhhbmRsZVRpZXJDaGFuZ2Uoc2VsZWN0ZWRUaWVyQnlGZWF0dXJlW2ZlYXR1cmVJZF0pO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuUHJpY2VDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRleHRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgIHdpdGhTdGFydGluZ0F0Um93ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgc3R5bGU6IHsgbWluSGVpZ2h0OiAnMjBweCcgfSwgY2xhc3NOYW1lOiBcInN0aWdnLXN0YXJ0aW5nLWF0LXRleHRcIiwgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBzaG93U3RhcnRpbmdBdCA/IHBheXdhbGxMb2NhbGUucHJpY2Uuc3RhcnRpbmdBdENhcHRpb24gOiBFTVBUWV9DSEFSKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VTcGFuLCB7IHZhcmlhbnQ6IFwiaDFcIiB9LCBwcmljZSksXHJcbiAgICAgICAgICAgIHdpdGhVbml0UHJpY2VSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdW5pdC1hbmQtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCBzdHlsZTogeyBtaW5IZWlnaHQ6ICc0OHB4JyB9IH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFVuaXRTcGFuLCB7IHNwYW46IHRydWUsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgdW5pdCksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFByaWNlQmlsbGluZ1BlcmlvZCwgeyBwbGFuOiBwbGFuLCBiaWxsaW5nUGVyaW9kOiBiaWxsaW5nUGVyaW9kLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSB9KSkpLFxyXG4gICAgICAgICAgICB3aXRoVGllcnNSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllcnNTZWxlY3RDb250YWluZXIsIHsgY29tcG9uZW50SWQ6IGAke3BsYW4uaWR9XyR7ZmVhdHVyZUlkfV90aWVyYCwgdGllcnM6IHRpZXJzLCB0aWVyVW5pdHM6IHRpZXJVbml0cywgc2VsZWN0ZWRUaWVyOiBzZWxlY3RlZFRpZXIsIGhhbmRsZVRpZXJDaGFuZ2U6IGhhbmRsZVRpZXJDaGFuZ2UgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QbGFuUHJpY2UuanMubWFwIl19 */",
1240
1243
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
1241
1244
  });
1242
1245
 
@@ -1246,7 +1249,7 @@ var PriceSpan = /*#__PURE__*/_styled(Typography, {
1246
1249
  })( {
1247
1250
  name: "nurf5y",
1248
1251
  styles: "white-space:normal;min-height:39px",
1249
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYXFDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBUaWVyc1NlbGVjdENvbnRhaW5lciB9IGZyb20gJy4uL2NvbW1vbi9UaWVyc1NlbGVjdENvbnRhaW5lcic7XHJcbmNvbnN0IEVNUFRZX0NIQVIgPSAn4oCOJztcclxuY29uc3QgUGxhblByaWNlQ29udGFpbmVyID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBVbml0U3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xyXG5jb25zdCBQcmljZVNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICBtaW4taGVpZ2h0OiAzOXB4O1xuYDtcclxuZnVuY3Rpb24gUHJpY2VCaWxsaW5nUGVyaW9kKHsgcGxhbiwgYmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlIH0pIHtcclxuICAgIGNvbnN0IGhhc1ByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKHByaWNlUG9pbnQgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kKTtcclxuICAgIGxldCBjb250ZW50ID0gRU1QVFlfQ0hBUjtcclxuICAgIGlmIChoYXNQcmljZSAmJiBoYXNNb250aGx5UHJpY2UgJiYgaGFzQW5udWFsbHlQcmljZSkge1xyXG4gICAgICAgIGNvbnRlbnQgPSBgLCBiaWxsZWQgJHtiaWxsaW5nUGVyaW9kLnRvTG93ZXJDYXNlKCl9YDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHNwYW46IHRydWUsIGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY29udGVudCkpO1xyXG59XHJcbmV4cG9ydCBjb25zdCBQbGFuUHJpY2UgPSAoeyBzaG93U3RhcnRpbmdBdCwgd2l0aFVuaXRQcmljZVJvdywgd2l0aFN0YXJ0aW5nQXRSb3csIHdpdGhUaWVyc1Jvdywgc2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUsIHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHByaWNlLCB1bml0LCB0aWVycywgdGllclVuaXRzIH0gPSBnZXRQbGFuUHJpY2UocGxhbiwgYmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UsIHNlbGVjdGVkVGllckJ5RmVhdHVyZSk7XHJcbiAgICBjb25zdCBbc2VsZWN0ZWRUaWVyLCBzZXRTZWxlY3RlZFRpZXJdID0gdXNlU3RhdGUoKTtcclxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgc2V0U2VsZWN0ZWRUaWVyKHNlbGVjdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdKTtcclxuICAgIH0sIFtzZWxlY3RlZFRpZXJCeUZlYXR1cmVdKTtcclxuICAgIC8vIFdlIGN1cnJlbnRseSBvbmx5IHN1cHBvcnQgcHJpY2VzIHdpdGggb25lIHRpZXIgLSBzbyB3ZSBzZWxlY3QgdGhlIGZpcnN0IG9uZVxyXG4gICAgY29uc3QgdGllcmVkUHJpY2UgPSBwbGFuLnByaWNlUG9pbnRzLmZpbmQocGxhblByaWNlID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlLmJpbGxpbmdQZXJpb2QgPT09IGJpbGxpbmdQZXJpb2QgJiYgcGxhblByaWNlLmlzVGllcmVkUHJpY2U7XHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGZlYXR1cmVJZCA9IHRpZXJlZFByaWNlID8gdGllcmVkUHJpY2UuZmVhdHVyZS5mZWF0dXJlSWQgOiB1bmRlZmluZWQ7XHJcbiAgICBjb25zdCBoYW5kbGVUaWVyQ2hhbmdlID0gKHRpZXIpID0+IHtcclxuICAgICAgICBjb25zdCB1cGRhdGVkVGllckJ5RmVhdHVyZSA9IHt9O1xyXG4gICAgICAgIHVwZGF0ZWRUaWVyQnlGZWF0dXJlW2ZlYXR1cmVJZF0gPSB0aWVyO1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllckJ5RmVhdHVyZSh1cGRhdGVkVGllckJ5RmVhdHVyZSk7XHJcbiAgICB9O1xyXG4gICAgdXNlRWZmZWN0KCgpID0+IHtcclxuICAgICAgICBpZiAodGllcnMpIHtcclxuICAgICAgICAgICAgaGFuZGxlVGllckNoYW5nZShzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSk7XHJcbiAgICAgICAgfVxyXG4gICAgfSwgW10pO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5QcmljZUNvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGV4dFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgd2l0aFN0YXJ0aW5nQXRSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzdHlsZTogeyBtaW5IZWlnaHQ6ICcyMHB4JyB9LCBjbGFzc05hbWU6IFwic3RpZ2ctc3RhcnRpbmctYXQtdGV4dFwiLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHNob3dTdGFydGluZ0F0ID8gcGF5d2FsbExvY2FsZS5wcmljZS5zdGFydGluZ0F0Q2FwdGlvbiA6IEVNUFRZX0NIQVIpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQcmljZVNwYW4sIHsgdmFyaWFudDogXCJoMVwiIH0sIHByaWNlKSxcclxuICAgICAgICAgICAgd2l0aFVuaXRQcmljZVJvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS11bml0LWFuZC1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHN0eWxlOiB7IG1pbkhlaWdodDogJzQ4cHgnIH0gfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVW5pdFNwYW4sIHsgc3BhbjogdHJ1ZSwgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCB1bml0KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VCaWxsaW5nUGVyaW9kLCB7IHBsYW46IHBsYW4sIGJpbGxpbmdQZXJpb2Q6IGJpbGxpbmdQZXJpb2QsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlIH0pKSksXHJcbiAgICAgICAgICAgIHdpdGhUaWVyc1JvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUaWVyc1NlbGVjdENvbnRhaW5lciwgeyBjb21wb25lbnRJZDogYCR7cGxhbi5pZH1fJHtmZWF0dXJlSWR9X3RpZXJgLCB0aWVyczogdGllcnMsIHRpZXJVbml0czogdGllclVuaXRzLCBzZWxlY3RlZFRpZXI6IHNlbGVjdGVkVGllciwgaGFuZGxlVGllckNoYW5nZTogaGFuZGxlVGllckNoYW5nZSB9KSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBsYW5QcmljZS5qcy5tYXAiXX0= */",
1252
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYXFDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBUaWVyc1NlbGVjdENvbnRhaW5lciB9IGZyb20gJy4uL2NvbW1vbi9UaWVyc1NlbGVjdENvbnRhaW5lcic7XHJcbmNvbnN0IEVNUFRZX0NIQVIgPSAn4oCOJztcclxuY29uc3QgUGxhblByaWNlQ29udGFpbmVyID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBVbml0U3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xyXG5jb25zdCBQcmljZVNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICBtaW4taGVpZ2h0OiAzOXB4O1xuYDtcclxuZnVuY3Rpb24gUHJpY2VCaWxsaW5nUGVyaW9kKHsgcGxhbiwgYmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCBwYXl3YWxsTG9jYWxlLCB9KSB7XHJcbiAgICBjb25zdCBoYXNQcmljZSA9IHBsYW4ucHJpY2VQb2ludHMuZmluZChwcmljZVBvaW50ID0+IHByaWNlUG9pbnQuYmlsbGluZ1BlcmlvZCA9PT0gYmlsbGluZ1BlcmlvZCk7XHJcbiAgICBsZXQgY29udGVudCA9IEVNUFRZX0NIQVI7XHJcbiAgICBpZiAoaGFzUHJpY2UgJiYgaGFzTW9udGhseVByaWNlICYmIGhhc0FubnVhbGx5UHJpY2UpIHtcclxuICAgICAgICBjb250ZW50ID0gcGF5d2FsbExvY2FsZS5wcmljZS5iaWxsaW5nUGVyaW9kPy4oYmlsbGluZ1BlcmlvZCkgfHwgYCwgYmlsbGVkICR7YmlsbGluZ1BlcmlvZC50b0xvd2VyQ2FzZSgpfWA7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzcGFuOiB0cnVlLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNvbnRlbnQpKTtcclxufVxyXG5leHBvcnQgY29uc3QgUGxhblByaWNlID0gKHsgc2hvd1N0YXJ0aW5nQXQsIHdpdGhVbml0UHJpY2VSb3csIHdpdGhTdGFydGluZ0F0Um93LCB3aXRoVGllcnNSb3csIHNlbGVjdGVkVGllckJ5RmVhdHVyZSwgc2V0U2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBwbGFuLCBiaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSwgaGFzQW5udWFsbHlQcmljZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBwcmljZSwgdW5pdCwgdGllcnMsIHRpZXJVbml0cyB9ID0gZ2V0UGxhblByaWNlKHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgY29uc3QgW3NlbGVjdGVkVGllciwgc2V0U2VsZWN0ZWRUaWVyXSA9IHVzZVN0YXRlKCk7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllcihzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSk7XHJcbiAgICB9LCBbc2VsZWN0ZWRUaWVyQnlGZWF0dXJlXSk7XHJcbiAgICAvLyBXZSBjdXJyZW50bHkgb25seSBzdXBwb3J0IHByaWNlcyB3aXRoIG9uZSB0aWVyIC0gc28gd2Ugc2VsZWN0IHRoZSBmaXJzdCBvbmVcclxuICAgIGNvbnN0IHRpZXJlZFByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKHBsYW5QcmljZSA9PiB7XHJcbiAgICAgICAgcmV0dXJuIHBsYW5QcmljZS5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kICYmIHBsYW5QcmljZS5pc1RpZXJlZFByaWNlO1xyXG4gICAgfSk7XHJcbiAgICBjb25zdCBmZWF0dXJlSWQgPSB0aWVyZWRQcmljZSA/IHRpZXJlZFByaWNlLmZlYXR1cmUuZmVhdHVyZUlkIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaGFuZGxlVGllckNoYW5nZSA9ICh0aWVyKSA9PiB7XHJcbiAgICAgICAgY29uc3QgdXBkYXRlZFRpZXJCeUZlYXR1cmUgPSB7fTtcclxuICAgICAgICB1cGRhdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdID0gdGllcjtcclxuICAgICAgICBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUodXBkYXRlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgfTtcclxuICAgIHVzZUVmZmVjdCgoKSA9PiB7XHJcbiAgICAgICAgaWYgKHRpZXJzKSB7XHJcbiAgICAgICAgICAgIGhhbmRsZVRpZXJDaGFuZ2Uoc2VsZWN0ZWRUaWVyQnlGZWF0dXJlW2ZlYXR1cmVJZF0pO1xyXG4gICAgICAgIH1cclxuICAgIH0sIFtdKTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChQbGFuUHJpY2VDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRleHRcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgICAgIHdpdGhTdGFydGluZ0F0Um93ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgc3R5bGU6IHsgbWluSGVpZ2h0OiAnMjBweCcgfSwgY2xhc3NOYW1lOiBcInN0aWdnLXN0YXJ0aW5nLWF0LXRleHRcIiwgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBzaG93U3RhcnRpbmdBdCA/IHBheXdhbGxMb2NhbGUucHJpY2Uuc3RhcnRpbmdBdENhcHRpb24gOiBFTVBUWV9DSEFSKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VTcGFuLCB7IHZhcmlhbnQ6IFwiaDFcIiB9LCBwcmljZSksXHJcbiAgICAgICAgICAgIHdpdGhVbml0UHJpY2VSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdW5pdC1hbmQtYmlsbGluZy1wZXJpb2QtdGV4dFwiLCBzdHlsZTogeyBtaW5IZWlnaHQ6ICc0OHB4JyB9IH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFVuaXRTcGFuLCB7IHNwYW46IHRydWUsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgdW5pdCksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFByaWNlQmlsbGluZ1BlcmlvZCwgeyBwbGFuOiBwbGFuLCBiaWxsaW5nUGVyaW9kOiBiaWxsaW5nUGVyaW9kLCBoYXNBbm51YWxseVByaWNlOiBoYXNBbm51YWxseVByaWNlLCBoYXNNb250aGx5UHJpY2U6IGhhc01vbnRobHlQcmljZSwgcGF5d2FsbExvY2FsZTogcGF5d2FsbExvY2FsZSB9KSkpLFxyXG4gICAgICAgICAgICB3aXRoVGllcnNSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllcnNTZWxlY3RDb250YWluZXIsIHsgY29tcG9uZW50SWQ6IGAke3BsYW4uaWR9XyR7ZmVhdHVyZUlkfV90aWVyYCwgdGllcnM6IHRpZXJzLCB0aWVyVW5pdHM6IHRpZXJVbml0cywgc2VsZWN0ZWRUaWVyOiBzZWxlY3RlZFRpZXIsIGhhbmRsZVRpZXJDaGFuZ2U6IGhhbmRsZVRpZXJDaGFuZ2UgfSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QbGFuUHJpY2UuanMubWFwIl19 */",
1250
1253
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
1251
1254
  });
1252
1255
 
@@ -1254,14 +1257,15 @@ function PriceBillingPeriod(_ref) {
1254
1257
  var plan = _ref.plan,
1255
1258
  billingPeriod = _ref.billingPeriod,
1256
1259
  hasMonthlyPrice = _ref.hasMonthlyPrice,
1257
- hasAnnuallyPrice = _ref.hasAnnuallyPrice;
1260
+ hasAnnuallyPrice = _ref.hasAnnuallyPrice,
1261
+ paywallLocale = _ref.paywallLocale;
1258
1262
  var hasPrice = plan.pricePoints.find(function (pricePoint) {
1259
1263
  return pricePoint.billingPeriod === billingPeriod;
1260
1264
  });
1261
1265
  var content = EMPTY_CHAR;
1262
1266
 
1263
1267
  if (hasPrice && hasMonthlyPrice && hasAnnuallyPrice) {
1264
- content = ", billed " + billingPeriod.toLowerCase();
1268
+ content = (paywallLocale.price.billingPeriod == null ? void 0 : paywallLocale.price.billingPeriod(billingPeriod)) || ", billed " + billingPeriod.toLowerCase();
1265
1269
  }
1266
1270
 
1267
1271
  return React__default.createElement(Typography, {
@@ -1340,7 +1344,8 @@ var PlanPrice = function PlanPrice(_ref2) {
1340
1344
  plan: plan,
1341
1345
  billingPeriod: billingPeriod,
1342
1346
  hasAnnuallyPrice: hasAnnuallyPrice,
1343
- hasMonthlyPrice: hasMonthlyPrice
1347
+ hasMonthlyPrice: hasMonthlyPrice,
1348
+ paywallLocale: paywallLocale
1344
1349
  })), withTiersRow && React__default.createElement(TiersSelectContainer, {
1345
1350
  componentId: plan.id + "_" + featureId + "_tier",
1346
1351
  tiers: tiers,
@@ -3303,6 +3308,9 @@ function getResolvedPaywallLocalize(localizeOverride) {
3303
3308
  },
3304
3309
  price: {
3305
3310
  startingAtCaption: 'Starts at',
3311
+ pricePeriod: function pricePeriod(billingPeriod) {
3312
+ return billingPeriod === Stigg.BillingPeriod.Monthly ? '/ month' : '/ year';
3313
+ },
3306
3314
  free: function free(currency) {
3307
3315
  return {
3308
3316
  price: (currency == null ? void 0 : currency.symbol) + "0"
@@ -4233,29 +4241,22 @@ var SvgTrash = function SvgTrash(props) {
4233
4241
  })));
4234
4242
  };
4235
4243
 
4236
- var _g$3, _path$c, _defs$4;
4244
+ var _path$c, _path2$4;
4237
4245
  function _extends$g() { _extends$g = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$g.apply(this, arguments); }
4238
4246
  var SvgPaymentMethod = function SvgPaymentMethod(props) {
4239
4247
  return /*#__PURE__*/React.createElement("svg", _extends$g({
4240
4248
  width: 24,
4241
- height: 16,
4249
+ height: 24,
4242
4250
  fill: "none",
4243
4251
  xmlns: "http://www.w3.org/2000/svg"
4244
- }, props), _g$3 || (_g$3 = /*#__PURE__*/React.createElement("g", {
4245
- clipPath: "url(#payment-method_svg__a)"
4246
- }, /*#__PURE__*/React.createElement("path", {
4247
- d: "M22 0H2a2 2 0 0 0-2 2v12a2 2 0 0 0 2 2h20a2 2 0 0 0 2-2V2a2 2 0 0 0-2-2Z",
4252
+ }, props), _path$c || (_path$c = /*#__PURE__*/React.createElement("path", {
4253
+ d: "M21.167 4H2.833C1.821 4 1 4.895 1 6v12c0 1.105.82 2 1.833 2h18.334C22.179 20 23 19.105 23 18V6c0-1.105-.82-2-1.833-2Z",
4248
4254
  fill: "#C6C6C7"
4249
- }))), _path$c || (_path$c = /*#__PURE__*/React.createElement("path", {
4255
+ })), _path2$4 || (_path2$4 = /*#__PURE__*/React.createElement("path", {
4250
4256
  opacity: 0.3,
4251
- d: "M18.75 12.429H16.5c-.488 0-.75-.229-.75-.762 0-.534.262-.762.75-.762h2.25c.488 0 .75.228.75.762 0 .533-.262.762-.75.762Zm-4.5 0H12c-.488 0-.75-.229-.75-.762 0-.534.262-.762.75-.762h2.25c.488 0 .75.228.75.762 0 .533-.262.762-.75.762Zm-4.5 0H7.5c-.487 0-.75-.229-.75-.762 0-.534.263-.762.75-.762h2.25c.488 0 .75.228.75.762 0 .533-.262.762-.75.762Zm-4.5 0H3c-.487 0-.75-.229-.75-.762 0-.534.263-.762.75-.762h2.25c.487 0 .75.228.75.762 0 .533-.263.762-.75.762Z",
4257
+ d: "M19.75 16.429H17.5c-.488 0-.75-.229-.75-.762 0-.534.262-.762.75-.762h2.25c.488 0 .75.228.75.762 0 .533-.262.762-.75.762Zm-4.5 0H13c-.488 0-.75-.229-.75-.762 0-.534.262-.762.75-.762h2.25c.488 0 .75.228.75.762 0 .533-.262.762-.75.762Zm-4.5 0H8.5c-.488 0-.75-.229-.75-.762 0-.534.262-.762.75-.762h2.25c.488 0 .75.228.75.762 0 .533-.262.762-.75.762Zm-4.5 0H4c-.487 0-.75-.229-.75-.762 0-.534.263-.762.75-.762h2.25c.487 0 .75.228.75.762 0 .533-.263.762-.75.762Z",
4252
4258
  fill: "#000"
4253
- })), _defs$4 || (_defs$4 = /*#__PURE__*/React.createElement("defs", null, /*#__PURE__*/React.createElement("clipPath", {
4254
- id: "payment-method_svg__a"
4255
- }, /*#__PURE__*/React.createElement("path", {
4256
- fill: "#fff",
4257
- d: "M0 0h24v16H0z"
4258
- })))));
4259
+ })));
4259
4260
  };
4260
4261
 
4261
4262
  var _circle;
@@ -4995,7 +4996,7 @@ function UpcomingBilling(_ref3) {
4995
4996
  }, content);
4996
4997
  }
4997
4998
 
4998
- var _path$i, _path2$4;
4999
+ var _path$i, _path2$5;
4999
5000
  function _extends$n() { _extends$n = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$n.apply(this, arguments); }
5000
5001
  var SvgSandClock = function SvgSandClock(props) {
5001
5002
  return /*#__PURE__*/React.createElement("svg", _extends$n({
@@ -5006,7 +5007,7 @@ var SvgSandClock = function SvgSandClock(props) {
5006
5007
  }, props), _path$i || (_path$i = /*#__PURE__*/React.createElement("path", {
5007
5008
  d: "M12.947 13.6h-1.013l.001-2.824a.522.522 0 0 0-.18-.392L8.622 7.918l3.134-2.465a.497.497 0 0 0 .18-.392V2.4h1.012c.278 0 .49-.212.49-.49a.481.481 0 0 0-.49-.49H3.053a.481.481 0 0 0-.49.49c0 .278.213.49.49.49h1.013l-.001 2.661c0 .147.065.294.18.392l3.117 2.465-3.117 2.466a.497.497 0 0 0-.18.392V13.6H3.054a.481.481 0 0 0-.49.49c0 .277.213.49.49.49h9.894c.277 0 .49-.213.49-.49a.481.481 0 0 0-.49-.49ZM5.045 2.4h5.91v2.416L8 7.167l-2.955-2.35V2.4Zm0 8.62L8 8.67l2.955 2.334v2.58h-5.91V11.02Z",
5008
5009
  fill: "#fff"
5009
- })), _path2$4 || (_path2$4 = /*#__PURE__*/React.createElement("path", {
5010
+ })), _path2$5 || (_path2$5 = /*#__PURE__*/React.createElement("path", {
5010
5011
  fillRule: "evenodd",
5011
5012
  clipRule: "evenodd",
5012
5013
  d: "M3.053 1.254h9.894c.37 0 .657.287.657.656 0 .37-.287.657-.657.657h-.845L12.1 5.06c0 .214-.088.39-.238.519l-.005.004L8.89 7.918l2.974 2.34c.152.13.238.323.238.518l-.001 2.657h.846c.37 0 .657.287.657.657 0 .37-.288.657-.657.657H3.053a.648.648 0 0 1-.657-.657c0-.37.287-.657.657-.657h.846v-2.657c0-.214.087-.39.237-.519l.005-.004 2.953-2.335L4.136 5.58a.688.688 0 0 1-.238-.519V2.567h-.845a.648.648 0 0 1-.657-.656c0-.37.287-.657.657-.657Zm9.894.333H3.053a.315.315 0 0 0-.323.324c0 .185.138.323.323.323h1.18l-.001 2.827c0 .099.043.198.119.264l3.28 2.593-3.28 2.594a.33.33 0 0 0-.119.264v2.99H3.053a.315.315 0 0 0-.323.324c0 .185.138.323.323.323h9.894a.315.315 0 0 0 .323-.323.315.315 0 0 0-.323-.323h-1.18l.001-2.991a.355.355 0 0 0-.119-.264L8.351 7.918l3.298-2.593a.33.33 0 0 0 .119-.264V2.233h1.18a.315.315 0 0 0 .323-.323.315.315 0 0 0-.324-.323Zm-8.069.646h6.244v2.664L8 7.38 4.878 4.897V2.233Zm.334.334v2.169L8 6.955l2.788-2.22V2.568H5.212ZM8 8.457l3.122 2.467v2.827H4.878v-2.81L8 8.456Zm0 .425-2.788 2.219v2.316h5.576v-2.332L8 8.882Z",
@@ -6475,13 +6476,6 @@ function resolveBillingPeriod(_ref2) {
6475
6476
  var hasAnnualPrices = plan == null ? void 0 : plan.pricePoints.some(function (pricePoint) {
6476
6477
  return pricePoint.billingPeriod === sdk.BillingPeriod.Annually;
6477
6478
  });
6478
- var isUpdate = (activeSubscription == null ? void 0 : (_activeSubscription$p2 = activeSubscription.plan) == null ? void 0 : _activeSubscription$p2.id) === (plan == null ? void 0 : plan.id);
6479
-
6480
- if (isUpdate) {
6481
- var _activeSubscription$p3;
6482
-
6483
- return (activeSubscription == null ? void 0 : (_activeSubscription$p3 = activeSubscription.price) == null ? void 0 : _activeSubscription$p3.billingPeriod) || sdk.BillingPeriod.Monthly;
6484
- }
6485
6479
 
6486
6480
  if (preferredBillingPeriod) {
6487
6481
  if (preferredBillingPeriod === sdk.BillingPeriod.Monthly && hasMonthlyPrices) {
@@ -6493,6 +6487,14 @@ function resolveBillingPeriod(_ref2) {
6493
6487
  }
6494
6488
  }
6495
6489
 
6490
+ var isUpdate = (activeSubscription == null ? void 0 : (_activeSubscription$p2 = activeSubscription.plan) == null ? void 0 : _activeSubscription$p2.id) === (plan == null ? void 0 : plan.id);
6491
+
6492
+ if (isUpdate) {
6493
+ var _activeSubscription$p3;
6494
+
6495
+ return (activeSubscription == null ? void 0 : (_activeSubscription$p3 = activeSubscription.price) == null ? void 0 : _activeSubscription$p3.billingPeriod) || sdk.BillingPeriod.Monthly;
6496
+ }
6497
+
6496
6498
  if (activeSubscription != null && (_activeSubscription$p4 = activeSubscription.price) != null && _activeSubscription$p4.billingPeriod) {
6497
6499
  var _activeSubscription$p5;
6498
6500
 
@@ -6593,7 +6595,8 @@ var CHECKOUT_STEPS = [{
6593
6595
  var INITIAL_STATE = {
6594
6596
  activeStep: 0,
6595
6597
  completedSteps: [],
6596
- steps: CHECKOUT_STEPS
6598
+ steps: CHECKOUT_STEPS,
6599
+ isDisabled: false
6597
6600
  };
6598
6601
  function getProgressBarInitialState(_ref) {
6599
6602
  var availableAddons = _ref.availableAddons;
@@ -6652,6 +6655,10 @@ function useGoNext() {
6652
6655
  return setState(function (_ref4) {
6653
6656
  var progressBar = _ref4.progressBar;
6654
6657
 
6658
+ if (progressBar.isDisabled) {
6659
+ return;
6660
+ }
6661
+
6655
6662
  if (!progressBar.completedSteps.includes(progressBar.activeStep)) {
6656
6663
  progressBar.completedSteps.push(progressBar.activeStep);
6657
6664
  }
@@ -6663,15 +6670,30 @@ function useGoNext() {
6663
6670
  };
6664
6671
  }
6665
6672
 
6673
+ function useSetIsDisabled() {
6674
+ var _useCheckoutContext5 = useCheckoutContext(),
6675
+ setState = _useCheckoutContext5[1];
6676
+
6677
+ return function (isDisabled) {
6678
+ return setState(function (_ref5) {
6679
+ var progressBar = _ref5.progressBar;
6680
+ progressBar.isDisabled = !!isDisabled;
6681
+ });
6682
+ };
6683
+ }
6684
+
6666
6685
  function useProgressBarModel() {
6667
6686
  var progressBarState = useProgressBarState();
6687
+ var currentStep = progressBarState.steps[progressBarState.activeStep];
6668
6688
  return {
6689
+ currentStep: currentStep,
6669
6690
  progressBarState: progressBarState,
6670
6691
  isLastStep: progressBarState.activeStep === progressBarState.steps.length - 1,
6671
6692
  isCheckoutComplete: isCheckoutComplete(progressBarState),
6672
6693
  setActiveStep: useSetActiveStep(),
6673
6694
  markStepAsCompleted: useMarkStepAsCompleted(),
6674
- goNext: useGoNext()
6695
+ goNext: useGoNext(),
6696
+ setIsDisabled: useSetIsDisabled()
6675
6697
  };
6676
6698
  }
6677
6699
 
@@ -6680,14 +6702,34 @@ function useSubscriptionModel() {
6680
6702
  _useCheckoutContext$ = _useCheckoutContext[0],
6681
6703
  planStep = _useCheckoutContext$.planStep,
6682
6704
  addonsStep = _useCheckoutContext$.addonsStep,
6683
- promotionCode = _useCheckoutContext$.promotionCode;
6705
+ promotionCode = _useCheckoutContext$.promotionCode,
6706
+ paymentStep = _useCheckoutContext$.paymentStep;
6684
6707
 
6685
6708
  return _extends({}, planStep, {
6686
6709
  addons: addonsStep.addons,
6687
- promotionCode: promotionCode
6710
+ promotionCode: promotionCode,
6711
+ billingAddress: paymentStep.billingAddress,
6712
+ taxPercentage: paymentStep.taxPercentage
6688
6713
  });
6689
6714
  }
6690
6715
 
6716
+ function mapBillingInformation(_ref) {
6717
+ var billingAddress = _ref.billingAddress,
6718
+ taxPercentage = _ref.taxPercentage;
6719
+
6720
+ if (!billingAddress && !taxPercentage) {
6721
+ return {};
6722
+ }
6723
+
6724
+ return {
6725
+ billingInformation: _extends({}, billingAddress ? {
6726
+ billingAddress: billingAddress
6727
+ } : {}, taxPercentage ? {
6728
+ taxPercentage: taxPercentage
6729
+ } : {})
6730
+ };
6731
+ }
6732
+
6691
6733
  var usePreviewSubscriptionAction = function usePreviewSubscriptionAction() {
6692
6734
  var _useStiggContext = useStiggContext(),
6693
6735
  stigg = _useStiggContext.stigg;
@@ -6702,22 +6744,22 @@ var usePreviewSubscriptionAction = function usePreviewSubscriptionAction() {
6702
6744
  var _useCheckoutModel = useCheckoutModel(),
6703
6745
  checkoutState = _useCheckoutModel.checkoutState;
6704
6746
 
6705
- var _ref = checkoutState || {},
6706
- plan = _ref.plan,
6707
- customer = _ref.customer;
6747
+ var _ref2 = checkoutState || {},
6748
+ plan = _ref2.plan,
6749
+ customer = _ref2.customer;
6708
6750
 
6709
6751
  var previewSubscriptionAction = React.useCallback( /*#__PURE__*/function () {
6710
- var _ref2 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee(_temp) {
6711
- var _ref3, promotionCode, estimateAddons, subscriptionPreview, errorMessage, previewSubscriptionProps, _error$message, _ref5, errorMsg;
6752
+ var _ref3 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee(_temp) {
6753
+ var _ref4, promotionCode, estimateAddons, subscriptionPreview, errorMessage, previewSubscriptionProps, _error$message, _ref6, errorMsg;
6712
6754
 
6713
6755
  return runtime_1.wrap(function _callee$(_context) {
6714
6756
  while (1) {
6715
6757
  switch (_context.prev = _context.next) {
6716
6758
  case 0:
6717
- _ref3 = _temp === void 0 ? {} : _temp, promotionCode = _ref3.promotionCode;
6718
- estimateAddons = subscription.addons.map(function (_ref4) {
6719
- var addon = _ref4.addon,
6720
- quantity = _ref4.quantity;
6759
+ _ref4 = _temp === void 0 ? {} : _temp, promotionCode = _ref4.promotionCode;
6760
+ estimateAddons = subscription.addons.map(function (_ref5) {
6761
+ var addon = _ref5.addon,
6762
+ quantity = _ref5.quantity;
6721
6763
  return {
6722
6764
  addonId: addon.id,
6723
6765
  quantity: quantity
@@ -6732,7 +6774,7 @@ var usePreviewSubscriptionAction = function usePreviewSubscriptionAction() {
6732
6774
  break;
6733
6775
  }
6734
6776
 
6735
- previewSubscriptionProps = {
6777
+ previewSubscriptionProps = _extends({
6736
6778
  customerId: customer.id,
6737
6779
  planId: plan == null ? void 0 : plan.id,
6738
6780
  billableFeatures: subscription.billableFeatures,
@@ -6741,7 +6783,10 @@ var usePreviewSubscriptionAction = function usePreviewSubscriptionAction() {
6741
6783
  promotionCode: promotionCode != null ? promotionCode : subscription.promotionCode,
6742
6784
  resourceId: resourceId,
6743
6785
  billingCountryCode: planStep.billingCountryCode
6744
- };
6786
+ }, mapBillingInformation({
6787
+ billingAddress: subscription.billingAddress,
6788
+ taxPercentage: subscription.taxPercentage
6789
+ }));
6745
6790
  _context.next = 9;
6746
6791
  return stigg.previewSubscription(previewSubscriptionProps);
6747
6792
 
@@ -6755,7 +6800,7 @@ var usePreviewSubscriptionAction = function usePreviewSubscriptionAction() {
6755
6800
  case 12:
6756
6801
  _context.prev = 12;
6757
6802
  _context.t0 = _context["catch"](4);
6758
- _ref5 = (_context.t0 == null ? void 0 : (_error$message = _context.t0.message) == null ? void 0 : _error$message.split('Error:')) || [], errorMsg = _ref5[1];
6803
+ _ref6 = (_context.t0 == null ? void 0 : (_error$message = _context.t0.message) == null ? void 0 : _error$message.split('Error:')) || [], errorMsg = _ref6[1];
6759
6804
  errorMessage = errorMsg == null ? void 0 : errorMsg.trim();
6760
6805
 
6761
6806
  case 16:
@@ -6773,9 +6818,9 @@ var usePreviewSubscriptionAction = function usePreviewSubscriptionAction() {
6773
6818
  }));
6774
6819
 
6775
6820
  return function (_x) {
6776
- return _ref2.apply(this, arguments);
6821
+ return _ref3.apply(this, arguments);
6777
6822
  };
6778
- }(), [customer, plan, resourceId, stigg, subscription.addons, subscription.billingPeriod, subscription.billableFeatures, subscription.promotionCode, planStep.billingCountryCode]);
6823
+ }(), [customer, plan, resourceId, stigg, subscription.addons, subscription.billingPeriod, subscription.billableFeatures, subscription.promotionCode, subscription.billingAddress, subscription.taxPercentage, planStep.billingCountryCode]);
6779
6824
  return {
6780
6825
  previewSubscriptionAction: previewSubscriptionAction
6781
6826
  };
@@ -6794,7 +6839,7 @@ var usePreviewSubscription = function usePreviewSubscription() {
6794
6839
 
6795
6840
  React.useEffect(function () {
6796
6841
  var estimateSubscription = /*#__PURE__*/function () {
6797
- var _ref6 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee2() {
6842
+ var _ref7 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee2() {
6798
6843
  var _yield$previewSubscri, subscriptionPreview;
6799
6844
 
6800
6845
  return runtime_1.wrap(function _callee2$(_context2) {
@@ -6820,7 +6865,7 @@ var usePreviewSubscription = function usePreviewSubscription() {
6820
6865
  }));
6821
6866
 
6822
6867
  return function estimateSubscription() {
6823
- return _ref6.apply(this, arguments);
6868
+ return _ref7.apply(this, arguments);
6824
6869
  };
6825
6870
  }();
6826
6871
 
@@ -6833,9 +6878,11 @@ var usePreviewSubscription = function usePreviewSubscription() {
6833
6878
  };
6834
6879
 
6835
6880
  function getPaymentStepInitialState(_ref) {
6836
- var customer = _ref.customer;
6881
+ var customer = _ref.customer,
6882
+ taxPercentage = _ref.taxPercentage;
6837
6883
  return {
6838
- useNewPaymentMethod: !(customer != null && customer.paymentMethodDetails)
6884
+ useNewPaymentMethod: !(customer != null && customer.paymentMethodDetails),
6885
+ taxPercentage: taxPercentage
6839
6886
  };
6840
6887
  }
6841
6888
 
@@ -6861,9 +6908,20 @@ function useSetErrorMessage() {
6861
6908
  };
6862
6909
  }
6863
6910
 
6864
- function usePaymentState() {
6911
+ function useSetBillingAddress() {
6865
6912
  var _useCheckoutContext3 = useCheckoutContext(),
6866
- paymentStep = _useCheckoutContext3[0].paymentStep;
6913
+ setState = _useCheckoutContext3[1];
6914
+
6915
+ return function (billingAddress) {
6916
+ return setState(function (draft) {
6917
+ draft.paymentStep.billingAddress = billingAddress;
6918
+ });
6919
+ };
6920
+ }
6921
+
6922
+ function usePaymentState() {
6923
+ var _useCheckoutContext4 = useCheckoutContext(),
6924
+ paymentStep = _useCheckoutContext4[0].paymentStep;
6867
6925
 
6868
6926
  return paymentStep;
6869
6927
  }
@@ -6872,23 +6930,11 @@ function usePaymentStepModel() {
6872
6930
  var state = usePaymentState();
6873
6931
  return _extends({}, state, {
6874
6932
  setUseNewPaymentMethod: useSetUseNewPaymentMethod(),
6875
- setErrorMessage: useSetErrorMessage()
6933
+ setErrorMessage: useSetErrorMessage(),
6934
+ setBillingAddress: useSetBillingAddress()
6876
6935
  });
6877
6936
  }
6878
6937
 
6879
- function formatBillingPeriod(billingPeriod) {
6880
- switch (billingPeriod) {
6881
- case Stigg.BillingPeriod.Annually:
6882
- return 'Annual';
6883
-
6884
- case Stigg.BillingPeriod.Monthly:
6885
- return 'Monthly';
6886
-
6887
- default:
6888
- return '';
6889
- }
6890
- }
6891
-
6892
6938
  function getResolvedCheckoutLocalize(localizeOverride) {
6893
6939
  var checkoutDefaultLocalization = {
6894
6940
  changePlan: 'Change plan',
@@ -6897,17 +6943,16 @@ function getResolvedCheckoutLocalize(localizeOverride) {
6897
6943
  newPaymentMethodText: 'New payment method',
6898
6944
  newPaymentMethodBillingAddressTitle: 'Billing address',
6899
6945
  newPaymentMethodCardTitle: 'Payment method',
6900
- baseChargeText: function baseChargeText(_ref) {
6901
- var billingPeriod = _ref.billingPeriod;
6902
- return formatBillingPeriod(billingPeriod) + " charge";
6946
+ baseChargeText: function baseChargeText() {
6947
+ return 'Base charge';
6903
6948
  },
6904
6949
  totalText: 'Total due today',
6905
6950
  subTotalText: 'Subtotal',
6906
6951
  addCouponCodeText: 'Add coupon code',
6907
6952
  couponCodeTitle: 'Coupon code',
6908
6953
  addonsSectionTitle: 'Add-ons',
6909
- changesWillApplyAtEndOfBillingPeriod: function changesWillApplyAtEndOfBillingPeriod(_ref2) {
6910
- var billingPeriodEnd = _ref2.billingPeriodEnd;
6954
+ changesWillApplyAtEndOfBillingPeriod: function changesWillApplyAtEndOfBillingPeriod(_ref) {
6955
+ var billingPeriodEnd = _ref.billingPeriodEnd;
6911
6956
  return "Your changes will apply on the end of your current billing cycle on " + moment(billingPeriodEnd).format('MMM D, YYYY') + ".";
6912
6957
  },
6913
6958
  checkoutButton: {
@@ -6917,9 +6962,12 @@ function getResolvedCheckoutLocalize(localizeOverride) {
6917
6962
  purchaseText: 'Purchase'
6918
6963
  },
6919
6964
  appliedCreditsTitle: 'Applied credits',
6920
- taxTitle: function taxTitle(_ref3) {
6921
- var taxDetails = _ref3.taxDetails;
6922
- return taxDetails.displayName + " (" + (taxDetails == null ? void 0 : taxDetails.percentage) + "%)";
6965
+ taxTitle: function taxTitle(_ref2) {
6966
+ var taxDetails = _ref2.taxDetails;
6967
+ return "Tax (" + (taxDetails == null ? void 0 : taxDetails.percentage) + "%)";
6968
+ },
6969
+ downgradeToFreeAlertText: function downgradeToFreeAlertText() {
6970
+ return "We\u2019re sorry to see you downgrade your plan \uD83D\uDE1E";
6923
6971
  }
6924
6972
  };
6925
6973
  return merge(checkoutDefaultLocalization, localizeOverride);
@@ -6990,6 +7038,8 @@ var CheckoutContextProvider = function CheckoutContextProvider(_ref) {
6990
7038
  };
6991
7039
 
6992
7040
  function CheckoutProvider(_ref2) {
7041
+ var _billingInformation$t2;
7042
+
6993
7043
  var children = _ref2.children,
6994
7044
  textOverrides = _ref2.textOverrides,
6995
7045
  theme = _ref2.theme,
@@ -6997,7 +7047,8 @@ function CheckoutProvider(_ref2) {
6997
7047
  billableFeatures = _ref2.billableFeatures,
6998
7048
  resourceId = _ref2.resourceId,
6999
7049
  planId = _ref2.planId,
7000
- billingCountryCode = _ref2.billingCountryCode;
7050
+ billingCountryCode = _ref2.billingCountryCode,
7051
+ billingInformation = _ref2.billingInformation;
7001
7052
 
7002
7053
  var _useLoadCheckout = useLoadCheckout({
7003
7054
  resourceId: resourceId,
@@ -7010,7 +7061,7 @@ function CheckoutProvider(_ref2) {
7010
7061
  var configuration = checkout != null && checkout.configuration ? mapCheckoutConfiguration(checkout.configuration) : undefined;
7011
7062
  var globalTheme = useStiggTheme(configuration);
7012
7063
  var initialState = React.useMemo(function () {
7013
- var _checkout$resource;
7064
+ var _billingInformation$t, _checkout$resource;
7014
7065
 
7015
7066
  var checkoutTheme = getResolvedCheckoutTheme(globalTheme, theme);
7016
7067
  var checkoutLocalization = getResolvedCheckoutLocalize(textOverrides);
@@ -7027,7 +7078,8 @@ function CheckoutProvider(_ref2) {
7027
7078
  activeSubscription: checkout == null ? void 0 : checkout.activeSubscription
7028
7079
  });
7029
7080
  var paymentStep = getPaymentStepInitialState({
7030
- customer: checkout == null ? void 0 : checkout.customer
7081
+ customer: checkout == null ? void 0 : checkout.customer,
7082
+ taxPercentage: billingInformation == null ? void 0 : (_billingInformation$t = billingInformation.taxDetails) == null ? void 0 : _billingInformation$t.taxPercentage
7031
7083
  });
7032
7084
  var progressBar = getProgressBarInitialState({
7033
7085
  availableAddons: isLoading ? undefined : addonsStep.availableAddons
@@ -7048,7 +7100,7 @@ function CheckoutProvider(_ref2) {
7048
7100
  }
7049
7101
  };
7050
7102
  return initialState; // eslint-disable-next-line react-hooks/exhaustive-deps
7051
- }, [preferredBillingPeriod, billingCountryCode, checkout, isLoading]);
7103
+ }, [preferredBillingPeriod, billingCountryCode, checkout, isLoading, billingInformation == null ? void 0 : (_billingInformation$t2 = billingInformation.taxDetails) == null ? void 0 : _billingInformation$t2.taxPercentage]);
7052
7104
  return React__default.createElement(SdkThemeProvider, {
7053
7105
  key: checkout == null ? void 0 : checkout.plan.id,
7054
7106
  componentTheme: configuration
@@ -7209,13 +7261,13 @@ var CheckoutProgressBar = function CheckoutProgressBar() {
7209
7261
  flexDirection: "row",
7210
7262
  flex: 1,
7211
7263
  justifyContent: "flex-start"
7212
- }, isLoadingCheckoutData && React__default.createElement(Skeleton, {
7264
+ }, isLoadingCheckoutData ? React__default.createElement(Skeleton, {
7213
7265
  width: 120,
7214
7266
  height: 20,
7215
7267
  style: {
7216
7268
  marginTop: 8
7217
7269
  }
7218
- }), !isLoadingCheckoutData && React__default.createElement(StyledStepButton, {
7270
+ }) : React__default.createElement(StyledStepButton, {
7219
7271
  onClick: function onClick() {
7220
7272
  return setActiveStep(index);
7221
7273
  },
@@ -7399,7 +7451,7 @@ function usePromotionCodeModel() {
7399
7451
  };
7400
7452
  }
7401
7453
 
7402
- var _g$4;
7454
+ var _g$3;
7403
7455
  function _extends$o() { _extends$o = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$o.apply(this, arguments); }
7404
7456
  var SvgPlusIcon = function SvgPlusIcon(props) {
7405
7457
  return /*#__PURE__*/React.createElement("svg", _extends$o({
@@ -7407,7 +7459,7 @@ var SvgPlusIcon = function SvgPlusIcon(props) {
7407
7459
  height: 20,
7408
7460
  fill: "none",
7409
7461
  xmlns: "http://www.w3.org/2000/svg"
7410
- }, props), _g$4 || (_g$4 = /*#__PURE__*/React.createElement("g", {
7462
+ }, props), _g$3 || (_g$3 = /*#__PURE__*/React.createElement("g", {
7411
7463
  stroke: "#327EEE",
7412
7464
  strokeWidth: 2,
7413
7465
  strokeLinecap: "round",
@@ -7647,19 +7699,77 @@ var PromotionCodeSection = function PromotionCodeSection(_ref) {
7647
7699
  return React__default.createElement(PromotionCodeSectionContainer, null, content);
7648
7700
  };
7649
7701
 
7650
- function StripePaymentForm() {
7702
+ var _excluded$6 = ["postal_code"];
7703
+ function StripePaymentForm(_ref) {
7651
7704
  var _configuration$conten;
7652
7705
 
7706
+ var onBillingAddressChange = _ref.onBillingAddressChange;
7707
+
7653
7708
  var _useCheckoutModel = useCheckoutModel(),
7654
7709
  checkoutState = _useCheckoutModel.checkoutState,
7655
7710
  checkoutLocalization = _useCheckoutModel.checkoutLocalization,
7656
- widgetState = _useCheckoutModel.widgetState;
7711
+ widgetState = _useCheckoutModel.widgetState,
7712
+ setWidgetReadOnly = _useCheckoutModel.setWidgetReadOnly;
7657
7713
 
7658
- var _ref = checkoutState || {},
7659
- customer = _ref.customer,
7660
- configuration = _ref.configuration;
7714
+ var _usePaymentStepModel = usePaymentStepModel(),
7715
+ setBillingAddress = _usePaymentStepModel.setBillingAddress;
7716
+
7717
+ var _ref2 = checkoutState || {},
7718
+ customer = _ref2.customer,
7719
+ configuration = _ref2.configuration;
7661
7720
 
7662
7721
  var readOnly = widgetState.readOnly;
7722
+
7723
+ var handleAddressChange = function handleAddressChange(args) {
7724
+ if (!args.complete) {
7725
+ return;
7726
+ }
7727
+
7728
+ var _args$value$address = args.value.address,
7729
+ postalCode = _args$value$address.postal_code,
7730
+ addressFields = _objectWithoutPropertiesLoose(_args$value$address, _excluded$6);
7731
+
7732
+ var billingAddress = _extends({
7733
+ postalCode: postalCode
7734
+ }, addressFields);
7735
+
7736
+ setWidgetReadOnly(true);
7737
+ setBillingAddress(billingAddress);
7738
+
7739
+ if (onBillingAddressChange) {
7740
+ var callExternalBillingAddressChanged = /*#__PURE__*/function () {
7741
+ var _ref3 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee() {
7742
+ return runtime_1.wrap(function _callee$(_context) {
7743
+ while (1) {
7744
+ switch (_context.prev = _context.next) {
7745
+ case 0:
7746
+ _context.next = 2;
7747
+ return onBillingAddressChange({
7748
+ billingAddress: billingAddress
7749
+ });
7750
+
7751
+ case 2:
7752
+ setWidgetReadOnly(false);
7753
+
7754
+ case 3:
7755
+ case "end":
7756
+ return _context.stop();
7757
+ }
7758
+ }
7759
+ }, _callee);
7760
+ }));
7761
+
7762
+ return function callExternalBillingAddressChanged() {
7763
+ return _ref3.apply(this, arguments);
7764
+ };
7765
+ }();
7766
+
7767
+ void callExternalBillingAddressChanged();
7768
+ } else {
7769
+ setWidgetReadOnly(false);
7770
+ }
7771
+ };
7772
+
7663
7773
  return React__default.createElement(material.Grid, {
7664
7774
  flexDirection: "column",
7665
7775
  container: true,
@@ -7675,10 +7785,11 @@ function StripePaymentForm() {
7675
7785
  }, React__default.createElement(Typography, {
7676
7786
  variant: "h6"
7677
7787
  }, checkoutLocalization.newPaymentMethodBillingAddressTitle), React__default.createElement(reactStripeJs.AddressElement, {
7788
+ onChange: handleAddressChange,
7678
7789
  options: {
7679
7790
  mode: 'billing',
7680
7791
  fields: {
7681
- phone: !!(configuration != null && (_configuration$conten = configuration.content) != null && _configuration$conten.collectPhoneNumber) ? 'always' : 'auto'
7792
+ phone: configuration != null && (_configuration$conten = configuration.content) != null && _configuration$conten.collectPhoneNumber ? 'always' : 'auto'
7682
7793
  },
7683
7794
  defaultValues: _extends({}, (customer == null ? void 0 : customer.name) && {
7684
7795
  name: customer.name
@@ -7766,10 +7877,10 @@ function useSubscriptionState() {
7766
7877
  });
7767
7878
 
7768
7879
  if (!(plan != null && plan.id)) {
7769
- return;
7880
+ return undefined;
7770
7881
  }
7771
7882
 
7772
- return {
7883
+ return _extends({
7773
7884
  resourceId: resourceId,
7774
7885
  planId: plan.id,
7775
7886
  billingPeriod: subscription.billingPeriod,
@@ -7777,7 +7888,11 @@ function useSubscriptionState() {
7777
7888
  addons: addons,
7778
7889
  promotionCode: subscription.promotionCode,
7779
7890
  billingCountryCode: subscription.billingCountryCode
7780
- };
7891
+ }, subscription.taxPercentage ? {
7892
+ billingInformation: {
7893
+ taxPercentage: subscription.taxPercentage
7894
+ }
7895
+ } : {});
7781
7896
  }
7782
7897
 
7783
7898
  function handleStripeFormValidations(_x) {
@@ -7786,7 +7901,7 @@ function handleStripeFormValidations(_x) {
7786
7901
 
7787
7902
  function _handleStripeFormValidations() {
7788
7903
  _handleStripeFormValidations = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee(_ref) {
7789
- var elements, _yield$elements$submi, elementsError;
7904
+ var elements, errorMessage, _yield$elements$submi, elementsError;
7790
7905
 
7791
7906
  return runtime_1.wrap(function _callee$(_context) {
7792
7907
  while (1) {
@@ -7795,39 +7910,42 @@ function _handleStripeFormValidations() {
7795
7910
  elements = _ref.elements;
7796
7911
 
7797
7912
  if (elements) {
7798
- _context.next = 4;
7913
+ _context.next = 5;
7799
7914
  break;
7800
7915
  }
7801
7916
 
7802
- console.error('Stripe elements not initialized');
7917
+ errorMessage = 'Stripe elements not initialized';
7918
+ console.error(errorMessage);
7803
7919
  return _context.abrupt("return", {
7804
- success: false
7920
+ success: false,
7921
+ errorMessage: errorMessage
7805
7922
  });
7806
7923
 
7807
- case 4:
7808
- _context.next = 6;
7924
+ case 5:
7925
+ _context.next = 7;
7809
7926
  return elements.submit();
7810
7927
 
7811
- case 6:
7928
+ case 7:
7812
7929
  _yield$elements$submi = _context.sent;
7813
7930
  elementsError = _yield$elements$submi.error;
7814
7931
 
7815
7932
  if (!elementsError) {
7816
- _context.next = 11;
7933
+ _context.next = 12;
7817
7934
  break;
7818
7935
  }
7819
7936
 
7820
7937
  console.log(elementsError.message);
7821
7938
  return _context.abrupt("return", {
7822
- success: false
7939
+ success: false,
7940
+ errorMessage: elementsError.message || ''
7823
7941
  });
7824
7942
 
7825
- case 11:
7943
+ case 12:
7826
7944
  return _context.abrupt("return", {
7827
7945
  success: true
7828
7946
  });
7829
7947
 
7830
- case 12:
7948
+ case 13:
7831
7949
  case "end":
7832
7950
  return _context.stop();
7833
7951
  }
@@ -10971,11 +11089,12 @@ var BACKGROUND_COLOR = /*#__PURE__*/Color('#0b2f7a').alpha(0.3).toString();
10971
11089
  var CheckoutSuccessContainer = /*#__PURE__*/_styled(material.Box, {
10972
11090
  target: "eeyi5d30",
10973
11091
  label: "CheckoutSuccessContainer"
10974
- })("position:absolute;top:0;left:0;bottom:0;right:0;background-color:", BACKGROUND_COLOR, ";* rect{fill:transparent;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0U3VjY2Vzcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTZDIiwiZmlsZSI6IkNoZWNrb3V0U3VjY2Vzcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEJveCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgQ29sb3IgZnJvbSAnY29sb3InO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgTG90dGllIGZyb20gJ3JlYWN0LWxvdHRpZSc7XHJcbmltcG9ydCBhbmltYXRpb25EYXRhIGZyb20gJy4uLy4uLy4uL2Fzc2V0cy9sb3R0aWUvY2hlY2tvdXQtc3VjY2Vzcy5qc29uJztcclxuZXhwb3J0IGNvbnN0IEFOSU1BVElPTl9EVVJBVElPTiA9IDUwMDA7XHJcbmNvbnN0IEJBQ0tHUk9VTkRfQ09MT1IgPSBDb2xvcignIzBiMmY3YScpLmFscGhhKDAuMykudG9TdHJpbmcoKTtcclxuY29uc3QgQ2hlY2tvdXRTdWNjZXNzQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgYm90dG9tOiAwO1xuICByaWdodDogMDtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtCQUNLR1JPVU5EX0NPTE9SfTtcbiAgKiByZWN0IHtcbiAgICBmaWxsOiB0cmFuc3BhcmVudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIENoZWNrb3V0U3VjY2VzcygpIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDaGVja291dFN1Y2Nlc3NDb250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMb3R0aWUsIHsgd2lkdGg6IDM1MCwgb3B0aW9uczogeyBsb29wOiBmYWxzZSwgYXV0b3BsYXk6IHRydWUsIGFuaW1hdGlvbkRhdGEgfSB9KSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0U3VjY2Vzcy5qcy5tYXAiXX0= */"));
11092
+ })("position:absolute;top:0;left:0;bottom:0;right:0;background-color:", BACKGROUND_COLOR, ";* rect{fill:transparent;}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkNoZWNrb3V0U3VjY2Vzcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUTZDIiwiZmlsZSI6IkNoZWNrb3V0U3VjY2Vzcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEJveCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgQ29sb3IgZnJvbSAnY29sb3InO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgTG90dGllIGZyb20gJ3JlYWN0LWxvdHRpZSc7XHJcbmltcG9ydCBhbmltYXRpb25EYXRhIGZyb20gJy4uLy4uLy4uL2Fzc2V0cy9sb3R0aWUvY2hlY2tvdXQtc3VjY2Vzcy5qc29uJztcclxuZXhwb3J0IGNvbnN0IEFOSU1BVElPTl9EVVJBVElPTiA9IDUwMDA7XHJcbmNvbnN0IEJBQ0tHUk9VTkRfQ09MT1IgPSBDb2xvcignIzBiMmY3YScpLmFscGhhKDAuMykudG9TdHJpbmcoKTtcclxuY29uc3QgQ2hlY2tvdXRTdWNjZXNzQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBwb3NpdGlvbjogYWJzb2x1dGU7XG4gIHRvcDogMDtcbiAgbGVmdDogMDtcbiAgYm90dG9tOiAwO1xuICByaWdodDogMDtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHtCQUNLR1JPVU5EX0NPTE9SfTtcbiAgKiByZWN0IHtcbiAgICBmaWxsOiB0cmFuc3BhcmVudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIENoZWNrb3V0U3VjY2VzcygpIHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChDaGVja291dFN1Y2Nlc3NDb250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMb3R0aWUsIHsgd2lkdGg6IDM1MCwgaXNDbGlja1RvUGF1c2VEaXNhYmxlZDogdHJ1ZSwgb3B0aW9uczogeyBsb29wOiBmYWxzZSwgYXV0b3BsYXk6IHRydWUsIGFuaW1hdGlvbkRhdGEgfSB9KSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUNoZWNrb3V0U3VjY2Vzcy5qcy5tYXAiXX0= */"));
10975
11093
 
10976
11094
  function CheckoutSuccess() {
10977
11095
  return React__default.createElement(CheckoutSuccessContainer, null, React__default.createElement(Lottie, {
10978
11096
  width: 350,
11097
+ isClickToPauseDisabled: true,
10979
11098
  options: {
10980
11099
  loop: false,
10981
11100
  autoplay: true,
@@ -11018,8 +11137,7 @@ function useSubmit(_ref) {
11018
11137
  var _ref3 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee2(e) {
11019
11138
  var _checkoutResults;
11020
11139
 
11021
- var checkoutResults, errorMessage, paymentMethodId, _yield$handleStripeFo, _success, paymentMethodResults, checkoutParams, checkoutAction, externalCheckoutResults, success;
11022
-
11140
+ var checkoutParams, checkoutResults, errorMessage, paymentMethodId, checkoutAction, externalCheckoutResults, checkoutActionResults, success;
11023
11141
  return runtime_1.wrap(function _callee2$(_context2) {
11024
11142
  while (1) {
11025
11143
  switch (_context2.prev = _context2.next) {
@@ -11031,80 +11149,92 @@ function useSubmit(_ref) {
11031
11149
  break;
11032
11150
  }
11033
11151
 
11034
- return _context2.abrupt("return");
11152
+ return _context2.abrupt("return", {
11153
+ success: false,
11154
+ errorMessage: 'Unexpected error, please contact support.'
11155
+ });
11035
11156
 
11036
11157
  case 3:
11037
- setWidgetReadOnly(true);
11158
+ checkoutParams = _extends({}, subscriptionState);
11038
11159
 
11039
- if (!useNewPaymentMethod) {
11040
- _context2.next = 17;
11041
- break;
11042
- }
11160
+ checkoutAction = /*#__PURE__*/function () {
11161
+ var _ref4 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee() {
11162
+ var _yield$handleStripeFo, _success, stripeValidationsErrorMessage, paymentMethodResults, applySubscriptionResults, nextActionResults;
11043
11163
 
11044
- _context2.next = 7;
11045
- return handleStripeFormValidations({
11046
- elements: elements
11047
- });
11164
+ return runtime_1.wrap(function _callee$(_context) {
11165
+ while (1) {
11166
+ switch (_context.prev = _context.next) {
11167
+ case 0:
11168
+ if (!useNewPaymentMethod) {
11169
+ _context.next = 13;
11170
+ break;
11171
+ }
11048
11172
 
11049
- case 7:
11050
- _yield$handleStripeFo = _context2.sent;
11051
- _success = _yield$handleStripeFo.success;
11173
+ _context.next = 3;
11174
+ return handleStripeFormValidations({
11175
+ elements: elements
11176
+ });
11052
11177
 
11053
- if (_success) {
11054
- _context2.next = 12;
11055
- break;
11056
- }
11178
+ case 3:
11179
+ _yield$handleStripeFo = _context.sent;
11180
+ _success = _yield$handleStripeFo.success;
11181
+ stripeValidationsErrorMessage = _yield$handleStripeFo.errorMessage;
11057
11182
 
11058
- setWidgetReadOnly(false);
11059
- return _context2.abrupt("return");
11183
+ if (_success) {
11184
+ _context.next = 8;
11185
+ break;
11186
+ }
11060
11187
 
11061
- case 12:
11062
- _context2.next = 14;
11063
- return handleNewPaymentMethod({
11064
- elements: elements,
11065
- stripe: stripe,
11066
- setupIntentClientSecret: setupIntentClientSecret
11067
- });
11188
+ return _context.abrupt("return", {
11189
+ success: false,
11190
+ errorMessage: stripeValidationsErrorMessage
11191
+ });
11068
11192
 
11069
- case 14:
11070
- paymentMethodResults = _context2.sent;
11193
+ case 8:
11194
+ _context.next = 10;
11195
+ return handleNewPaymentMethod({
11196
+ elements: elements,
11197
+ stripe: stripe,
11198
+ setupIntentClientSecret: setupIntentClientSecret
11199
+ });
11071
11200
 
11072
- if (!paymentMethodResults.success) {
11073
- errorMessage = paymentMethodResults.errorMessage;
11074
- }
11201
+ case 10:
11202
+ paymentMethodResults = _context.sent;
11075
11203
 
11076
- paymentMethodId = paymentMethodResults.paymentMethodId;
11204
+ if (!paymentMethodResults.success) {
11205
+ errorMessage = paymentMethodResults.errorMessage;
11206
+ }
11077
11207
 
11078
- case 17:
11079
- if (errorMessage) {
11080
- _context2.next = 29;
11081
- break;
11082
- }
11208
+ paymentMethodId = paymentMethodResults.paymentMethodId;
11083
11209
 
11084
- checkoutParams = _extends({}, subscriptionState, {
11085
- paymentMethodId: paymentMethodId
11086
- });
11210
+ case 13:
11211
+ if (!errorMessage) {
11212
+ _context.next = 15;
11213
+ break;
11214
+ }
11087
11215
 
11088
- checkoutAction = /*#__PURE__*/function () {
11089
- var _ref4 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee() {
11090
- var applySubscriptionResults, nextActionResults;
11091
- return runtime_1.wrap(function _callee$(_context) {
11092
- while (1) {
11093
- switch (_context.prev = _context.next) {
11094
- case 0:
11095
- _context.prev = 0;
11096
- _context.next = 3;
11216
+ return _context.abrupt("return", {
11217
+ success: false,
11218
+ errorMessage: errorMessage
11219
+ });
11220
+
11221
+ case 15:
11222
+ checkoutParams = _extends({}, checkoutParams, {
11223
+ paymentMethodId: paymentMethodId
11224
+ });
11225
+ _context.prev = 16;
11226
+ _context.next = 19;
11097
11227
  return stigg.applySubscription(checkoutParams);
11098
11228
 
11099
- case 3:
11229
+ case 19:
11100
11230
  applySubscriptionResults = _context.sent;
11101
- _context.next = 6;
11231
+ _context.next = 22;
11102
11232
  return handleStripeNextAction({
11103
11233
  applySubscriptionResults: applySubscriptionResults,
11104
11234
  stripe: stripe
11105
11235
  });
11106
11236
 
11107
- case 6:
11237
+ case 22:
11108
11238
  nextActionResults = _context.sent;
11109
11239
  checkoutResults = nextActionResults;
11110
11240
 
@@ -11117,9 +11247,9 @@ function useSubmit(_ref) {
11117
11247
  errorMessage: nextActionResults.errorMessage
11118
11248
  });
11119
11249
 
11120
- case 12:
11121
- _context.prev = 12;
11122
- _context.t0 = _context["catch"](0);
11250
+ case 28:
11251
+ _context.prev = 28;
11252
+ _context.t0 = _context["catch"](16);
11123
11253
  console.error(_context.t0);
11124
11254
  errorMessage = _context.t0 == null ? void 0 : _context.t0.message;
11125
11255
  return _context.abrupt("return", {
@@ -11127,12 +11257,12 @@ function useSubmit(_ref) {
11127
11257
  errorMessage: errorMessage
11128
11258
  });
11129
11259
 
11130
- case 17:
11260
+ case 33:
11131
11261
  case "end":
11132
11262
  return _context.stop();
11133
11263
  }
11134
11264
  }
11135
- }, _callee, null, [[0, 12]]);
11265
+ }, _callee, null, [[16, 28]]);
11136
11266
  }));
11137
11267
 
11138
11268
  return function checkoutAction() {
@@ -11140,56 +11270,68 @@ function useSubmit(_ref) {
11140
11270
  };
11141
11271
  }();
11142
11272
 
11273
+ setWidgetReadOnly(true);
11274
+
11143
11275
  if (!onCheckout) {
11144
- _context2.next = 27;
11276
+ _context2.next = 13;
11145
11277
  break;
11146
11278
  }
11147
11279
 
11148
- _context2.next = 23;
11280
+ _context2.next = 9;
11149
11281
  return onCheckout({
11150
11282
  checkoutParams: checkoutParams,
11151
11283
  checkoutAction: checkoutAction
11152
11284
  });
11153
11285
 
11154
- case 23:
11286
+ case 9:
11155
11287
  externalCheckoutResults = _context2.sent;
11156
11288
 
11157
11289
  if (!externalCheckoutResults.success && externalCheckoutResults.errorMessage) {
11158
11290
  errorMessage = externalCheckoutResults.errorMessage;
11159
11291
  }
11160
11292
 
11161
- _context2.next = 29;
11293
+ _context2.next = 17;
11162
11294
  break;
11163
11295
 
11164
- case 27:
11165
- _context2.next = 29;
11296
+ case 13:
11297
+ _context2.next = 15;
11166
11298
  return checkoutAction();
11167
11299
 
11168
- case 29:
11300
+ case 15:
11301
+ checkoutActionResults = _context2.sent;
11302
+
11303
+ if (!checkoutActionResults.success && checkoutActionResults.errorMessage) {
11304
+ errorMessage = checkoutActionResults.errorMessage;
11305
+ }
11306
+
11307
+ case 17:
11169
11308
  setWidgetReadOnly(false);
11170
11309
  success = !errorMessage && !!((_checkoutResults = checkoutResults) != null && _checkoutResults.subscription);
11171
11310
 
11172
- if (success && onSuccess) {
11173
- onSuccess();
11311
+ if (!(success && onSuccess)) {
11312
+ _context2.next = 23;
11313
+ break;
11174
11314
  }
11175
11315
 
11176
- _context2.next = 34;
11316
+ onSuccess();
11317
+ _context2.next = 23;
11177
11318
  return delay(ANIMATION_DURATION);
11178
11319
 
11179
- case 34:
11180
- _context2.next = 36;
11320
+ case 23:
11321
+ _context2.next = 25;
11181
11322
  return onCheckoutCompleted({
11182
11323
  success: success,
11183
11324
  error: errorMessage
11184
11325
  });
11185
11326
 
11186
- case 36:
11327
+ case 25:
11187
11328
  return _context2.abrupt("return", {
11188
11329
  results: checkoutResults,
11330
+ success: !errorMessage,
11189
11331
  errorMessage: errorMessage
11190
11332
  });
11191
11333
 
11192
- case 37:
11334
+ case 26:
11193
11335
  case "end":
11194
11336
  return _context2.stop();
11195
11337
  }
@@ -11336,7 +11478,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", {
11336
11478
  })( {
11337
11479
  name: "rdmn2i",
11338
11480
  styles: "&+&{margin-top:8px;}",
11339
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpbmVJdGVtcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUzRDIiwiZmlsZSI6IkxpbmVJdGVtcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEdyaWQgfSBmcm9tICdAbXVpL21hdGVyaWFsJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZCwgRGlzY291bnRUeXBlIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBjdXJyZW5jeVByaWNlRm9ybWF0dGVyIH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvY3VycmVuY3lVdGlscyc7XHJcbmltcG9ydCB7IGdldFRpZXJCeVF1YW50aXR5IH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5pbXBvcnQgeyBXaXRoU2tlbGV0b24gfSBmcm9tICcuL1dpdGhTa2VsZXRvbic7XHJcbmltcG9ydCB7IFNrZWxldG9uIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9Ta2VsZXRvbnMuc3R5bGUnO1xyXG5leHBvcnQgY29uc3QgTGluZUl0ZW1Db250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgJiArICYge1xuICAgIG1hcmdpbi10b3A6IDhweDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IExpbmVJdGVtUm93ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmV4cG9ydCBjb25zdCBnZXRQcmljZVN0cmluZyA9ICh7IGFtb3VudFBlck1vbnRoLCBwcmljZSwgcXVhbnRpdHksIH0pID0+IHtcclxuICAgIGNvbnN0IHsgYmlsbGluZ1BlcmlvZCB9ID0gcHJpY2U7XHJcbiAgICBsZXQgYmlsbGluZ1BlcmlvZFN0cmluZyA9IG51bGw7XHJcbiAgICBpZiAoYmlsbGluZ1BlcmlvZCA9PT0gQmlsbGluZ1BlcmlvZC5Bbm51YWxseSkge1xyXG4gICAgICAgIGFtb3VudFBlck1vbnRoIC89IDEyO1xyXG4gICAgICAgIGJpbGxpbmdQZXJpb2RTdHJpbmcgPSAnMTIgbW9udGhzJztcclxuICAgIH1cclxuICAgIGNvbnN0IGFkZG9uUHJpY2VGb3JtYXQgPSBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiBhbW91bnRQZXJNb250aCwgY3VycmVuY3k6IHByaWNlLmN1cnJlbmN5IH0pO1xyXG4gICAgcmV0dXJuIGAke3F1YW50aXR5ID4gMSA/IGAke3F1YW50aXR5fSB4ICR7YWRkb25QcmljZUZvcm1hdH0gZWFjaGAgOiBhZGRvblByaWNlRm9ybWF0fSR7YmlsbGluZ1BlcmlvZFN0cmluZyA/IGAgeCAke2JpbGxpbmdQZXJpb2RTdHJpbmd9YCA6ICcnfWA7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBCaWxsZWRQcmljZUxpbmVJdGVtID0gKHsgbGFiZWwsIHF1YW50aXR5LCBwcmljZSB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGJpbGxpbmdQZXJpb2QgfSA9IHByaWNlO1xyXG4gICAgbGV0IGFtb3VudFBlck1vbnRoO1xyXG4gICAgaWYgKHByaWNlLmlzVGllcmVkUHJpY2UpIHtcclxuICAgICAgICBjb25zdCB0aWVyID0gZ2V0VGllckJ5UXVhbnRpdHkocHJpY2UudGllcnMsIHF1YW50aXR5KTtcclxuICAgICAgICBhbW91bnRQZXJNb250aCA9IHRpZXIudW5pdFByaWNlLmFtb3VudDtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIGFtb3VudFBlck1vbnRoID0gcHJpY2UuYW1vdW50O1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Sb3csIHsgc3R5bGU6IHsgYWxpZ25JdGVtczogJ2ZsZXgtZW5kJyB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJwcmltYXJ5XCIgfSwgbGFiZWwpLFxyXG4gICAgICAgICAgICAgICAgKHF1YW50aXR5ID4gMSB8fCBiaWxsaW5nUGVyaW9kID09PSBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgZ2V0UHJpY2VTdHJpbmcoeyBhbW91bnRQZXJNb250aCwgcHJpY2UsIHF1YW50aXR5IH0pKSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgaXRlbTogdHJ1ZSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIsIHN0eWxlOiB7IHdvcmRCcmVhazogJ2JyZWFrLXdvcmQnIH0gfSwgY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudDogcXVhbnRpdHkgKiBhbW91bnRQZXJNb250aCwgY3VycmVuY3k6IHByaWNlLmN1cnJlbmN5IH0pKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudExpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgc3ViVG90YWwsIGRpc2NvdW50IH0gPSBzdWJzY3JpcHRpb25QcmV2aWV3IHx8IHt9O1xyXG4gICAgaWYgKCFzdWJUb3RhbCB8fCAhZGlzY291bnQpIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIGxldCBkaXNjb3VudEFtb3VudDtcclxuICAgIGlmIChkaXNjb3VudC50eXBlID09PSBEaXNjb3VudFR5cGUuUGVyY2VudGFnZSkge1xyXG4gICAgICAgIGRpc2NvdW50QW1vdW50ID0gLTEgKiBNYXRoLmFicygoZGlzY291bnQudmFsdWUgLyAxMDApICogc3ViVG90YWwuYW1vdW50KTtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIGRpc2NvdW50QW1vdW50ID0gLTEgKiBNYXRoLmFicyhkaXNjb3VudC52YWx1ZSk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgYERpc2NvdW50JHtkaXNjb3VudC50eXBlID09PSBEaXNjb3VudFR5cGUuUGVyY2VudGFnZSA/IGAgKCR7ZGlzY291bnQudmFsdWV9JSBvZmYpYCA6ICcnfWApLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiA1MCwgaGVpZ2h0OiAxNiB9KSkgOiAoY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudDogZGlzY291bnRBbW91bnQsIGN1cnJlbmN5OiBzdWJUb3RhbC5jdXJyZW5jeSB9KSkpKSkpO1xyXG59O1xyXG5leHBvcnQgY29uc3QgQXBwbGllZENyZWRpdHNMaW5lSXRlbSA9ICh7IHN1YnNjcmlwdGlvblByZXZpZXcsIGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3LCBjaGVja291dExvY2FsaXphdGlvbiwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBjcmVkaXRzIH0gPSBzdWJzY3JpcHRpb25QcmV2aWV3IHx8IHt9O1xyXG4gICAgaWYgKCFjcmVkaXRzIHx8IGNyZWRpdHMudXNlZC5hbW91bnQgPD0gMCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Sb3csIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNoZWNrb3V0TG9jYWxpemF0aW9uLmFwcGxpZWRDcmVkaXRzVGl0bGUpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChXaXRoU2tlbGV0b24sIHsgaXNMb2FkaW5nOiBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyB9LCBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiAtMSAqIGNyZWRpdHMudXNlZC5hbW91bnQsIGN1cnJlbmN5OiBjcmVkaXRzLnVzZWQuY3VycmVuY3kgfSkpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IFRheExpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHRheCwgdGF4RGV0YWlscyB9ID0gc3Vic2NyaXB0aW9uUHJldmlldyB8fCB7fTtcclxuICAgIGlmICghdGF4RGV0YWlscyB8fCAhdGF4KSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24udGF4VGl0bGUoeyB0YXhEZXRhaWxzIH0pKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoV2l0aFNrZWxldG9uLCB7IGlzTG9hZGluZzogaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcgfSwgY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudDogdGF4Py5hbW91bnQsIGN1cnJlbmN5OiB0YXg/LmN1cnJlbmN5IH0pKSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUxpbmVJdGVtcy5qcy5tYXAiXX0= */",
11481
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpbmVJdGVtcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUzRDIiwiZmlsZSI6IkxpbmVJdGVtcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEdyaWQgfSBmcm9tICdAbXVpL21hdGVyaWFsJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZCwgRGlzY291bnRUeXBlIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBjdXJyZW5jeVByaWNlRm9ybWF0dGVyIH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvY3VycmVuY3lVdGlscyc7XHJcbmltcG9ydCB7IGdldFRpZXJCeVF1YW50aXR5IH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5pbXBvcnQgeyBXaXRoU2tlbGV0b24gfSBmcm9tICcuL1dpdGhTa2VsZXRvbic7XHJcbmltcG9ydCB7IFNrZWxldG9uIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9Ta2VsZXRvbnMuc3R5bGUnO1xyXG5leHBvcnQgY29uc3QgTGluZUl0ZW1Db250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgJiArICYge1xuICAgIG1hcmdpbi10b3A6IDhweDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IExpbmVJdGVtUm93ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmV4cG9ydCBjb25zdCBnZXRQcmljZVN0cmluZyA9ICh7IGFtb3VudCwgcHJpY2UsIHF1YW50aXR5IH0pID0+IHtcclxuICAgIGNvbnN0IHsgYmlsbGluZ1BlcmlvZCB9ID0gcHJpY2U7XHJcbiAgICBsZXQgYmlsbGluZ1BlcmlvZFN0cmluZyA9IG51bGw7XHJcbiAgICBpZiAoYmlsbGluZ1BlcmlvZCA9PT0gQmlsbGluZ1BlcmlvZC5Bbm51YWxseSkge1xyXG4gICAgICAgIGFtb3VudCAvPSAxMjtcclxuICAgICAgICBiaWxsaW5nUGVyaW9kU3RyaW5nID0gJzEyIG1vbnRocyc7XHJcbiAgICB9XHJcbiAgICBjb25zdCBhZGRvblByaWNlRm9ybWF0ID0gY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudCwgY3VycmVuY3k6IHByaWNlLmN1cnJlbmN5IH0pO1xyXG4gICAgcmV0dXJuIGAke3F1YW50aXR5ID4gMSA/IGAke3F1YW50aXR5fSB4ICR7YWRkb25QcmljZUZvcm1hdH0gZWFjaGAgOiBhZGRvblByaWNlRm9ybWF0fSR7YmlsbGluZ1BlcmlvZFN0cmluZyA/IGAgeCAke2JpbGxpbmdQZXJpb2RTdHJpbmd9YCA6ICcnfWA7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBCaWxsZWRQcmljZUxpbmVJdGVtID0gKHsgbGFiZWwsIHF1YW50aXR5LCBwcmljZSB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGJpbGxpbmdQZXJpb2QgfSA9IHByaWNlO1xyXG4gICAgbGV0IGFtb3VudDtcclxuICAgIGlmIChwcmljZS5pc1RpZXJlZFByaWNlKSB7XHJcbiAgICAgICAgY29uc3QgdGllciA9IGdldFRpZXJCeVF1YW50aXR5KHByaWNlLnRpZXJzLCBxdWFudGl0eSk7XHJcbiAgICAgICAgYW1vdW50ID0gdGllci51bml0UHJpY2UuYW1vdW50O1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgYW1vdW50ID0gcHJpY2UuYW1vdW50O1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Sb3csIHsgc3R5bGU6IHsgYWxpZ25JdGVtczogJ2ZsZXgtZW5kJyB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJwcmltYXJ5XCIgfSwgbGFiZWwpLFxyXG4gICAgICAgICAgICAgICAgKHF1YW50aXR5ID4gMSB8fCBiaWxsaW5nUGVyaW9kID09PSBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgZ2V0UHJpY2VTdHJpbmcoeyBhbW91bnQsIHByaWNlLCBxdWFudGl0eSB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGl0ZW06IHRydWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiLCBzdHlsZTogeyB3b3JkQnJlYWs6ICdicmVhay13b3JkJyB9IH0sIGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoeyBhbW91bnQ6IHF1YW50aXR5ICogYW1vdW50LCBjdXJyZW5jeTogcHJpY2UuY3VycmVuY3kgfSkpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IERpc2NvdW50TGluZUl0ZW0gPSAoeyBzdWJzY3JpcHRpb25QcmV2aWV3LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldywgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBzdWJUb3RhbCwgZGlzY291bnQgfSA9IHN1YnNjcmlwdGlvblByZXZpZXcgfHwge307XHJcbiAgICBpZiAoIXN1YlRvdGFsIHx8ICFkaXNjb3VudCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgbGV0IGRpc2NvdW50QW1vdW50O1xyXG4gICAgaWYgKGRpc2NvdW50LnR5cGUgPT09IERpc2NvdW50VHlwZS5QZXJjZW50YWdlKSB7XHJcbiAgICAgICAgZGlzY291bnRBbW91bnQgPSAtMSAqIE1hdGguYWJzKChkaXNjb3VudC52YWx1ZSAvIDEwMCkgKiBzdWJUb3RhbC5hbW91bnQpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgZGlzY291bnRBbW91bnQgPSAtMSAqIE1hdGguYWJzKGRpc2NvdW50LnZhbHVlKTtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBgRGlzY291bnQke2Rpc2NvdW50LnR5cGUgPT09IERpc2NvdW50VHlwZS5QZXJjZW50YWdlID8gYCAoJHtkaXNjb3VudC52YWx1ZX0lIG9mZilgIDogJyd9YCksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDUwLCBoZWlnaHQ6IDE2IH0pKSA6IChjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiBkaXNjb3VudEFtb3VudCwgY3VycmVuY3k6IHN1YlRvdGFsLmN1cnJlbmN5IH0pKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBBcHBsaWVkQ3JlZGl0c0xpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGNyZWRpdHMgfSA9IHN1YnNjcmlwdGlvblByZXZpZXcgfHwge307XHJcbiAgICBpZiAoIWNyZWRpdHMgfHwgY3JlZGl0cy51c2VkLmFtb3VudCA8PSAwKSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24uYXBwbGllZENyZWRpdHNUaXRsZSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFdpdGhTa2VsZXRvbiwgeyBpc0xvYWRpbmc6IGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3IH0sIGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoeyBhbW91bnQ6IC0xICogY3JlZGl0cy51c2VkLmFtb3VudCwgY3VycmVuY3k6IGNyZWRpdHMudXNlZC5jdXJyZW5jeSB9KSkpKSkpO1xyXG59O1xyXG5leHBvcnQgY29uc3QgVGF4TGluZUl0ZW0gPSAoeyBzdWJzY3JpcHRpb25QcmV2aWV3LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldywgY2hlY2tvdXRMb2NhbGl6YXRpb24sIH0pID0+IHtcclxuICAgIGNvbnN0IHsgdGF4LCB0YXhEZXRhaWxzIH0gPSBzdWJzY3JpcHRpb25QcmV2aWV3IHx8IHt9O1xyXG4gICAgaWYgKCF0YXhEZXRhaWxzIHx8ICF0YXgpIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi50YXhUaXRsZSh7IHRheERldGFpbHMgfSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChXaXRoU2tlbGV0b24sIHsgaXNMb2FkaW5nOiBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyB9LCBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiB0YXg/LmFtb3VudCwgY3VycmVuY3k6IHRheD8uY3VycmVuY3kgfSkpKSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9TGluZUl0ZW1zLmpzLm1hcCJdfQ== */",
11340
11482
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$m
11341
11483
  });
11342
11484
  var LineItemRow = /*#__PURE__*/_styled("div", {
@@ -11345,23 +11487,23 @@ var LineItemRow = /*#__PURE__*/_styled("div", {
11345
11487
  })( {
11346
11488
  name: "bcffy2",
11347
11489
  styles: "display:flex;align-items:center;justify-content:space-between",
11348
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpbmVJdGVtcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY3NDIiwiZmlsZSI6IkxpbmVJdGVtcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEdyaWQgfSBmcm9tICdAbXVpL21hdGVyaWFsJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZCwgRGlzY291bnRUeXBlIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBjdXJyZW5jeVByaWNlRm9ybWF0dGVyIH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvY3VycmVuY3lVdGlscyc7XHJcbmltcG9ydCB7IGdldFRpZXJCeVF1YW50aXR5IH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5pbXBvcnQgeyBXaXRoU2tlbGV0b24gfSBmcm9tICcuL1dpdGhTa2VsZXRvbic7XHJcbmltcG9ydCB7IFNrZWxldG9uIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9Ta2VsZXRvbnMuc3R5bGUnO1xyXG5leHBvcnQgY29uc3QgTGluZUl0ZW1Db250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgJiArICYge1xuICAgIG1hcmdpbi10b3A6IDhweDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IExpbmVJdGVtUm93ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmV4cG9ydCBjb25zdCBnZXRQcmljZVN0cmluZyA9ICh7IGFtb3VudFBlck1vbnRoLCBwcmljZSwgcXVhbnRpdHksIH0pID0+IHtcclxuICAgIGNvbnN0IHsgYmlsbGluZ1BlcmlvZCB9ID0gcHJpY2U7XHJcbiAgICBsZXQgYmlsbGluZ1BlcmlvZFN0cmluZyA9IG51bGw7XHJcbiAgICBpZiAoYmlsbGluZ1BlcmlvZCA9PT0gQmlsbGluZ1BlcmlvZC5Bbm51YWxseSkge1xyXG4gICAgICAgIGFtb3VudFBlck1vbnRoIC89IDEyO1xyXG4gICAgICAgIGJpbGxpbmdQZXJpb2RTdHJpbmcgPSAnMTIgbW9udGhzJztcclxuICAgIH1cclxuICAgIGNvbnN0IGFkZG9uUHJpY2VGb3JtYXQgPSBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiBhbW91bnRQZXJNb250aCwgY3VycmVuY3k6IHByaWNlLmN1cnJlbmN5IH0pO1xyXG4gICAgcmV0dXJuIGAke3F1YW50aXR5ID4gMSA/IGAke3F1YW50aXR5fSB4ICR7YWRkb25QcmljZUZvcm1hdH0gZWFjaGAgOiBhZGRvblByaWNlRm9ybWF0fSR7YmlsbGluZ1BlcmlvZFN0cmluZyA/IGAgeCAke2JpbGxpbmdQZXJpb2RTdHJpbmd9YCA6ICcnfWA7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBCaWxsZWRQcmljZUxpbmVJdGVtID0gKHsgbGFiZWwsIHF1YW50aXR5LCBwcmljZSB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGJpbGxpbmdQZXJpb2QgfSA9IHByaWNlO1xyXG4gICAgbGV0IGFtb3VudFBlck1vbnRoO1xyXG4gICAgaWYgKHByaWNlLmlzVGllcmVkUHJpY2UpIHtcclxuICAgICAgICBjb25zdCB0aWVyID0gZ2V0VGllckJ5UXVhbnRpdHkocHJpY2UudGllcnMsIHF1YW50aXR5KTtcclxuICAgICAgICBhbW91bnRQZXJNb250aCA9IHRpZXIudW5pdFByaWNlLmFtb3VudDtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIGFtb3VudFBlck1vbnRoID0gcHJpY2UuYW1vdW50O1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Sb3csIHsgc3R5bGU6IHsgYWxpZ25JdGVtczogJ2ZsZXgtZW5kJyB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJwcmltYXJ5XCIgfSwgbGFiZWwpLFxyXG4gICAgICAgICAgICAgICAgKHF1YW50aXR5ID4gMSB8fCBiaWxsaW5nUGVyaW9kID09PSBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgZ2V0UHJpY2VTdHJpbmcoeyBhbW91bnRQZXJNb250aCwgcHJpY2UsIHF1YW50aXR5IH0pKSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgaXRlbTogdHJ1ZSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIsIHN0eWxlOiB7IHdvcmRCcmVhazogJ2JyZWFrLXdvcmQnIH0gfSwgY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudDogcXVhbnRpdHkgKiBhbW91bnRQZXJNb250aCwgY3VycmVuY3k6IHByaWNlLmN1cnJlbmN5IH0pKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudExpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgc3ViVG90YWwsIGRpc2NvdW50IH0gPSBzdWJzY3JpcHRpb25QcmV2aWV3IHx8IHt9O1xyXG4gICAgaWYgKCFzdWJUb3RhbCB8fCAhZGlzY291bnQpIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIGxldCBkaXNjb3VudEFtb3VudDtcclxuICAgIGlmIChkaXNjb3VudC50eXBlID09PSBEaXNjb3VudFR5cGUuUGVyY2VudGFnZSkge1xyXG4gICAgICAgIGRpc2NvdW50QW1vdW50ID0gLTEgKiBNYXRoLmFicygoZGlzY291bnQudmFsdWUgLyAxMDApICogc3ViVG90YWwuYW1vdW50KTtcclxuICAgIH1cclxuICAgIGVsc2Uge1xyXG4gICAgICAgIGRpc2NvdW50QW1vdW50ID0gLTEgKiBNYXRoLmFicyhkaXNjb3VudC52YWx1ZSk7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgYERpc2NvdW50JHtkaXNjb3VudC50eXBlID09PSBEaXNjb3VudFR5cGUuUGVyY2VudGFnZSA/IGAgKCR7ZGlzY291bnQudmFsdWV9JSBvZmYpYCA6ICcnfWApLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiA1MCwgaGVpZ2h0OiAxNiB9KSkgOiAoY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudDogZGlzY291bnRBbW91bnQsIGN1cnJlbmN5OiBzdWJUb3RhbC5jdXJyZW5jeSB9KSkpKSkpO1xyXG59O1xyXG5leHBvcnQgY29uc3QgQXBwbGllZENyZWRpdHNMaW5lSXRlbSA9ICh7IHN1YnNjcmlwdGlvblByZXZpZXcsIGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3LCBjaGVja291dExvY2FsaXphdGlvbiwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBjcmVkaXRzIH0gPSBzdWJzY3JpcHRpb25QcmV2aWV3IHx8IHt9O1xyXG4gICAgaWYgKCFjcmVkaXRzIHx8IGNyZWRpdHMudXNlZC5hbW91bnQgPD0gMCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Sb3csIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNoZWNrb3V0TG9jYWxpemF0aW9uLmFwcGxpZWRDcmVkaXRzVGl0bGUpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChXaXRoU2tlbGV0b24sIHsgaXNMb2FkaW5nOiBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyB9LCBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiAtMSAqIGNyZWRpdHMudXNlZC5hbW91bnQsIGN1cnJlbmN5OiBjcmVkaXRzLnVzZWQuY3VycmVuY3kgfSkpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IFRheExpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHRheCwgdGF4RGV0YWlscyB9ID0gc3Vic2NyaXB0aW9uUHJldmlldyB8fCB7fTtcclxuICAgIGlmICghdGF4RGV0YWlscyB8fCAhdGF4KSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24udGF4VGl0bGUoeyB0YXhEZXRhaWxzIH0pKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoV2l0aFNrZWxldG9uLCB7IGlzTG9hZGluZzogaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcgfSwgY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudDogdGF4Py5hbW91bnQsIGN1cnJlbmN5OiB0YXg/LmN1cnJlbmN5IH0pKSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUxpbmVJdGVtcy5qcy5tYXAiXX0= */",
11490
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpbmVJdGVtcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBY3NDIiwiZmlsZSI6IkxpbmVJdGVtcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IEdyaWQgfSBmcm9tICdAbXVpL21hdGVyaWFsJztcclxuaW1wb3J0IHsgQmlsbGluZ1BlcmlvZCwgRGlzY291bnRUeXBlIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBjdXJyZW5jeVByaWNlRm9ybWF0dGVyIH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvY3VycmVuY3lVdGlscyc7XHJcbmltcG9ydCB7IGdldFRpZXJCeVF1YW50aXR5IH0gZnJvbSAnLi4vLi4vLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5pbXBvcnQgeyBXaXRoU2tlbGV0b24gfSBmcm9tICcuL1dpdGhTa2VsZXRvbic7XHJcbmltcG9ydCB7IFNrZWxldG9uIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9Ta2VsZXRvbnMuc3R5bGUnO1xyXG5leHBvcnQgY29uc3QgTGluZUl0ZW1Db250YWluZXIgPSBzdHlsZWQuZGl2IGBcbiAgJiArICYge1xuICAgIG1hcmdpbi10b3A6IDhweDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IExpbmVJdGVtUm93ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmV4cG9ydCBjb25zdCBnZXRQcmljZVN0cmluZyA9ICh7IGFtb3VudCwgcHJpY2UsIHF1YW50aXR5IH0pID0+IHtcclxuICAgIGNvbnN0IHsgYmlsbGluZ1BlcmlvZCB9ID0gcHJpY2U7XHJcbiAgICBsZXQgYmlsbGluZ1BlcmlvZFN0cmluZyA9IG51bGw7XHJcbiAgICBpZiAoYmlsbGluZ1BlcmlvZCA9PT0gQmlsbGluZ1BlcmlvZC5Bbm51YWxseSkge1xyXG4gICAgICAgIGFtb3VudCAvPSAxMjtcclxuICAgICAgICBiaWxsaW5nUGVyaW9kU3RyaW5nID0gJzEyIG1vbnRocyc7XHJcbiAgICB9XHJcbiAgICBjb25zdCBhZGRvblByaWNlRm9ybWF0ID0gY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudCwgY3VycmVuY3k6IHByaWNlLmN1cnJlbmN5IH0pO1xyXG4gICAgcmV0dXJuIGAke3F1YW50aXR5ID4gMSA/IGAke3F1YW50aXR5fSB4ICR7YWRkb25QcmljZUZvcm1hdH0gZWFjaGAgOiBhZGRvblByaWNlRm9ybWF0fSR7YmlsbGluZ1BlcmlvZFN0cmluZyA/IGAgeCAke2JpbGxpbmdQZXJpb2RTdHJpbmd9YCA6ICcnfWA7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBCaWxsZWRQcmljZUxpbmVJdGVtID0gKHsgbGFiZWwsIHF1YW50aXR5LCBwcmljZSB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGJpbGxpbmdQZXJpb2QgfSA9IHByaWNlO1xyXG4gICAgbGV0IGFtb3VudDtcclxuICAgIGlmIChwcmljZS5pc1RpZXJlZFByaWNlKSB7XHJcbiAgICAgICAgY29uc3QgdGllciA9IGdldFRpZXJCeVF1YW50aXR5KHByaWNlLnRpZXJzLCBxdWFudGl0eSk7XHJcbiAgICAgICAgYW1vdW50ID0gdGllci51bml0UHJpY2UuYW1vdW50O1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgYW1vdW50ID0gcHJpY2UuYW1vdW50O1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Sb3csIHsgc3R5bGU6IHsgYWxpZ25JdGVtczogJ2ZsZXgtZW5kJyB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJwcmltYXJ5XCIgfSwgbGFiZWwpLFxyXG4gICAgICAgICAgICAgICAgKHF1YW50aXR5ID4gMSB8fCBiaWxsaW5nUGVyaW9kID09PSBCaWxsaW5nUGVyaW9kLkFubnVhbGx5KSAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgZ2V0UHJpY2VTdHJpbmcoeyBhbW91bnQsIHByaWNlLCBxdWFudGl0eSB9KSkpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGl0ZW06IHRydWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiLCBzdHlsZTogeyB3b3JkQnJlYWs6ICdicmVhay13b3JkJyB9IH0sIGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoeyBhbW91bnQ6IHF1YW50aXR5ICogYW1vdW50LCBjdXJyZW5jeTogcHJpY2UuY3VycmVuY3kgfSkpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IERpc2NvdW50TGluZUl0ZW0gPSAoeyBzdWJzY3JpcHRpb25QcmV2aWV3LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldywgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBzdWJUb3RhbCwgZGlzY291bnQgfSA9IHN1YnNjcmlwdGlvblByZXZpZXcgfHwge307XHJcbiAgICBpZiAoIXN1YlRvdGFsIHx8ICFkaXNjb3VudCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgbGV0IGRpc2NvdW50QW1vdW50O1xyXG4gICAgaWYgKGRpc2NvdW50LnR5cGUgPT09IERpc2NvdW50VHlwZS5QZXJjZW50YWdlKSB7XHJcbiAgICAgICAgZGlzY291bnRBbW91bnQgPSAtMSAqIE1hdGguYWJzKChkaXNjb3VudC52YWx1ZSAvIDEwMCkgKiBzdWJUb3RhbC5hbW91bnQpO1xyXG4gICAgfVxyXG4gICAgZWxzZSB7XHJcbiAgICAgICAgZGlzY291bnRBbW91bnQgPSAtMSAqIE1hdGguYWJzKGRpc2NvdW50LnZhbHVlKTtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBgRGlzY291bnQke2Rpc2NvdW50LnR5cGUgPT09IERpc2NvdW50VHlwZS5QZXJjZW50YWdlID8gYCAoJHtkaXNjb3VudC52YWx1ZX0lIG9mZilgIDogJyd9YCksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2tlbGV0b24sIHsgd2lkdGg6IDUwLCBoZWlnaHQ6IDE2IH0pKSA6IChjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiBkaXNjb3VudEFtb3VudCwgY3VycmVuY3k6IHN1YlRvdGFsLmN1cnJlbmN5IH0pKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBBcHBsaWVkQ3JlZGl0c0xpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGNyZWRpdHMgfSA9IHN1YnNjcmlwdGlvblByZXZpZXcgfHwge307XHJcbiAgICBpZiAoIWNyZWRpdHMgfHwgY3JlZGl0cy51c2VkLmFtb3VudCA8PSAwKSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24uYXBwbGllZENyZWRpdHNUaXRsZSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFdpdGhTa2VsZXRvbiwgeyBpc0xvYWRpbmc6IGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3IH0sIGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoeyBhbW91bnQ6IC0xICogY3JlZGl0cy51c2VkLmFtb3VudCwgY3VycmVuY3k6IGNyZWRpdHMudXNlZC5jdXJyZW5jeSB9KSkpKSkpO1xyXG59O1xyXG5leHBvcnQgY29uc3QgVGF4TGluZUl0ZW0gPSAoeyBzdWJzY3JpcHRpb25QcmV2aWV3LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldywgY2hlY2tvdXRMb2NhbGl6YXRpb24sIH0pID0+IHtcclxuICAgIGNvbnN0IHsgdGF4LCB0YXhEZXRhaWxzIH0gPSBzdWJzY3JpcHRpb25QcmV2aWV3IHx8IHt9O1xyXG4gICAgaWYgKCF0YXhEZXRhaWxzIHx8ICF0YXgpIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi50YXhUaXRsZSh7IHRheERldGFpbHMgfSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChXaXRoU2tlbGV0b24sIHsgaXNMb2FkaW5nOiBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyB9LCBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiB0YXg/LmFtb3VudCwgY3VycmVuY3k6IHRheD8uY3VycmVuY3kgfSkpKSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9TGluZUl0ZW1zLmpzLm1hcCJdfQ== */",
11349
11491
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$m
11350
11492
  });
11351
11493
  var getPriceString = function getPriceString(_ref) {
11352
- var amountPerMonth = _ref.amountPerMonth,
11494
+ var amount = _ref.amount,
11353
11495
  price = _ref.price,
11354
11496
  quantity = _ref.quantity;
11355
11497
  var billingPeriod = price.billingPeriod;
11356
11498
  var billingPeriodString = null;
11357
11499
 
11358
11500
  if (billingPeriod === Stigg.BillingPeriod.Annually) {
11359
- amountPerMonth /= 12;
11501
+ amount /= 12;
11360
11502
  billingPeriodString = '12 months';
11361
11503
  }
11362
11504
 
11363
11505
  var addonPriceFormat = currencyPriceFormatter({
11364
- amount: amountPerMonth,
11506
+ amount: amount,
11365
11507
  currency: price.currency
11366
11508
  });
11367
11509
  return "" + (quantity > 1 ? quantity + " x " + addonPriceFormat + " each" : addonPriceFormat) + (billingPeriodString ? " x " + billingPeriodString : '');
@@ -11371,13 +11513,13 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
11371
11513
  quantity = _ref2.quantity,
11372
11514
  price = _ref2.price;
11373
11515
  var billingPeriod = price.billingPeriod;
11374
- var amountPerMonth;
11516
+ var amount;
11375
11517
 
11376
11518
  if (price.isTieredPrice) {
11377
11519
  var tier = getTierByQuantity(price.tiers, quantity);
11378
- amountPerMonth = tier.unitPrice.amount;
11520
+ amount = tier.unitPrice.amount;
11379
11521
  } else {
11380
- amountPerMonth = price.amount;
11522
+ amount = price.amount;
11381
11523
  }
11382
11524
 
11383
11525
  return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
@@ -11393,7 +11535,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
11393
11535
  variant: "body1",
11394
11536
  color: "secondary"
11395
11537
  }, getPriceString({
11396
- amountPerMonth: amountPerMonth,
11538
+ amount: amount,
11397
11539
  price: price,
11398
11540
  quantity: quantity
11399
11541
  }))), React__default.createElement(material.Grid, {
@@ -11405,7 +11547,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
11405
11547
  wordBreak: 'break-word'
11406
11548
  }
11407
11549
  }, currencyPriceFormatter({
11408
- amount: quantity * amountPerMonth,
11550
+ amount: quantity * amount,
11409
11551
  currency: price.currency
11410
11552
  })))));
11411
11553
  };
@@ -11504,7 +11646,7 @@ var SummaryCard = /*#__PURE__*/_styled(material.Paper, {
11504
11646
  })("border-radius:10px;background:", function (_ref) {
11505
11647
  var theme = _ref.theme;
11506
11648
  return theme.stigg.palette.backgroundHighlight;
11507
- }, ";padding:16px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAkByC","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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\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 isFirstSubscription = !activeSubscription?.id;\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({\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            return;\r\n        }\r\n        setErrorMessage(undefined);\r\n        setIsCheckoutCompletedSuccessfully(true);\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            isFirstSubscription && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { 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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", color: \"white\", style: { display: 'flex' } },\r\n                    isCheckoutCompletedSuccessfully && React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } }),\r\n                    isLoading && React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } }),\r\n                    !isLoading &&\r\n                        !isCheckoutCompletedSuccessfully &&\r\n                        resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization })))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */"));
11649
+ }, ";padding:16px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAkByC","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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, isFreeDowngrade, }) => {\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();\r\n    const { handleSubmit, isLoading } = useSubmit({\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            !disablePromotionCode && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading || progressBar.progressBarState.isDisabled, \"$isLoading\": isLoading || progressBar.progressBarState.isDisabled, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, disabled: isLoading || isFetchingSubscriptionPreview, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", 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({ isLastStep, subscriptionPreview, checkoutLocalization }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */"));
11508
11650
  SummaryCard.defaultProps = {
11509
11651
  elevation: 0
11510
11652
  };
@@ -11515,7 +11657,7 @@ var PlanName = /*#__PURE__*/_styled(Typography, {
11515
11657
  })( {
11516
11658
  name: "18uqayh",
11517
11659
  styles: "margin-bottom:16px",
11518
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA0BoC","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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\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 isFirstSubscription = !activeSubscription?.id;\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({\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            return;\r\n        }\r\n        setErrorMessage(undefined);\r\n        setIsCheckoutCompletedSuccessfully(true);\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            isFirstSubscription && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { 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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", color: \"white\", style: { display: 'flex' } },\r\n                    isCheckoutCompletedSuccessfully && React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } }),\r\n                    isLoading && React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } }),\r\n                    !isLoading &&\r\n                        !isCheckoutCompletedSuccessfully &&\r\n                        resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization })))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
11660
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA0BoC","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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, isFreeDowngrade, }) => {\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();\r\n    const { handleSubmit, isLoading } = useSubmit({\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            !disablePromotionCode && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading || progressBar.progressBarState.isDisabled, \"$isLoading\": isLoading || progressBar.progressBarState.isDisabled, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, disabled: isLoading || isFetchingSubscriptionPreview, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", 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({ isLastStep, subscriptionPreview, checkoutLocalization }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
11519
11661
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
11520
11662
  });
11521
11663
 
@@ -11525,7 +11667,7 @@ var StyledDivider$1 = /*#__PURE__*/_styled(material.Divider, {
11525
11667
  })( {
11526
11668
  name: "1k6141t",
11527
11669
  styles: "margin:16px 0",
11528
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA6BsC","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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\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 isFirstSubscription = !activeSubscription?.id;\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({\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            return;\r\n        }\r\n        setErrorMessage(undefined);\r\n        setIsCheckoutCompletedSuccessfully(true);\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            isFirstSubscription && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { 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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", color: \"white\", style: { display: 'flex' } },\r\n                    isCheckoutCompletedSuccessfully && React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } }),\r\n                    isLoading && React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } }),\r\n                    !isLoading &&\r\n                        !isCheckoutCompletedSuccessfully &&\r\n                        resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization })))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
11670
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA6BsC","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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, isFreeDowngrade, }) => {\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();\r\n    const { handleSubmit, isLoading } = useSubmit({\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            !disablePromotionCode && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading || progressBar.progressBarState.isDisabled, \"$isLoading\": isLoading || progressBar.progressBarState.isDisabled, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, disabled: isLoading || isFetchingSubscriptionPreview, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", 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({ isLastStep, subscriptionPreview, checkoutLocalization }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
11529
11671
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
11530
11672
  });
11531
11673
 
@@ -11535,7 +11677,7 @@ var SubtotalText = /*#__PURE__*/_styled(Typography, {
11535
11677
  })( {
11536
11678
  name: "1d0nbku",
11537
11679
  styles: "margin-top:24px",
11538
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAgCwC","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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\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 isFirstSubscription = !activeSubscription?.id;\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({\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            return;\r\n        }\r\n        setErrorMessage(undefined);\r\n        setIsCheckoutCompletedSuccessfully(true);\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            isFirstSubscription && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { 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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", color: \"white\", style: { display: 'flex' } },\r\n                    isCheckoutCompletedSuccessfully && React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } }),\r\n                    isLoading && React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } }),\r\n                    !isLoading &&\r\n                        !isCheckoutCompletedSuccessfully &&\r\n                        resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization })))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
11680
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAgCwC","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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, isFreeDowngrade, }) => {\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();\r\n    const { handleSubmit, isLoading } = useSubmit({\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            !disablePromotionCode && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading || progressBar.progressBarState.isDisabled, \"$isLoading\": isLoading || progressBar.progressBarState.isDisabled, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, disabled: isLoading || isFetchingSubscriptionPreview, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", 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({ isLastStep, subscriptionPreview, checkoutLocalization }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
11539
11681
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
11540
11682
  });
11541
11683
 
@@ -11545,7 +11687,7 @@ var TotalDueText = /*#__PURE__*/_styled(Typography, {
11545
11687
  })( {
11546
11688
  name: "5bhc30",
11547
11689
  styles: "margin-bottom:8px",
11548
- 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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted }) => {\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 isFirstSubscription = !activeSubscription?.id;\r\n    const isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription();\r\n    const { handleSubmit, isLoading } = useSubmit({\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            return;\r\n        }\r\n        setErrorMessage(undefined);\r\n        setIsCheckoutCompletedSuccessfully(true);\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            isFirstSubscription && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { 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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading, \"$isLoading\": isLoading, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", color: \"white\", style: { display: 'flex' } },\r\n                    isCheckoutCompletedSuccessfully && React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } }),\r\n                    isLoading && React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } }),\r\n                    !isLoading &&\r\n                        !isCheckoutCompletedSuccessfully &&\r\n                        resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization })))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
11690
+ 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, CircularProgress, Divider, Grid, Paper } from '@mui/material';\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, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\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 PlanName = styled(Typography) `\n  margin-bottom: 16px;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst SubtotalText = styled(Typography) `\n  margin-top: 24px;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, subscriptionPreview, checkoutLocalization, isFirstSubscription, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (subscriptionPreview?.isPlanDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeText;\r\n    }\r\n    if (!isFirstSubscription) {\r\n        return checkoutLocalization.checkoutButton.upgradeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.purchaseText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, isFreeDowngrade, }) => {\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();\r\n    const { handleSubmit, isLoading } = useSubmit({\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    return (React.createElement(Box, { flex: 1 },\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(PlanName, { variant: \"h6\" }, plan?.displayName),\r\n            baseCharge && (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\" }, typeof checkoutLocalization.baseChargeText === 'function'\r\n                        ? checkoutLocalization.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n                        : checkoutLocalization.baseChargeText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, currencyPriceFormatter({ amount: baseCharge.amount, currency: baseCharge.currency }))))),\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { key: price.feature?.featureId, label: price.feature?.displayName || '', quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 1 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1 } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    return (React.createElement(BilledPriceLineItem, { key: addon?.addon?.id, label: addon.addon.displayName, quantity: addon.quantity, price: addonPrice }));\r\n                }))),\r\n            React.createElement(LineItemRow, null,\r\n                React.createElement(SubtotalText, { variant: \"h6\" }, checkoutLocalization.subTotalText),\r\n                React.createElement(SubtotalText, { variant: \"h6\" },\r\n                    React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.subTotal })))),\r\n            React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            !disablePromotionCode && (React.createElement(React.Fragment, null,\r\n                React.createElement(PromotionCodeSection, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))),\r\n            React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview }),\r\n            React.createElement(TaxLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\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.totalText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(Button, { disableRipple: isLoading || progressBar.progressBarState.isDisabled, \"$isLoading\": isLoading || progressBar.progressBarState.isDisabled, \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && subscriptionPreview?.isPlanDowngrade, disabled: isLoading || isFetchingSubscriptionPreview, className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px' }, 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\", 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({ isLastStep, subscriptionPreview, checkoutLocalization }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        isCheckoutCompletedSuccessfully && React.createElement(CheckoutSuccess, null)));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
11549
11691
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
11550
11692
  });
11551
11693
 
@@ -11574,7 +11716,9 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
11574
11716
  var _plan$pricePoints, _subscription$addons;
11575
11717
 
11576
11718
  var onCheckout = _ref3.onCheckout,
11577
- onCheckoutCompleted = _ref3.onCheckoutCompleted;
11719
+ onCheckoutCompleted = _ref3.onCheckoutCompleted,
11720
+ disablePromotionCode = _ref3.disablePromotionCode,
11721
+ isFreeDowngrade = _ref3.isFreeDowngrade;
11578
11722
 
11579
11723
  var _useState = React.useState(false),
11580
11724
  isCheckoutCompletedSuccessfully = _useState[0],
@@ -11607,8 +11751,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
11607
11751
  var _ref5 = baseCharges || [],
11608
11752
  baseCharge = _ref5[0];
11609
11753
 
11610
- var isFirstSubscription = !(activeSubscription != null && activeSubscription.id);
11611
- var isLastStep = progressBar.isCheckoutComplete && progressBar.isLastStep;
11754
+ var isLastStep = isFreeDowngrade || progressBar.isCheckoutComplete && progressBar.isLastStep;
11612
11755
 
11613
11756
  var _usePreviewSubscripti = usePreviewSubscription(),
11614
11757
  subscriptionPreview = _usePreviewSubscripti.subscriptionPreview,
@@ -11658,20 +11801,14 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
11658
11801
  _ref7 = _context.t0;
11659
11802
  errorMessage = _ref7.errorMessage;
11660
11803
 
11661
- if (!errorMessage) {
11662
- _context.next = 13;
11663
- break;
11804
+ if (errorMessage) {
11805
+ setErrorMessage(errorMessage);
11806
+ setIsCheckoutCompletedSuccessfully(false);
11807
+ } else {
11808
+ setErrorMessage(undefined);
11664
11809
  }
11665
11810
 
11666
- setErrorMessage(errorMessage);
11667
- setIsCheckoutCompletedSuccessfully(false);
11668
- return _context.abrupt("return");
11669
-
11670
- case 13:
11671
- setErrorMessage(undefined);
11672
- setIsCheckoutCompletedSuccessfully(true);
11673
-
11674
- case 15:
11811
+ case 10:
11675
11812
  case "end":
11676
11813
  return _context.stop();
11677
11814
  }
@@ -11794,21 +11931,21 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
11794
11931
  amount: 0
11795
11932
  }, subscriptionPreview == null ? void 0 : subscriptionPreview.subTotal))))), React__default.createElement(StyledDivider$1, {
11796
11933
  className: "stigg-checkout-summary-divider"
11797
- }), isFirstSubscription && React__default.createElement(React__default.Fragment, null, React__default.createElement(PromotionCodeSection, {
11934
+ }), !disablePromotionCode && React__default.createElement(React__default.Fragment, null, React__default.createElement(PromotionCodeSection, {
11798
11935
  checkoutLocalization: checkoutLocalization
11799
11936
  }), React__default.createElement(StyledDivider$1, {
11800
11937
  className: "stigg-checkout-summary-divider"
11801
- })), React__default.createElement(AppliedCreditsLineItem, {
11802
- subscriptionPreview: subscriptionPreview,
11803
- isFetchingSubscriptionPreview: isFetchingSubscriptionPreview,
11804
- checkoutLocalization: checkoutLocalization
11805
- }), React__default.createElement(DiscountLineItem, {
11938
+ })), React__default.createElement(DiscountLineItem, {
11806
11939
  subscriptionPreview: subscriptionPreview,
11807
11940
  isFetchingSubscriptionPreview: isFetchingSubscriptionPreview
11808
11941
  }), React__default.createElement(TaxLineItem, {
11809
11942
  subscriptionPreview: subscriptionPreview,
11810
11943
  isFetchingSubscriptionPreview: isFetchingSubscriptionPreview,
11811
11944
  checkoutLocalization: checkoutLocalization
11945
+ }), React__default.createElement(AppliedCreditsLineItem, {
11946
+ subscriptionPreview: subscriptionPreview,
11947
+ isFetchingSubscriptionPreview: isFetchingSubscriptionPreview,
11948
+ checkoutLocalization: checkoutLocalization
11812
11949
  }), React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, null, React__default.createElement(TotalDueText, {
11813
11950
  variant: "h6"
11814
11951
  }, checkoutLocalization.totalText), React__default.createElement(TotalDueText, {
@@ -11824,10 +11961,11 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
11824
11961
  isFetchingSubscriptionPreview: isFetchingSubscriptionPreview,
11825
11962
  checkoutLocalization: checkoutLocalization
11826
11963
  }), React__default.createElement(Button, {
11827
- disableRipple: isLoading,
11828
- "$isLoading": isLoading,
11964
+ disableRipple: isLoading || progressBar.progressBarState.isDisabled,
11965
+ "$isLoading": isLoading || progressBar.progressBarState.isDisabled,
11829
11966
  "$success": isCheckoutCompletedSuccessfully,
11830
11967
  "$error": isLastStep && (subscriptionPreview == null ? void 0 : subscriptionPreview.isPlanDowngrade),
11968
+ disabled: isLoading || isFetchingSubscriptionPreview,
11831
11969
  className: "stigg-checkout-summary-cta-button",
11832
11970
  sx: {
11833
11971
  textTransform: 'none',
@@ -11846,17 +11984,17 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
11846
11984
  style: {
11847
11985
  display: 'flex'
11848
11986
  }
11849
- }, isCheckoutCompletedSuccessfully && React__default.createElement(Icon, {
11987
+ }, isCheckoutCompletedSuccessfully ? React__default.createElement(Icon, {
11850
11988
  icon: "Check",
11851
11989
  style: {
11852
11990
  display: 'contents'
11853
11991
  }
11854
- }), isLoading && React__default.createElement(material.CircularProgress, {
11992
+ }) : isLoading || isFetchingSubscriptionPreview ? React__default.createElement(material.CircularProgress, {
11855
11993
  size: 20,
11856
11994
  sx: {
11857
11995
  color: 'white'
11858
11996
  }
11859
- }), !isLoading && !isCheckoutCompletedSuccessfully && resolveCheckoutButtonText({
11997
+ }) : resolveCheckoutButtonText({
11860
11998
  isLastStep: isLastStep,
11861
11999
  subscriptionPreview: subscriptionPreview,
11862
12000
  checkoutLocalization: checkoutLocalization
@@ -11915,7 +12053,7 @@ var CheckoutSummarySkeleton = function CheckoutSummarySkeleton() {
11915
12053
  }));
11916
12054
  };
11917
12055
 
11918
- var _g$5;
12056
+ var _g$4;
11919
12057
  function _extends$p() { _extends$p = Object.assign ? Object.assign.bind() : function (target) { for (var i = 1; i < arguments.length; i++) { var source = arguments[i]; for (var key in source) { if (Object.prototype.hasOwnProperty.call(source, key)) { target[key] = source[key]; } } } return target; }; return _extends$p.apply(this, arguments); }
11920
12058
  var SvgArrowRight = function SvgArrowRight(props) {
11921
12059
  return /*#__PURE__*/React.createElement("svg", _extends$p({
@@ -11923,7 +12061,7 @@ var SvgArrowRight = function SvgArrowRight(props) {
11923
12061
  height: 16,
11924
12062
  fill: "none",
11925
12063
  xmlns: "http://www.w3.org/2000/svg"
11926
- }, props), _g$5 || (_g$5 = /*#__PURE__*/React.createElement("g", {
12064
+ }, props), _g$4 || (_g$4 = /*#__PURE__*/React.createElement("g", {
11927
12065
  stroke: "#7586B0",
11928
12066
  strokeWidth: 1.333,
11929
12067
  strokeLinecap: "round",
@@ -12176,7 +12314,7 @@ function PaymentMethodLayout(_ref) {
12176
12314
  }), React__default.createElement(Icon, {
12177
12315
  icon: icon,
12178
12316
  style: {
12179
- display: 'contents'
12317
+ display: 'flex'
12180
12318
  }
12181
12319
  }), React__default.createElement(PaymentMethodTextContainer, {
12182
12320
  container: true
@@ -12210,17 +12348,18 @@ function ExistingPaymentMethod(_ref2) {
12210
12348
  icon: "PaymentMethod",
12211
12349
  text: React__default.createElement(Typography, {
12212
12350
  variant: "h6"
12213
- }, "Ending in " + last4Digits),
12351
+ }, "Card ending in " + last4Digits),
12214
12352
  subtitle: !!expirationMonth && !!expirationYear && React__default.createElement(Typography, {
12215
12353
  variant: "body1"
12216
- }, "Exp. " + expirationMonth.toString().padStart(2, '0') + "/" + expirationYear)
12354
+ }, "Expires " + expirationMonth.toString().padStart(2, '0') + "/" + expirationYear)
12217
12355
  }));
12218
12356
  }
12219
12357
  function NewPaymentMethod(_ref3) {
12220
12358
  var checked = _ref3.checked,
12221
12359
  onSelect = _ref3.onSelect,
12222
12360
  readOnly = _ref3.readOnly,
12223
- checkoutLocalization = _ref3.checkoutLocalization;
12361
+ checkoutLocalization = _ref3.checkoutLocalization,
12362
+ onBillingAddressChange = _ref3.onBillingAddressChange;
12224
12363
  return React__default.createElement(NewPaymentMethodContainer, {
12225
12364
  item: true,
12226
12365
  onClick: onSelect,
@@ -12234,19 +12373,23 @@ function NewPaymentMethod(_ref3) {
12234
12373
  }, checkoutLocalization.newPaymentMethodText)
12235
12374
  }), React__default.createElement(material.Collapse, {
12236
12375
  "in": checked
12237
- }, React__default.createElement(StripePaymentForm, null)));
12376
+ }, React__default.createElement(StripePaymentForm, {
12377
+ onBillingAddressChange: onBillingAddressChange
12378
+ })));
12238
12379
  }
12239
12380
 
12240
12381
  var _templateObject$9;
12241
12382
  var PaymentContainer = /*#__PURE__*/styled$1(material.Grid)(_templateObject$9 || (_templateObject$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n gap: 24px;\n margin: 32px 0;\n"])));
12242
- function PaymentStep() {
12383
+ function PaymentStep(_ref) {
12384
+ var onBillingAddressChange = _ref.onBillingAddressChange;
12385
+
12243
12386
  var _useCheckoutModel = useCheckoutModel(),
12244
12387
  checkoutState = _useCheckoutModel.checkoutState,
12245
12388
  checkoutLocalization = _useCheckoutModel.checkoutLocalization,
12246
12389
  widgetState = _useCheckoutModel.widgetState;
12247
12390
 
12248
- var _ref = checkoutState || {},
12249
- customer = _ref.customer;
12391
+ var _ref2 = checkoutState || {},
12392
+ customer = _ref2.customer;
12250
12393
 
12251
12394
  var _usePaymentStepModel = usePaymentStepModel(),
12252
12395
  errorMessage = _usePaymentStepModel.errorMessage,
@@ -12285,10 +12428,24 @@ function PaymentStep() {
12285
12428
  checkoutLocalization: checkoutLocalization,
12286
12429
  onSelect: function onSelect() {
12287
12430
  return handleOnSelect(true);
12288
- }
12431
+ },
12432
+ onBillingAddressChange: onBillingAddressChange
12289
12433
  }));
12290
12434
  }
12291
12435
 
12436
+ function formatBillingPeriod(billingPeriod) {
12437
+ switch (billingPeriod) {
12438
+ case Stigg.BillingPeriod.Annually:
12439
+ return 'Annual';
12440
+
12441
+ case Stigg.BillingPeriod.Monthly:
12442
+ return 'Monthly';
12443
+
12444
+ default:
12445
+ return '';
12446
+ }
12447
+ }
12448
+
12292
12449
  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)."; }
12293
12450
  var BillingPeriodPickerContainer = /*#__PURE__*/_styled(material.Box, {
12294
12451
  target: "ekae5v44",
@@ -12383,19 +12540,45 @@ function PlanCharge(_ref) {
12383
12540
 
12384
12541
  var charge = _ref.charge,
12385
12542
  setBillableFeature = _ref.setBillableFeature,
12386
- billableFeature = _ref.billableFeature;
12543
+ billableFeature = _ref.billableFeature,
12544
+ onValidationChange = _ref.onValidationChange;
12545
+
12546
+ var _React$useState = React__default.useState(true),
12547
+ isValid = _React$useState[0],
12548
+ setIsValid = _React$useState[1];
12549
+
12387
12550
  var featureId = (_charge$feature = charge.feature) == null ? void 0 : _charge$feature.featureId;
12388
12551
  var isBaseCharge = !featureId;
12389
12552
  var isPayAsYouGo = charge.pricingModel === Stigg.BillingModel.UsageBased;
12390
12553
  var displayName = isBaseCharge ? 'Base charge' : (_charge$feature2 = charge.feature) == null ? void 0 : _charge$feature2.displayName;
12391
12554
  var hasQuantityRestrictions = !!(charge != null && charge.minUnitQuantity || charge != null && charge.maxUnitQuantity);
12555
+ React.useEffect(function () {
12556
+ if (!featureId) {
12557
+ return;
12558
+ }
12559
+
12560
+ onValidationChange({
12561
+ featureId: featureId,
12562
+ isValid: isValid
12563
+ });
12564
+ }, [featureId, isValid, onValidationChange]);
12392
12565
 
12393
12566
  var handleQuantityChange = function handleQuantityChange(event) {
12394
12567
  var _event$target, _event$target2;
12395
12568
 
12396
12569
  if (isBaseCharge || !featureId) return;
12397
- var value = event != null && (_event$target = event.target) != null && _event$target.value ? Number(event == null ? void 0 : (_event$target2 = event.target) == null ? void 0 : _event$target2.value) : charge.minUnitQuantity || 1;
12398
- var quantity = getValidPriceQuantity(charge, value || 1);
12570
+ var value = event != null && (_event$target = event.target) != null && _event$target.value ? Number(event == null ? void 0 : (_event$target2 = event.target) == null ? void 0 : _event$target2.value) : charge.minUnitQuantity;
12571
+
12572
+ if (!value || value <= 0) {
12573
+ setIsValid(false); // Reset the input value to null
12574
+ // @ts-ignore
12575
+
12576
+ setBillableFeature(featureId, null);
12577
+ return;
12578
+ }
12579
+
12580
+ setIsValid(true);
12581
+ var quantity = getValidPriceQuantity(charge, value);
12399
12582
  setBillableFeature(featureId, quantity);
12400
12583
  };
12401
12584
 
@@ -12426,7 +12609,7 @@ function PlanCharge(_ref) {
12426
12609
  } else {
12427
12610
  chargeRow = React__default.createElement(InputField, {
12428
12611
  sx: {
12429
- width: 120
12612
+ width: 145
12430
12613
  },
12431
12614
  id: featureId + "-input",
12432
12615
  type: "number",
@@ -12436,7 +12619,14 @@ function PlanCharge(_ref) {
12436
12619
  max: charge.maxUnitQuantity
12437
12620
  }
12438
12621
  } : {},
12439
- value: (billableFeature == null ? void 0 : billableFeature.quantity) || charge.minUnitQuantity || 1,
12622
+ error: !isValid,
12623
+ helperText: !isValid ? 'Not a valid value' : '',
12624
+ FormHelperTextProps: {
12625
+ sx: {
12626
+ margin: '4px'
12627
+ }
12628
+ },
12629
+ value: (billableFeature == null ? void 0 : billableFeature.quantity) || charge.minUnitQuantity,
12440
12630
  onChange: handleQuantityChange
12441
12631
  });
12442
12632
  }
@@ -12467,9 +12657,23 @@ function CheckoutChargeList(_ref2) {
12467
12657
  billableFeatures = _usePlanStepModel.billableFeatures,
12468
12658
  setBillableFeature = _usePlanStepModel.setBillableFeature;
12469
12659
 
12660
+ var _useProgressBarModel = useProgressBarModel(),
12661
+ setIsDisabled = _useProgressBarModel.setIsDisabled;
12662
+
12470
12663
  var planCharges = useChargesSort((plan == null ? void 0 : (_plan$pricePoints = plan.pricePoints) == null ? void 0 : _plan$pricePoints.filter(function (p) {
12471
12664
  return p.billingPeriod === billingPeriod;
12472
12665
  })) || []);
12666
+
12667
+ var _useState = React.useState({}),
12668
+ chargesValidation = _useState[0],
12669
+ setChargesValidation = _useState[1];
12670
+
12671
+ React.useEffect(function () {
12672
+ var isDisabled = Object.values(chargesValidation).some(function (x) {
12673
+ return !x;
12674
+ });
12675
+ setIsDisabled(isDisabled);
12676
+ }, [chargesValidation, setIsDisabled]);
12473
12677
  return React__default.createElement("div", null, planCharges == null ? void 0 : planCharges.map(function (charge) {
12474
12678
  var _charge$feature5;
12475
12679
 
@@ -12482,7 +12686,16 @@ function CheckoutChargeList(_ref2) {
12482
12686
  key: ((_charge$feature5 = charge.feature) == null ? void 0 : _charge$feature5.featureId) || 'base-charge',
12483
12687
  charge: charge,
12484
12688
  setBillableFeature: setBillableFeature,
12485
- billableFeature: billableFeature
12689
+ billableFeature: billableFeature,
12690
+ onValidationChange: function onValidationChange(_ref3) {
12691
+ var featureId = _ref3.featureId,
12692
+ isValid = _ref3.isValid;
12693
+ return setChargesValidation(function (prev) {
12694
+ var _extends2;
12695
+
12696
+ return _extends({}, prev, (_extends2 = {}, _extends2[featureId] = isValid, _extends2));
12697
+ });
12698
+ }
12486
12699
  });
12487
12700
  }));
12488
12701
  }
@@ -12518,22 +12731,111 @@ var CheckoutPlanStep = function CheckoutPlanStep() {
12518
12731
  }));
12519
12732
  };
12520
12733
 
12521
- var getStepProps = function getStepProps(step) {
12522
- switch (step) {
12523
- case 0:
12734
+ 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)."; }
12735
+
12736
+ var DowngradeToFreePlansContainer = /*#__PURE__*/_styled(material.Box, {
12737
+ target: "eaawmuo2",
12738
+ label: "DowngradeToFreePlansContainer"
12739
+ })( {
12740
+ name: "zjik7",
12741
+ styles: "display:flex",
12742
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTWtEIiwiZmlsZSI6IkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBTdHlsZWRBcnJvd1JpZ2h0SWNvbiB9IGZyb20gJy4uL3BsYW5IZWFkZXIvUGxhbkhlYWRlci5zdHlsZSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQWxlcnQsIEJveCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBjdXJyZW5jeVByaWNlRm9ybWF0dGVyIH0gZnJvbSAnLi4vLi4vdXRpbHMvY3VycmVuY3lVdGlscyc7XHJcbmNvbnN0IERvd25ncmFkZVRvRnJlZVBsYW5zQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuYDtcclxuY29uc3QgRG93bmdyYWRlVG9GcmVlQWxlcnQgPSBzdHlsZWQoQWxlcnQpIGBcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEb3duZ3JhZGVUb0ZyZWVQbGFuQm94ID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICB3aWR0aDogMTAwJTtcbiAgYm9yZGVyOiAkeyh7IHRoZW1lIH0pID0+IGAxcHggc29saWQgJHt0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuYDtcclxuZXhwb3J0IGNvbnN0IERvd25ncmFkZVRvRnJlZUNvbnRlbnQgPSAoeyBwbGFuTmFtZSwgdG90YWxQcmljZSwgYmlsbGluZ1BlcmlvZCwgfSkgPT4ge1xyXG4gICAgY29uc3QgcHJpY2VUZXh0ID0gdG90YWxQcmljZVxyXG4gICAgICAgID8gY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudDogdG90YWxQcmljZS5hbW91bnQsIGN1cnJlbmN5OiB0b3RhbFByaWNlLmN1cnJlbmN5IH0pXHJcbiAgICAgICAgOiAnRnJlZSc7XHJcbiAgICBjb25zdCBiaWxsaW5nUGVyaW9kVGV4dCA9IGJpbGxpbmdQZXJpb2QgPyBgIC8gUGFpZCAke2JpbGxpbmdQZXJpb2QudG9Mb3dlckNhc2UoKX1gIDogJyc7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlUGxhbkJveCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZnJlZS1kb3duZ3JhZGUtcGxhbi1ib3hcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtdGV4dC1wbGFuXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHBsYW5OYW1lKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtdGV4dC1wcmljZVwiLCBzcGFuOiB0cnVlLCBib2xkOiB0cnVlLCB2YXJpYW50OiBcImgzXCIsIGNvbG9yOiBcInByaW1hcnlcIiB9LCBwcmljZVRleHQpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LWRvd25ncmFkZS10by1mcmVlLXRleHQtYmlsbGluZy1wZXJpb2RcIiwgc3BhbjogdHJ1ZSwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgYmlsbGluZ1BlcmlvZFRleHQpKSkpO1xyXG59O1xyXG5leHBvcnQgY29uc3QgRG93bmdyYWRlVG9GcmVlUGxhbiA9ICh7IGNoZWNrb3V0TG9jYWxpemF0aW9uLCBhY3RpdmVTdWJzY3JpcHRpb24sIGZyZWVQbGFuLCB9KSA9PiB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEb3duZ3JhZGVUb0ZyZWVBbGVydCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtYWxlcnRcIiwgc2V2ZXJpdHk6IFwiaW5mb1wiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWVBbGVydFRleHQoeyBwbGFuOiBhY3RpdmVTdWJzY3JpcHRpb24ucGxhbiB9KSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LWRvd25ncmFkZS10by1mcmVlLXBsYW5zLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlQ29udGVudCwgeyBwbGFuTmFtZTogYWN0aXZlU3Vic2NyaXB0aW9uLnBsYW4uZGlzcGxheU5hbWUsIHRvdGFsUHJpY2U6IGFjdGl2ZVN1YnNjcmlwdGlvbi50b3RhbFByaWNlPy50b3RhbCwgYmlsbGluZ1BlcmlvZDogYWN0aXZlU3Vic2NyaXB0aW9uLnByaWNlc1swXS5iaWxsaW5nUGVyaW9kIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFycm93UmlnaHRJY29uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS1hcnJvd1wiLCBzdHlsZTogeyBtYXJnaW46ICdhdXRvIDE2cHgnLCBtaW5XaWR0aDogJzE2cHgnIH0gfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlQ29udGVudCwgeyBwbGFuTmFtZTogZnJlZVBsYW4uZGlzcGxheU5hbWUgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPURvd25ncmFkZVRvRnJlZUNvbnRhaW5lci5qcy5tYXAiXX0= */",
12743
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$s
12744
+ });
12745
+
12746
+ var DowngradeToFreeAlert = /*#__PURE__*/_styled(material.Alert, {
12747
+ target: "eaawmuo1",
12748
+ label: "DowngradeToFreeAlert"
12749
+ })( {
12750
+ name: "18uqayh",
12751
+ styles: "margin-bottom:16px",
12752
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUzJDIiwiZmlsZSI6IkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBTdHlsZWRBcnJvd1JpZ2h0SWNvbiB9IGZyb20gJy4uL3BsYW5IZWFkZXIvUGxhbkhlYWRlci5zdHlsZSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQWxlcnQsIEJveCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBjdXJyZW5jeVByaWNlRm9ybWF0dGVyIH0gZnJvbSAnLi4vLi4vdXRpbHMvY3VycmVuY3lVdGlscyc7XHJcbmNvbnN0IERvd25ncmFkZVRvRnJlZVBsYW5zQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuYDtcclxuY29uc3QgRG93bmdyYWRlVG9GcmVlQWxlcnQgPSBzdHlsZWQoQWxlcnQpIGBcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEb3duZ3JhZGVUb0ZyZWVQbGFuQm94ID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICB3aWR0aDogMTAwJTtcbiAgYm9yZGVyOiAkeyh7IHRoZW1lIH0pID0+IGAxcHggc29saWQgJHt0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuYDtcclxuZXhwb3J0IGNvbnN0IERvd25ncmFkZVRvRnJlZUNvbnRlbnQgPSAoeyBwbGFuTmFtZSwgdG90YWxQcmljZSwgYmlsbGluZ1BlcmlvZCwgfSkgPT4ge1xyXG4gICAgY29uc3QgcHJpY2VUZXh0ID0gdG90YWxQcmljZVxyXG4gICAgICAgID8gY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudDogdG90YWxQcmljZS5hbW91bnQsIGN1cnJlbmN5OiB0b3RhbFByaWNlLmN1cnJlbmN5IH0pXHJcbiAgICAgICAgOiAnRnJlZSc7XHJcbiAgICBjb25zdCBiaWxsaW5nUGVyaW9kVGV4dCA9IGJpbGxpbmdQZXJpb2QgPyBgIC8gUGFpZCAke2JpbGxpbmdQZXJpb2QudG9Mb3dlckNhc2UoKX1gIDogJyc7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlUGxhbkJveCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZnJlZS1kb3duZ3JhZGUtcGxhbi1ib3hcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtdGV4dC1wbGFuXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHBsYW5OYW1lKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtdGV4dC1wcmljZVwiLCBzcGFuOiB0cnVlLCBib2xkOiB0cnVlLCB2YXJpYW50OiBcImgzXCIsIGNvbG9yOiBcInByaW1hcnlcIiB9LCBwcmljZVRleHQpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LWRvd25ncmFkZS10by1mcmVlLXRleHQtYmlsbGluZy1wZXJpb2RcIiwgc3BhbjogdHJ1ZSwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgYmlsbGluZ1BlcmlvZFRleHQpKSkpO1xyXG59O1xyXG5leHBvcnQgY29uc3QgRG93bmdyYWRlVG9GcmVlUGxhbiA9ICh7IGNoZWNrb3V0TG9jYWxpemF0aW9uLCBhY3RpdmVTdWJzY3JpcHRpb24sIGZyZWVQbGFuLCB9KSA9PiB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEb3duZ3JhZGVUb0ZyZWVBbGVydCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtYWxlcnRcIiwgc2V2ZXJpdHk6IFwiaW5mb1wiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWVBbGVydFRleHQoeyBwbGFuOiBhY3RpdmVTdWJzY3JpcHRpb24ucGxhbiB9KSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LWRvd25ncmFkZS10by1mcmVlLXBsYW5zLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlQ29udGVudCwgeyBwbGFuTmFtZTogYWN0aXZlU3Vic2NyaXB0aW9uLnBsYW4uZGlzcGxheU5hbWUsIHRvdGFsUHJpY2U6IGFjdGl2ZVN1YnNjcmlwdGlvbi50b3RhbFByaWNlPy50b3RhbCwgYmlsbGluZ1BlcmlvZDogYWN0aXZlU3Vic2NyaXB0aW9uLnByaWNlc1swXS5iaWxsaW5nUGVyaW9kIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFycm93UmlnaHRJY29uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS1hcnJvd1wiLCBzdHlsZTogeyBtYXJnaW46ICdhdXRvIDE2cHgnLCBtaW5XaWR0aDogJzE2cHgnIH0gfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlQ29udGVudCwgeyBwbGFuTmFtZTogZnJlZVBsYW4uZGlzcGxheU5hbWUgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPURvd25ncmFkZVRvRnJlZUNvbnRhaW5lci5qcy5tYXAiXX0= */",
12753
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$s
12754
+ });
12755
+
12756
+ var DowngradeToFreePlanBox = /*#__PURE__*/_styled(material.Box, {
12757
+ target: "eaawmuo0",
12758
+ label: "DowngradeToFreePlanBox"
12759
+ })("padding:16px;border-radius:10px;width:100%;border:", function (_ref) {
12760
+ var theme = _ref.theme;
12761
+ return "1px solid " + theme.stigg.palette.outlinedBorder;
12762
+ }, ";" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBWWtEIiwiZmlsZSI6IkRvd25ncmFkZVRvRnJlZUNvbnRhaW5lci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgeyBTdHlsZWRBcnJvd1JpZ2h0SWNvbiB9IGZyb20gJy4uL3BsYW5IZWFkZXIvUGxhbkhlYWRlci5zdHlsZSc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IHsgQWxlcnQsIEJveCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBjdXJyZW5jeVByaWNlRm9ybWF0dGVyIH0gZnJvbSAnLi4vLi4vdXRpbHMvY3VycmVuY3lVdGlscyc7XHJcbmNvbnN0IERvd25ncmFkZVRvRnJlZVBsYW5zQ29udGFpbmVyID0gc3R5bGVkKEJveCkgYFxuICBkaXNwbGF5OiBmbGV4O1xuYDtcclxuY29uc3QgRG93bmdyYWRlVG9GcmVlQWxlcnQgPSBzdHlsZWQoQWxlcnQpIGBcbiAgbWFyZ2luLWJvdHRvbTogMTZweDtcbmA7XHJcbmV4cG9ydCBjb25zdCBEb3duZ3JhZGVUb0ZyZWVQbGFuQm94ID0gc3R5bGVkKEJveCkgYFxuICBwYWRkaW5nOiAxNnB4O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICB3aWR0aDogMTAwJTtcbiAgYm9yZGVyOiAkeyh7IHRoZW1lIH0pID0+IGAxcHggc29saWQgJHt0aGVtZS5zdGlnZy5wYWxldHRlLm91dGxpbmVkQm9yZGVyfWB9O1xuYDtcclxuZXhwb3J0IGNvbnN0IERvd25ncmFkZVRvRnJlZUNvbnRlbnQgPSAoeyBwbGFuTmFtZSwgdG90YWxQcmljZSwgYmlsbGluZ1BlcmlvZCwgfSkgPT4ge1xyXG4gICAgY29uc3QgcHJpY2VUZXh0ID0gdG90YWxQcmljZVxyXG4gICAgICAgID8gY3VycmVuY3lQcmljZUZvcm1hdHRlcih7IGFtb3VudDogdG90YWxQcmljZS5hbW91bnQsIGN1cnJlbmN5OiB0b3RhbFByaWNlLmN1cnJlbmN5IH0pXHJcbiAgICAgICAgOiAnRnJlZSc7XHJcbiAgICBjb25zdCBiaWxsaW5nUGVyaW9kVGV4dCA9IGJpbGxpbmdQZXJpb2QgPyBgIC8gUGFpZCAke2JpbGxpbmdQZXJpb2QudG9Mb3dlckNhc2UoKX1gIDogJyc7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlUGxhbkJveCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZnJlZS1kb3duZ3JhZGUtcGxhbi1ib3hcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtdGV4dC1wbGFuXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHBsYW5OYW1lKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtdGV4dC1wcmljZVwiLCBzcGFuOiB0cnVlLCBib2xkOiB0cnVlLCB2YXJpYW50OiBcImgzXCIsIGNvbG9yOiBcInByaW1hcnlcIiB9LCBwcmljZVRleHQpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LWRvd25ncmFkZS10by1mcmVlLXRleHQtYmlsbGluZy1wZXJpb2RcIiwgc3BhbjogdHJ1ZSwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgYmlsbGluZ1BlcmlvZFRleHQpKSkpO1xyXG59O1xyXG5leHBvcnQgY29uc3QgRG93bmdyYWRlVG9GcmVlUGxhbiA9ICh7IGNoZWNrb3V0TG9jYWxpemF0aW9uLCBhY3RpdmVTdWJzY3JpcHRpb24sIGZyZWVQbGFuLCB9KSA9PiB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUmVhY3QuRnJhZ21lbnQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChEb3duZ3JhZGVUb0ZyZWVBbGVydCwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtZG93bmdyYWRlLXRvLWZyZWUtYWxlcnRcIiwgc2V2ZXJpdHk6IFwiaW5mb1wiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5kb3duZ3JhZGVUb0ZyZWVBbGVydFRleHQoeyBwbGFuOiBhY3RpdmVTdWJzY3JpcHRpb24ucGxhbiB9KSkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlUGxhbnNDb250YWluZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LWRvd25ncmFkZS10by1mcmVlLXBsYW5zLWNvbnRhaW5lclwiIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlQ29udGVudCwgeyBwbGFuTmFtZTogYWN0aXZlU3Vic2NyaXB0aW9uLnBsYW4uZGlzcGxheU5hbWUsIHRvdGFsUHJpY2U6IGFjdGl2ZVN1YnNjcmlwdGlvbi50b3RhbFByaWNlPy50b3RhbCwgYmlsbGluZ1BlcmlvZDogYWN0aXZlU3Vic2NyaXB0aW9uLnByaWNlc1swXS5iaWxsaW5nUGVyaW9kIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEFycm93UmlnaHRJY29uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1jaGVja291dC1kb3duZ3JhZGUtdG8tZnJlZS1hcnJvd1wiLCBzdHlsZTogeyBtYXJnaW46ICdhdXRvIDE2cHgnLCBtaW5XaWR0aDogJzE2cHgnIH0gfSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoRG93bmdyYWRlVG9GcmVlQ29udGVudCwgeyBwbGFuTmFtZTogZnJlZVBsYW4uZGlzcGxheU5hbWUgfSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPURvd25ncmFkZVRvRnJlZUNvbnRhaW5lci5qcy5tYXAiXX0= */"));
12763
+ var DowngradeToFreeContent = function DowngradeToFreeContent(_ref2) {
12764
+ var planName = _ref2.planName,
12765
+ totalPrice = _ref2.totalPrice,
12766
+ billingPeriod = _ref2.billingPeriod;
12767
+ var priceText = totalPrice ? currencyPriceFormatter({
12768
+ amount: totalPrice.amount,
12769
+ currency: totalPrice.currency
12770
+ }) : 'Free';
12771
+ var billingPeriodText = billingPeriod ? " / Paid " + billingPeriod.toLowerCase() : '';
12772
+ return React__default.createElement(DowngradeToFreePlanBox, {
12773
+ className: "stigg-checkout-free-downgrade-plan-box"
12774
+ }, React__default.createElement(Typography, {
12775
+ className: "stigg-checkout-downgrade-to-free-text-plan",
12776
+ color: "secondary"
12777
+ }, planName), React__default.createElement("div", null, React__default.createElement(Typography, {
12778
+ className: "stigg-checkout-downgrade-to-free-text-price",
12779
+ span: true,
12780
+ bold: true,
12781
+ variant: "h3",
12782
+ color: "primary"
12783
+ }, priceText), React__default.createElement(Typography, {
12784
+ className: "stigg-checkout-downgrade-to-free-text-billing-period",
12785
+ span: true,
12786
+ color: "secondary"
12787
+ }, billingPeriodText)));
12788
+ };
12789
+ var DowngradeToFreePlan = function DowngradeToFreePlan(_ref3) {
12790
+ var _activeSubscription$t;
12791
+
12792
+ var checkoutLocalization = _ref3.checkoutLocalization,
12793
+ activeSubscription = _ref3.activeSubscription,
12794
+ freePlan = _ref3.freePlan;
12795
+ return React__default.createElement(React__default.Fragment, null, React__default.createElement(DowngradeToFreeAlert, {
12796
+ className: "stigg-checkout-downgrade-to-free-alert",
12797
+ severity: "info"
12798
+ }, React__default.createElement(Typography, {
12799
+ color: "secondary"
12800
+ }, checkoutLocalization.downgradeToFreeAlertText({
12801
+ plan: activeSubscription.plan
12802
+ }))), React__default.createElement(DowngradeToFreePlansContainer, {
12803
+ className: "stigg-checkout-downgrade-to-free-plans-container"
12804
+ }, React__default.createElement(DowngradeToFreeContent, {
12805
+ planName: activeSubscription.plan.displayName,
12806
+ totalPrice: (_activeSubscription$t = activeSubscription.totalPrice) == null ? void 0 : _activeSubscription$t.total,
12807
+ billingPeriod: activeSubscription.prices[0].billingPeriod
12808
+ }), React__default.createElement(StyledArrowRightIcon, {
12809
+ className: "stigg-checkout-downgrade-to-free-arrow",
12810
+ style: {
12811
+ margin: 'auto 16px',
12812
+ minWidth: '16px'
12813
+ }
12814
+ }), React__default.createElement(DowngradeToFreeContent, {
12815
+ planName: freePlan.displayName
12816
+ })));
12817
+ };
12818
+
12819
+ var getStepProps = function getStepProps(currentStep, _ref) {
12820
+ var onBillingAddressChange = _ref.onBillingAddressChange;
12821
+
12822
+ switch (currentStep.key) {
12823
+ case CheckoutStepKey.PLAN:
12524
12824
  return {
12525
12825
  allowChangePlan: true,
12526
12826
  content: React__default.createElement(CheckoutPlanStep, null)
12527
12827
  };
12528
12828
 
12529
- case 1:
12829
+ case CheckoutStepKey.ADDONS:
12530
12830
  return {
12531
12831
  content: React__default.createElement(CheckoutAddonsStep, null)
12532
12832
  };
12533
12833
 
12534
- case 2:
12834
+ case CheckoutStepKey.PAYMENT:
12535
12835
  return {
12536
- content: React__default.createElement(PaymentStep, null)
12836
+ content: React__default.createElement(PaymentStep, {
12837
+ onBillingAddressChange: onBillingAddressChange
12838
+ })
12537
12839
  };
12538
12840
 
12539
12841
  default:
@@ -12543,10 +12845,12 @@ var getStepProps = function getStepProps(step) {
12543
12845
  }
12544
12846
  };
12545
12847
 
12546
- function CheckoutContainer(_ref) {
12547
- var onCheckout = _ref.onCheckout,
12548
- onCheckoutCompleted = _ref.onCheckoutCompleted,
12549
- onChangePlan = _ref.onChangePlan;
12848
+ function CheckoutContainer(_ref2) {
12849
+ var onCheckout = _ref2.onCheckout,
12850
+ onCheckoutCompleted = _ref2.onCheckoutCompleted,
12851
+ onChangePlan = _ref2.onChangePlan,
12852
+ onBillingAddressChange = _ref2.onBillingAddressChange,
12853
+ disablePromotionCode = _ref2.disablePromotionCode;
12550
12854
 
12551
12855
  var _useStripeIntegration = useStripeIntegration(),
12552
12856
  stripePromise = _useStripeIntegration.stripePromise,
@@ -12558,22 +12862,34 @@ function CheckoutContainer(_ref) {
12558
12862
  widgetState = _useCheckoutContext$.widgetState;
12559
12863
 
12560
12864
  var _useProgressBarModel = useProgressBarModel(),
12561
- progressBarState = _useProgressBarModel.progressBarState;
12865
+ currentStep = _useProgressBarModel.currentStep;
12562
12866
 
12563
- var activeStep = progressBarState.activeStep;
12564
- var isLoadingCheckoutData = widgetState.isLoadingCheckoutData; // uncomment for fun!
12565
- // if (activeStep > 2) {
12566
- // return <SurpriseStep />;
12567
- // }
12867
+ var isLoadingCheckoutData = widgetState.isLoadingCheckoutData;
12568
12868
 
12569
- var _getStepProps = getStepProps(activeStep),
12869
+ var _useCheckoutModel = useCheckoutModel(),
12870
+ checkoutState = _useCheckoutModel.checkoutState,
12871
+ checkoutLocalization = _useCheckoutModel.checkoutLocalization;
12872
+
12873
+ var _ref3 = checkoutState || {},
12874
+ plan = _ref3.plan,
12875
+ activeSubscription = _ref3.activeSubscription;
12876
+
12877
+ var isFreeDowngrade = !!plan && plan.pricingType === Stigg.PricingType.Free && !!activeSubscription && activeSubscription.pricingType !== Stigg.PricingType.Free;
12878
+
12879
+ var _getStepProps = getStepProps(currentStep, {
12880
+ onBillingAddressChange: onBillingAddressChange
12881
+ }),
12570
12882
  content = _getStepProps.content,
12571
12883
  allowChangePlan = _getStepProps.allowChangePlan;
12572
12884
 
12573
- var checkoutContent = React__default.createElement(React__default.Fragment, null, React__default.createElement(PlanHeader$1, {
12885
+ var checkoutContent = React__default.createElement(React__default.Fragment, null, isFreeDowngrade ? React__default.createElement(DowngradeToFreePlan, {
12886
+ checkoutLocalization: checkoutLocalization,
12887
+ freePlan: plan,
12888
+ activeSubscription: activeSubscription
12889
+ }) : React__default.createElement(React__default.Fragment, null, React__default.createElement(PlanHeader$1, {
12574
12890
  allowChangePlan: allowChangePlan,
12575
12891
  onChangePlan: onChangePlan
12576
- }), content);
12892
+ }), content));
12577
12893
  return React__default.createElement(reactStripeJs.Elements, {
12578
12894
  stripe: stripePromise,
12579
12895
  options: {
@@ -12590,13 +12906,15 @@ function CheckoutContainer(_ref) {
12590
12906
  }
12591
12907
  }, React__default.createElement(CheckoutLayout, {
12592
12908
  className: "stigg-checkout-layout"
12593
- }, React__default.createElement(CheckoutProgressBar, null), React__default.createElement(CheckoutContent, null, React__default.createElement(CheckoutPanel, null, isLoadingCheckoutData && React__default.createElement(ContentLoadingSkeleton, null), !isLoadingCheckoutData && checkoutContent), isLoadingCheckoutData && React__default.createElement(CheckoutSummarySkeleton, null), !isLoadingCheckoutData && React__default.createElement(CheckoutSummary, {
12909
+ }, !isFreeDowngrade && React__default.createElement(CheckoutProgressBar, null), React__default.createElement(CheckoutContent, null, React__default.createElement(CheckoutPanel, null, isLoadingCheckoutData ? React__default.createElement(ContentLoadingSkeleton, null) : checkoutContent), isLoadingCheckoutData ? React__default.createElement(CheckoutSummarySkeleton, null) : React__default.createElement(CheckoutSummary, {
12910
+ disablePromotionCode: disablePromotionCode,
12594
12911
  onCheckout: onCheckout,
12595
- onCheckoutCompleted: onCheckoutCompleted
12912
+ onCheckoutCompleted: onCheckoutCompleted,
12913
+ isFreeDowngrade: isFreeDowngrade
12596
12914
  }))));
12597
12915
  }
12598
12916
 
12599
- var _excluded$6 = ["textOverrides", "theme", "resourceId", "planId", "preferredBillingPeriod", "billingCountryCode", "billableFeatures"];
12917
+ var _excluded$7 = ["textOverrides", "theme", "resourceId", "planId", "preferredBillingPeriod", "billingCountryCode", "billableFeatures", "billingInformation"];
12600
12918
  var Checkout = function Checkout(_ref) {
12601
12919
  var textOverrides = _ref.textOverrides,
12602
12920
  theme = _ref.theme,
@@ -12605,7 +12923,8 @@ var Checkout = function Checkout(_ref) {
12605
12923
  preferredBillingPeriod = _ref.preferredBillingPeriod,
12606
12924
  billingCountryCode = _ref.billingCountryCode,
12607
12925
  billableFeatures = _ref.billableFeatures,
12608
- containerProps = _objectWithoutPropertiesLoose(_ref, _excluded$6);
12926
+ billingInformation = _ref.billingInformation,
12927
+ containerProps = _objectWithoutPropertiesLoose(_ref, _excluded$7);
12609
12928
 
12610
12929
  return React__default.createElement(CheckoutProvider, {
12611
12930
  textOverrides: textOverrides,
@@ -12614,7 +12933,8 @@ var Checkout = function Checkout(_ref) {
12614
12933
  planId: planId,
12615
12934
  preferredBillingPeriod: preferredBillingPeriod,
12616
12935
  billingCountryCode: billingCountryCode,
12617
- billableFeatures: billableFeatures
12936
+ billableFeatures: billableFeatures,
12937
+ billingInformation: billingInformation
12618
12938
  }, React__default.createElement(CheckoutContainer, Object.assign({}, containerProps)));
12619
12939
  };
12620
12940