@stigg/react-sdk 5.6.0 → 5.8.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.
@@ -843,6 +843,13 @@ function hasTierWithUnitPrice(tiers) {
843
843
  return unitPrice && !isNil(upTo);
844
844
  });
845
845
  }
846
+ function isBulkTiers(tiers) {
847
+ return tiers == null ? void 0 : tiers.every(function (_ref3) {
848
+ var unitPrice = _ref3.unitPrice,
849
+ upTo = _ref3.upTo;
850
+ return !unitPrice || isNil(upTo);
851
+ });
852
+ }
846
853
  function getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex) {
847
854
  var planTierPrices = plan.pricePoints.filter(function (price) {
848
855
  return price.billingPeriod === billingPeriod && price.isTieredPrice;
@@ -1509,6 +1516,10 @@ function ContentLoadingSkeleton() {
1509
1516
  })))));
1510
1517
  }
1511
1518
 
1519
+ var ON_WHEEL_BLUR = function ON_WHEEL_BLUR(e) {
1520
+ return e.target.blur();
1521
+ };
1522
+
1512
1523
  function VolumePerUnitInput(_ref) {
1513
1524
  var width = _ref.width,
1514
1525
  tierUnits = _ref.tierUnits,
@@ -1516,6 +1527,7 @@ function VolumePerUnitInput(_ref) {
1516
1527
  handleChange = _ref.handleChange;
1517
1528
  return React__default.createElement(InputField, {
1518
1529
  type: "number",
1530
+ onWheel: ON_WHEEL_BLUR,
1519
1531
  fullWidth: true,
1520
1532
  sx: {
1521
1533
  minHeight: '46px',
@@ -12524,6 +12536,51 @@ function CheckoutCaptions(props) {
12524
12536
  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)));
12525
12537
  }
12526
12538
 
12539
+ 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;
12546
+ var isPerUnit = pricingModel === BillingModel.PerUnit;
12547
+ var featureUnits = quantity && (isPerUnit || quantity > 1) ? new Intl.NumberFormat().format(quantity) + " x " : '';
12548
+ var billingPeriodString = billingPeriod === BillingPeriod.Annually ? ' x 12 months' : '';
12549
+ var unitPrice = totalAmount / quantity / (billingPeriod === BillingPeriod.Annually ? 12 : 1);
12550
+ var formattedUnitPrice = currencyPriceFormatter({
12551
+ amount: unitPrice,
12552
+ currency: currency,
12553
+ minimumFractionDigits: 2
12554
+ });
12555
+ var formattedTotalPrice = currencyPriceFormatter({
12556
+ amount: totalAmount,
12557
+ currency: currency,
12558
+ minimumFractionDigits: 2
12559
+ });
12560
+ return "" + featureUnits + formattedUnitPrice + billingPeriodString + " " + (billingPeriodString || featureUnits ? " = " + formattedTotalPrice : '');
12561
+ }
12562
+
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) {
12569
+ var formattedTotalPrice = currencyPriceFormatter({
12570
+ amount: amount,
12571
+ currency: price.currency,
12572
+ minimumFractionDigits: 2
12573
+ });
12574
+ return quantity + " for " + formattedTotalPrice;
12575
+ }
12576
+
12577
+ return formatPricePerUnit({
12578
+ price: price,
12579
+ quantity: quantity,
12580
+ totalAmount: amount
12581
+ });
12582
+ }
12583
+
12527
12584
  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)."; }
12528
12585
  var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
12529
12586
  target: "e1ultpe61"
@@ -12531,12 +12588,12 @@ var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
12531
12588
  target: "e1ultpe61",
12532
12589
  label: "LineItemContainer"
