@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.
@@ -62,8 +62,9 @@ var CircularProgress = _interopDefault(require('@mui/material/CircularProgress')
62
62
  var Paper = _interopDefault(require('@mui/material/Paper'));
63
63
  var stripeJs = require('@stripe/stripe-js');
64
64
  var Lottie = _interopDefault(require('lottie-react'));
65
- var Alert = _interopDefault(require('@mui/material/Alert'));
65
+ var material = require('@mui/material');
66
66
  var Collapse = _interopDefault(require('@mui/material/Collapse'));
67
+ var Alert = _interopDefault(require('@mui/material/Alert'));
67
68
  var Radio = _interopDefault(require('@mui/material/Radio'));
68
69
  require('@mui/material/Chip');
69
70
 
@@ -589,7 +590,8 @@ var getResolvedTheme = function getResolvedTheme(customizedTheme) {
589
590
  text: {
590
591
  primary: textColor.hex(),
591
592
  secondary: textColor.alpha(0.75).toString(),
592
- disabled: textColor.alpha(0.5).toString()
593
+ tertiary: textColor.alpha(0.5).toString(),
594
+ disabled: textColor.alpha(0.35).toString()
593
595
  }
594
596
  },
595
597
  layout: {
@@ -832,6 +834,16 @@ function hasTierWithUnitPrice(tiers) {
832
834
  return unitPrice && !isNil(upTo);
833
835
  });
834
836
  }
837
+ function isBulkTiers(tiers) {
838
+ return tiers == null ? void 0 : tiers.every(function (_ref3) {
839
+ var unitPrice = _ref3.unitPrice,
840
+ upTo = _ref3.upTo;
841
+ return !unitPrice || isNil(upTo);
842
+ });
843
+ }
844
+ function isQuantityInFirstTier(tiers, quantity) {
845
+ return (tiers == null ? void 0 : tiers[0].upTo) && quantity <= tiers[0].upTo;
846
+ }
835
847
  function getTiersPerUnitQuantities(plan, billingPeriod, currentSubscription, selectDefaultTierIndex) {
836
848
  var planTierPrices = plan.pricePoints.filter(function (price) {
837
849
  return price.billingPeriod === billingPeriod && price.isTieredPrice;
@@ -12180,51 +12192,161 @@ function CheckoutCaptions(props) {
12180
12192
  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)));
12181
12193
  }
12182
12194
 
