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