12533
12590
  })(process.env.NODE_ENV === "production" ? {
12534
- name: "rdmn2i",
12535
- styles: "&+&{margin-top:8px;}"
12591
+ name: "x9km8e",
12592
+ styles: "&+&{margin-top:16px;}"
12536
12593
  } : {
12537
- name: "rdmn2i",
12538
- styles: "&+&{margin-top:8px;}",
12539
- 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 { calculateTierPrice } 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        amount = calculateTierPrice(price, quantity);\r\n    }\r\n    else {\r\n        amount = price.amount * quantity;\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({\r\n                        amount,\r\n                        currency: price.currency,\r\n                        minimumFractionDigits: 2,\r\n                    }),\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"]} */",
12594
+ name: "x9km8e",
12595
+ styles: "&+&{margin-top:16px;}",
12596
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpbmVJdGVtcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVzRDIiwiZmlsZSI6IkxpbmVJdGVtcy50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCBHcmlkIGZyb20gJ0BtdWkvbWF0ZXJpYWwvR3JpZCc7XHJcbmltcG9ydCB7IEJpbGxpbmdNb2RlbCB9IGZyb20gJ0BzdGlnZy9qcy1jbGllbnQtc2RrJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuaW1wb3J0IHsgY3VycmVuY3lQcmljZUZvcm1hdHRlciB9IGZyb20gJy4uLy4uLy4uL3V0aWxzL2N1cnJlbmN5VXRpbHMnO1xyXG5pbXBvcnQgeyBXaXRoU2tlbGV0b24gfSBmcm9tICcuL1dpdGhTa2VsZXRvbic7XHJcbmltcG9ydCB7IFNrZWxldG9uIH0gZnJvbSAnLi4vLi4vY29tcG9uZW50cy9Ta2VsZXRvbnMuc3R5bGUnO1xyXG5pbXBvcnQgeyBJY29uIH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL0ljb24nO1xyXG5pbXBvcnQgeyBJbmZvcm1hdGlvblRvb2x0aXAgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vSW5mb3JtYXRpb25Ub29sdGlwJztcclxuaW1wb3J0IHsgZ2V0UHJpY2VCcmVha2Rvd25TdHJpbmcgfSBmcm9tICcuL2dldFByaWNlQnJlYWtkb3duU3RyaW5nJztcclxuZXhwb3J0IGNvbnN0IExpbmVJdGVtQ29udGFpbmVyID0gc3R5bGVkLmRpdiBgXG4gICYgKyAmIHtcbiAgICBtYXJnaW4tdG9wOiAxNnB4O1xuICB9XG5gO1xyXG5leHBvcnQgY29uc3QgTGluZUl0ZW1Sb3cgPSBzdHlsZWQuZGl2IGBcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAganVzdGlmeS1jb250ZW50OiBzcGFjZS1iZXR3ZWVuO1xuYDtcclxuY29uc3QgUGF5QXNZb3VHb1ByaWNlVG9vbHRpcCA9ICh7IGNoZWNrb3V0TG9jYWxpemF0aW9uIH0pID0+IHtcclxuICAgIGNvbnN0IHRpdGxlID0gUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LnBheUFzWW91R29Ub29sdGlwVGV4dCk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoSW5mb3JtYXRpb25Ub29sdGlwLCB7IHBsYWNlbWVudDogXCJsZWZ0XCIsIHRpdGxlOiB0aXRsZSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoSWNvbiwgeyBpY29uOiBcIlBheUFzWW91R29DaGFyZ2VcIiwgc3R5bGU6IHsgZGlzcGxheTogJ2ZsZXgnIH0gfSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IEJpbGxlZFByaWNlTGluZUl0ZW0gPSAoeyBjaGVja291dExvY2FsaXphdGlvbiwgbGFiZWwsIHF1YW50aXR5LCBwcmljZSwgfSkgPT4ge1xyXG4gICAgY29uc3QgaXNQYXlBc1lvdUdvID0gcHJpY2UucHJpY2luZ01vZGVsID09PSBCaWxsaW5nTW9kZWwuVXNhZ2VCYXNlZDtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCB7IHN0eWxlOiB7IGFsaWduSXRlbXM6ICdmbGV4LXN0YXJ0JyB9IH0sXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBsYWJlbCkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgaXRlbTogdHJ1ZSwgZGlzcGxheTogXCJmbGV4XCIsIGdhcDogMSwgYWxpZ25JdGVtczogXCJjZW50ZXJcIiB9LFxyXG4gICAgICAgICAgICAgICAgaXNQYXlBc1lvdUdvICYmIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGF5QXNZb3VHb1ByaWNlVG9vbHRpcCwgeyBjaGVja291dExvY2FsaXphdGlvbjogY2hlY2tvdXRMb2NhbGl6YXRpb24gfSksXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiwgc3R5bGU6IHsgd29yZEJyZWFrOiAnYnJlYWstd29yZCcgfSB9LFxyXG4gICAgICAgICAgICAgICAgICAgIGdldFByaWNlQnJlYWtkb3duU3RyaW5nKHsgcHJpY2UsIHF1YW50aXR5IH0pLFxyXG4gICAgICAgICAgICAgICAgICAgIGlzUGF5QXNZb3VHbyAmJiAnIC8gdW5pdCcpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IEZyZWVDaGFyZ2VMaW5lSXRlbSA9ICh7IGxhYmVsIH0pID0+IHtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCB7IHN0eWxlOiB7IGFsaWduSXRlbXM6ICdmbGV4LWVuZCcgfSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgaXRlbTogdHJ1ZSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgbGFiZWwpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGl0ZW06IHRydWUsIGRpc3BsYXk6IFwiZmxleFwiLCBnYXA6IDEsIGFsaWduSXRlbXM6IFwiY2VudGVyXCIgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiLCBzdHlsZTogeyB3b3JkQnJlYWs6ICdicmVhay13b3JkJyB9IH0sIFwiRnJlZVwiKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBEaXNjb3VudExpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGltbWVkaWF0ZUludm9pY2UsIHJlY3VycmluZ0ludm9pY2UgfSA9IHN1YnNjcmlwdGlvblByZXZpZXc7XHJcbiAgICBjb25zdCB7IGRpc2NvdW50LCBkaXNjb3VudERldGFpbHMgfSA9IHJlY3VycmluZ0ludm9pY2UgfHwge307XHJcbiAgICBpZiAoIWRpc2NvdW50IHx8ICFkaXNjb3VudERldGFpbHMpIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LmRpc2NvdW50VGV4dCh7XHJcbiAgICAgICAgICAgICAgICBkaXNjb3VudERldGFpbHMsXHJcbiAgICAgICAgICAgICAgICBjdXJyZW5jeTogaW1tZWRpYXRlSW52b2ljZS50b3RhbC5jdXJyZW5jeSxcclxuICAgICAgICAgICAgfSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFNrZWxldG9uLCB7IHdpZHRoOiA1MCwgaGVpZ2h0OiAxNiB9KSkgOiAoY3VycmVuY3lQcmljZUZvcm1hdHRlcih7XHJcbiAgICAgICAgICAgICAgICBhbW91bnQ6IGRpc2NvdW50LmFtb3VudCxcclxuICAgICAgICAgICAgICAgIGN1cnJlbmN5OiBkaXNjb3VudC5jdXJyZW5jeSxcclxuICAgICAgICAgICAgICAgIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMixcclxuICAgICAgICAgICAgfSkpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IEFwcGxpZWRDcmVkaXRzTGluZUl0ZW0gPSAoeyBzdWJzY3JpcHRpb25QcmV2aWV3LCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldywgY2hlY2tvdXRMb2NhbGl6YXRpb24sIH0pID0+IHtcclxuICAgIGNvbnN0IHsgaW1tZWRpYXRlSW52b2ljZSB9ID0gc3Vic2NyaXB0aW9uUHJldmlldyB8fCB7fTtcclxuICAgIGNvbnN0IHsgY3JlZGl0cyB9ID0gaW1tZWRpYXRlSW52b2ljZSB8fCB7fTtcclxuICAgIGlmICghY3JlZGl0cyB8fCAhY3JlZGl0cy51c2VkIHx8IGNyZWRpdHMudXNlZC5hbW91bnQgPD0gMCkge1xyXG4gICAgICAgIHJldHVybiBudWxsO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtQ29udGFpbmVyLCBudWxsLFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Sb3csIG51bGwsXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGNoZWNrb3V0TG9jYWxpemF0aW9uLnN1bW1hcnkuYXBwbGllZENyZWRpdHNUaXRsZSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFdpdGhTa2VsZXRvbiwgeyBpc0xvYWRpbmc6IGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3IH0sIGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoe1xyXG4gICAgICAgICAgICAgICAgICAgIGFtb3VudDogLTEgKiBjcmVkaXRzLnVzZWQuYW1vdW50LFxyXG4gICAgICAgICAgICAgICAgICAgIGN1cnJlbmN5OiBjcmVkaXRzLnVzZWQuY3VycmVuY3ksXHJcbiAgICAgICAgICAgICAgICAgICAgbWluaW11bUZyYWN0aW9uRGlnaXRzOiAyLFxyXG4gICAgICAgICAgICAgICAgfSkpKSkpKTtcclxufTtcclxuZXhwb3J0IGNvbnN0IFRheExpbmVJdGVtID0gKHsgdGF4LCB0YXhEZXRhaWxzLCBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldywgY2hlY2tvdXRMb2NhbGl6YXRpb24sIH0pID0+IHtcclxuICAgIGlmICghdGF4RGV0YWlscyB8fCAhdGF4IHx8IHRheD8uYW1vdW50IDw9IDApIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LnRheFRpdGxlKHsgdGF4RGV0YWlscyB9KSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFdpdGhTa2VsZXRvbiwgeyBpc0xvYWRpbmc6IGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3IH0sIGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoeyBhbW91bnQ6IHRheD8uYW1vdW50LCBjdXJyZW5jeTogdGF4Py5jdXJyZW5jeSwgbWluaW11bUZyYWN0aW9uRGlnaXRzOiAyIH0pKSkpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPUxpbmVJdGVtcy5qcy5tYXAiXX0= */",
12540
12597
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12541
12598
  });