12195
+ function numberFormatter(number, _temp) {
12196
+ var _ref = _temp === void 0 ? {} : _temp,
12197
+ locate = _ref.locate;
12198
+
12199
+ return new Intl.NumberFormat(locate).format(number);
12200
+ }
12201
+
12202
+ function formatPricePerUnit(_ref) {
12203
+ var quantity = _ref.quantity,
12204
+ totalAmount = _ref.totalAmount,
12205
+ pricingModel = _ref.pricingModel,
12206
+ billingPeriod = _ref.billingPeriod,
12207
+ currency = _ref.currency;
12208
+ var isPerUnit = pricingModel === Stigg.BillingModel.PerUnit;
12209
+ var featureUnits = quantity && (isPerUnit || quantity > 1) ? numberFormatter(quantity) + " x " : '';
12210
+ var billingPeriodString = billingPeriod === Stigg.BillingPeriod.Annually ? ' x 12 months' : '';
12211
+ var unitPrice = totalAmount / quantity / (billingPeriod === Stigg.BillingPeriod.Annually ? 12 : 1);
12212
+ var formattedUnitPrice = currencyPriceFormatter({
12213
+ amount: unitPrice,
12214
+ currency: currency,
12215
+ minimumFractionDigits: 2
12216
+ });
12217
+ var formattedTotalPrice = currencyPriceFormatter({
12218
+ amount: totalAmount,
12219
+ currency: currency,
12220
+ minimumFractionDigits: 2
12221
+ });
12222
+ return "" + featureUnits + formattedUnitPrice + billingPeriodString + " " + (billingPeriodString || featureUnits ? " = " + formattedTotalPrice : '');
12223
+ }
12224
+ function getPriceBreakdownString(params) {
12225
+ var totalAmount = params.totalAmount,
12226
+ quantity = params.quantity,
12227
+ tiersMode = params.tiersMode,
12228
+ tiers = params.tiers,
12229
+ currency = params.currency;
12230
+
12231
+ if (isBulkTiers(tiers) || tiersMode === Stigg.TiersMode.Graduated && !isQuantityInFirstTier(tiers, quantity)) {
12232
+ var formattedTotalPrice = currencyPriceFormatter({
12233
+ amount: totalAmount,
12234
+ currency: currency,
12235
+ minimumFractionDigits: 2
12236
+ });
12237
+ return numberFormatter(quantity) + " for " + formattedTotalPrice;
12238
+ }
12239
+
12240
+ return formatPricePerUnit(params);
12241
+ }
12242
+
12243
+ function getLabel(tiers, index) {
12244
+ var _tiers$index = tiers[index],
12245
+ unitPrice = _tiers$index.unitPrice,
12246
+ upTo = _tiers$index.upTo;
12247
+
12248
+ if (!unitPrice) {
12249
+ return '';
12250
+ }
12251
+
12252
+ if (index === 0) {
12253
+ return "First " + upTo;
12254
+ }
12255
+
12256
+ var previousTierUpTo = tiers[index - 1].upTo || 0;
12257
+ var startUnit = previousTierUpTo + 1;
12258
+ return isNil(upTo) ? numberFormatter(startUnit) + " and above" : "Next " + numberFormatter(startUnit) + " to " + numberFormatter(upTo);
12259
+ }
12260
+
12261
+ function GraduatedPriceBreakdown(_ref) {
12262
+ var price = _ref.price,
12263
+ unitQuantity = _ref.unitQuantity;
12264
+ var tiers = price.tiers || [];
12265
+
12266
+ var _calculateTierPriceGr = calculateTierPriceGraduated(tiers, unitQuantity),
12267
+ breakdown = _calculateTierPriceGr.breakdown;
12268
+
12269
+ if (breakdown.length === 1) {
12270
+ return null;
12271
+ }
12272
+
12273
+ return React__default.createElement(React__default.Fragment, null, breakdown.map(function (_ref2, index) {
12274
+ var unitQuantity = _ref2.unitQuantity,
12275
+ amount = _ref2.amount;
12276
+ return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
12277
+ key: index,
12278
+ style: {
12279
+ alignItems: 'flex-start'
12280
+ }
12281
+ }, React__default.createElement(Typography, {
12282
+ variant: "body1",
12283
+ color: "tertiary",
12284
+ style: {
12285
+ whiteSpace: 'nowrap'
12286
+ }
12287
+ }, getLabel(tiers, index)), React__default.createElement(Typography, {
12288
+ variant: "body1",
12289
+ color: "tertiary",
12290
+ style: {
12291
+ whiteSpace: 'nowrap'
12292
+ }
12293
+ }, formatPricePerUnit({
12294
+ quantity: unitQuantity,
12295
+ totalAmount: amount,
12296
+ currency: price.currency,
12297
+ pricingModel: price.pricingModel,
12298
+ billingPeriod: price.billingPeriod,
12299
+ tiers: price.tiers,
12300
+ tiersMode: price.tiersMode
12301
+ }))));
12302
+ }));
12303
+ }
12304
+
12305
+ var _templateObject$6;
12306
+ var CollapsableSectionIcon = /*#__PURE__*/styled$1__default(reactFeather.ChevronRight)(_templateObject$6 || (_templateObject$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n height: ", ";\n width: ", ";\n transition: all 0.2s ease-in;\n ", "\n"])), function (_ref) {
12307
+ var _ref$$size = _ref.$size,
12308
+ $size = _ref$$size === void 0 ? 24 : _ref$$size;
12309
+ return $size + "px";
12310
+ }, function (_ref2) {
12311
+ var _ref2$$size = _ref2.$size,
12312
+ $size = _ref2$$size === void 0 ? 24 : _ref2$$size;
12313
+ return $size + "px";
12314
+ }, function (_ref3) {
12315
+ var $isOpen = _ref3.$isOpen;
12316
+ return $isOpen && "transform: rotate(90deg)";
12317
+ });
12318
+
12183
12319
  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)."; }
12184
12320
  var LineItemContainer = /*#__PURE__*/_styled("div", {
12185
- target: "e1ultpe61",
12321
+ target: "e1ultpe62",
12186
12322
  label: "LineItemContainer"
12187
12323
  })( {
12188
- name: "rdmn2i",
12189
- styles: "&+&{margin-top:8px;}",
12190
- 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"]} */",
12324
+ name: "x9km8e",
12325
+ styles: "&+&{margin-top:16px;}",
12326
+ 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"]} */",
12327
+ toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12328
+ });
12329
+ var NestedBreakdownContainer = /*#__PURE__*/_styled("div", {
12330
+ target: "e1ultpe61",
12331
+ label: "NestedBreakdownContainer"
12332
+ })( {
12333
+ name: "96yaa5",
12334
+ styles: "margin-top:16px;margin-left:16px",
12335
+ 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"]} */",
12191
12336
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12192
12337
  });
