@stigg/react-sdk 5.7.0 → 5.9.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.
@@ -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: {
@@ -843,6 +845,16 @@ function hasTierWithUnitPrice(tiers) {
843
845
  return unitPrice && !isNil(upTo);
844
846
  });
845
847
  }
848
+ function isBulkTiers(tiers) {
849
+ return tiers == null ? void 0 : tiers.every(function (_ref3) {
850
+ var unitPrice = _ref3.unitPrice,
851
+ upTo = _ref3.upTo;
852
+ return !unitPrice || isNil(upTo);
853
+ });
854
+ }
855
+ function isQuantityInFirstTier(tiers, quantity) {
856
+ return (tiers == null ? void 0 : tiers[0].upTo) && quantity <= tiers[0].upTo;
857
+ }
846
858
  function getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex) {
847
859
  var planTierPrices = plan.pricePoints.filter(function (price) {
848
860
  return price.billingPeriod === billingPeriod && price.isTieredPrice;
@@ -12529,19 +12541,157 @@ function CheckoutCaptions(props) {
12529
12541
  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)));
12530
12542
  }
12531
12543
 
12544
+ function numberFormatter(number, _temp) {
12545
+ var _ref = _temp === void 0 ? {} : _temp,
12546
+ locate = _ref.locate;
12547
+
12548
+ return new Intl.NumberFormat(locate).format(number);
12549
+ }
12550
+
12551
+ function formatPricePerUnit(_ref) {
12552
+ var quantity = _ref.quantity,
12553
+ totalAmount = _ref.totalAmount,
12554
+ pricingModel = _ref.pricingModel,
12555
+ billingPeriod = _ref.billingPeriod,
12556
+ currency = _ref.currency;
12557
+ var isPerUnit = pricingModel === BillingModel.PerUnit;
12558
+ var featureUnits = quantity && (isPerUnit || quantity > 1) ? numberFormatter(quantity) + " x " : '';
12559
+ var billingPeriodString = billingPeriod === BillingPeriod.Annually ? ' x 12 months' : '';
12560
+ var unitPrice = totalAmount / quantity / (billingPeriod === BillingPeriod.Annually ? 12 : 1);
12561
+ var formattedUnitPrice = currencyPriceFormatter({
12562
+ amount: unitPrice,
12563
+ currency: currency,
12564
+ minimumFractionDigits: 2
12565
+ });
12566
+ var formattedTotalPrice = currencyPriceFormatter({
12567
+ amount: totalAmount,
12568
+ currency: currency,
12569
+ minimumFractionDigits: 2
12570
+ });
12571
+ return "" + featureUnits + formattedUnitPrice + billingPeriodString + " " + (billingPeriodString || featureUnits ? " = " + formattedTotalPrice : '');
12572
+ }
12573
+ function getPriceBreakdownString(params) {
12574
+ var totalAmount = params.totalAmount,
12575
+ quantity = params.quantity,
12576
+ tiersMode = params.tiersMode,
12577
+ tiers = params.tiers,
12578
+ currency = params.currency;
12579
+
12580
+ if (isBulkTiers(tiers) || tiersMode === TiersMode.Graduated && !isQuantityInFirstTier(tiers, quantity)) {
12581
+ var formattedTotalPrice = currencyPriceFormatter({
12582
+ amount: totalAmount,
12583
+ currency: currency,
12584
+ minimumFractionDigits: 2
12585
+ });
12586
+ return numberFormatter(quantity) + " for " + formattedTotalPrice;
12587
+ }
12588
+
12589
+ return formatPricePerUnit(params);
12590
+ }
12591
+
12592
+ function getLabel(tiers, index) {
12593
+ var _tiers$index = tiers[index],
12594
+ unitPrice = _tiers$index.unitPrice,
12595
+ upTo = _tiers$index.upTo;
12596
+
12597
+ if (!unitPrice) {
12598
+ return '';
12599
+ }
12600
+
12601
+ if (index === 0) {
12602
+ return "First " + upTo;
12603
+ }
12604
+
12605
+ var previousTierUpTo = tiers[index - 1].upTo || 0;
12606
+ var startUnit = previousTierUpTo + 1;
12607
+ return isNil(upTo) ? numberFormatter(startUnit) + " and above" : "Next " + numberFormatter(startUnit) + " to " + numberFormatter(upTo);
12608
+ }
12609
+
12610
+ function GraduatedPriceBreakdown(_ref) {
12611
+ var price = _ref.price,
12612
+ unitQuantity = _ref.unitQuantity;
12613
+ var tiers = price.tiers || [];
12614
+
12615
+ var _calculateTierPriceGr = calculateTierPriceGraduated(tiers, unitQuantity),
12616
+ breakdown = _calculateTierPriceGr.breakdown;
12617
+
12618
+ if (breakdown.length === 1) {
12619
+ return null;
12620
+ }
12621
+
12622
+ return React__default.createElement(React__default.Fragment, null, breakdown.map(function (_ref2, index) {
12623
+ var unitQuantity = _ref2.unitQuantity,
12624
+ amount = _ref2.amount;
12625
+ return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
12626
+ key: index,
12627
+ style: {
12628
+ alignItems: 'flex-start'
12629
+ }
12630
+ }, React__default.createElement(Typography, {
12631
+ variant: "body1",
12632
+ color: "tertiary",
12633
+ style: {
12634
+ whiteSpace: 'nowrap'
12635
+ }
12636
+ }, getLabel(tiers, index)), React__default.createElement(Typography, {
12637
+ variant: "body1",
12638
+ color: "tertiary",
12639
+ style: {
12640
+ whiteSpace: 'nowrap'
12641
+ }
12642
+ }, formatPricePerUnit({
12643
+ quantity: unitQuantity,
12644
+ totalAmount: amount,
12645
+ currency: price.currency,
12646
+ pricingModel: price.pricingModel,
12647
+ billingPeriod: price.billingPeriod,
12648
+ tiers: price.tiers,
12649
+ tiersMode: price.tiersMode
12650
+ }))));
12651
+ }));
12652
+ }
12653
+
12654
+ var _templateObject$6;
12655
+ 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) {
12656
+ var _ref$$size = _ref.$size,
12657
+ $size = _ref$$size === void 0 ? 24 : _ref$$size;
12658
+ return $size + "px";
12659
+ }, function (_ref2) {
12660
+ var _ref2$$size = _ref2.$size,
12661
+ $size = _ref2$$size === void 0 ? 24 : _ref2$$size;
12662
+ return $size + "px";
12663
+ }, function (_ref3) {
12664
+ var $isOpen = _ref3.$isOpen;
12665
+ return $isOpen && "transform: rotate(90deg)";
12666
+ });
12667
+
12532
12668
  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)."; }