12542
12599
  var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
@@ -12550,35 +12607,12 @@ var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
12550
12607
  } : {
12551
12608
  name: "bcffy2",
12552
12609
  styles: "display:flex;align-items:center;justify-content:space-between",
12553
- 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 { calculateTierPrice } 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        amount = calculateTierPrice(price, quantity);\r\n    }\r\n    else {\r\n        amount = price.amount * quantity;\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({\r\n                        amount,\r\n                        currency: price.currency,\r\n                        minimumFractionDigits: 2,\r\n                    }),\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"]} */",
12610
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkxpbmVJdGVtcy50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBZ0JzQyIsImZpbGUiOiJMaW5lSXRlbXMudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IFJlYWN0IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgR3JpZCBmcm9tICdAbXVpL21hdGVyaWFsL0dyaWQnO1xyXG5pbXBvcnQgeyBCaWxsaW5nTW9kZWwgfSBmcm9tICdAc3RpZ2cvanMtY2xpZW50LXNkayc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIgfSBmcm9tICcuLi8uLi8uLi91dGlscy9jdXJyZW5jeVV0aWxzJztcclxuaW1wb3J0IHsgV2l0aFNrZWxldG9uIH0gZnJvbSAnLi9XaXRoU2tlbGV0b24nO1xyXG5pbXBvcnQgeyBTa2VsZXRvbiB9IGZyb20gJy4uLy4uL2NvbXBvbmVudHMvU2tlbGV0b25zLnN0eWxlJztcclxuaW1wb3J0IHsgSWNvbiB9IGZyb20gJy4uLy4uLy4uL2NvbW1vbi9JY29uJztcclxuaW1wb3J0IHsgSW5mb3JtYXRpb25Ub29sdGlwIH0gZnJvbSAnLi4vLi4vLi4vY29tbW9uL0luZm9ybWF0aW9uVG9vbHRpcCc7XHJcbmltcG9ydCB7IGdldFByaWNlQnJlYWtkb3duU3RyaW5nIH0gZnJvbSAnLi9nZXRQcmljZUJyZWFrZG93blN0cmluZyc7XHJcbmV4cG9ydCBjb25zdCBMaW5lSXRlbUNvbnRhaW5lciA9IHN0eWxlZC5kaXYgYFxuICAmICsgJiB7XG4gICAgbWFyZ2luLXRvcDogMTZweDtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IExpbmVJdGVtUm93ID0gc3R5bGVkLmRpdiBgXG4gIGRpc3BsYXk6IGZsZXg7XG4gIGFsaWduLWl0ZW1zOiBjZW50ZXI7XG4gIGp1c3RpZnktY29udGVudDogc3BhY2UtYmV0d2VlbjtcbmA7XHJcbmNvbnN0IFBheUFzWW91R29QcmljZVRvb2x0aXAgPSAoeyBjaGVja291dExvY2FsaXphdGlvbiB9KSA9PiB7XHJcbiAgICBjb25zdCB0aXRsZSA9IFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24uc3VtbWFyeS5wYXlBc1lvdUdvVG9vbHRpcFRleHQpO1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEluZm9ybWF0aW9uVG9vbHRpcCwgeyBwbGFjZW1lbnQ6IFwibGVmdFwiLCB0aXRsZTogdGl0bGUgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEljb24sIHsgaWNvbjogXCJQYXlBc1lvdUdvQ2hhcmdlXCIsIHN0eWxlOiB7IGRpc3BsYXk6ICdmbGV4JyB9IH0pKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBCaWxsZWRQcmljZUxpbmVJdGVtID0gKHsgY2hlY2tvdXRMb2NhbGl6YXRpb24sIGxhYmVsLCBxdWFudGl0eSwgcHJpY2UsIH0pID0+IHtcclxuICAgIGNvbnN0IGlzUGF5QXNZb3VHbyA9IHByaWNlLnByaWNpbmdNb2RlbCA9PT0gQmlsbGluZ01vZGVsLlVzYWdlQmFzZWQ7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgeyBzdHlsZTogeyBhbGlnbkl0ZW1zOiAnZmxleC1zdGFydCcgfSB9LFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIHsgaXRlbTogdHJ1ZSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgbGFiZWwpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGl0ZW06IHRydWUsIGRpc3BsYXk6IFwiZmxleFwiLCBnYXA6IDEsIGFsaWduSXRlbXM6IFwiY2VudGVyXCIgfSxcclxuICAgICAgICAgICAgICAgIGlzUGF5QXNZb3VHbyAmJiBSZWFjdC5jcmVhdGVFbGVtZW50KFBheUFzWW91R29QcmljZVRvb2x0aXAsIHsgY2hlY2tvdXRMb2NhbGl6YXRpb246IGNoZWNrb3V0TG9jYWxpemF0aW9uIH0pLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIsIHN0eWxlOiB7IHdvcmRCcmVhazogJ2JyZWFrLXdvcmQnIH0gfSxcclxuICAgICAgICAgICAgICAgICAgICBnZXRQcmljZUJyZWFrZG93blN0cmluZyh7IHByaWNlLCBxdWFudGl0eSB9KSxcclxuICAgICAgICAgICAgICAgICAgICBpc1BheUFzWW91R28gJiYgJyAvIHVuaXQnKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBGcmVlQ2hhcmdlTGluZUl0ZW0gPSAoeyBsYWJlbCB9KSA9PiB7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgeyBzdHlsZTogeyBhbGlnbkl0ZW1zOiAnZmxleC1lbmQnIH0gfSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChHcmlkLCB7IGl0ZW06IHRydWUgfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIGxhYmVsKSksXHJcbiAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoR3JpZCwgeyBpdGVtOiB0cnVlLCBkaXNwbGF5OiBcImZsZXhcIiwgZ2FwOiAxLCBhbGlnbkl0ZW1zOiBcImNlbnRlclwiIH0sXHJcbiAgICAgICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiwgc3R5bGU6IHsgd29yZEJyZWFrOiAnYnJlYWstd29yZCcgfSB9LCBcIkZyZWVcIikpKSkpO1xyXG59O1xyXG5leHBvcnQgY29uc3QgRGlzY291bnRMaW5lSXRlbSA9ICh7IHN1YnNjcmlwdGlvblByZXZpZXcsIGlzRmV0Y2hpbmdTdWJzY3JpcHRpb25QcmV2aWV3LCBjaGVja291dExvY2FsaXphdGlvbiwgfSkgPT4ge1xyXG4gICAgY29uc3QgeyBpbW1lZGlhdGVJbnZvaWNlLCByZWN1cnJpbmdJbnZvaWNlIH0gPSBzdWJzY3JpcHRpb25QcmV2aWV3O1xyXG4gICAgY29uc3QgeyBkaXNjb3VudCwgZGlzY291bnREZXRhaWxzIH0gPSByZWN1cnJpbmdJbnZvaWNlIHx8IHt9O1xyXG4gICAgaWYgKCFkaXNjb3VudCB8fCAhZGlzY291bnREZXRhaWxzKSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24uc3VtbWFyeS5kaXNjb3VudFRleHQoe1xyXG4gICAgICAgICAgICAgICAgZGlzY291bnREZXRhaWxzLFxyXG4gICAgICAgICAgICAgICAgY3VycmVuY3k6IGltbWVkaWF0ZUludm9pY2UudG90YWwuY3VycmVuY3ksXHJcbiAgICAgICAgICAgIH0pKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChTa2VsZXRvbiwgeyB3aWR0aDogNTAsIGhlaWdodDogMTYgfSkpIDogKGN1cnJlbmN5UHJpY2VGb3JtYXR0ZXIoe1xyXG4gICAgICAgICAgICAgICAgYW1vdW50OiBkaXNjb3VudC5hbW91bnQsXHJcbiAgICAgICAgICAgICAgICBjdXJyZW5jeTogZGlzY291bnQuY3VycmVuY3ksXHJcbiAgICAgICAgICAgICAgICBtaW5pbXVtRnJhY3Rpb25EaWdpdHM6IDIsXHJcbiAgICAgICAgICAgIH0pKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBBcHBsaWVkQ3JlZGl0c0xpbmVJdGVtID0gKHsgc3Vic2NyaXB0aW9uUHJldmlldywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IGltbWVkaWF0ZUludm9pY2UgfSA9IHN1YnNjcmlwdGlvblByZXZpZXcgfHwge307XHJcbiAgICBjb25zdCB7IGNyZWRpdHMgfSA9IGltbWVkaWF0ZUludm9pY2UgfHwge307XHJcbiAgICBpZiAoIWNyZWRpdHMgfHwgIWNyZWRpdHMudXNlZCB8fCBjcmVkaXRzLnVzZWQuYW1vdW50IDw9IDApIHtcclxuICAgICAgICByZXR1cm4gbnVsbDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbUNvbnRhaW5lciwgbnVsbCxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KExpbmVJdGVtUm93LCBudWxsLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LmFwcGxpZWRDcmVkaXRzVGl0bGUpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChXaXRoU2tlbGV0b24sIHsgaXNMb2FkaW5nOiBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyB9LCBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHtcclxuICAgICAgICAgICAgICAgICAgICBhbW91bnQ6IC0xICogY3JlZGl0cy51c2VkLmFtb3VudCxcclxuICAgICAgICAgICAgICAgICAgICBjdXJyZW5jeTogY3JlZGl0cy51c2VkLmN1cnJlbmN5LFxyXG4gICAgICAgICAgICAgICAgICAgIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMixcclxuICAgICAgICAgICAgICAgIH0pKSkpKSk7XHJcbn07XHJcbmV4cG9ydCBjb25zdCBUYXhMaW5lSXRlbSA9ICh7IHRheCwgdGF4RGV0YWlscywgaXNGZXRjaGluZ1N1YnNjcmlwdGlvblByZXZpZXcsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCB9KSA9PiB7XHJcbiAgICBpZiAoIXRheERldGFpbHMgfHwgIXRheCB8fCB0YXg/LmFtb3VudCA8PSAwKSB7XHJcbiAgICAgICAgcmV0dXJuIG51bGw7XHJcbiAgICB9XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTGluZUl0ZW1Db250YWluZXIsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChMaW5lSXRlbVJvdywgbnVsbCxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY2hlY2tvdXRMb2NhbGl6YXRpb24uc3VtbWFyeS50YXhUaXRsZSh7IHRheERldGFpbHMgfSkpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgdmFyaWFudDogXCJib2R5MVwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChXaXRoU2tlbGV0b24sIHsgaXNMb2FkaW5nOiBpc0ZldGNoaW5nU3Vic2NyaXB0aW9uUHJldmlldyB9LCBjdXJyZW5jeVByaWNlRm9ybWF0dGVyKHsgYW1vdW50OiB0YXg/LmFtb3VudCwgY3VycmVuY3k6IHRheD8uY3VycmVuY3ksIG1pbmltdW1GcmFjdGlvbkRpZ2l0czogMiB9KSkpKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1MaW5lSXRlbXMuanMubWFwIl19 */",
12554
12611
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12555
12612
  });
