@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.
- package/dist/components/checkout/summary/components/GraduatedPriceBreakdown.d.ts +7 -0
- package/dist/components/checkout/summary/components/LineItems.d.ts +4 -5
- package/dist/components/checkout/summary/components/getPriceBreakdownString.d.ts +12 -0
- package/dist/components/common/CollapsableSectionIcon.d.ts +5 -0
- package/dist/components/common/Typography.d.ts +2 -2
- package/dist/components/utils/numberUtils.d.ts +3 -0
- package/dist/components/utils/priceTierUtils.d.ts +2 -0
- package/dist/react-sdk.cjs.development.js +248 -89
- package/dist/react-sdk.cjs.development.js.map +1 -1
- package/dist/react-sdk.cjs.production.min.js +1 -1
- package/dist/react-sdk.cjs.production.min.js.map +1 -1
- package/dist/react-sdk.esm.js +258 -94
- package/dist/react-sdk.esm.js.map +1 -1
- package/dist/theme/getResolvedTheme.d.ts +1 -0
- package/dist/theme/types.d.ts +1 -0
- package/package.json +1 -1
- package/src/components/checkout/summary/components/GraduatedPriceBreakdown.tsx +66 -0
- package/src/components/checkout/summary/components/LineItems.tsx +65 -42
- package/src/components/checkout/summary/components/getPriceBreakdownString.ts +56 -0
- package/src/components/common/CollapsableSectionIcon.tsx +9 -0
- package/src/components/common/Typography.tsx +1 -0
- package/src/components/utils/numberUtils.ts +3 -0
- package/src/components/utils/priceTierUtils.ts +8 -0
- package/src/theme/getResolvedTheme.ts +2 -1
- package/src/theme/types.ts +1 -0
|
@@ -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
|
|
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
|
-
|
|
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: "
|
|
12321
|
+
target: "e1ultpe62",
|
|
12186
12322
|
label: "LineItemContainer"
|
|
12187
12323
|
})( {
|
|
12188
|
-
name: "
|
|
12189
|
-
styles: "&+&{margin-top:
|
|
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: "
|
|
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(
|
|
12227
|
-
var 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(
|
|
12243
|
-
var checkoutLocalization =
|
|
12244
|
-
label =
|
|
12245
|
-
quantity =
|
|
12246
|
-
price =
|
|
12247
|
-
|
|
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
|
-
|
|
12252
|
-
|
|
12253
|
-
|
|
12254
|
-
|
|
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
|
-
|
|
12264
|
-
|
|
12265
|
-
|
|
12266
|
-
|
|
12267
|
-
|
|
12268
|
-
|
|
12269
|
-
|
|
12270
|
-
|
|
12271
|
-
|
|
12272
|
-
|
|
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
|
-
|
|
12437
|
+
whiteSpace: 'nowrap'
|
|
12285
12438
|
}
|
|
12286
|
-
},
|
|
12287
|
-
|
|
12439
|
+
}, getPriceBreakdownString({
|
|
12440
|
+
totalAmount: totalAmount,
|
|
12441
|
+
quantity: quantity,
|
|
12288
12442
|
currency: price.currency,
|
|
12289
|
-
|
|
12290
|
-
|
|
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(
|
|
12293
|
-
var 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(
|
|
12317
|
-
var subscriptionPreview =
|
|
12318
|
-
isFetchingSubscriptionPreview =
|
|
12319
|
-
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
|
|
12324
|
-
discount =
|
|
12325
|
-
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(
|
|
12350
|
-
var subscriptionPreview =
|
|
12351
|
-
isFetchingSubscriptionPreview =
|
|
12352
|
-
checkoutLocalization =
|
|
12508
|
+
var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref6) {
|
|
12509
|
+
var subscriptionPreview = _ref6.subscriptionPreview,
|
|
12510
|
+
isFetchingSubscriptionPreview = _ref6.isFetchingSubscriptionPreview,
|
|
12511
|
+
checkoutLocalization = _ref6.checkoutLocalization;
|
|
12353
12512
|
|
|
12354
|
-
var
|
|
12355
|
-
immediateInvoice =
|
|
12513
|
+
var _ref7 = subscriptionPreview || {},
|
|
12514
|
+
immediateInvoice = _ref7.immediateInvoice;
|
|
12356
12515
|
|
|
12357
|
-
var
|
|
12358
|
-
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(
|
|
12379
|
-
var tax =
|
|
12380
|
-
taxDetails =
|
|
12381
|
-
isFetchingSubscriptionPreview =
|
|
12382
|
-
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$
|
|
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$
|
|
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$
|
|
13241
|
-
var PaymentContainer = /*#__PURE__*/styled(Grid)(_templateObject$
|
|
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$
|
|
13497
|
-
var StyledPlanCharge = /*#__PURE__*/styled.div(_templateObject$
|
|
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,
|