12193
12338
  var LineItemRow = /*#__PURE__*/_styled("div", {
12194
12339
  target: "e1ultpe60",
12195
12340
  label: "LineItemRow"
12196
12341
  })( {
12197
- name: "bcffy2",
12198
- styles: "display:flex;align-items:center;justify-content:space-between",
12199
- 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"]} */",
12342
+ name: "153q11y",
12343
+ styles: "display:flex;align-items:center;justify-content:space-between;gap:16px",
12344
+ 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"]} */",
12200
12345
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12201
12346
  });
12202
- var getPriceString = function getPriceString(_ref) {
12203
- var amount = _ref.amount,
12204
- price = _ref.price,
12205
- quantity = _ref.quantity;
12206
- var billingPeriod = price.billingPeriod;
12207
- var billingPeriodString = null;
12208
-
12209
- if (quantity) {
12210
- amount /= quantity;
12211
- }
12212
-
12213
- if (billingPeriod === Stigg.BillingPeriod.Annually) {
12214
- amount /= 12;
12215
- billingPeriodString = '12 months';
12216
- }
12217
-
12218
- var addonPriceFormat = currencyPriceFormatter({
12219
- amount: amount,
12220
- currency: price.currency,
12221
- minimumFractionDigits: 2
12222
- });
12223
- return "" + (quantity > 1 ? quantity + " x " + addonPriceFormat + " each" : addonPriceFormat) + (billingPeriodString ? " x " + billingPeriodString : '');
12224
- };
12225
12347
 
12226
- var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref2) {
12227
- var checkoutLocalization = _ref2.checkoutLocalization;
12348
+ var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref) {
12349
+ var checkoutLocalization = _ref.checkoutLocalization;
12228
12350
  var title = React__default.createElement(Typography, {
12229
12351
  variant: "body1"
12230
12352
  }, checkoutLocalization.summary.payAsYouGoTooltipText);
@@ -12239,19 +12361,47 @@ var PayAsYouGoPriceTooltip = function PayAsYouGoPriceTooltip(_ref2) {
12239
12361
  }));
12240
12362
  };
12241
12363
 
12242
- var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12243
- var checkoutLocalization = _ref3.checkoutLocalization,
12244
- label = _ref3.label,
12245
- quantity = _ref3.quantity,
12246
- price = _ref3.price;
12247
- var billingPeriod = price.billingPeriod;
12364
+ var BilledPriceLineItem = function BilledPriceLineItem(_ref2) {
12365
+ var checkoutLocalization = _ref2.checkoutLocalization,
12366
+ label = _ref2.label,
12367
+ quantity = _ref2.quantity,
12368
+ price = _ref2.price;
12369
+
12370
+ var _useState = React.useState(false),
12371
+ isNestedBreakdownOpen = _useState[0],
12372
+ setIsNestedBreakdownOpen = _useState[1];
12373
+
12374
+ var toggleNestedBreakdown = function toggleNestedBreakdown() {
12375
+ return setIsNestedBreakdownOpen(function (prev) {
12376
+ return !prev;
12377
+ });
12378
+ };
12379
+
12248
12380
  var isPayAsYouGo = price.pricingModel === Stigg.BillingModel.UsageBased;
12249
- var amount;
12381
+ var totalAmount = price.isTieredPrice ? calculateTierPrice(price, quantity) : (price.amount || 0) * quantity;
12382
+ var nestedBreakdown;
12383
+ var shouldShowGraduatedPriceBreakdown = price.tiersMode === Stigg.TiersMode.Graduated && !!price.tiers && !isEmpty(price.tiers) && !isNil(price.tiers[0].upTo) && quantity > price.tiers[0].upTo;
12384
+
12385
+ if (shouldShowGraduatedPriceBreakdown) {
12386
+ nestedBreakdown = React__default.createElement(GraduatedPriceBreakdown, {
12387
+ price: price,
12388
+ unitQuantity: quantity
12389
+ });
12390
+ }
12250
12391
 
12251
- if (price.isTieredPrice) {
12252
- amount = calculateTierPrice(price, quantity);
12253
- } else {
12254
- amount = price.amount * quantity;
12392
+ var title = React__default.createElement(Typography, {
12393
+ variant: "body1",
12394
+ color: "secondary"
12395
+ }, label);
12396
+
12397
+ if (nestedBreakdown) {
12398
+ title = React__default.createElement(Link, {
12399
+ onClick: toggleNestedBreakdown,
12400
+ underline: "none",
12401
+ style: {
12402
+ cursor: 'pointer'
12403
+ }
12404
+ }, title);
12255
12405
  }
12256
12406
 
12257
12407
  return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
@@ -12259,17 +12409,20 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12259
12409
  alignItems: 'flex-start'
12260
12410
  }
12261
12411
  }, React__default.createElement(Grid, {
12262
- item: true
12263
- }, React__default.createElement(Typography, {
12264
- variant: "body1",
12265
- color: "secondary"
12266
- }, label), (quantity > 1 || billingPeriod === Stigg.BillingPeriod.Annually) && React__default.createElement(Typography, {
12267
- variant: "body1",
12268
- color: "secondary"
12269
- }, getPriceString({
12270
- amount: amount,
12271
- price: price,
12272
- quantity: quantity
12412
+ item: true,
12413
+ display: "flex",
12414
+ gap: 0.5,
12415
+ style: {
12416
+ whiteSpace: 'nowrap'
12417
+ }
12418
+ }, title, nestedBreakdown && React__default.createElement(material.IconButton, {
12419
+ onClick: toggleNestedBreakdown,
12420
+ sx: {
12421
+ padding: 0
12422
+ }
12423
+ }, React__default.createElement(CollapsableSectionIcon, {
12424
+ "$isOpen": isNestedBreakdownOpen,
12425
+ "$size": 16
12273
12426
  }))), React__default.createElement(Grid, {
12274
12427
  item: true,
12275
12428
  display: "flex",
@@ -12281,16 +12434,22 @@ var BilledPriceLineItem = function BilledPriceLineItem(_ref3) {
12281
12434
  variant: "body1",
12282
12435
  color: "secondary",
12283
12436
  style: {
12284
- wordBreak: 'break-word'
12437
+ whiteSpace: 'nowrap'
12285
12438
  }
12286
- }, currencyPriceFormatter({
12287
- amount: amount,
12439
+ }, getPriceBreakdownString({
12440
+ totalAmount: totalAmount,
12441
+ quantity: quantity,
12288
12442
  currency: price.currency,
12289
- minimumFractionDigits: 2
12290
- }), isPayAsYouGo && ' / unit'))));
12443
+ pricingModel: price.pricingModel,
12444
+ billingPeriod: price.billingPeriod,
12445
+ tiers: price.tiers,
12446
+ tiersMode: price.tiersMode
12447
+ }), isPayAsYouGo && ' / unit'))), nestedBreakdown && React__default.createElement(Collapse, {
12448
+ "in": isNestedBreakdownOpen
12449
+ }, React__default.createElement(NestedBreakdownContainer, null, nestedBreakdown)));
12291
12450
  };