12556
- var getPriceString = function getPriceString(_ref) {
12557
- var amount = _ref.amount,
12558
- price = _ref.price,
12559
- quantity = _ref.quantity;
12560
- var billingPeriod = price.billingPeriod;
12561
- var billingPeriodString = null;
12562
12613
 
12563
- if (quantity) {
12564
- amount /= quantity;
12565
- }
12566
-
12567
- if (billingPeriod === BillingPeriod.Annually) {
12568
- amount /= 12;
12569
- billingPeriodString = '12 months';
12570
- }
12571
-
12572
- var addonPriceFormat = currencyPriceFormatter({
12573
- amount: amount,
12574
- currency: price.currency,
12575
- minimumFractionDigits: 2
12576
- });
12577
- return "" + (quantity > 1 ? quantity + " x " + addonPriceFormat + " each" : addonPriceFormat) + (billingPeriodString ? " x " + billingPeriodString : '');
12578
- };
12579
-
12580
- var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref2) {
12581
- var checkoutLocalization = _ref2.checkoutLocalization;
12614
+ var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref) {
12615
+ var checkoutLocalization = _ref.checkoutLocalization;
12582
12616
  var title = React__default.createElement(Typography, {
12583
12617
  variant: "body1"
12584
12618
  }, checkoutLocalization.summary.payAsYouGoTooltipText);
@@ -12593,21 +12627,12 @@ var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref2) {
12593
12627
  }));