12533
12669
  var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
12670
+ target: "e1ultpe62"
12671
+ } : {
12672
+ target: "e1ultpe62",
12673
+ label: "LineItemContainer"
12674
+ })(process.env.NODE_ENV === "production" ? {
12675
+ name: "x9km8e",
12676
+ styles: "&+&{margin-top:16px;}"
12677
+ } : {
12678
+ name: "x9km8e",
12679
+ styles: "&+&{margin-top:16px;}",
12680
+ 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"]} */",
12681
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12682
+ });
12683
+ var NestedBreakdownContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
12534
12684
  target: "e1ultpe61"
12535
12685
  } : {
12536
12686
  target: "e1ultpe61",
12537
- label: "LineItemContainer"
12687
+ label: "NestedBreakdownContainer"
12538
12688
  })(process.env.NODE_ENV === "production" ? {
12539
- name: "rdmn2i",
12540
- styles: "&+&{margin-top:8px;}"
12689
+ name: "96yaa5",
12690
+ styles: "margin-top:16px;margin-left:16px"
12541
12691
  } : {
12542
- name: "rdmn2i",
12543
- styles: "&+&{margin-top:8px;}",
12544
- 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"]} */",
12692
+ name: "96yaa5",
12693
+ styles: "margin-top:16px;margin-left:16px",
12694
+ 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"]} */",
12545
12695
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12546
12696
  });
12547
12697
  var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
@@ -12550,40 +12700,17 @@ var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
12550
12700
  target: "e1ultpe60",
12551
12701
  label: "LineItemRow"
12552
12702
  })(process.env.NODE_ENV === "production" ? {
12553
- name: "bcffy2",
12554
- styles: "display:flex;align-items:center;justify-content:space-between"
12703
+ name: "153q11y",
12704
+ styles: "display:flex;align-items:center;justify-content:space-between;gap:16px"
12555
12705
  } : {
12556
- name: "bcffy2",
12557
- styles: "display:flex;align-items:center;justify-content:space-between",
12558
- 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"]} */",
12706
+ name: "153q11y",
12707
+ styles: "display:flex;align-items:center;justify-content:space-between;gap:16px",
12708
+ 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"]} */",
12559
12709
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12560
12710
  });