12292
- var FreeChargeLineItem = function FreeChargeLineItem(_ref4) {
12293
- var label = _ref4.label;
12451
+ var FreeChargeLineItem = function FreeChargeLineItem(_ref3) {
12452
+ var label = _ref3.label;
12294
12453
  return React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, {
12295
12454
  style: {
12296
12455
  alignItems: 'flex-end'
@@ -12313,16 +12472,16 @@ var FreeChargeLineItem = function FreeChargeLineItem(_ref4) {
12313
12472
  }
12314
12473
  }, "Free"))));
12315
12474
  };
12316
- var DiscountLineItem = function DiscountLineItem(_ref5) {
12317
- var subscriptionPreview = _ref5.subscriptionPreview,
12318
- isFetchingSubscriptionPreview = _ref5.isFetchingSubscriptionPreview,
12319
- checkoutLocalization = _ref5.checkoutLocalization;
12475
+ var DiscountLineItem = function DiscountLineItem(_ref4) {
12476
+ var subscriptionPreview = _ref4.subscriptionPreview,
12477
+ isFetchingSubscriptionPreview = _ref4.isFetchingSubscriptionPreview,
12478
+ checkoutLocalization = _ref4.checkoutLocalization;
12320
12479
  var immediateInvoice = subscriptionPreview.immediateInvoice,
12321
12480
  recurringInvoice = subscriptionPreview.recurringInvoice;
12322
12481
 
12323
- var _ref6 = recurringInvoice || {},
12324
- discount = _ref6.discount,
12325
- discountDetails = _ref6.discountDetails;
12482
+ var _ref5 = recurringInvoice || {},
12483
+ discount = _ref5.discount,
12484
+ discountDetails = _ref5.discountDetails;
12326
12485
 
12327
12486
  if (!discount || !discountDetails) {
12328
12487
  return null;
@@ -12346,16 +12505,16 @@ var DiscountLineItem = function DiscountLineItem(_ref5) {
12346
12505
  minimumFractionDigits: 2
12347
12506
  }))));
12348
12507
  };