12594
12628
  };
12595
12629
 
12596
- var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12597
- var checkoutLocalization = _ref3.checkoutLocalization,
12598
- label = _ref3.label,
12599
- quantity = _ref3.quantity,
12600
- price = _ref3.price;
12601
- var billingPeriod = price.billingPeriod;
12630
+ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
12631
+ var checkoutLocalization = _ref2.checkoutLocalization,
12632
+ label = _ref2.label,
12633
+ quantity = _ref2.quantity,
12634
+ price = _ref2.price;
12602
12635
  var isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;
12603
- var amount;
12604
-
12605
- if (price.isTieredPrice) {
12606
- amount = calculateTierPrice(price, quantity);
12607
- } else {
12608
- amount = price.amount * quantity;
12609
- }
12610
-
12611
12636
  return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
12612
12637
  style: {
12613
12638
  alignItems: 'flex-start'
@@ -12617,14 +12642,7 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12617
12642
  }, React__default.createElement(Typography, {
12618
12643
  variant: "body1",
12619
12644
  color: "secondary"
12620
- }, label), (quantity > 1 || billingPeriod === BillingPeriod.Annually) && React__default.createElement(Typography, {
12621
- variant: "body1",
12622
- color: "secondary"
12623
- }, getPriceString({
12624
- amount: amount,
12625
- price: price,
12626
- quantity: quantity
12627
- }))), React__default.createElement(Grid, {
12645
+ }, label)), React__default.createElement(Grid, {
12628
12646
  item: true,
12629
12647
  display: "flex",
12630
12648
  gap: 1,
@@ -12637,14 +12655,13 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12637
12655
  style: {
12638
12656
  wordBreak: 'break-word'
12639
12657
  }
12640
- }, currencyPriceFormatter({
12641
- amount: amount,
12642
- currency: price.currency,
12643
- minimumFractionDigits: 2
12658
+ }, getPriceBreakdownString({
12659
+ price: price,
12660
+ quantity: quantity
12644
12661
  }), isPayAsYouGo && ' / unit'))));