12561
- var getPriceString = function getPriceString(_ref) {
12562
- var amount = _ref.amount,
12563
- price = _ref.price,
12564
- quantity = _ref.quantity;
12565
- var billingPeriod = price.billingPeriod;
12566
- var billingPeriodString = null;
12567
-
12568
- if (quantity) {
12569
- amount /= quantity;
12570
- }
12571
-
12572
- if (billingPeriod === BillingPeriod.Annually) {
12573
- amount /= 12;
12574
- billingPeriodString = '12 months';
12575
- }
12576
-
12577
- var addonPriceFormat = currencyPriceFormatter({
12578
- amount: amount,
12579
- currency: price.currency,
12580
- minimumFractionDigits: 2
12581
- });
12582
- return "" + (quantity > 1 ? quantity + " x " + addonPriceFormat + " each" : addonPriceFormat) + (billingPeriodString ? " x " + billingPeriodString : '');
12583
- };
12584
12711
 
12585
- var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref2) {
12586
- var checkoutLocalization = _ref2.checkoutLocalization;
12712
+ var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref) {
12713
+ var checkoutLocalization = _ref.checkoutLocalization;
12587
12714
  var title = React__default.createElement(Typography, {
12588
12715
  variant: "body1"
12589
12716
  }, checkoutLocalization.summary.payAsYouGoTooltipText);
@@ -12598,19 +12725,47 @@ var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref2) {
12598
12725
  }));
12599
12726
  };
12600
12727
 
12601
- var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12602
- var checkoutLocalization = _ref3.checkoutLocalization,
12603
- label = _ref3.label,
12604
- quantity = _ref3.quantity,
12605
- price = _ref3.price;
12606
- var billingPeriod = price.billingPeriod;
12728
+ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
12729
+ var checkoutLocalization = _ref2.checkoutLocalization,
12730
+ label = _ref2.label,
12731
+ quantity = _ref2.quantity,
12732
+ price = _ref2.price;
12733
+
12734
+ var _useState = useState(false),
12735
+ isNestedBreakdownOpen = _useState[0],
12736
+ setIsNestedBreakdownOpen = _useState[1];
12737
+
12738
+ var toggleNestedBreakdown = function toggleNestedBreakdown() {
12739
+ return setIsNestedBreakdownOpen(function (prev) {
12740
+ return !prev;
12741
+ });
12742
+ };
12743
+
12607
12744
  var isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;
12608
- var amount;
12745
+ var totalAmount = price.isTieredPrice ? calculateTierPrice(price, quantity) : (price.amount || 0) * quantity;
12746
+ var nestedBreakdown;
12747
+ var shouldShowGraduatedPriceBreakdown = price.tiersMode === TiersMode.Graduated && !!price.tiers && !isEmpty(price.tiers) && !isNil(price.tiers[0].upTo) && quantity > price.tiers[0].upTo;
12748
+
12749
+ if (shouldShowGraduatedPriceBreakdown) {
12750
+ nestedBreakdown = React__default.createElement(GraduatedPriceBreakdown, {
12751
+ price: price,
12752
+ unitQuantity: quantity
12753
+ });
12754
+ }
12609
12755
 
12610
- if (price.isTieredPrice) {
12611
- amount = calculateTierPrice(price, quantity);
12612
- } else {
12613
- amount = price.amount * quantity;
12756
+ var title = React__default.createElement(Typography, {
12757
+ variant: "body1",
12758
+ color: "secondary"
12759
+ }, label);
12760
+
12761
+ if (nestedBreakdown) {
12762
+ title = React__default.createElement(Link, {
12763
+ onClick: toggleNestedBreakdown,
12764
+ underline: "none",
12765
+ style: {
12766
+ cursor: 'pointer'
12767
+ }
12768
+ }, title);
12614
12769
  }
12615
12770
 
12616
12771
  return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
@@ -12618,17 +12773,20 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12618
12773
  alignItems: 'flex-start'
12619
12774
  }
