@stigg/react-sdk 4.14.0 → 5.0.0

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 (46) hide show
  1. package/dist/components/customerPortal/CustomerPortal.d.ts +2 -2
  2. package/dist/components/customerPortal/CustomerPortalContainer.d.ts +4 -0
  3. package/dist/components/customerPortal/index.d.ts +3 -0
  4. package/dist/components/customerPortal/subscriptionOverview/SubscriptionsOverview.d.ts +2 -1
  5. package/dist/components/customerPortal/subscriptionOverview/SubscriptionsOverviewHeader.d.ts +2 -1
  6. package/dist/components/customerPortal/subscriptionOverview/charges/ChargeItem.d.ts +2 -1
  7. package/dist/components/customerPortal/subscriptionOverview/charges/ChargeList.d.ts +2 -1
  8. package/dist/components/customerPortal/subscriptionOverview/subscriptionView/SubscriptionView.d.ts +2 -1
  9. package/dist/components/customerPortal/subscriptionOverview/subscriptionView/TrialPanel.d.ts +2 -1
  10. package/dist/components/customerPortal/types.d.ts +10 -1
  11. package/dist/components/customerPortal/usage/CustomerUsageData.d.ts +2 -1
  12. package/dist/components/customerPortal/usage/featureUsage/EntitlementCTAButton.d.ts +2 -1
  13. package/dist/components/customerPortal/usage/featureUsage/FeatureUsage.d.ts +2 -1
  14. package/dist/components/paywall/index.d.ts +1 -1
  15. package/dist/components/paywall/paywallTextOverrides.d.ts +6 -1
  16. package/dist/components/utils/priceTierUtils.d.ts +3 -1
  17. package/dist/index.d.ts +3 -3
  18. package/dist/react-sdk.cjs.development.js +82 -55
  19. package/dist/react-sdk.cjs.development.js.map +1 -1
  20. package/dist/react-sdk.cjs.production.min.js +1 -1
  21. package/dist/react-sdk.cjs.production.min.js.map +1 -1
  22. package/dist/react-sdk.esm.js +87 -58
  23. package/dist/react-sdk.esm.js.map +1 -1
  24. package/package.json +2 -2
  25. package/src/components/checkout/hooks/usePlanStepModel.ts +3 -3
  26. package/src/components/checkout/summary/components/LineItems.tsx +7 -3
  27. package/src/components/common/TiersSelectContainer.tsx +7 -14
  28. package/src/components/customerPortal/CustomerPortal.tsx +2 -2
  29. package/src/components/customerPortal/CustomerPortalContainer.tsx +8 -3
  30. package/src/components/customerPortal/index.ts +3 -0
  31. package/src/components/customerPortal/subscriptionOverview/SubscriptionsOverview.tsx +2 -1
  32. package/src/components/customerPortal/subscriptionOverview/SubscriptionsOverviewHeader.tsx +7 -2
  33. package/src/components/customerPortal/subscriptionOverview/charges/ChargeItem.tsx +2 -1
  34. package/src/components/customerPortal/subscriptionOverview/charges/ChargeList.tsx +2 -1
  35. package/src/components/customerPortal/subscriptionOverview/subscriptionView/SubscriptionView.tsx +2 -1
  36. package/src/components/customerPortal/subscriptionOverview/subscriptionView/TrialPanel.tsx +6 -2
  37. package/src/components/customerPortal/types.ts +15 -1
  38. package/src/components/customerPortal/usage/CustomerUsageData.tsx +2 -1
  39. package/src/components/customerPortal/usage/featureUsage/EntitlementCTAButton.tsx +6 -3
  40. package/src/components/customerPortal/usage/featureUsage/FeatureUsage.tsx +2 -1
  41. package/src/components/paywall/index.ts +1 -1
  42. package/src/components/utils/calculateDiscountRate.ts +2 -1
  43. package/src/components/utils/getPaidPriceText.ts +1 -1
  44. package/src/components/utils/priceTierUtils.ts +41 -21
  45. package/src/index.ts +9 -1
  46. package/src/stories/mocks/checkout/mockCheckoutState.ts +4 -4
@@ -746,18 +746,30 @@ function getTierByQuantity(tiers, quantity) {
746
746
 
747
747
  return ascendingTiers[ascendingTiers.length - 1];
748
748
  }