12645
12662
  };
12646
- var FreeChargeLineItem = function FreeChargeLineItem(_ref4) {
12647
- var label = _ref4.label;
12663
+ var FreeChargeLineItem = function FreeChargeLineItem(_ref3) {
12664
+ var label = _ref3.label;
12648
12665
  return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
12649
12666
  style: {
12650
12667
  alignItems: 'flex-end'
@@ -12667,16 +12684,16 @@ var FreeChargeLineItem = function FreeChargeLineItem(_ref4) {
12667
12684
  }
12668
12685
  }, "Free"))));
12669
12686
  };
12670
- var DiscountLineItem = function DiscountLineItem(_ref5) {
12671
- var subscriptionPreview = _ref5.subscriptionPreview,
12672
- isFetchingSubscriptionPreview = _ref5.isFetchingSubscriptionPreview,
12673
- checkoutLocalization = _ref5.checkoutLocalization;
12687
+ var DiscountLineItem = function DiscountLineItem(_ref4) {
12688
+ var subscriptionPreview = _ref4.subscriptionPreview,
12689
+ isFetchingSubscriptionPreview = _ref4.isFetchingSubscriptionPreview,
12690
+ checkoutLocalization = _ref4.checkoutLocalization;
12674
12691
  var immediateInvoice = subscriptionPreview.immediateInvoice,
12675
12692
  recurringInvoice = subscriptionPreview.recurringInvoice;
12676
12693
 
12677
- var _ref6 = recurringInvoice || {},
12678
- discount = _ref6.discount,
12679
- discountDetails = _ref6.discountDetails;
12694
+ var _ref5 = recurringInvoice || {},
12695
+ discount = _ref5.discount,
12696
+ discountDetails = _ref5.discountDetails;
12680
12697
 
12681
12698
  if (!discount || !discountDetails) {
12682
12699
  return null;
@@ -12700,16 +12717,16 @@ var DiscountLineItem = function DiscountLineItem(_ref5) {
12700
12717
  minimumFractionDigits: 2
12701
12718
  }))));