12620
12775
  }, React__default.createElement(Grid, {
12621
- item: true
12622
- }, React__default.createElement(Typography, {
12623
- variant: "body1",
12624
- color: "secondary"
12625
- }, label), (quantity > 1 || billingPeriod === BillingPeriod.Annually) && React__default.createElement(Typography, {
12626
- variant: "body1",
12627
- color: "secondary"
12628
- }, getPriceString({
12629
- amount: amount,
12630
- price: price,
12631
- quantity: quantity
12776
+ item: true,
12777
+ display: "flex",
12778
+ gap: 0.5,
12779
+ style: {
12780
+ whiteSpace: 'nowrap'
12781
+ }
12782
+ }, title, nestedBreakdown && React__default.createElement(IconButton, {
12783
+ onClick: toggleNestedBreakdown,
12784
+ sx: {
12785
+ padding: 0
12786
+ }
12787
+ }, React__default.createElement(CollapsableSectionIcon, {
12788
+ "$isOpen": isNestedBreakdownOpen,
12789
+ "$size": 16
12632
12790
  }))), React__default.createElement(Grid, {
12633
12791
  item: true,
12634
12792
  display: "flex",
@@ -12640,16 +12798,22 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12640
12798
  variant: "body1",
12641
12799
  color: "secondary",
12642
12800
  style: {
12643
- wordBreak: 'break-word'
12801
+ whiteSpace: 'nowrap'
12644
12802
  }
12645
- }, currencyPriceFormatter({
12646
- amount: amount,
12803
+ }, getPriceBreakdownString({
12804
+ totalAmount: totalAmount,
12805
+ quantity: quantity,
12647
12806
  currency: price.currency,
12648
- minimumFractionDigits: 2
12649
- }), isPayAsYouGo && ' / unit'))));
12807
+ pricingModel: price.pricingModel,
12808
+ billingPeriod: price.billingPeriod,
12809
+ tiers: price.tiers,
12810
+ tiersMode: price.tiersMode
12811
+ }), isPayAsYouGo && ' / unit'))), nestedBreakdown && React__default.createElement(Collapse, {
12812
+ "in": isNestedBreakdownOpen
12813
+ }, React__default.createElement(NestedBreakdownContainer, null, nestedBreakdown)));
12650
12814
  };
12651
- var FreeChargeLineItem = function FreeChargeLineItem(_ref4) {
12652
- var label = _ref4.label;
12815
+ var FreeChargeLineItem = function FreeChargeLineItem(_ref3) {
12816
+ var label = _ref3.label;
12653
12817
  return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
12654
12818
  style: {
12655
12819
  alignItems: 'flex-end'
@@ -12672,16 +12836,16 @@ var FreeChargeLineItem = function FreeChargeLineItem(_ref4) {
12672
12836
  }
12673
12837
  }, "Free"))));
12674
12838
  };
12675
- var DiscountLineItem = function DiscountLineItem(_ref5) {
12676
- var subscriptionPreview = _ref5.subscriptionPreview,
12677
- isFetchingSubscriptionPreview = _ref5.isFetchingSubscriptionPreview,
12678
- checkoutLocalization = _ref5.checkoutLocalization;
12839
+ var DiscountLineItem = function DiscountLineItem(_ref4) {
12840
+ var subscriptionPreview = _ref4.subscriptionPreview,
12841
+ isFetchingSubscriptionPreview = _ref4.isFetchingSubscriptionPreview,
12842
+ checkoutLocalization = _ref4.checkoutLocalization;
12679
12843
  var immediateInvoice = subscriptionPreview.immediateInvoice,
12680
12844
  recurringInvoice = subscriptionPreview.recurringInvoice;
12681
12845
 
12682
- var _ref6 = recurringInvoice || {},
12683
- discount = _ref6.discount,
12684
- discountDetails = _ref6.discountDetails;
12846
+ var _ref5 = recurringInvoice || {},
12847
+ discount = _ref5.discount,
12848
+ discountDetails = _ref5.discountDetails;
12685
12849
 
12686
12850
  if (!discount || !discountDetails) {
12687
12851
  return null;
@@ -12705,16 +12869,16 @@ var DiscountLineItem = function DiscountLineItem(_ref5) {
12705
12869
  minimumFractionDigits: 2
12706
12870
  }))));
12707
12871
  };