749
- function calculateTierPrice(price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, perUnitQuantity) {
750
- var unitPrice = selectedBillingPeriod === Stigg.BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? currentTier.unitPrice.amount / 12 : currentTier.unitPrice.amount;
751
749
 
750
+ function getAmount(amount, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
751
+ return selectedBillingPeriod === Stigg.BillingPeriod.Annually && shouldShowMonthlyPriceAmount ? amount / 12 : amount;
752
+ }
753
+
754
+ function calculateTierPriceVolume(currentTier, perUnitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount) {
755
+ var amount = 0;
756
+
757
+ if (currentTier.unitPrice) {
758
+ var unitPrice = getAmount(currentTier.unitPrice.amount, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
759
+ amount += unitPrice * perUnitQuantity;
760
+ }
761
+
762
+ if (currentTier.flatPrice) {
763
+ amount += getAmount(currentTier.flatPrice.amount, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
764
+ }
765
+
766
+ return amount;
767
+ }
768
+ function calculateTierPrice(price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, perUnitQuantity) {
752
769
  switch (price.tiersMode) {
753
770
  case Stigg.TiersMode.Volume:
754
771
  {
755
- return unitPrice * (currentTier.upTo || 1);
756
- }
757
-
758
- case Stigg.TiersMode.VolumePerUnit:
759
- {
760
- return unitPrice * (perUnitQuantity || 1);
772
+ return calculateTierPriceVolume(currentTier, perUnitQuantity, selectedBillingPeriod, shouldShowMonthlyPriceAmount);
761
773
  }
762
774
 
763
775
  default:
@@ -791,6 +803,13 @@ function getSelectedTierQuantityBeFeature(plan, billingPeriod, currentSubscripti
791
803
 
792
804
  return result;
793
805
  }
806
+ function hasTierWithUnitPrice(tiers) {
807
+ return tiers == null ? void 0 : tiers.some(function (_ref) {
808
+ var unitPrice = _ref.unitPrice,
809
+ upTo = _ref.upTo;
810
+ return unitPrice && !isNil(upTo);
811
+ });
812
+ }
794
813
  function getSelectedTier(plan, billingPeriod, currentSubscription, selectedTierByFeature, selectDefaultTierIndex) {
795
814
  var planTierPrices = plan.pricePoints.filter(function (price) {
796
815
  return price.billingPeriod === billingPeriod && price.isTieredPrice;
@@ -853,7 +872,7 @@ function compareSelectedTierToCurrentTier(selectedTierByFeature, perUnitQuantity
853
872
  var _currentTierPrice$fea = currentTierPrice.feature,
854
873
  featureId = _currentTierPrice$fea.featureId,
855
874
  unitQuantity = _currentTierPrice$fea.unitQuantity;
856
- var tiersMode = currentTierPrice.tiersMode;
875
+ var tiers = currentTierPrice.tiers;
857
876
 
858
877
  if (!unitQuantity) {
859
878
  return PriceTierComparison.Equal;
@@ -866,20 +885,14 @@ function compareSelectedTierToCurrentTier(selectedTierByFeature, perUnitQuantity
866
885
  return PriceTierComparison.Equal;
867
886
  }
868
887
 
869
- if (tiersMode === Stigg.TiersMode.Volume) {
870
- if (selectedTier.upTo && selectedTier.upTo < unitQuantity) {
871
- return PriceTierComparison.Lower;
872
- }
888
+ var effectiveQuantity = hasTierWithUnitPrice(tiers) ? selectedQuantity : selectedTier.upTo;
873
889
 
874
- if (selectedTier.upTo && selectedTier.upTo > unitQuantity) {
875
- return PriceTierComparison.Higher;
876
- }
877
- } else if (tiersMode === Stigg.TiersMode.VolumePerUnit) {
878
- if (selectedQuantity && selectedQuantity < unitQuantity) {
890
+ if (!isNil(effectiveQuantity)) {
891
+ if (effectiveQuantity < unitQuantity) {
879
892
  return PriceTierComparison.Lower;
880
893
  }
881
894
 
882
- if (selectedQuantity && selectedQuantity > unitQuantity) {
895
+ if (effectiveQuantity > unitQuantity) {
883
896
  return PriceTierComparison.Higher;
884
897
  }
885
898
  }
@@ -1179,7 +1192,7 @@ function getPaidPriceText(_ref) {
1179
1192
  tierUnits = getPriceFeatureUnit(_price);
1180
1193
  }
1181
1194
 
1182
- priceNumber += calculateTierPrice(_price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, perUnitQuantityByFeature == null ? void 0 : perUnitQuantityByFeature[_price.feature.featureId]);
1195
+ priceNumber += calculateTierPrice(_price, currentTier, selectedBillingPeriod, shouldShowMonthlyPriceAmount, (perUnitQuantityByFeature == null ? void 0 : perUnitQuantityByFeature[_price.feature.featureId]) || 1);
1183
1196
  }
1184
1197
  }
1185
1198
 
@@ -1541,13 +1554,12 @@ var TiersSelectLayout = /*#__PURE__*/_styled(Typography, {
1541
1554
  })( {
1542
1555
  name: "1m2htit",
1543
1556
  styles: "min-height:46px",
1544
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzU2VsZWN0Q29udGFpbmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFPNkMiLCJmaWxlIjoiVGllcnNTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgVGllcnNNb2RlIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IGdldFRpZXJCeVF1YW50aXR5IH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi9UeXBvZ3JhcGh5JztcclxuaW1wb3J0IHsgVm9sdW1lUGVyVW5pdElucHV0IH0gZnJvbSAnLi9Wb2x1bWVQZXJVbml0SW5wdXQnO1xyXG5pbXBvcnQgeyBWb2x1bWVCdWxrU2VsZWN0IH0gZnJvbSAnLi9Wb2x1bWVCdWxrU2VsZWN0JztcclxuY29uc3QgVGllcnNTZWxlY3RMYXlvdXQgPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICBtaW4taGVpZ2h0OiA0NnB4O1xuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFRpZXJzU2VsZWN0Q29udGFpbmVyKHByb3BzKSB7XHJcbiAgICBjb25zdCB7IHRpZXJzLCB0aWVyc01vZGUsIGhhbmRsZVRpZXJDaGFuZ2UgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaGFuZGxlQ2hhbmdlID0gKHF1YW50aXR5KSA9PiB7XHJcbiAgICAgICAgaWYgKCF0aWVycylcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIGhhbmRsZVRpZXJDaGFuZ2UoZ2V0VGllckJ5UXVhbnRpdHkodGllcnMsIHF1YW50aXR5KSk7XHJcbiAgICB9O1xyXG4gICAgY29uc3QgZ2V0Q29udGVudCA9ICgpID0+IHtcclxuICAgICAgICBzd2l0Y2ggKHRpZXJzTW9kZSkge1xyXG4gICAgICAgICAgICBjYXNlIFRpZXJzTW9kZS5Wb2x1bWVQZXJVbml0OlxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVm9sdW1lUGVyVW5pdElucHV0LCBPYmplY3QuYXNzaWduKHsgaGFuZGxlQ2hhbmdlOiBoYW5kbGVDaGFuZ2UgfSwgcHJvcHMpKTtcclxuICAgICAgICAgICAgY2FzZSBUaWVyc01vZGUuVm9sdW1lOlxyXG4gICAgICAgICAgICAgICAgcmV0dXJuIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVm9sdW1lQnVsa1NlbGVjdCwgT2JqZWN0LmFzc2lnbih7IGhhbmRsZUNoYW5nZTogaGFuZGxlQ2hhbmdlIH0sIHByb3BzKSk7XHJcbiAgICAgICAgICAgIGRlZmF1bHQ6XHJcbiAgICAgICAgICAgICAgICByZXR1cm4gUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCBudWxsKTtcclxuICAgICAgICB9XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJzU2VsZWN0TGF5b3V0LCB7IGFzOiBcImRpdlwiLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGllci1zZWxlY3RcIiB9LCBnZXRDb250ZW50KCkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UaWVyc1NlbGVjdENvbnRhaW5lci5qcy5tYXAiXX0= */",
1557
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzU2VsZWN0Q29udGFpbmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNNkMiLCJmaWxlIjoiVGllcnNTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBnZXRUaWVyQnlRdWFudGl0eSwgaGFzVGllcldpdGhVbml0UHJpY2UgfSBmcm9tICcuLi91dGlscy9wcmljZVRpZXJVdGlscyc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBWb2x1bWVQZXJVbml0SW5wdXQgfSBmcm9tICcuL1ZvbHVtZVBlclVuaXRJbnB1dCc7XHJcbmltcG9ydCB7IFZvbHVtZUJ1bGtTZWxlY3QgfSBmcm9tICcuL1ZvbHVtZUJ1bGtTZWxlY3QnO1xyXG5jb25zdCBUaWVyc1NlbGVjdExheW91dCA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIG1pbi1oZWlnaHQ6IDQ2cHg7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gVGllcnNTZWxlY3RDb250YWluZXIocHJvcHMpIHtcclxuICAgIGNvbnN0IHsgdGllcnMsIGhhbmRsZVRpZXJDaGFuZ2UgfSA9IHByb3BzO1xyXG4gICAgY29uc3QgaGFuZGxlQ2hhbmdlID0gKHF1YW50aXR5KSA9PiB7XHJcbiAgICAgICAgaWYgKCF0aWVycylcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIGhhbmRsZVRpZXJDaGFuZ2UoZ2V0VGllckJ5UXVhbnRpdHkodGllcnMsIHF1YW50aXR5KSk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJzU2VsZWN0TGF5b3V0LCB7IGFzOiBcImRpdlwiLCBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGllci1zZWxlY3RcIiB9LCBoYXNUaWVyV2l0aFVuaXRQcmljZSh0aWVycykgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChWb2x1bWVQZXJVbml0SW5wdXQsIE9iamVjdC5hc3NpZ24oeyBoYW5kbGVDaGFuZ2U6IGhhbmRsZUNoYW5nZSB9LCBwcm9wcykpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFZvbHVtZUJ1bGtTZWxlY3QsIE9iamVjdC5hc3NpZ24oeyBoYW5kbGVDaGFuZ2U6IGhhbmRsZUNoYW5nZSB9LCBwcm9wcykpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRpZXJzU2VsZWN0Q29udGFpbmVyLmpzLm1hcCJdfQ== */",
1545
1558
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$5
1546
1559
  });
1547
1560
 
1548
1561
  function TiersSelectContainer(props) {
1549
1562
  var tiers = props.tiers,
1550
- tiersMode = props.tiersMode,
1551
1563
  handleTierChange = props.handleTierChange;
1552
1564
 
1553
1565
  var handleChange = function handleChange(quantity) {
@@ -1555,27 +1567,14 @@ function TiersSelectContainer(props) {
1555
1567
  handleTierChange(getTierByQuantity(tiers, quantity));
1556
1568
  };
1557
1569
 
1558
- var getContent = function getContent() {
1559
- switch (tiersMode) {
1560
- case Stigg.TiersMode.VolumePerUnit:
1561
- return React__default.createElement(VolumePerUnitInput, Object.assign({
1562
- handleChange: handleChange
1563
- }, props));
1564
-
1565
- case Stigg.TiersMode.Volume:
1566
- return React__default.createElement(VolumeBulkSelect, Object.assign({
1567
- handleChange: handleChange
1568
- }, props));
1569
-
1570
- default:
1571
- return React__default.createElement("div", null);
1572
- }
1573
- };
1574
-
1575
1570
  return React__default.createElement(TiersSelectLayout, {
1576
1571
  as: "div",
1577
1572
  className: "stigg-price-tier-select"
1578
- }, getContent());
1573
+ }, hasTierWithUnitPrice(tiers) ? React__default.createElement(VolumePerUnitInput, Object.assign({
1574
+ handleChange: handleChange
1575
+ }, props)) : React__default.createElement(VolumeBulkSelect, Object.assign({
1576
+ handleChange: handleChange
1577
+ }, props)));
1579
1578
  }
1580
1579
 
1581
1580
  function _EMOTION_STRINGIFIED_CSS_ERROR__$6() { 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)."; }
@@ -2093,7 +2092,7 @@ function getPlanBillingPeriodAmount(plan, billingPeriod) {
2093
2092
  });
2094
2093
 
2095
2094
  if (tieredPrice) {
2096
- return tieredPrice.tiers[0].unitPrice.amount;
2095
+ return calculateTierPriceVolume(tieredPrice.tiers[0], 1);
2097
2096
  }
2098
2097
  }
2099
2098
 
@@ -4258,13 +4257,19 @@ function SectionTitle(_ref) {
4258
4257
  }, title);
4259
4258
  }
4260
4259
 
4260
+ (function (CustomerPortalIntentionType) {
4261
+ CustomerPortalIntentionType["MANAGE_SUBSCRIPTION"] = "MANAGE_SUBSCRIPTION";
4262
+ CustomerPortalIntentionType["UPGRADE_PLAN"] = "UPGRADE_PLAN";
4263
+ CustomerPortalIntentionType["UPGRADE_TRIAL_PLAN"] = "UPGRADE_TRIAL_PLAN";
4264
+ })(exports.CustomerPortalIntentionType || (exports.CustomerPortalIntentionType = {}));
4265
+
4261
4266
  var StyledEditIcon = /*#__PURE__*/_styled(SvgEditIcon, {
4262
4267
  target: "e1fjw26b0",
4263
4268
  label: "StyledEditIcon"
4264
4269
  })("path{stroke:", function (_ref) {
4265
4270
  var theme = _ref.theme;
4266
4271
  return theme.stigg.palette.primary;
4267
- }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBT3dDIiwiZmlsZSI6IlN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFN0eWxlZEJ1dHRvbiB9IGZyb20gJy4uL2NvbW1vbi9TdHlsZWRCdXR0b24nO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgRWRpdEljb24gZnJvbSAnLi4vLi4vLi4vYXNzZXRzL2VkaXQtaWNvbi5zdmcnO1xyXG5pbXBvcnQgeyBTZWN0aW9uSGVhZGVyIH0gZnJvbSAnLi4vY29tbW9uL1NlY3Rpb25IZWFkZXInO1xyXG5pbXBvcnQgeyBTZWN0aW9uVGl0bGUgfSBmcm9tICcuLi9jb21tb24vU2VjdGlvblRpdGxlJztcclxuY29uc3QgU3R5bGVkRWRpdEljb24gPSBzdHlsZWQoRWRpdEljb24pIGBcbiAgcGF0aCB7XG4gICAgc3Ryb2tlOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUucHJpbWFyeX07XG4gIH1cbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBTdWJzY3JpcHRpb25zT3ZlcnZpZXdIZWFkZXIoeyBvbk1hbmFnZVN1YnNjcmlwdGlvbiwgaGlkZU1hbmFnZUJ1dHRvbiwgdGV4dE92ZXJyaWRlcywgfSkge1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFNlY3Rpb25IZWFkZXIsIHsgY2xhc3NOYW1lOiBcInN0aWdnLWN1c3RvbWVyLXBvcnRhbC1vdmVydmlldy1oZWFkZXJcIiwgXCIkZGlzYWJsZU1hcmdpblwiOiB0cnVlIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTZWN0aW9uVGl0bGUsIHsgdGl0bGU6IFwiU3Vic2NyaXB0aW9uXCIsIGNsYXNzTmFtZTogXCJzdGlnZy1vdmVydmlldy10aXRsZVwiIH0pLFxyXG4gICAgICAgICFoaWRlTWFuYWdlQnV0dG9uICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEJ1dHRvbiwgeyBjbGFzc05hbWU6IFwic3RpZ2ctbWFuYWdlLXN1YnNjcmlwdGlvbi1idXR0b25cIiwgdmFyaWFudDogXCJvdXRsaW5lZFwiLCBvbkNsaWNrOiBvbk1hbmFnZVN1YnNjcmlwdGlvbiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZEVkaXRJY29uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1tYW5hZ2Utc3Vic2NyaXB0aW9uLWJ1dHRvbi1pbWFnZVwiIH0pLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLW1hbmFnZS1zdWJzY3JpcHRpb24tYnV0dG9uLXRleHRcIiwgY29sb3I6IFwicHJpbWFyeS5tYWluXCIsIHN0eWxlOiB7IG1hcmdpbkxlZnQ6ICc4cHgnIH0sIHZhcmlhbnQ6IFwiYm9keTFcIiB9LCB0ZXh0T3ZlcnJpZGVzPy5tYW5hZ2VTdWJzY3JpcHRpb24pKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1TdWJzY3JpcHRpb25zT3ZlcnZpZXdIZWFkZXIuanMubWFwIl19 */"));
4272
+ }, ";}" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlci50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBUXdDIiwiZmlsZSI6IlN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlci50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IFN0eWxlZEJ1dHRvbiB9IGZyb20gJy4uL2NvbW1vbi9TdHlsZWRCdXR0b24nO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgRWRpdEljb24gZnJvbSAnLi4vLi4vLi4vYXNzZXRzL2VkaXQtaWNvbi5zdmcnO1xyXG5pbXBvcnQgeyBTZWN0aW9uSGVhZGVyIH0gZnJvbSAnLi4vY29tbW9uL1NlY3Rpb25IZWFkZXInO1xyXG5pbXBvcnQgeyBTZWN0aW9uVGl0bGUgfSBmcm9tICcuLi9jb21tb24vU2VjdGlvblRpdGxlJztcclxuaW1wb3J0IHsgQ3VzdG9tZXJQb3J0YWxJbnRlbnRpb25UeXBlIH0gZnJvbSAnLi4vdHlwZXMnO1xyXG5jb25zdCBTdHlsZWRFZGl0SWNvbiA9IHN0eWxlZChFZGl0SWNvbikgYFxuICBwYXRoIHtcbiAgICBzdHJva2U6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5wcmltYXJ5fTtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFN1YnNjcmlwdGlvbnNPdmVydmlld0hlYWRlcih7IG9uTWFuYWdlU3Vic2NyaXB0aW9uLCBoaWRlTWFuYWdlQnV0dG9uLCB0ZXh0T3ZlcnJpZGVzLCB9KSB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2VjdGlvbkhlYWRlciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctY3VzdG9tZXItcG9ydGFsLW92ZXJ2aWV3LWhlYWRlclwiLCBcIiRkaXNhYmxlTWFyZ2luXCI6IHRydWUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNlY3Rpb25UaXRsZSwgeyB0aXRsZTogXCJTdWJzY3JpcHRpb25cIiwgY2xhc3NOYW1lOiBcInN0aWdnLW92ZXJ2aWV3LXRpdGxlXCIgfSksXHJcbiAgICAgICAgIWhpZGVNYW5hZ2VCdXR0b24gJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkQnV0dG9uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1tYW5hZ2Utc3Vic2NyaXB0aW9uLWJ1dHRvblwiLCB2YXJpYW50OiBcIm91dGxpbmVkXCIsIG9uQ2xpY2s6ICgpID0+IG9uTWFuYWdlU3Vic2NyaXB0aW9uKHsgaW50ZW50aW9uVHlwZTogQ3VzdG9tZXJQb3J0YWxJbnRlbnRpb25UeXBlLk1BTkFHRV9TVUJTQ1JJUFRJT04gfSkgfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRFZGl0SWNvbiwgeyBjbGFzc05hbWU6IFwic3RpZ2ctbWFuYWdlLXN1YnNjcmlwdGlvbi1idXR0b24taW1hZ2VcIiB9KSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1tYW5hZ2Utc3Vic2NyaXB0aW9uLWJ1dHRvbi10ZXh0XCIsIGNvbG9yOiBcInByaW1hcnkubWFpblwiLCBzdHlsZTogeyBtYXJnaW5MZWZ0OiAnOHB4JyB9LCB2YXJpYW50OiBcImJvZHkxXCIgfSwgdGV4dE92ZXJyaWRlcz8ubWFuYWdlU3Vic2NyaXB0aW9uKSkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9U3Vic2NyaXB0aW9uc092ZXJ2aWV3SGVhZGVyLmpzLm1hcCJdfQ== */"));
4268
4273
 
4269
4274
  function SubscriptionsOverviewHeader(_ref2) {
4270
4275
  var onManageSubscription = _ref2.onManageSubscription,
@@ -4279,7 +4284,11 @@ function SubscriptionsOverviewHeader(_ref2) {
4279
4284
  }), !hideManageButton && React__default.createElement(StyledButton$1, {
4280
4285
  className: "stigg-manage-subscription-button",
4281
4286
  variant: "outlined",
4282
- onClick: onManageSubscription
4287
+ onClick: function onClick() {
4288
+ return onManageSubscription({
4289
+ intentionType: exports.CustomerPortalIntentionType.MANAGE_SUBSCRIPTION
4290
+ });
4291
+ }
4283
4292
  }, React__default.createElement(StyledEditIcon, {
4284
4293
  className: "stigg-manage-subscription-button-image"
4285
4294
  }), React__default.createElement(Typography, {
@@ -5634,7 +5643,7 @@ var OnTrialBadge = /*#__PURE__*/_styled("div", {
5634
5643
  })("width:100%;display:flex;align-items:center;gap:4px;background-color:", function (_ref) {
5635
5644
  var theme = _ref.theme;
5636
5645
  return theme.stigg.palette.warning;
5637
- }, ";border-radius:10px;padding:8px 16px;margin-top:16px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyaWFsUGFuZWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQU9nQyIsImZpbGUiOiJUcmlhbFBhbmVsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uU3RhdHVzIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgTGluayBmcm9tICdAbXVpL21hdGVyaWFsL0xpbmsnO1xyXG5pbXBvcnQgU2FuZENsb2NrSWNvbiBmcm9tICcuLi8uLi8uLi8uLi9hc3NldHMvc2FuZC1jbG9jay5zdmcnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBMb25nVGV4dCB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9Mb25nVGV4dCc7XHJcbmNvbnN0IE9uVHJpYWxCYWRnZSA9IHN0eWxlZC5kaXYgYFxuICB3aWR0aDogMTAwJTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZ2FwOiA0cHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS53YXJuaW5nfTtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgcGFkZGluZzogOHB4IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5jb25zdCBTdHlsZWRMaW5rID0gc3R5bGVkKExpbmspIGBcbiAgdGV4dC1kZWNvcmF0aW9uLWNvbG9yOiB3aGl0ZTtcbiAgY29sb3I6IHdoaXRlO1xuICBjdXJzb3I6IHBvaW50ZXI7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gVHJpYWxQYW5lbCh7IHN1YnNjcmlwdGlvbiwgaW5jbHVkZVBsYW5OYW1lLCBvbk1hbmFnZVN1YnNjcmlwdGlvbiwgfSkge1xyXG4gICAgaWYgKHN1YnNjcmlwdGlvbj8uc3RhdHVzICE9PSBTdWJzY3JpcHRpb25TdGF0dXMuSW5UcmlhbCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KE9uVHJpYWxCYWRnZSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlXCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNhbmRDbG9ja0ljb24sIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi10cmlhbC1iYWRnZS1pbWFnZVwiIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgeyBzdHlsZTogeyBmbGV4OiAxLCBtYXJnaW5SaWdodDogNCB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9uZ1RleHQsIHsgdmFyaWFudDogXCJib2R5MVwiLCBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlLXRleHRcIiwgY29sb3I6IFwid2hpdGVcIiB9LFxyXG4gICAgICAgICAgICAgICAgYCR7c3Vic2NyaXB0aW9uLnRyaWFsUmVtYWluaW5nRGF5c30gZGF5cyByZW1haW5pbmcgaW4gdHJpYWxgLFxyXG4gICAgICAgICAgICAgICAgaW5jbHVkZVBsYW5OYW1lICYmIGAgb2YgdGhlICR7c3Vic2NyaXB0aW9uLnBsYW5OYW1lfSBwbGFuYCkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGluaywgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLXVwZ3JhZGUtYnV0dG9uXCIsIG9uQ2xpY2s6IG9uTWFuYWdlU3Vic2NyaXB0aW9uIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogXCJ3aGl0ZVwiIH0sIFwiVXBncmFkZSBwbGFuXCIpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRyaWFsUGFuZWwuanMubWFwIl19 */"));
5646
+ }, ";border-radius:10px;padding:8px 16px;margin-top:16px;" + ( "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyaWFsUGFuZWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVFnQyIsImZpbGUiOiJUcmlhbFBhbmVsLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHsgU3Vic2NyaXB0aW9uU3RhdHVzIH0gZnJvbSAnQHN0aWdnL2pzLWNsaWVudC1zZGsnO1xyXG5pbXBvcnQgTGluayBmcm9tICdAbXVpL21hdGVyaWFsL0xpbmsnO1xyXG5pbXBvcnQgU2FuZENsb2NrSWNvbiBmcm9tICcuLi8uLi8uLi8uLi9hc3NldHMvc2FuZC1jbG9jay5zdmcnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBMb25nVGV4dCB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9Mb25nVGV4dCc7XHJcbmltcG9ydCB7IEN1c3RvbWVyUG9ydGFsSW50ZW50aW9uVHlwZSB9IGZyb20gJy4uLy4uL3R5cGVzJztcclxuY29uc3QgT25UcmlhbEJhZGdlID0gc3R5bGVkLmRpdiBgXG4gIHdpZHRoOiAxMDAlO1xuICBkaXNwbGF5OiBmbGV4O1xuICBhbGlnbi1pdGVtczogY2VudGVyO1xuICBnYXA6IDRweDtcbiAgYmFja2dyb3VuZC1jb2xvcjogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5wYWxldHRlLndhcm5pbmd9O1xuICBib3JkZXItcmFkaXVzOiAxMHB4O1xuICBwYWRkaW5nOiA4cHggMTZweDtcbiAgbWFyZ2luLXRvcDogMTZweDtcbmA7XHJcbmNvbnN0IFN0eWxlZExpbmsgPSBzdHlsZWQoTGluaykgYFxuICB0ZXh0LWRlY29yYXRpb24tY29sb3I6IHdoaXRlO1xuICBjb2xvcjogd2hpdGU7XG4gIGN1cnNvcjogcG9pbnRlcjtcbmA7XHJcbmV4cG9ydCBmdW5jdGlvbiBUcmlhbFBhbmVsKHsgc3Vic2NyaXB0aW9uLCBpbmNsdWRlUGxhbk5hbWUsIG9uTWFuYWdlU3Vic2NyaXB0aW9uLCB9KSB7XHJcbiAgICBpZiAoc3Vic2NyaXB0aW9uPy5zdGF0dXMgIT09IFN1YnNjcmlwdGlvblN0YXR1cy5JblRyaWFsKSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoT25UcmlhbEJhZGdlLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtYmFkZ2VcIiB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU2FuZENsb2NrSWNvbiwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlLWltYWdlXCIgfSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChcImRpdlwiLCB7IHN0eWxlOiB7IGZsZXg6IDEsIG1hcmdpblJpZ2h0OiA0IH0gfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMb25nVGV4dCwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtYmFkZ2UtdGV4dFwiLCBjb2xvcjogXCJ3aGl0ZVwiIH0sXHJcbiAgICAgICAgICAgICAgICBgJHtzdWJzY3JpcHRpb24udHJpYWxSZW1haW5pbmdEYXlzfSBkYXlzIHJlbWFpbmluZyBpbiB0cmlhbGAsXHJcbiAgICAgICAgICAgICAgICBpbmNsdWRlUGxhbk5hbWUgJiYgYCBvZiB0aGUgJHtzdWJzY3JpcHRpb24ucGxhbk5hbWV9IHBsYW5gKSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRMaW5rLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtdXBncmFkZS1idXR0b25cIiwgb25DbGljazogKCkgPT4gb25NYW5hZ2VTdWJzY3JpcHRpb24oeyBpbnRlbnRpb25UeXBlOiBDdXN0b21lclBvcnRhbEludGVudGlvblR5cGUuVVBHUkFERV9UUklBTF9QTEFOIH0pIH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjb2xvcjogXCJ3aGl0ZVwiIH0sIFwiVXBncmFkZSBwbGFuXCIpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRyaWFsUGFuZWwuanMubWFwIl19 */"));
5638
5647
 
5639
5648
  var StyledLink = /*#__PURE__*/_styled(Link, {
5640
5649
  target: "el5iwyw0",
@@ -5642,7 +5651,7 @@ var StyledLink = /*#__PURE__*/_styled(Link, {
5642
5651
  })( {
5643
5652
  name: "69ka7t",
5644
5653
  styles: "text-decoration-color:white;color:white;cursor:pointer",
5645
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyaWFsUGFuZWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWlCZ0MiLCJmaWxlIjoiVHJpYWxQYW5lbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvblN0YXR1cyB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IExpbmsgZnJvbSAnQG11aS9tYXRlcmlhbC9MaW5rJztcclxuaW1wb3J0IFNhbmRDbG9ja0ljb24gZnJvbSAnLi4vLi4vLi4vLi4vYXNzZXRzL3NhbmQtY2xvY2suc3ZnJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuaW1wb3J0IHsgTG9uZ1RleHQgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vTG9uZ1RleHQnO1xyXG5jb25zdCBPblRyaWFsQmFkZ2UgPSBzdHlsZWQuZGl2IGBcbiAgd2lkdGg6IDEwMCU7XG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGdhcDogNHB4O1xuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUud2FybmluZ307XG4gIGJvcmRlci1yYWRpdXM6IDEwcHg7XG4gIHBhZGRpbmc6IDhweCAxNnB4O1xuICBtYXJnaW4tdG9wOiAxNnB4O1xuYDtcclxuY29uc3QgU3R5bGVkTGluayA9IHN0eWxlZChMaW5rKSBgXG4gIHRleHQtZGVjb3JhdGlvbi1jb2xvcjogd2hpdGU7XG4gIGNvbG9yOiB3aGl0ZTtcbiAgY3Vyc29yOiBwb2ludGVyO1xuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFRyaWFsUGFuZWwoeyBzdWJzY3JpcHRpb24sIGluY2x1ZGVQbGFuTmFtZSwgb25NYW5hZ2VTdWJzY3JpcHRpb24sIH0pIHtcclxuICAgIGlmIChzdWJzY3JpcHRpb24/LnN0YXR1cyAhPT0gU3Vic2NyaXB0aW9uU3RhdHVzLkluVHJpYWwpIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChPblRyaWFsQmFkZ2UsIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi10cmlhbC1iYWRnZVwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChTYW5kQ2xvY2tJY29uLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1zdWJzY3JpcHRpb24tdHJpYWwtYmFkZ2UtaW1hZ2VcIiB9KSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIHsgc3R5bGU6IHsgZmxleDogMSwgbWFyZ2luUmlnaHQ6IDQgfSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExvbmdUZXh0LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi10cmlhbC1iYWRnZS10ZXh0XCIsIGNvbG9yOiBcIndoaXRlXCIgfSxcclxuICAgICAgICAgICAgICAgIGAke3N1YnNjcmlwdGlvbi50cmlhbFJlbWFpbmluZ0RheXN9IGRheXMgcmVtYWluaW5nIGluIHRyaWFsYCxcclxuICAgICAgICAgICAgICAgIGluY2x1ZGVQbGFuTmFtZSAmJiBgIG9mIHRoZSAke3N1YnNjcmlwdGlvbi5wbGFuTmFtZX0gcGxhbmApKSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFN0eWxlZExpbmssIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi10cmlhbC11cGdyYWRlLWJ1dHRvblwiLCBvbkNsaWNrOiBvbk1hbmFnZVN1YnNjcmlwdGlvbiB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY29sb3I6IFwid2hpdGVcIiB9LCBcIlVwZ3JhZGUgcGxhblwiKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UcmlhbFBhbmVsLmpzLm1hcCJdfQ== */",
5654
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRyaWFsUGFuZWwudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQWtCZ0MiLCJmaWxlIjoiVHJpYWxQYW5lbC50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvblN0YXR1cyB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IExpbmsgZnJvbSAnQG11aS9tYXRlcmlhbC9MaW5rJztcclxuaW1wb3J0IFNhbmRDbG9ja0ljb24gZnJvbSAnLi4vLi4vLi4vLi4vYXNzZXRzL3NhbmQtY2xvY2suc3ZnJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuaW1wb3J0IHsgTG9uZ1RleHQgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vTG9uZ1RleHQnO1xyXG5pbXBvcnQgeyBDdXN0b21lclBvcnRhbEludGVudGlvblR5cGUgfSBmcm9tICcuLi8uLi90eXBlcyc7XHJcbmNvbnN0IE9uVHJpYWxCYWRnZSA9IHN0eWxlZC5kaXYgYFxuICB3aWR0aDogMTAwJTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgZ2FwOiA0cHg7XG4gIGJhY2tncm91bmQtY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS53YXJuaW5nfTtcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgcGFkZGluZzogOHB4IDE2cHg7XG4gIG1hcmdpbi10b3A6IDE2cHg7XG5gO1xyXG5jb25zdCBTdHlsZWRMaW5rID0gc3R5bGVkKExpbmspIGBcbiAgdGV4dC1kZWNvcmF0aW9uLWNvbG9yOiB3aGl0ZTtcbiAgY29sb3I6IHdoaXRlO1xuICBjdXJzb3I6IHBvaW50ZXI7XG5gO1xyXG5leHBvcnQgZnVuY3Rpb24gVHJpYWxQYW5lbCh7IHN1YnNjcmlwdGlvbiwgaW5jbHVkZVBsYW5OYW1lLCBvbk1hbmFnZVN1YnNjcmlwdGlvbiwgfSkge1xyXG4gICAgaWYgKHN1YnNjcmlwdGlvbj8uc3RhdHVzICE9PSBTdWJzY3JpcHRpb25TdGF0dXMuSW5UcmlhbCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KE9uVHJpYWxCYWRnZSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlXCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFNhbmRDbG9ja0ljb24sIHsgY2xhc3NOYW1lOiBcInN0aWdnLXN1YnNjcmlwdGlvbi10cmlhbC1iYWRnZS1pbWFnZVwiIH0pLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgeyBzdHlsZTogeyBmbGV4OiAxLCBtYXJnaW5SaWdodDogNCB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTG9uZ1RleHQsIHsgdmFyaWFudDogXCJib2R5MVwiLCBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLWJhZGdlLXRleHRcIiwgY29sb3I6IFwid2hpdGVcIiB9LFxyXG4gICAgICAgICAgICAgICAgYCR7c3Vic2NyaXB0aW9uLnRyaWFsUmVtYWluaW5nRGF5c30gZGF5cyByZW1haW5pbmcgaW4gdHJpYWxgLFxyXG4gICAgICAgICAgICAgICAgaW5jbHVkZVBsYW5OYW1lICYmIGAgb2YgdGhlICR7c3Vic2NyaXB0aW9uLnBsYW5OYW1lfSBwbGFuYCkpLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoU3R5bGVkTGluaywgeyBjbGFzc05hbWU6IFwic3RpZ2ctc3Vic2NyaXB0aW9uLXRyaWFsLXVwZ3JhZGUtYnV0dG9uXCIsIG9uQ2xpY2s6ICgpID0+IG9uTWFuYWdlU3Vic2NyaXB0aW9uKHsgaW50ZW50aW9uVHlwZTogQ3VzdG9tZXJQb3J0YWxJbnRlbnRpb25UeXBlLlVQR1JBREVfVFJJQUxfUExBTiB9KSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY29sb3I6IFwid2hpdGVcIiB9LCBcIlVwZ3JhZGUgcGxhblwiKSkpKTtcclxufVxyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1UcmlhbFBhbmVsLmpzLm1hcCJdfQ== */",
5646
5655
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$f
5647
5656
  });
5648
5657
 
@@ -5670,7 +5679,11 @@ function TrialPanel(_ref2) {
5670
5679
  color: "white"
5671
5680
  }, subscription.trialRemainingDays + " days remaining in trial", includePlanName && " of the " + subscription.planName + " plan")), React__default.createElement(StyledLink, {
5672
5681
  className: "stigg-subscription-trial-upgrade-button",
5673
- onClick: onManageSubscription
5682
+ onClick: function onClick() {
5683
+ return onManageSubscription({
5684
+ intentionType: exports.CustomerPortalIntentionType.UPGRADE_TRIAL_PLAN
5685
+ });
5686
+ }
5674
5687
  }, React__default.createElement(Typography, {
5675
5688
  color: "white"
5676
5689
  }, "Upgrade plan")));
@@ -5825,7 +5838,11 @@ function EntitlementCtaButton(_ref) {
5825
5838
  if (canUpgradeSubscription) {
5826
5839
  return onManageSubscription ? React__default.createElement(StyledButton$2, {
5827
5840
  variant: "text",
5828
- onClick: onManageSubscription
5841
+ onClick: function onClick() {
5842
+ return onManageSubscription({
5843
+ intentionType: exports.CustomerPortalIntentionType.UPGRADE_PLAN
5844
+ });
5845
+ }
5829
5846
  }, React__default.createElement(Typography, {
5830
5847
  color: "primary.main"
5831
5848
  }, "Upgrade")) : null;
@@ -6563,10 +6580,16 @@ function CustomerPortalContainer(_ref) {
6563
6580
 
6564
6581
  var customerPortalSectionRef = React.useRef(null);
6565
6582
 
6566
- var onManageClick = function onManageClick() {
6583
+ var onManageClick = function onManageClick(_ref2) {
6584
+ var intentionType = _ref2.intentionType;
6585
+
6567
6586
  if (onManageSubscription) {
6568
- // eslint-disable-next-line @typescript-eslint/no-floating-promises
6569
- onManageSubscription();
6587
+ var _customerPortal$subsc;
6588
+
6589
+ void onManageSubscription({
6590
+ intentionType: intentionType,
6591
+ customerSubscriptions: (_customerPortal$subsc = customerPortal == null ? void 0 : customerPortal.subscriptions) != null ? _customerPortal$subsc : []
6592
+ });
6570
6593
  } else {
6571
6594
  var _customerPortalSectio;
6572
6595
 
@@ -7000,7 +7023,7 @@ function getBillableFeatures(preconfiguredBillableFeatures, planPrices, activeSu
7000
7023
  var preconfiguredQuantity = ((_preconfBillableFeatu = preconfBillableFeaturesByFeatureId[featureId]) == null ? void 0 : _preconfBillableFeatu.quantity) || ((_quantityByFeatureId$ = quantityByFeatureId[featureId]) == null ? void 0 : _quantityByFeatureId$.quantity);
7001
7024
  quantity = getValidPriceQuantity(price, preconfiguredQuantity || 1);
7002
7025
 
7003
- if (price.isTieredPrice && price.tiersMode === sdk.TiersMode.Volume) {
7026
+ if (price.isTieredPrice && !hasTierWithUnitPrice(price.tiers)) {
7004
7027
  var tier = getTierByQuantity(price.tiers, quantity);
7005
7028
  quantity = tier.upTo;
7006
7029
  }
@@ -12197,7 +12220,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", {
12197
12220
  })( {
12198
12221
  name: "rdmn2i",
12199
12222
  styles: "&+&{margin-top:8px;}",
12200
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAW4C","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, BillingPeriod, } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount: quantity * amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12223
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAW4C","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, BillingPeriod, } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { calculateTierPriceVolume, getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (quantity) {\r\n        amount /= quantity;\r\n    }\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = calculateTierPriceVolume(tier, quantity);\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12201
12224
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12202
12225
  });
12203
12226
  var LineItemRow = /*#__PURE__*/_styled("div", {
@@ -12206,7 +12229,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", {
12206
12229
  })( {
12207
12230
  name: "bcffy2",
12208
12231
  styles: "display:flex;align-items:center;justify-content:space-between",
12209
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAgBsC","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, BillingPeriod, } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount: quantity * amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12232
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAgBsC","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, BillingPeriod, } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { calculateTierPriceVolume, getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (quantity) {\r\n        amount /= quantity;\r\n    }\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = calculateTierPriceVolume(tier, quantity);\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12210
12233
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12211
12234
  });
12212
12235
  var getPriceString = function getPriceString(_ref) {
@@ -12216,6 +12239,10 @@ var getPriceString = function getPriceString(_ref) {
12216
12239
  var billingPeriod = price.billingPeriod;
12217
12240
  var billingPeriodString = null;
12218
12241
 
12242
+ if (quantity) {
12243
+ amount /= quantity;
12244
+ }
12245
+
12219
12246
  if (billingPeriod === Stigg.BillingPeriod.Annually) {
12220
12247
  amount /= 12;
12221
12248
  billingPeriodString = '12 months';
@@ -12256,7 +12283,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12256
12283
 
12257
12284
  if (price.isTieredPrice) {
12258
12285
  var tier = getTierByQuantity(price.tiers, quantity);
12259
- amount = tier.unitPrice.amount;
12286
+ amount = calculateTierPriceVolume(tier, quantity);
12260
12287
  } else {
12261
12288
  amount = price.amount;
12262
12289
  }
@@ -12291,7 +12318,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12291
12318
  wordBreak: 'break-word'
12292
12319
  }
12293
12320
  }, currencyPriceFormatter({
12294
- amount: quantity * amount,
12321
+ amount: amount,
12295
12322
  currency: price.currency,
12296
12323
  minimumFractionDigits: 2
12297
12324
  }), isPayAsYouGo && ' / unit'))));