12349
- var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref7) {
12350
- var subscriptionPreview = _ref7.subscriptionPreview,
12351
- isFetchingSubscriptionPreview = _ref7.isFetchingSubscriptionPreview,
12352
- checkoutLocalization = _ref7.checkoutLocalization;
12508
+ var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref6) {
12509
+ var subscriptionPreview = _ref6.subscriptionPreview,
12510
+ isFetchingSubscriptionPreview = _ref6.isFetchingSubscriptionPreview,
12511
+ checkoutLocalization = _ref6.checkoutLocalization;
12353
12512
 
12354
- var _ref8 = subscriptionPreview || {},
12355
- immediateInvoice = _ref8.immediateInvoice;
12513
+ var _ref7 = subscriptionPreview || {},
12514
+ immediateInvoice = _ref7.immediateInvoice;
12356
12515
 
12357
- var _ref9 = immediateInvoice || {},
12358
- credits = _ref9.credits;
12516
+ var _ref8 = immediateInvoice || {},
12517
+ credits = _ref8.credits;
12359
12518
 
12360
12519
  if (!credits || !credits.used || credits.used.amount <= 0) {
12361
12520
  return null;
@@ -12375,11 +12534,11 @@ var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref7) {
12375
12534
  minimumFractionDigits: 2
12376
12535
  })))));
12377
12536
  };
12378
- var TaxLineItem = function TaxLineItem(_ref10) {
12379
- var tax = _ref10.tax,
12380
- taxDetails = _ref10.taxDetails,
12381
- isFetchingSubscriptionPreview = _ref10.isFetchingSubscriptionPreview,
12382
- checkoutLocalization = _ref10.checkoutLocalization;
12537
+ var TaxLineItem = function TaxLineItem(_ref9) {
12538
+ var tax = _ref9.tax,
12539
+ taxDetails = _ref9.taxDetails,
12540
+ isFetchingSubscriptionPreview = _ref9.isFetchingSubscriptionPreview,
12541
+ checkoutLocalization = _ref9.checkoutLocalization;
12383
12542
 
12384
12543
  if (!taxDetails || !tax || (tax == null ? void 0 : tax.amount) <= 0) {
12385
12544
  return null;
@@ -13140,12 +13299,12 @@ function CheckoutAddonsStep() {
13140
13299
  }));
13141
13300
  }
13142
13301
 
13143
- var _templateObject$6, _templateObject2$2, _templateObject3$2, _templateObject4;
13302
+ var _templateObject$7, _templateObject2$2, _templateObject3$2, _templateObject4;
13144
13303
  var PaymentMethodContainer = /*#__PURE__*/styled(Grid, {
13145
13304
  shouldForwardProp: function shouldForwardProp(prop) {
13146
13305
  return !prop.startsWith('$');
13147
13306
  }
13148
- })(_templateObject$6 || (_templateObject$6 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding: 8px;\n border-radius: 10px;\n border: 1px solid ", ";\n cursor: ", ";\n opacity: ", ";\n"])), function (_ref) {
13307
+ })(_templateObject$7 || (_templateObject$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n padding: 8px;\n border-radius: 10px;\n border: 1px solid ", ";\n cursor: ", ";\n opacity: ", ";\n"])), function (_ref) {
13149
13308
  var theme = _ref.theme;
13150
13309
  return theme.stigg.palette.outlinedBorder;
13151
13310
  }, function (_ref2) {
@@ -13237,8 +13396,8 @@ function NewPaymentMethod(_ref3) {
13237
13396
  })));
13238
13397
  }
13239
13398
 
13240
- var _templateObject$7;
13241
- var PaymentContainer = /*#__PURE__*/styled(Grid)(_templateObject$7 || (_templateObject$7 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n gap: 24px;\n"])));
13399
+ var _templateObject$8;
13400
+ var PaymentContainer = /*#__PURE__*/styled(Grid)(_templateObject$8 || (_templateObject$8 = /*#__PURE__*/_taggedTemplateLiteralLoose(["\n display: flex;\n flex-direction: column;\n gap: 24px;\n"])));
13242
13401
  function PaymentStep(_ref) {
13243
13402
  var onBillingAddressChange = _ref.onBillingAddressChange,
13244
13403
  collectPhoneNumber = _ref.collectPhoneNumber;
@@ -13493,8 +13652,8 @@ function BillingPeriodPicker$1(_ref2) {
13493
13652
  })));
13494
13653
  }
13495
13654
 
13496
- var _templateObject$8;
13497
- 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"])));
13655
+ var _templateObject$9;
13656
+ 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"])));
13498
13657
 
13499
13658
  var getValidationText = function getValidationText(charge, quantity) {
13500
13659
  var minUnitQuantity = charge.minUnitQuantity,