12708
- var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref7) {
12709
- var subscriptionPreview = _ref7.subscriptionPreview,
12710
- isFetchingSubscriptionPreview = _ref7.isFetchingSubscriptionPreview,
12711
- checkoutLocalization = _ref7.checkoutLocalization;
12872
+ var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref6) {
12873
+ var subscriptionPreview = _ref6.subscriptionPreview,
12874
+ isFetchingSubscriptionPreview = _ref6.isFetchingSubscriptionPreview,
12875
+ checkoutLocalization = _ref6.checkoutLocalization;
12712
12876
 
12713
- var _ref8 = subscriptionPreview || {},
12714
- immediateInvoice = _ref8.immediateInvoice;
12877
+ var _ref7 = subscriptionPreview || {},
12878
+ immediateInvoice = _ref7.immediateInvoice;
12715
12879
 
12716
- var _ref9 = immediateInvoice || {},
12717
- credits = _ref9.credits;
12880
+ var _ref8 = immediateInvoice || {},
12881
+ credits = _ref8.credits;
12718
12882
 
12719
12883
  if (!credits || !credits.used || credits.used.amount <= 0) {
12720
12884
  return null;
@@ -12734,11 +12898,11 @@ var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref7) {
12734
12898
  minimumFractionDigits: 2
12735
12899
  })))));
12736
12900
  };
12737
- var TaxLineItem = function TaxLineItem(_ref10) {
12738
- var tax = _ref10.tax,
12739
- taxDetails = _ref10.taxDetails,
12740
- isFetchingSubscriptionPreview = _ref10.isFetchingSubscriptionPreview,
12741
- checkoutLocalization = _ref10.checkoutLocalization;
12901
+ var TaxLineItem = function TaxLineItem(_ref9) {
12902
+ var tax = _ref9.tax,
12903
+ taxDetails = _ref9.taxDetails,
12904
+ isFetchingSubscriptionPreview = _ref9.isFetchingSubscriptionPreview,
12905
+ checkoutLocalization = _ref9.checkoutLocalization;
12742
12906
 
12743
12907
  if (!taxDetails || !tax || (tax == null ? void 0 : tax.amount) <= 0) {
12744
12908
  return null;
@@ -13536,12 +13700,12 @@ function CheckoutAddonsStep() {
13536
13700
  }));
13537
13701
  }
13538
13702
 
13539
- var _templateObject$6, _templateObject2$2, _templateObject3$2, _templateObject4;
13703
+ var _templateObject$7, _templateObject2$2, _templateObject3$2, _templateObject4;
13540
13704
  var PaymentMethodContainer = /*#__PURE__*/styled(Grid, {
13541
13705
  shouldForwardProp: function shouldForwardProp(prop) {
13542
13706
  return !prop.startsWith('$');
13543
13707
  }
13544
- })(_templateObject$6 || (_templateObject$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding: 8px;\n border-radius: 10px;\n border: 1px solid ", ";\n cursor: ", ";\n opacity: ", ";\n"])), function (_ref) {
13708
+ })(_templateObject$7 || (_templateObject$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding: 8px;\n border-radius: 10px;\n border: 1px solid ", ";\n cursor: ", ";\n opacity: ", ";\n"])), function (_ref) {
13545
13709
  var theme = _ref.theme;
13546
13710
  return theme.stigg.palette.outlinedBorder;
13547
13711
  }, function (_ref2) {
@@ -13633,8 +13797,8 @@ function NewPaymentMethod(_ref3) {
13633
13797
  })));
13634
13798
  }
13635
13799
 
13636
- var _templateObject$7;
13637
- var PaymentContainer = /*#__PURE__*/styled(Grid)(_templateObject$7 || (_templateObject$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n gap: 24px;\n"])));
13800
+ var _templateObject$8;
13801
+ var PaymentContainer = /*#__PURE__*/styled(Grid)(_templateObject$8 || (_templateObject$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n gap: 24px;\n"])));
13638
13802
  function PaymentStep(_ref) {
13639
13803
  var onBillingAddressChange = _ref.onBillingAddressChange,
13640
13804
  collectPhoneNumber = _ref.collectPhoneNumber;
@@ -13929,8 +14093,8 @@ function BillingPeriodPicker$1(_ref2) {
13929
14093
  })));
13930
14094
  }
13931
14095
 
13932
- var _templateObject$8;
13933
- 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"])));
14096
+ var _templateObject$9;
14097
+ 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"])));
13934
14098
 
13935
14099
  var getValidationText = function getValidationText(charge, quantity) {
13936
14100
  var minUnitQuantity = charge.minUnitQuantity,