@stigg/react-sdk 5.8.0 → 5.10.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 (27) hide show
  1. package/dist/components/StiggProvider.d.ts +2 -0
  2. package/dist/components/checkout/summary/components/GraduatedPriceBreakdown.d.ts +7 -0
  3. package/dist/components/checkout/summary/components/LineItems.d.ts +4 -0
  4. package/dist/components/checkout/summary/components/getPriceBreakdownString.d.ts +11 -4
  5. package/dist/components/common/CollapsableSectionIcon.d.ts +5 -0
  6. package/dist/components/common/Typography.d.ts +2 -2
  7. package/dist/components/utils/numberUtils.d.ts +3 -0
  8. package/dist/components/utils/priceTierUtils.d.ts +1 -0
  9. package/dist/react-sdk.cjs.development.js +201 -45
  10. package/dist/react-sdk.cjs.development.js.map +1 -1
  11. package/dist/react-sdk.cjs.production.min.js +1 -1
  12. package/dist/react-sdk.cjs.production.min.js.map +1 -1
  13. package/dist/react-sdk.esm.js +210 -49
  14. package/dist/react-sdk.esm.js.map +1 -1
  15. package/dist/theme/getResolvedTheme.d.ts +1 -0
  16. package/dist/theme/types.d.ts +1 -0
  17. package/package.json +2 -2
  18. package/src/components/StiggProvider.tsx +7 -0
  19. package/src/components/checkout/summary/components/GraduatedPriceBreakdown.tsx +66 -0
  20. package/src/components/checkout/summary/components/LineItems.tsx +74 -8
  21. package/src/components/checkout/summary/components/getPriceBreakdownString.ts +28 -17
  22. package/src/components/common/CollapsableSectionIcon.tsx +9 -0
  23. package/src/components/common/Typography.tsx +1 -0
  24. package/src/components/utils/numberUtils.ts +3 -0
  25. package/src/components/utils/priceTierUtils.ts +4 -0
  26. package/src/theme/getResolvedTheme.ts +2 -1
  27. package/src/theme/types.ts +1 -0
@@ -31,7 +31,7 @@ import Box from '@mui/material/Box';
31
31
  import Tab from '@mui/material/Tab';
32
32
  import isEmpty from 'lodash-es/isEmpty';
33
33
  import Tabs from '@mui/material/Tabs';
34
- import { ArrowDown, ExternalLink, Minus, Plus } from 'react-feather';
34
+ import { ArrowDown, ExternalLink, Minus, Plus, ChevronRight } from 'react-feather';
35
35
  import Link from '@mui/material/Link';
36
36
  import Tooltip, { tooltipClasses } from '@mui/material/Tooltip';
37
37
  import LinearProgress, { linearProgressClasses } from '@mui/material/LinearProgress';
@@ -50,8 +50,9 @@ import CircularProgress from '@mui/material/CircularProgress';
50
50
  import Paper from '@mui/material/Paper';
51
51
  import { loadStripe } from '@stripe/stripe-js';
52
52
  import Lottie from 'lottie-react';
53
- import Alert from '@mui/material/Alert';
53
+ import { IconButton } from '@mui/material';
54
54
  import Collapse from '@mui/material/Collapse';
55
+ import Alert from '@mui/material/Alert';
55
56
  import Radio from '@mui/material/Radio';
56
57
  import Chip from '@mui/material/Chip';
57
58
 
@@ -600,7 +601,8 @@ var getResolvedTheme = function getResolvedTheme(customizedTheme) {
600
601
  text: {
601
602
  primary: textColor.hex(),
602
603
  secondary: textColor.alpha(0.75).toString(),
603
- disabled: textColor.alpha(0.5).toString()
604
+ tertiary: textColor.alpha(0.5).toString(),
605
+ disabled: textColor.alpha(0.35).toString()
604
606
  }
605
607
  },
606
608
  layout: {
@@ -850,6 +852,9 @@ function isBulkTiers(tiers) {
850
852
  return !unitPrice || isNil(upTo);
851
853
  });
852
854
  }