12702
12719
  };
12703
- var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref7) {
12704
- var subscriptionPreview = _ref7.subscriptionPreview,
12705
- isFetchingSubscriptionPreview = _ref7.isFetchingSubscriptionPreview,
12706
- checkoutLocalization = _ref7.checkoutLocalization;
12720
+ var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref6) {
12721
+ var subscriptionPreview = _ref6.subscriptionPreview,
12722
+ isFetchingSubscriptionPreview = _ref6.isFetchingSubscriptionPreview,
12723
+ checkoutLocalization = _ref6.checkoutLocalization;
12707
12724
 
12708
- var _ref8 = subscriptionPreview || {},
12709
- immediateInvoice = _ref8.immediateInvoice;
12725
+ var _ref7 = subscriptionPreview || {},
12726
+ immediateInvoice = _ref7.immediateInvoice;
12710
12727
 
12711
- var _ref9 = immediateInvoice || {},
12712
- credits = _ref9.credits;
12728
+ var _ref8 = immediateInvoice || {},
12729
+ credits = _ref8.credits;
12713
12730
 
12714
12731
  if (!credits || !credits.used || credits.used.amount <= 0) {
12715
12732
  return null;
@@ -12729,11 +12746,11 @@ var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref7) {
12729
12746
  minimumFractionDigits: 2
12730
12747
  })))));