855
+ function isQuantityInFirstTier(tiers, quantity) {
856
+ return (tiers == null ? void 0 : tiers[0].upTo) && quantity <= tiers[0].upTo;
857
+ }
853
858
  function getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex) {
854
859
  var planTierPrices = plan.pricePoints.filter(function (price) {
855
860
  return price.billingPeriod === billingPeriod && price.isTieredPrice;
@@ -3225,6 +3230,9 @@ var LoggerService = /*#__PURE__*/function () {
3225
3230
 
3226
3231
  var logger = /*#__PURE__*/new LoggerService();
3227
3232
 
3233
+ var version = "5.10.0";
3234
+ var name = "@stigg/react-sdk";
3235
+
3228
3236
  var StiggContext = /*#__PURE__*/React__default.createContext(null);
3229
3237
  StiggContext.displayName = 'StiggContext';
3230
3238
  var DEFAULT_LOCALE = 'en-US';
@@ -3242,7 +3250,11 @@ var StiggProvider = function StiggProvider(_ref) {
3242
3250
  entitlementPollingInterval = _ref.entitlementPollingInterval,
3243
3251
  entitlementsFallback = _ref.entitlementsFallback,
3244
3252
  stiggClient = _ref.stiggClient,
3245
- children = _ref.children;
3253
+ children = _ref.children,
3254
+ _ref$clientName = _ref.clientName,
3255
+ clientName = _ref$clientName === void 0 ? name : _ref$clientName,
3256
+ _ref$clientVersion = _ref.clientVersion,
3257
+ clientVersion = _ref$clientVersion === void 0 ? version : _ref$clientVersion;
3246
3258
  var currentApiKey = useRef(apiKey);
3247
3259
  var initializeParams = {
3248
3260
  apiKey: apiKey,
@@ -3254,7 +3266,9 @@ var StiggProvider = function StiggProvider(_ref) {
3254
3266
  enableEdge: enableEdge,
3255
3267
  entitlementsFallback: entitlementsFallback,
3256
3268
  useEntitlementPolling: useEntitlementPolling,
3257
- entitlementPollingInterval: entitlementPollingInterval
3269
+ entitlementPollingInterval: entitlementPollingInterval,
3270
+ clientName: clientName,
3271
+ clientVersion: clientVersion
3258
3272
  };
3259
3273
 
3260
3274
  var _useState = useState(function () {
@@ -12536,15 +12550,21 @@ function CheckoutCaptions(props) {
12536
12550
  return React__default.createElement(React__default.Fragment, null, React__default.createElement(RemainingCreditsCaption, Object.assign({}, props)), React__default.createElement(ScheduledUpdatesCaption, Object.assign({}, props)), React__default.createElement(NextBillingCaption, Object.assign({}, props)));
12537
12551
  }
12538
12552
 
12553
+ function numberFormatter(number, _temp) {
12554
+ var _ref = _temp === void 0 ? {} : _temp,
12555
+ locate = _ref.locate;
12556
+
12557
+ return new Intl.NumberFormat(locate).format(number);
12558
+ }
12559
+
12539
12560
  function formatPricePerUnit(_ref) {
12540
- var price = _ref.price,
12541
- quantity = _ref.quantity,
12542
- totalAmount = _ref.totalAmount;
12543
- var currency = price.currency,
12544
- pricingModel = price.pricingModel,
12545
- billingPeriod = price.billingPeriod;
12561
+ var quantity = _ref.quantity,
12562
+ totalAmount = _ref.totalAmount,
12563
+ pricingModel = _ref.pricingModel,
12564
+ billingPeriod = _ref.billingPeriod,
12565
+ currency = _ref.currency;
12546
12566
  var isPerUnit = pricingModel === BillingModel.PerUnit;
12547
- var featureUnits = quantity && (isPerUnit || quantity > 1) ? new Intl.NumberFormat().format(quantity) + " x " : '';
12567
+ var featureUnits = quantity && (isPerUnit || quantity > 1) ? numberFormatter(quantity) + " x " : '';
12548
12568
  var billingPeriodString = billingPeriod === BillingPeriod.Annually ? ' x 12 months' : '';
12549
12569
  var unitPrice = totalAmount / quantity / (billingPeriod === BillingPeriod.Annually ? 12 : 1);
12550
12570
  var formattedUnitPrice = currencyPriceFormatter({
@@ -12559,33 +12579,106 @@ function formatPricePerUnit(_ref) {
12559
12579
  });
12560
12580
  return "" + featureUnits + formattedUnitPrice + billingPeriodString + " " + (billingPeriodString || featureUnits ? " = " + formattedTotalPrice : '');
12561
12581
  }
12582
+ function getPriceBreakdownString(params) {
12583
+ var totalAmount = params.totalAmount,
12584
+ quantity = params.quantity,
12585
+ tiersMode = params.tiersMode,
12586
+ tiers = params.tiers,
12587
+ currency = params.currency;
12562
12588
 
12563
- function getPriceBreakdownString(_ref2) {
12564
- var price = _ref2.price,
12565
- quantity = _ref2.quantity;
12566
- var amount = price.isTieredPrice ? calculateTierPrice(price, quantity) : (price.amount || 0) * quantity;
12567
-
12568
- if (isBulkTiers(price.tiers) || price.tiersMode === TiersMode.Graduated) {
12589
+ if (isBulkTiers(tiers) || tiersMode === TiersMode.Graduated && !isQuantityInFirstTier(tiers, quantity)) {
12569
12590
  var formattedTotalPrice = currencyPriceFormatter({
12570
- amount: amount,
12571
- currency: price.currency,
12591
+ amount: totalAmount,
12592
+ currency: currency,
12572
12593
  minimumFractionDigits: 2
12573
12594
  });
12574
- return quantity + " for " + formattedTotalPrice;
12595
+ return numberFormatter(quantity) + " for " + formattedTotalPrice;
12575
12596
  }
12576
12597
 
12577
- return formatPricePerUnit({
12578
- price: price,
12579
- quantity: quantity,
12580
- totalAmount: amount
12581
- });
12598
+ return formatPricePerUnit(params);
12599
+ }
12600
+
12601
+ function getLabel(tiers, index) {
12602
+ var _tiers$index = tiers[index],
12603
+ unitPrice = _tiers$index.unitPrice,
12604
+ upTo = _tiers$index.upTo;
12605
+
12606
+ if (!unitPrice) {
12607
+ return '';
12608
+ }
12609
+
12610
+ if (index === 0) {
12611
+ return "First " + upTo;
12612
+ }
12613
+
12614
+ var previousTierUpTo = tiers[index - 1].upTo || 0;
12615
+ var startUnit = previousTierUpTo + 1;
12616
+ return isNil(upTo) ? numberFormatter(startUnit) + " and above" : "Next " + numberFormatter(startUnit) + " to " + numberFormatter(upTo);
12582
12617
  }
12583
12618
 
12619
+ function GraduatedPriceBreakdown(_ref) {
12620
+ var price = _ref.price,
12621
+ unitQuantity = _ref.unitQuantity;
12622
+ var tiers = price.tiers || [];
12623
+
12624
+ var _calculateTierPriceGr = calculateTierPriceGraduated(tiers, unitQuantity),
12625
+ breakdown = _calculateTierPriceGr.breakdown;
12626
+
12627
+ if (breakdown.length === 1) {
12628
+ return null;
12629
+ }
12630
+
12631
+ return React__default.createElement(React__default.Fragment, null, breakdown.map(function (_ref2, index) {
12632
+ var unitQuantity = _ref2.unitQuantity,
12633
+ amount = _ref2.amount;
12634
+ return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
12635
+ key: index,
12636
+ style: {
12637
+ alignItems: 'flex-start'
12638
+ }
12639
+ }, React__default.createElement(Typography, {
12640
+ variant: "body1",
12641
+ color: "tertiary",
12642
+ style: {
12643
+ whiteSpace: 'nowrap'
12644
+ }
12645
+ }, getLabel(tiers, index)), React__default.createElement(Typography, {
12646
+ variant: "body1",
12647
+ color: "tertiary",
12648
+ style: {
12649
+ whiteSpace: 'nowrap'
12650
+ }
12651
+ }, formatPricePerUnit({
12652
+ quantity: unitQuantity,
12653
+ totalAmount: amount,
12654
+ currency: price.currency,
12655
+ pricingModel: price.pricingModel,
12656
+ billingPeriod: price.billingPeriod,
12657
+ tiers: price.tiers,
12658
+ tiersMode: price.tiersMode
12659
+ }))));
12660
+ }));
12661
+ }
12662
+
12663
+ var _templateObject$6;
12664
+ var CollapsableSectionIcon = /*#__PURE__*/styled$1(ChevronRight)(_templateObject$6 || (_templateObject$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n height: ", ";\n width: ", ";\n transition: all 0.2s ease-in;\n ", "\n"])), function (_ref) {
12665
+ var _ref$$size = _ref.$size,
12666
+ $size = _ref$$size === void 0 ? 24 : _ref$$size;
12667
+ return $size + "px";
12668
+ }, function (_ref2) {
12669
+ var _ref2$$size = _ref2.$size,
12670
+ $size = _ref2$$size === void 0 ? 24 : _ref2$$size;
12671
+ return $size + "px";
12672
+ }, function (_ref3) {
12673
+ var $isOpen = _ref3.$isOpen;
12674
+ return $isOpen && "transform: rotate(90deg)";
12675
+ });
12676
+
12584
12677
  function _EMOTION_STRINGIFIED_CSS_ERROR__$o() { return "You have tried to stringify object returned from `css` function. It isn't supposed to be used directly (e.g. as value of the `className` prop), but rather handed to emotion so it can handle it (e.g. as value of `css` prop)."; }
12585
12678
  var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
12586
- target: "e1ultpe61"
12679
+ target: "e1ultpe62"
12587
12680
  } : {
12588
- target: "e1ultpe61",
12681
+ target: "e1ultpe62",
12589
12682
  label: "LineItemContainer"
12590
12683
  })(process.env.NODE_ENV === "production" ? {
12591
12684
  name: "x9km8e",
@@ -12593,7 +12686,21 @@ var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
12593
12686
  } : {
12594
12687
  name: "x9km8e",
12595
12688
  styles: "&+&{margin-top:16px;}",
12596
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpbmVJdGVtcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVzRDIiwiZmlsZSI6IkxpbmVJdGVtcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBHcmlkIGZyb20gJ0BtdWkvbWF0ZXJpYWwvR3JpZCc7XHJcbmltcG9ydCB7IEJpbGxpbmdNb2RlbCB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuaW1wb3J0IHsgY3VycmVuY3lQcmljZUZvcm1hdHRlciB9IGZyb20gJy4uLy4uLy4uL3V0aWxzL2N1cnJlbmN5VXRpbHMnO1xyXG5pbXBvcnQgeyBXaXRoU2tlbGV0b24gfSBmcm9tICcuL1dpdGhTa2VsZXRvbic7XHJcbmltcG9ydCB7IFNrZWxldG9uIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9Ta2VsZXRvbnMuc3R5bGUnO1xyXG5pbXBvcnQgeyBJY29uIH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL0ljb24nO1xyXG5pbXBvcnQgeyBJbmZvcm1hdGlvblRvb2x0aXAgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vSW5mb3JtYXRpb25Ub29sdGlwJztcclxuaW1wb3J0IHsgZ2V0UHJpY2VCcmVha2Rvd25TdHJpbmcgfSBmcm9tICcuL2dldFByaWNlQnJlYWtkb3duU3RyaW5nJztcclxuZXhwb3J0IGNvbnN0IExpbmVJdGVtQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gICYgKyAmIHtcbiAgICBtYXJnaW4tdG9wOiAxNnB4O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgTGluZUl0ZW1Sb3cgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuYDtcclxuY29uc3QgUGF5QXNZb3VHb1ByaWNlVG9vbHRpcCA9ICh7IGNoZWNrb3V0TG9jYWxpemF0aW9uIH0pID0+IHtcclxuICAgIGNvbnN0IHRpdGxlID0gUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LnBheUFzWW91R29Ub29sdGlwVGV4dCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5mb3JtYXRpb25Ub29sdGlwLCB7IHBsYWNlbWVudDogXCJsZWZ0XCIsIHRpdGxlOiB0aXRsZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbiwgeyBpY29uOiBcIlBheUFzWW91R29DaGFyZ2VcIiwgc3R5bGU6IHsgZGlzcGxheTogJ2ZsZXgnIH0gfSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IEJpbGxlZFByaWNlTGluZUl0ZW0gPSAoeyBjaGVja291dExvY2FsaXphdGlvbiwgbGFiZWwsIHF1YW50aXR5LCBwcmljZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgaXNQYXlBc1lvdUdvID0gcHJpY2UucHJpY2luZ01vZGVsID09PSBCaWxsaW5nTW9kZWwuVXNhZ2VCYXNlZDtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCB7IHN0eWxlOiB7IGFsaWduSXRlbXM6ICdmbGV4LXN0YXJ0JyB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBsYWJlbCkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgaXRlbTogdHJ1ZSwgZGlzcGxheTogXCJmbGV4XCIsIGdhcDogMSwgYWxpZ25JdGVtczogXCJjZW50ZXJcIiB9LFxyXG4gICAgICAgICAgICAgICAgaXNQYXlBc1lvdUdvICYmIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5QXNZb3VHb1ByaWNlVG9vbHRpcCwgeyBjaGVja291dExvY2FsaXphdGlvbjogY2hlY2tvdXRMb2NhbGl6YXRpb24gfSksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiwgc3R5bGU6IHsgd29yZEJyZWFrOiAnYnJlYWstd29yZCcgfSB9LFxyXG4gICAgICAgICAgICAgICAgICAgIGdldFByaWNlQnJlYWtkb3duU3RyaW5nKHsgcHJpY2UsIHF1YW50aXR5IH0pLFxyXG4gICAgICAgICAgICAgICAgICAgIGlzUGF5QXNZb3VHbyAmJiAnIC8gdW5pdCcpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IEZyZWVDaGFyZ2VMaW5lSXRlbSA9ICh7IGxhYmVsIH0pID0+IHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCB7IHN0eWxlOiB7IGFsaWduSXRlbXM6ICdmbGV4LWVuZCcgfSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgaXRlbTogdHJ1ZSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgbGFiZWwpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGl0ZW06IHRydWUsIGRpc3BsYXk6IFwiZmxleFwiLCBnYXA6IDEsIGFsaWduSXRlbXM6IFwiY2VudGVyXCIgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiLCBzdHlsZTogeyB3b3JkQnJlYWs6ICdicmVhay13b3JkJyB9IH0sIFwiRnJlZVwiKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudExpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGltbWVkaWF0ZUludm9pY2UsIHJlY3VycmluZ0ludm9pY2UgfSA9IHN1YnNjcmlwdGlvblByZXZpZXc7XHJcbiAgICBjb25zdCB7IGRpc2NvdW50LCBkaXNjb3VudERldGFpbHMgfSA9IHJlY3VycmluZ0ludm9pY2UgfHwge307XHJcbiAgICBpZiAoIWRpc2NvdW50IHx8ICFkaXNjb3VudERldGFpbHMpIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LmRpc2NvdW50VGV4dCh7XHJcbiAgICAgICAgICAgICAgICBkaXNjb3VudERldGFpbHMsXHJcbiAgICAgICAgICAgICAgICBjdXJyZW5jeTogaW1tZWRpYXRlSW52b2ljZS50b3RhbC5jdXJyZW5jeSxcclxuICAgICAgICAgICAgfSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiA1MCwgaGVpZ2h0OiAxNiB9KSkgOiAoY3VycmVuY3lQcmljZUZvcm1hdHRlcih7XHJcbiAgICAgICAgICAgICAgICBhbW91bnQ6IGRpc2NvdW50LmFtb3VudCxcclxuICAgICAgICAgICAgICAgIGN1cnJlbmN5OiBkaXNjb3VudC5jdXJyZW5jeSxcclxuICAgICAgICAgICAgICAgIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMixcclxuICAgICAgICAgICAgfSkpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IEFwcGxpZWRDcmVkaXRzTGluZUl0ZW0gPSAoeyBzdWJzY3JpcHRpb25QcmV2aWV3LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldywgY2hlY2tvdXRMb2NhbGl6YXRpb24sIH0pID0+IHtcclxuICAgIGNvbnN0IHsgaW1tZWRpYXRlSW52b2ljZSB9ID0gc3Vic2NyaXB0aW9uUHJldmlldyB8fCB7fTtcclxuICAgIGNvbnN0IHsgY3JlZGl0cyB9ID0gaW1tZWRpYXRlSW52b2ljZSB8fCB7fTtcclxuICAgIGlmICghY3JlZGl0cyB8fCAhY3JlZGl0cy51c2VkIHx8IGNyZWRpdHMudXNlZC5hbW91bnQgPD0gMCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Sb3csIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNoZWNrb3V0TG9jYWxpemF0aW9uLnN1bW1hcnkuYXBwbGllZENyZWRpdHNUaXRsZSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFdpdGhTa2VsZXRvbiwgeyBpc0xvYWRpbmc6IGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3IH0sIGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoe1xyXG4gICAgICAgICAgICAgICAgICAgIGFtb3VudDogLTEgKiBjcmVkaXRzLnVzZWQuYW1vdW50LFxyXG4gICAgICAgICAgICAgICAgICAgIGN1cnJlbmN5OiBjcmVkaXRzLnVzZWQuY3VycmVuY3ksXHJcbiAgICAgICAgICAgICAgICAgICAgbWluaW11bUZyYWN0aW9uRGlnaXRzOiAyLFxyXG4gICAgICAgICAgICAgICAgfSkpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IFRheExpbmVJdGVtID0gKHsgdGF4LCB0YXhEZXRhaWxzLCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldywgY2hlY2tvdXRMb2NhbGl6YXRpb24sIH0pID0+IHtcclxuICAgIGlmICghdGF4RGV0YWlscyB8fCAhdGF4IHx8IHRheD8uYW1vdW50IDw9IDApIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LnRheFRpdGxlKHsgdGF4RGV0YWlscyB9KSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFdpdGhTa2VsZXRvbiwgeyBpc0xvYWRpbmc6IGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3IH0sIGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoeyBhbW91bnQ6IHRheD8uYW1vdW50LCBjdXJyZW5jeTogdGF4Py5jdXJyZW5jeSwgbWluaW11bUZyYWN0aW9uRGlnaXRzOiAyIH0pKSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUxpbmVJdGVtcy5qcy5tYXAiXX0= */",
12689
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAmB4C","file":"LineItems.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, TiersMode, } from '@stigg/js-client-sdk';\r\nimport isEmpty from 'lodash/isEmpty';\r\nimport isNil from 'lodash/isNil';\r\nimport Link from '@mui/material/Link';\r\nimport { IconButton } from '@mui/material';\r\nimport Collapse from '@mui/material/Collapse';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nimport { getPriceBreakdownString } from './getPriceBreakdownString';\r\nimport { GraduatedPriceBreakdown } from './GraduatedPriceBreakdown';\r\nimport { CollapsableSectionIcon } from '../../../common/CollapsableSectionIcon';\r\nimport { calculateTierPrice } from '../../../utils/priceTierUtils';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 16px;\n  }\n`;\r\nexport const NestedBreakdownContainer = styled.div `\n  margin-top: 16px;\n  margin-left: 16px;\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  gap: 16px;\n`;\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const [isNestedBreakdownOpen, setIsNestedBreakdownOpen] = useState(false);\r\n    const toggleNestedBreakdown = () => setIsNestedBreakdownOpen((prev) => !prev);\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    const totalAmount = price.isTieredPrice ? calculateTierPrice(price, quantity) : (price.amount || 0) * quantity;\r\n    let nestedBreakdown;\r\n    const shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated &&\r\n        !!price.tiers &&\r\n        !isEmpty(price.tiers) &&\r\n        !isNil(price.tiers[0].upTo) &&\r\n        quantity > price.tiers[0].upTo;\r\n    if (shouldShowGraduatedPriceBreakdown) {\r\n        nestedBreakdown = React.createElement(GraduatedPriceBreakdown, { price: price, unitQuantity: quantity });\r\n    }\r\n    let title = (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label));\r\n    if (nestedBreakdown) {\r\n        title = (React.createElement(Link, { onClick: toggleNestedBreakdown, underline: \"none\", style: { cursor: 'pointer' } }, title));\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 0.5, style: { whiteSpace: 'nowrap' } },\r\n                title,\r\n                nestedBreakdown && (React.createElement(IconButton, { onClick: toggleNestedBreakdown, sx: { padding: 0 } },\r\n                    React.createElement(CollapsableSectionIcon, { \"$isOpen\": isNestedBreakdownOpen, \"$size\": 16 })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { whiteSpace: 'nowrap' } },\r\n                    getPriceBreakdownString({\r\n                        totalAmount,\r\n                        quantity,\r\n                        currency: price.currency,\r\n                        pricingModel: price.pricingModel,\r\n                        billingPeriod: price.billingPeriod,\r\n                        tiers: price.tiers,\r\n                        tiersMode: price.tiersMode,\r\n                    }),\r\n                    isPayAsYouGo && ' / unit'))),\r\n        nestedBreakdown && (React.createElement(Collapse, { in: isNestedBreakdownOpen },\r\n            React.createElement(NestedBreakdownContainer, null, nestedBreakdown)))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12690
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12691
+ });
12692
+ var NestedBreakdownContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
12693
+ target: "e1ultpe61"
12694
+ } : {
12695
+ target: "e1ultpe61",
12696
+ label: "NestedBreakdownContainer"
12697
+ })(process.env.NODE_ENV === "production" ? {
12698
+ name: "96yaa5",
12699
+ styles: "margin-top:16px;margin-left:16px"
12700
+ } : {
12701
+ name: "96yaa5",
12702
+ styles: "margin-top:16px;margin-left:16px",
12703
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAwBmD","file":"LineItems.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, TiersMode, } from '@stigg/js-client-sdk';\r\nimport isEmpty from 'lodash/isEmpty';\r\nimport isNil from 'lodash/isNil';\r\nimport Link from '@mui/material/Link';\r\nimport { IconButton } from '@mui/material';\r\nimport Collapse from '@mui/material/Collapse';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nimport { getPriceBreakdownString } from './getPriceBreakdownString';\r\nimport { GraduatedPriceBreakdown } from './GraduatedPriceBreakdown';\r\nimport { CollapsableSectionIcon } from '../../../common/CollapsableSectionIcon';\r\nimport { calculateTierPrice } from '../../../utils/priceTierUtils';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 16px;\n  }\n`;\r\nexport const NestedBreakdownContainer = styled.div `\n  margin-top: 16px;\n  margin-left: 16px;\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  gap: 16px;\n`;\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const [isNestedBreakdownOpen, setIsNestedBreakdownOpen] = useState(false);\r\n    const toggleNestedBreakdown = () => setIsNestedBreakdownOpen((prev) => !prev);\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    const totalAmount = price.isTieredPrice ? calculateTierPrice(price, quantity) : (price.amount || 0) * quantity;\r\n    let nestedBreakdown;\r\n    const shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated &&\r\n        !!price.tiers &&\r\n        !isEmpty(price.tiers) &&\r\n        !isNil(price.tiers[0].upTo) &&\r\n        quantity > price.tiers[0].upTo;\r\n    if (shouldShowGraduatedPriceBreakdown) {\r\n        nestedBreakdown = React.createElement(GraduatedPriceBreakdown, { price: price, unitQuantity: quantity });\r\n    }\r\n    let title = (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label));\r\n    if (nestedBreakdown) {\r\n        title = (React.createElement(Link, { onClick: toggleNestedBreakdown, underline: \"none\", style: { cursor: 'pointer' } }, title));\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 0.5, style: { whiteSpace: 'nowrap' } },\r\n                title,\r\n                nestedBreakdown && (React.createElement(IconButton, { onClick: toggleNestedBreakdown, sx: { padding: 0 } },\r\n                    React.createElement(CollapsableSectionIcon, { \"$isOpen\": isNestedBreakdownOpen, \"$size\": 16 })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { whiteSpace: 'nowrap' } },\r\n                    getPriceBreakdownString({\r\n                        totalAmount,\r\n                        quantity,\r\n                        currency: price.currency,\r\n                        pricingModel: price.pricingModel,\r\n                        billingPeriod: price.billingPeriod,\r\n                        tiers: price.tiers,\r\n                        tiersMode: price.tiersMode,\r\n                    }),\r\n                    isPayAsYouGo && ' / unit'))),\r\n        nestedBreakdown && (React.createElement(Collapse, { in: isNestedBreakdownOpen },\r\n            React.createElement(NestedBreakdownContainer, null, nestedBreakdown)))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12597
12704
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12598
12705
  });
12599
12706
  var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
@@ -12602,12 +12709,12 @@ var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
12602
12709
  target: "e1ultpe60",
12603
12710
  label: "LineItemRow"
12604
12711
  })(process.env.NODE_ENV === "production" ? {
12605
- name: "bcffy2",
12606
- styles: "display:flex;align-items:center;justify-content:space-between"
12712
+ name: "153q11y",
12713
+ styles: "display:flex;align-items:center;justify-content:space-between;gap:16px"
12607
12714
  } : {
12608
- name: "bcffy2",
12609
- styles: "display:flex;align-items:center;justify-content:space-between",
12610
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpbmVJdGVtcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JzQyIsImZpbGUiOiJMaW5lSXRlbXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgR3JpZCBmcm9tICdAbXVpL21hdGVyaWFsL0dyaWQnO1xyXG5pbXBvcnQgeyBCaWxsaW5nTW9kZWwgfSBmcm9tICdAc3RpZ2cvanMtY2xpZW50LXNkayc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIgfSBmcm9tICcuLi8uLi8uLi91dGlscy9jdXJyZW5jeVV0aWxzJztcclxuaW1wb3J0IHsgV2l0aFNrZWxldG9uIH0gZnJvbSAnLi9XaXRoU2tlbGV0b24nO1xyXG5pbXBvcnQgeyBTa2VsZXRvbiB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvU2tlbGV0b25zLnN0eWxlJztcclxuaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9JY29uJztcclxuaW1wb3J0IHsgSW5mb3JtYXRpb25Ub29sdGlwIH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL0luZm9ybWF0aW9uVG9vbHRpcCc7XHJcbmltcG9ydCB7IGdldFByaWNlQnJlYWtkb3duU3RyaW5nIH0gZnJvbSAnLi9nZXRQcmljZUJyZWFrZG93blN0cmluZyc7XHJcbmV4cG9ydCBjb25zdCBMaW5lSXRlbUNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICAmICsgJiB7XG4gICAgbWFyZ2luLXRvcDogMTZweDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IExpbmVJdGVtUm93ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmNvbnN0IFBheUFzWW91R29QcmljZVRvb2x0aXAgPSAoeyBjaGVja291dExvY2FsaXphdGlvbiB9KSA9PiB7XHJcbiAgICBjb25zdCB0aXRsZSA9IFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24uc3VtbWFyeS5wYXlBc1lvdUdvVG9vbHRpcFRleHQpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEluZm9ybWF0aW9uVG9vbHRpcCwgeyBwbGFjZW1lbnQ6IFwibGVmdFwiLCB0aXRsZTogdGl0bGUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb24sIHsgaWNvbjogXCJQYXlBc1lvdUdvQ2hhcmdlXCIsIHN0eWxlOiB7IGRpc3BsYXk6ICdmbGV4JyB9IH0pKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBCaWxsZWRQcmljZUxpbmVJdGVtID0gKHsgY2hlY2tvdXRMb2NhbGl6YXRpb24sIGxhYmVsLCBxdWFudGl0eSwgcHJpY2UsIH0pID0+IHtcclxuICAgIGNvbnN0IGlzUGF5QXNZb3VHbyA9IHByaWNlLnByaWNpbmdNb2RlbCA9PT0gQmlsbGluZ01vZGVsLlVzYWdlQmFzZWQ7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgeyBzdHlsZTogeyBhbGlnbkl0ZW1zOiAnZmxleC1zdGFydCcgfSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgaXRlbTogdHJ1ZSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgbGFiZWwpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGl0ZW06IHRydWUsIGRpc3BsYXk6IFwiZmxleFwiLCBnYXA6IDEsIGFsaWduSXRlbXM6IFwiY2VudGVyXCIgfSxcclxuICAgICAgICAgICAgICAgIGlzUGF5QXNZb3VHbyAmJiBSZWFjdC5jcmVhdGVFbGVtZW50KFBheUFzWW91R29QcmljZVRvb2x0aXAsIHsgY2hlY2tvdXRMb2NhbGl6YXRpb246IGNoZWNrb3V0TG9jYWxpemF0aW9uIH0pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIsIHN0eWxlOiB7IHdvcmRCcmVhazogJ2JyZWFrLXdvcmQnIH0gfSxcclxuICAgICAgICAgICAgICAgICAgICBnZXRQcmljZUJyZWFrZG93blN0cmluZyh7IHByaWNlLCBxdWFudGl0eSB9KSxcclxuICAgICAgICAgICAgICAgICAgICBpc1BheUFzWW91R28gJiYgJyAvIHVuaXQnKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBGcmVlQ2hhcmdlTGluZUl0ZW0gPSAoeyBsYWJlbCB9KSA9PiB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgeyBzdHlsZTogeyBhbGlnbkl0ZW1zOiAnZmxleC1lbmQnIH0gfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGl0ZW06IHRydWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGxhYmVsKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlLCBkaXNwbGF5OiBcImZsZXhcIiwgZ2FwOiAxLCBhbGlnbkl0ZW1zOiBcImNlbnRlclwiIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiwgc3R5bGU6IHsgd29yZEJyZWFrOiAnYnJlYWstd29yZCcgfSB9LCBcIkZyZWVcIikpKSkpO1xyXG59O1xyXG5leHBvcnQgY29uc3QgRGlzY291bnRMaW5lSXRlbSA9ICh7IHN1YnNjcmlwdGlvblByZXZpZXcsIGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3LCBjaGVja291dExvY2FsaXphdGlvbiwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBpbW1lZGlhdGVJbnZvaWNlLCByZWN1cnJpbmdJbnZvaWNlIH0gPSBzdWJzY3JpcHRpb25QcmV2aWV3O1xyXG4gICAgY29uc3QgeyBkaXNjb3VudCwgZGlzY291bnREZXRhaWxzIH0gPSByZWN1cnJpbmdJbnZvaWNlIHx8IHt9O1xyXG4gICAgaWYgKCFkaXNjb3VudCB8fCAhZGlzY291bnREZXRhaWxzKSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24uc3VtbWFyeS5kaXNjb3VudFRleHQoe1xyXG4gICAgICAgICAgICAgICAgZGlzY291bnREZXRhaWxzLFxyXG4gICAgICAgICAgICAgICAgY3VycmVuY3k6IGltbWVkaWF0ZUludm9pY2UudG90YWwuY3VycmVuY3ksXHJcbiAgICAgICAgICAgIH0pKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogNTAsIGhlaWdodDogMTYgfSkpIDogKGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoe1xyXG4gICAgICAgICAgICAgICAgYW1vdW50OiBkaXNjb3VudC5hbW91bnQsXHJcbiAgICAgICAgICAgICAgICBjdXJyZW5jeTogZGlzY291bnQuY3VycmVuY3ksXHJcbiAgICAgICAgICAgICAgICBtaW5pbXVtRnJhY3Rpb25EaWdpdHM6IDIsXHJcbiAgICAgICAgICAgIH0pKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBBcHBsaWVkQ3JlZGl0c0xpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGltbWVkaWF0ZUludm9pY2UgfSA9IHN1YnNjcmlwdGlvblByZXZpZXcgfHwge307XHJcbiAgICBjb25zdCB7IGNyZWRpdHMgfSA9IGltbWVkaWF0ZUludm9pY2UgfHwge307XHJcbiAgICBpZiAoIWNyZWRpdHMgfHwgIWNyZWRpdHMudXNlZCB8fCBjcmVkaXRzLnVzZWQuYW1vdW50IDw9IDApIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LmFwcGxpZWRDcmVkaXRzVGl0bGUpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChXaXRoU2tlbGV0b24sIHsgaXNMb2FkaW5nOiBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyB9LCBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHtcclxuICAgICAgICAgICAgICAgICAgICBhbW91bnQ6IC0xICogY3JlZGl0cy51c2VkLmFtb3VudCxcclxuICAgICAgICAgICAgICAgICAgICBjdXJyZW5jeTogY3JlZGl0cy51c2VkLmN1cnJlbmN5LFxyXG4gICAgICAgICAgICAgICAgICAgIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMixcclxuICAgICAgICAgICAgICAgIH0pKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBUYXhMaW5lSXRlbSA9ICh7IHRheCwgdGF4RGV0YWlscywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBpZiAoIXRheERldGFpbHMgfHwgIXRheCB8fCB0YXg/LmFtb3VudCA8PSAwKSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24uc3VtbWFyeS50YXhUaXRsZSh7IHRheERldGFpbHMgfSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChXaXRoU2tlbGV0b24sIHsgaXNMb2FkaW5nOiBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyB9LCBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiB0YXg/LmFtb3VudCwgY3VycmVuY3k6IHRheD8uY3VycmVuY3ksIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMiB9KSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1MaW5lSXRlbXMuanMubWFwIl19 */",
12715
+ name: "153q11y",
12716
+ styles: "display:flex;align-items:center;justify-content:space-between;gap:16px",
12717
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AA4BsC","file":"LineItems.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport Grid from '@mui/material/Grid';\r\nimport { BillingModel, TiersMode, } from '@stigg/js-client-sdk';\r\nimport isEmpty from 'lodash/isEmpty';\r\nimport isNil from 'lodash/isNil';\r\nimport Link from '@mui/material/Link';\r\nimport { IconButton } from '@mui/material';\r\nimport Collapse from '@mui/material/Collapse';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nimport { getPriceBreakdownString } from './getPriceBreakdownString';\r\nimport { GraduatedPriceBreakdown } from './GraduatedPriceBreakdown';\r\nimport { CollapsableSectionIcon } from '../../../common/CollapsableSectionIcon';\r\nimport { calculateTierPrice } from '../../../utils/priceTierUtils';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 16px;\n  }\n`;\r\nexport const NestedBreakdownContainer = styled.div `\n  margin-top: 16px;\n  margin-left: 16px;\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n  gap: 16px;\n`;\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const [isNestedBreakdownOpen, setIsNestedBreakdownOpen] = useState(false);\r\n    const toggleNestedBreakdown = () => setIsNestedBreakdownOpen((prev) => !prev);\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    const totalAmount = price.isTieredPrice ? calculateTierPrice(price, quantity) : (price.amount || 0) * quantity;\r\n    let nestedBreakdown;\r\n    const shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated &&\r\n        !!price.tiers &&\r\n        !isEmpty(price.tiers) &&\r\n        !isNil(price.tiers[0].upTo) &&\r\n        quantity > price.tiers[0].upTo;\r\n    if (shouldShowGraduatedPriceBreakdown) {\r\n        nestedBreakdown = React.createElement(GraduatedPriceBreakdown, { price: price, unitQuantity: quantity });\r\n    }\r\n    let title = (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label));\r\n    if (nestedBreakdown) {\r\n        title = (React.createElement(Link, { onClick: toggleNestedBreakdown, underline: \"none\", style: { cursor: 'pointer' } }, title));\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 0.5, style: { whiteSpace: 'nowrap' } },\r\n                title,\r\n                nestedBreakdown && (React.createElement(IconButton, { onClick: toggleNestedBreakdown, sx: { padding: 0 } },\r\n                    React.createElement(CollapsableSectionIcon, { \"$isOpen\": isNestedBreakdownOpen, \"$size\": 16 })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { whiteSpace: 'nowrap' } },\r\n                    getPriceBreakdownString({\r\n                        totalAmount,\r\n                        quantity,\r\n                        currency: price.currency,\r\n                        pricingModel: price.pricingModel,\r\n                        billingPeriod: price.billingPeriod,\r\n                        tiers: price.tiers,\r\n                        tiersMode: price.tiersMode,\r\n                    }),\r\n                    isPayAsYouGo && ' / unit'))),\r\n        nestedBreakdown && (React.createElement(Collapse, { in: isNestedBreakdownOpen },\r\n            React.createElement(NestedBreakdownContainer, null, nestedBreakdown)))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12611
12718
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12612
12719
  });
12613
12720
 
@@ -12632,17 +12739,64 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
12632
12739
  label = _ref2.label,
12633
12740
  quantity = _ref2.quantity,
12634
12741
  price = _ref2.price;
12742
+
12743
+ var _useState = useState(false),
12744
+ isNestedBreakdownOpen = _useState[0],
12745
+ setIsNestedBreakdownOpen = _useState[1];
12746
+
12747
+ var toggleNestedBreakdown = function toggleNestedBreakdown() {
12748
+ return setIsNestedBreakdownOpen(function (prev) {
12749
+ return !prev;
12750
+ });
12751
+ };
12752
+
12635
12753
  var isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;
12754
+ var totalAmount = price.isTieredPrice ? calculateTierPrice(price, quantity) : (price.amount || 0) * quantity;
12755
+ var nestedBreakdown;
12756
+ var shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated && !!price.tiers && !isEmpty(price.tiers) && !isNil(price.tiers[0].upTo) && quantity > price.tiers[0].upTo;
12757
+
12758
+ if (shouldShowGraduatedPriceBreakdown) {
12759
+ nestedBreakdown = React__default.createElement(GraduatedPriceBreakdown, {
12760
+ price: price,
12761
+ unitQuantity: quantity
12762
+ });
12763
+ }
12764
+
12765
+ var title = React__default.createElement(Typography, {
12766
+ variant: "body1",
12767
+ color: "secondary"
12768
+ }, label);
12769
+
12770
+ if (nestedBreakdown) {
12771
+ title = React__default.createElement(Link, {
12772
+ onClick: toggleNestedBreakdown,
12773
+ underline: "none",
12774
+ style: {
12775
+ cursor: 'pointer'
12776
+ }
12777
+ }, title);
12778
+ }
12779
+
12636
12780
  return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
12637
12781
  style: {
12638
12782
  alignItems: 'flex-start'
12639
12783
  }
12640
12784
  }, React__default.createElement(Grid, {
12641
- item: true
12642
- }, React__default.createElement(Typography, {
12643
- variant: "body1",
12644
- color: "secondary"
12645
- }, label)), React__default.createElement(Grid, {
12785
+ item: true,
12786
+ display: "flex",
12787
+ gap: 0.5,
12788
+ style: {
12789
+ whiteSpace: 'nowrap'
12790
+ }
12791
+ }, title, nestedBreakdown && React__default.createElement(IconButton, {
12792
+ onClick: toggleNestedBreakdown,
12793
+ sx: {
12794
+ padding: 0
12795
+ }
12796
+ }, React__default.createElement(CollapsableSectionIcon, {
12797
+ "$isOpen": isNestedBreakdownOpen,
12798
+ "$size": 16
12799
+ }))), React__default.createElement(Grid, {
12646
12800
  item: true,
12647
12801
  display: "flex",
12648
12802
  gap: 1,
@@ -12653,12 +12807,19 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
12653
12807
  variant: "body1",
12654
12808
  color: "secondary",
12655
12809
  style: {
12656
- wordBreak: 'break-word'
12810
+ whiteSpace: 'nowrap'
12657
12811
  }
12658
12812
  }, getPriceBreakdownString({
12659
- price: price,
12660
- quantity: quantity
12661
- }), isPayAsYouGo && ' / unit'))));
12813
+ totalAmount: totalAmount,
12814
+ quantity: quantity,
12815
+ currency: price.currency,
12816
+ pricingModel: price.pricingModel,
12817
+ billingPeriod: price.billingPeriod,
12818
+ tiers: price.tiers,
12819
+ tiersMode: price.tiersMode
12820
+ }), isPayAsYouGo && ' / unit'))), nestedBreakdown && React__default.createElement(Collapse, {
12821
+ "in": isNestedBreakdownOpen
12822
+ }, React__default.createElement(NestedBreakdownContainer, null, nestedBreakdown)));
12662
12823
  };
12663
12824
  var FreeChargeLineItem = function FreeChargeLineItem(_ref3) {
12664
12825
  var label = _ref3.label;
@@ -13548,12 +13709,12 @@ function CheckoutAddonsStep() {
13548
13709
  }));
13549
13710
  }
13550
13711
 
13551
- var _templateObject$6, _templateObject2$2, _templateObject3$2, _templateObject4;
13712
+ var _templateObject$7, _templateObject2$2, _templateObject3$2, _templateObject4;
13552
13713
  var PaymentMethodContainer = /*#__PURE__*/styled(Grid, {
13553
13714
  shouldForwardProp: function shouldForwardProp(prop) {
13554
13715
  return !prop.startsWith('$');
13555
13716
  }
13556
- })(_templateObject$6 || (_templateObject$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding: 8px;\n border-radius: 10px;\n border: 1px solid ", ";\n cursor: ", ";\n opacity: ", ";\n"])), function (_ref) {
13717
+ })(_templateObject$7 || (_templateObject$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding: 8px;\n border-radius: 10px;\n border: 1px solid ", ";\n cursor: ", ";\n opacity: ", ";\n"])), function (_ref) {
13557
13718
  var theme = _ref.theme;
13558
13719
  return theme.stigg.palette.outlinedBorder;
13559
13720
  }, function (_ref2) {
@@ -13645,8 +13806,8 @@ function NewPaymentMethod(_ref3) {
13645
13806
  })));
13646
13807
  }
13647
13808
 
13648
- var _templateObject$7;
13649
- var PaymentContainer = /*#__PURE__*/styled(Grid)(_templateObject$7 || (_templateObject$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n gap: 24px;\n"])));
13809
+ var _templateObject$8;
13810
+ var PaymentContainer = /*#__PURE__*/styled(Grid)(_templateObject$8 || (_templateObject$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n gap: 24px;\n"])));
13650
13811
  function PaymentStep(_ref) {
13651
13812
  var onBillingAddressChange = _ref.onBillingAddressChange,
13652
13813
  collectPhoneNumber = _ref.collectPhoneNumber;
@@ -13941,8 +14102,8 @@ function BillingPeriodPicker$1(_ref2) {
13941
14102
  })));
13942
14103
  }
13943
14104
 
13944
- var _templateObject$8;
13945
- var StyledPlanCharge = /*#__PURE__*/styled.div(_templateObject$8 || (_templateObject$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n min-height: 60px;\n margin-top: 16px;\n"])));
14105
+ var _templateObject$9;
14106
+ var StyledPlanCharge = /*#__PURE__*/styled.div(_templateObject$9 || (_templateObject$9 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: row;\n justify-content: space-between;\n align-items: center;\n min-height: 60px;\n margin-top: 16px;\n"])));
13946
14107
 
13947
14108
  var getValidationText = function getValidationText(charge, quantity) {
13948
14109
  var minUnitQuantity = charge.minUnitQuantity,