12731
12748
  };
12732
- var TaxLineItem = function TaxLineItem(_ref10) {
12733
- var tax = _ref10.tax,
12734
- taxDetails = _ref10.taxDetails,
12735
- isFetchingSubscriptionPreview = _ref10.isFetchingSubscriptionPreview,
12736
- checkoutLocalization = _ref10.checkoutLocalization;
12749
+ var TaxLineItem = function TaxLineItem(_ref9) {
12750
+ var tax = _ref9.tax,
12751
+ taxDetails = _ref9.taxDetails,
12752
+ isFetchingSubscriptionPreview = _ref9.isFetchingSubscriptionPreview,
12753
+ checkoutLocalization = _ref9.checkoutLocalization;
12737
12754
 
12738
12755
  if (!taxDetails || !tax || (tax == null ? void 0 : tax.amount) <= 0) {
12739
12756
  return null;
@@ -13422,6 +13439,7 @@ function AddonListItem(_ref) {
13422
13439
  }, "Undo")), isAdded && React__default.createElement(React__default.Fragment, null, React__default.createElement(InputField, {
13423
13440
  id: addon.id + "-input",
13424
13441
  type: "number",
13442
+ onWheel: ON_WHEEL_BLUR,
13425
13443
  sx: {
13426
13444
  width: 120,
13427
13445
  marginX: 2
@@ -14017,6 +14035,7 @@ function PlanCharge(_ref) {
14017
14035
  },
14018
14036
  id: featureId + "-input",
14019
14037
  type: "number",
14038
+ onWheel: ON_WHEEL_BLUR,
14020
14039
  error: !isValid,
14021
14040
  helperText: !isValid ? getValidationText(charge, billableFeature == null ? void 0 : billableFeature.quantity) : undefined,
14022
14041
  FormHelperTextProps: {
@@ -14025,10 +14044,7 @@ function PlanCharge(_ref) {
14025
14044
  }
14026
14045
  },
14027
14046
  value: (_billableFeature$quan = billableFeature == null ? void 0 : billableFeature.quantity) != null ? _billableFeature$quan : '',
14028
- onChange: handleQuantityChange,
14029
- onWheel: function onWheel(e) {
14030
- return e.target.blur();
14031
- }
14047
+ onChange: handleQuantityChange
14032
14048
  });
14033
14049
  }
14034
14050