@stigg/react-sdk 4.4.4 → 4.4.6
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/CheckoutProvider.d.ts +2 -2
- package/dist/components/checkout/components/ChangePlanButton.d.ts +1 -1
- package/dist/components/checkout/components/DowngradeToFreeContainer.d.ts +1 -1
- package/dist/components/checkout/{textOverrides.d.ts → configurations/textOverrides.d.ts} +1 -1
- package/dist/components/checkout/{theme.d.ts → configurations/theme.d.ts} +2 -2
- package/dist/components/checkout/configurations/typography.d.ts +2 -0
- package/dist/components/checkout/index.d.ts +2 -2
- package/dist/components/checkout/promotionCode/AddPromotionCodeButton.d.ts +1 -1
- package/dist/components/checkout/promotionCode/PromotionCodeSection.d.ts +1 -1
- package/dist/components/checkout/steps/payment/PaymentMethods.d.ts +1 -1
- package/dist/components/checkout/steps/plan/BillingPeriodPicker.d.ts +1 -1
- package/dist/components/checkout/summary/CheckoutSuccess.d.ts +1 -1
- package/dist/components/checkout/summary/components/CheckoutCaptions.d.ts +1 -1
- package/dist/components/checkout/summary/components/LineItems.d.ts +1 -1
- package/dist/components/common/TiersSelectContainer.d.ts +2 -1
- package/dist/components/common/mapExternalTheme.d.ts +2 -1
- package/dist/components/paywall/PlanPrice.d.ts +2 -2
- package/dist/react-sdk.cjs.development.js +70 -51
- 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 +70 -51
- package/dist/react-sdk.esm.js.map +1 -1
- package/package.json +1 -1
- package/src/components/checkout/CheckoutProvider.tsx +6 -5
- package/src/components/checkout/components/ChangePlanButton.tsx +4 -4
- package/src/components/checkout/components/DowngradeToFreeContainer.tsx +1 -1
- package/src/components/checkout/{textOverrides.ts → configurations/textOverrides.ts} +2 -2
- package/src/components/checkout/{theme.ts → configurations/theme.ts} +2 -2
- package/src/components/checkout/configurations/typography.ts +20 -0
- package/src/components/checkout/index.ts +2 -2
- package/src/components/checkout/planHeader/PlanHeader.tsx +1 -3
- package/src/components/checkout/promotionCode/AddPromotionCodeButton.tsx +3 -2
- package/src/components/checkout/promotionCode/PromotionCodeSection.tsx +1 -1
- package/src/components/checkout/steps/addons/CheckoutAddonsStep.tsx +1 -1
- package/src/components/checkout/steps/payment/PaymentMethods.tsx +1 -1
- package/src/components/checkout/steps/plan/BillingPeriodPicker.tsx +2 -2
- package/src/components/checkout/summary/CheckoutSuccess.tsx +1 -1
- package/src/components/checkout/summary/CheckoutSummary.tsx +10 -6
- package/src/components/checkout/summary/components/CheckoutCaptions.tsx +2 -2
- package/src/components/checkout/summary/components/LineItems.tsx +1 -1
- package/src/components/common/TiersSelectContainer.tsx +3 -1
- package/src/components/common/mapExternalTheme.ts +14 -10
- package/src/components/paywall/PlanPrice.tsx +12 -17
package/dist/react-sdk.esm.js
CHANGED
|
@@ -1210,7 +1210,7 @@ var TierSelect = /*#__PURE__*/_styled(Select, process.env.NODE_ENV === "producti
|
|
|
1210
1210
|
})("border-radius:10px;min-height:42px;min-width:120px;&:hover .MuiOutlinedInput-notchedOutline{border-color:", function (_ref) {
|
|
1211
1211
|
var theme = _ref.theme;
|
|
1212
1212
|
return theme.stigg.palette.outlinedBorder;
|
|
1213
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzU2VsZWN0Q29udGFpbmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNa0MiLCJmaWxlIjoiVGllcnNTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWVudUl0ZW0sIE91dGxpbmVkSW5wdXQsIFNlbGVjdCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdsb2Rhc2gnO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IGdldFRpZXJCeVF1YW50aXR5IH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi9UeXBvZ3JhcGh5JztcclxuY29uc3QgVGllclNlbGVjdCA9IHN0eWxlZChTZWxlY3QpIGBcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgbWluLWhlaWdodDogNDJweDtcbiAgbWluLXdpZHRoOiAxMjBweDtcblxuICAmOmhvdmVyIC5NdWlPdXRsaW5lZElucHV0LW5vdGNoZWRPdXRsaW5lIHtcbiAgICBib3JkZXItY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn07XG4gIH1cbmA7XHJcbmNvbnN0IFRpZXJJbnB1dCA9IHN0eWxlZChPdXRsaW5lZElucHV0KSBgXG4gICYgLk11aUlucHV0QmFzZS1pbnB1dCB7XG4gICAgcGFkZGluZzogMTBweCAxMnB4O1xuICB9XG5cbiAgJi5NdWktZm9jdXNlZCAuTXVpT3V0bGluZWRJbnB1dC1ub3RjaGVkT3V0bGluZSB7XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+
|
|
1213
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzU2VsZWN0Q29udGFpbmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFNa0MiLCJmaWxlIjoiVGllcnNTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWVudUl0ZW0sIE91dGxpbmVkSW5wdXQsIFNlbGVjdCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdsb2Rhc2gnO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IGdldFRpZXJCeVF1YW50aXR5IH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi9UeXBvZ3JhcGh5JztcclxuY29uc3QgVGllclNlbGVjdCA9IHN0eWxlZChTZWxlY3QpIGBcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgbWluLWhlaWdodDogNDJweDtcbiAgbWluLXdpZHRoOiAxMjBweDtcblxuICAmOmhvdmVyIC5NdWlPdXRsaW5lZElucHV0LW5vdGNoZWRPdXRsaW5lIHtcbiAgICBib3JkZXItY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn07XG4gIH1cbmA7XHJcbmNvbnN0IFRpZXJJbnB1dCA9IHN0eWxlZChPdXRsaW5lZElucHV0KSBgXG4gICYgLk11aUlucHV0QmFzZS1pbnB1dCB7XG4gICAgcGFkZGluZzogMTBweCAxMnB4O1xuICB9XG5cbiAgJi5NdWktZm9jdXNlZCAuTXVpT3V0bGluZWRJbnB1dC1ub3RjaGVkT3V0bGluZSB7XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUucHJpbWFyeX0gIWltcG9ydGFudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFRpZXJzU2VsZWN0Q29udGFpbmVyKHsgY29tcG9uZW50SWQsIHRpZXJzLCB0aWVyVW5pdHMsIHNlbGVjdGVkVGllciwgaGFuZGxlVGllckNoYW5nZSwgfSkge1xyXG4gICAgY29uc3QgaGFuZGxlQ2hhbmdlID0gKGV2ZW50LCBfKSA9PiB7XHJcbiAgICAgICAgaWYgKCF0aWVycylcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIGhhbmRsZVRpZXJDaGFuZ2UoZ2V0VGllckJ5UXVhbnRpdHkodGllcnMsIGV2ZW50LnRhcmdldC52YWx1ZSkpO1xyXG4gICAgfTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS10aWVyLXNlbGVjdFwiLCBzdHlsZTogeyBtaW5IZWlnaHQ6ICc0NnB4JyB9IH0sIHRpZXJzID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllclNlbGVjdCwgeyB2YWx1ZTogc2VsZWN0ZWRUaWVyID8gc2VsZWN0ZWRUaWVyLnVwVG8udG9TdHJpbmcoKSA6IHRpZXJzWzBdLnVwVG8udG9TdHJpbmcoKSwgZnVsbFdpZHRoOiB0cnVlLCBvbkNoYW5nZTogaGFuZGxlQ2hhbmdlLCBpZDogY29tcG9uZW50SWQsIGlucHV0OiBSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJJbnB1dCwgbnVsbCksIE1lbnVQcm9wczoge1xyXG4gICAgICAgICAgICBNZW51TGlzdFByb3BzOiB7IGRpc2FibGVQYWRkaW5nOiB0cnVlIH0sXHJcbiAgICAgICAgICAgIFBhcGVyUHJvcHM6IHtcclxuICAgICAgICAgICAgICAgIHN4OiB7IG1hcmdpblRvcDogJzRweCcsIGJvcmRlclJhZGl1czogJzEwcHgnIH0sXHJcbiAgICAgICAgICAgIH0sXHJcbiAgICAgICAgfSB9LCBtYXAodGllcnMsICh0aWVyKSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChNZW51SXRlbSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGllci1tZW51LWl0ZW0tdGV4dFwiLCBrZXk6IHRpZXIudXBUbywgdmFsdWU6IHRpZXIudXBUby50b1N0cmluZygpIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwicHJpbWFyeVwiLCBzdHlsZTogeyBsaW5lSGVpZ2h0OiAndW5zZXQnIH0gfSxcclxuICAgICAgICAgICAgdGllci51cFRvLFxyXG4gICAgICAgICAgICBcIiBcIixcclxuICAgICAgICAgICAgdGllclVuaXRzKSkpKSkpIDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgbnVsbCkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9VGllcnNTZWxlY3RDb250YWluZXIuanMubWFwIl19 */"));
|
|
1214
1214
|
|
|
1215
1215
|
var TierInput = /*#__PURE__*/_styled(OutlinedInput, process.env.NODE_ENV === "production" ? {
|
|
1216
1216
|
target: "eeq8l4e0"
|
|
@@ -1220,11 +1220,12 @@ var TierInput = /*#__PURE__*/_styled(OutlinedInput, process.env.NODE_ENV === "pr
|
|
|
1220
1220
|
})("& .MuiInputBase-input{padding:10px 12px;}&.Mui-focused .MuiOutlinedInput-notchedOutline{border-color:", function (_ref2) {
|
|
1221
1221
|
var theme = _ref2.theme;
|
|
1222
1222
|
return theme.stigg.palette.primary;
|
|
1223
|
-
}, "!important;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzU2VsZWN0Q29udGFpbmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFld0MiLCJmaWxlIjoiVGllcnNTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWVudUl0ZW0sIE91dGxpbmVkSW5wdXQsIFNlbGVjdCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdsb2Rhc2gnO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IGdldFRpZXJCeVF1YW50aXR5IH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi9UeXBvZ3JhcGh5JztcclxuY29uc3QgVGllclNlbGVjdCA9IHN0eWxlZChTZWxlY3QpIGBcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgbWluLWhlaWdodDogNDJweDtcbiAgbWluLXdpZHRoOiAxMjBweDtcblxuICAmOmhvdmVyIC5NdWlPdXRsaW5lZElucHV0LW5vdGNoZWRPdXRsaW5lIHtcbiAgICBib3JkZXItY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn07XG4gIH1cbmA7XHJcbmNvbnN0IFRpZXJJbnB1dCA9IHN0eWxlZChPdXRsaW5lZElucHV0KSBgXG4gICYgLk11aUlucHV0QmFzZS1pbnB1dCB7XG4gICAgcGFkZGluZzogMTBweCAxMnB4O1xuICB9XG5cbiAgJi5NdWktZm9jdXNlZCAuTXVpT3V0bGluZWRJbnB1dC1ub3RjaGVkT3V0bGluZSB7XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+
|
|
1223
|
+
}, "!important;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlRpZXJzU2VsZWN0Q29udGFpbmVyLnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFld0MiLCJmaWxlIjoiVGllcnNTZWxlY3RDb250YWluZXIudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgTWVudUl0ZW0sIE91dGxpbmVkSW5wdXQsIFNlbGVjdCB9IGZyb20gJ0BtdWkvbWF0ZXJpYWwnO1xyXG5pbXBvcnQgeyBtYXAgfSBmcm9tICdsb2Rhc2gnO1xyXG5pbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IGdldFRpZXJCeVF1YW50aXR5IH0gZnJvbSAnLi4vdXRpbHMvcHJpY2VUaWVyVXRpbHMnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi9UeXBvZ3JhcGh5JztcclxuY29uc3QgVGllclNlbGVjdCA9IHN0eWxlZChTZWxlY3QpIGBcbiAgYm9yZGVyLXJhZGl1czogMTBweDtcbiAgbWluLWhlaWdodDogNDJweDtcbiAgbWluLXdpZHRoOiAxMjBweDtcblxuICAmOmhvdmVyIC5NdWlPdXRsaW5lZElucHV0LW5vdGNoZWRPdXRsaW5lIHtcbiAgICBib3JkZXItY29sb3I6ICR7KHsgdGhlbWUgfSkgPT4gdGhlbWUuc3RpZ2cucGFsZXR0ZS5vdXRsaW5lZEJvcmRlcn07XG4gIH1cbmA7XHJcbmNvbnN0IFRpZXJJbnB1dCA9IHN0eWxlZChPdXRsaW5lZElucHV0KSBgXG4gICYgLk11aUlucHV0QmFzZS1pbnB1dCB7XG4gICAgcGFkZGluZzogMTBweCAxMnB4O1xuICB9XG5cbiAgJi5NdWktZm9jdXNlZCAuTXVpT3V0bGluZWRJbnB1dC1ub3RjaGVkT3V0bGluZSB7XG4gICAgYm9yZGVyLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnN0aWdnLnBhbGV0dGUucHJpbWFyeX0gIWltcG9ydGFudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFRpZXJzU2VsZWN0Q29udGFpbmVyKHsgY29tcG9uZW50SWQsIHRpZXJzLCB0aWVyVW5pdHMsIHNlbGVjdGVkVGllciwgaGFuZGxlVGllckNoYW5nZSwgfSkge1xyXG4gICAgY29uc3QgaGFuZGxlQ2hhbmdlID0gKGV2ZW50LCBfKSA9PiB7XHJcbiAgICAgICAgaWYgKCF0aWVycylcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIGhhbmRsZVRpZXJDaGFuZ2UoZ2V0VGllckJ5UXVhbnRpdHkodGllcnMsIGV2ZW50LnRhcmdldC52YWx1ZSkpO1xyXG4gICAgfTtcclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS10aWVyLXNlbGVjdFwiLCBzdHlsZTogeyBtaW5IZWlnaHQ6ICc0NnB4JyB9IH0sIHRpZXJzID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllclNlbGVjdCwgeyB2YWx1ZTogc2VsZWN0ZWRUaWVyID8gc2VsZWN0ZWRUaWVyLnVwVG8udG9TdHJpbmcoKSA6IHRpZXJzWzBdLnVwVG8udG9TdHJpbmcoKSwgZnVsbFdpZHRoOiB0cnVlLCBvbkNoYW5nZTogaGFuZGxlQ2hhbmdlLCBpZDogY29tcG9uZW50SWQsIGlucHV0OiBSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJJbnB1dCwgbnVsbCksIE1lbnVQcm9wczoge1xyXG4gICAgICAgICAgICBNZW51TGlzdFByb3BzOiB7IGRpc2FibGVQYWRkaW5nOiB0cnVlIH0sXHJcbiAgICAgICAgICAgIFBhcGVyUHJvcHM6IHtcclxuICAgICAgICAgICAgICAgIHN4OiB7IG1hcmdpblRvcDogJzRweCcsIGJvcmRlclJhZGl1czogJzEwcHgnIH0sXHJcbiAgICAgICAgICAgIH0sXHJcbiAgICAgICAgfSB9LCBtYXAodGllcnMsICh0aWVyKSA9PiAoUmVhY3QuY3JlYXRlRWxlbWVudChNZW51SXRlbSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGllci1tZW51LWl0ZW0tdGV4dFwiLCBrZXk6IHRpZXIudXBUbywgdmFsdWU6IHRpZXIudXBUby50b1N0cmluZygpIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwicHJpbWFyeVwiLCBzdHlsZTogeyBsaW5lSGVpZ2h0OiAndW5zZXQnIH0gfSxcclxuICAgICAgICAgICAgdGllci51cFRvLFxyXG4gICAgICAgICAgICBcIiBcIixcclxuICAgICAgICAgICAgdGllclVuaXRzKSkpKSkpIDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoXCJkaXZcIiwgbnVsbCkpKSk7XHJcbn1cclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9VGllcnNTZWxlY3RDb250YWluZXIuanMubWFwIl19 */"));
|
|
1224
1224
|
|
|
1225
1225
|
function TiersSelectContainer(_ref3) {
|
|
1226
1226
|
var componentId = _ref3.componentId,
|
|
1227
1227
|
tiers = _ref3.tiers,
|
|
1228
|
+
tierUnits = _ref3.tierUnits,
|
|
1228
1229
|
selectedTier = _ref3.selectedTier,
|
|
1229
1230
|
handleTierChange = _ref3.handleTierChange;
|
|
1230
1231
|
|
|
@@ -1266,7 +1267,7 @@ function TiersSelectContainer(_ref3) {
|
|
|
1266
1267
|
style: {
|
|
1267
1268
|
lineHeight: 'unset'
|
|
1268
1269
|
}
|
|
1269
|
-
}, tier.upTo));
|
|
1270
|
+
}, tier.upTo, " ", tierUnits));
|
|
1270
1271
|
})) : React__default.createElement("div", null));
|
|
1271
1272
|
}
|
|
1272
1273
|
|
|
@@ -1284,7 +1285,7 @@ var PlanPriceContainer = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV =
|
|
|
1284
1285
|
} : {
|
|
1285
1286
|
name: "bfvx8c",
|
|
1286
1287
|
styles: "word-break:break-word;width:100%",
|
|
1287
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
1288
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTThDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IGdldFBsYW5QcmljZSB9IGZyb20gJy4uL3V0aWxzL2dldFBsYW5QcmljZSc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IFRpZXJzU2VsZWN0Q29udGFpbmVyIH0gZnJvbSAnLi4vY29tbW9uL1RpZXJzU2VsZWN0Q29udGFpbmVyJztcclxuY29uc3QgRU1QVFlfQ0hBUiA9ICfigI4nO1xyXG5jb25zdCBQbGFuUHJpY2VDb250YWluZXIgPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3b3JkLWJyZWFrOiBicmVhay13b3JkO1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmNvbnN0IFVuaXRTcGFuID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbmA7XHJcbmNvbnN0IFByaWNlU3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3JtYWw7XG4gIG1pbi1oZWlnaHQ6IDM5cHg7XG5gO1xyXG5mdW5jdGlvbiBQcmljZUJpbGxpbmdQZXJpb2QoeyBwbGFuLCBiaWxsaW5nUGVyaW9kLCBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2UsIHBheXdhbGxMb2NhbGUsIH0pIHtcclxuICAgIGNvbnN0IGhhc1ByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IGJpbGxpbmdQZXJpb2QpO1xyXG4gICAgbGV0IGNvbnRlbnQgPSBFTVBUWV9DSEFSO1xyXG4gICAgaWYgKGhhc1ByaWNlICYmIGhhc01vbnRobHlQcmljZSAmJiBoYXNBbm51YWxseVByaWNlKSB7XHJcbiAgICAgICAgY29udGVudCA9IHBheXdhbGxMb2NhbGUucHJpY2UuYmlsbGluZ1BlcmlvZD8uKGJpbGxpbmdQZXJpb2QpIHx8IGAsIGJpbGxlZCAke2JpbGxpbmdQZXJpb2QudG9Mb3dlckNhc2UoKX1gO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgc3BhbjogdHJ1ZSwgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLWJpbGxpbmctcGVyaW9kLXRleHRcIiwgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjb250ZW50KSk7XHJcbn1cclxuZXhwb3J0IGNvbnN0IFBsYW5QcmljZSA9ICh7IHNob3dTdGFydGluZ0F0LCB3aXRoVW5pdFByaWNlUm93LCB3aXRoU3RhcnRpbmdBdFJvdywgd2l0aFRpZXJzUm93LCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUsIHNldFNlbGVjdGVkVGllckJ5RmVhdHVyZSwgcGxhbiwgYmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2UsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgcHJpY2UsIHVuaXQsIHRpZXJzLCB0aWVyVW5pdHMgfSA9IGdldFBsYW5QcmljZShwbGFuLCBiaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSwgc2VsZWN0ZWRUaWVyQnlGZWF0dXJlKTtcclxuICAgIC8vIFdlIGN1cnJlbnRseSBvbmx5IHN1cHBvcnQgcHJpY2VzIHdpdGggb25lIHRpZXIgLSBzbyB3ZSBzZWxlY3QgdGhlIGZpcnN0IG9uZVxyXG4gICAgY29uc3QgdGllcmVkUHJpY2UgPSBwbGFuLnByaWNlUG9pbnRzLmZpbmQoKHBsYW5QcmljZSkgPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2UuYmlsbGluZ1BlcmlvZCA9PT0gYmlsbGluZ1BlcmlvZCAmJiBwbGFuUHJpY2UuaXNUaWVyZWRQcmljZTtcclxuICAgIH0pO1xyXG4gICAgY29uc3QgZmVhdHVyZUlkID0gdGllcmVkUHJpY2UgPyB0aWVyZWRQcmljZS5mZWF0dXJlLmZlYXR1cmVJZCA6IHVuZGVmaW5lZDtcclxuICAgIGNvbnN0IHNlbGVjdGVkVGllciA9IGZlYXR1cmVJZCA/IHNlbGVjdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaGFuZGxlVGllckNoYW5nZSA9ICh0aWVyKSA9PiB7XHJcbiAgICAgICAgaWYgKCFmZWF0dXJlSWQpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUoKHByZXZTdGF0ZSkgPT4gKHtcclxuICAgICAgICAgICAgLi4ucHJldlN0YXRlLFxyXG4gICAgICAgICAgICBbZmVhdHVyZUlkXTogdGllcixcclxuICAgICAgICB9KSk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5QcmljZUNvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGV4dFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgd2l0aFN0YXJ0aW5nQXRSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzdHlsZTogeyBtaW5IZWlnaHQ6ICcyMHB4JyB9LCBjbGFzc05hbWU6IFwic3RpZ2ctc3RhcnRpbmctYXQtdGV4dFwiLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHNob3dTdGFydGluZ0F0ID8gcGF5d2FsbExvY2FsZS5wcmljZS5zdGFydGluZ0F0Q2FwdGlvbiA6IEVNUFRZX0NIQVIpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQcmljZVNwYW4sIHsgdmFyaWFudDogXCJoMVwiIH0sIHByaWNlKSxcclxuICAgICAgICAgICAgd2l0aFVuaXRQcmljZVJvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS11bml0LWFuZC1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHN0eWxlOiB7IG1pbkhlaWdodDogJzQ4cHgnIH0gfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVW5pdFNwYW4sIHsgc3BhbjogdHJ1ZSwgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCB1bml0KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VCaWxsaW5nUGVyaW9kLCB7IHBsYW46IHBsYW4sIGJpbGxpbmdQZXJpb2Q6IGJpbGxpbmdQZXJpb2QsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlLCBwYXl3YWxsTG9jYWxlOiBwYXl3YWxsTG9jYWxlIH0pKSksXHJcbiAgICAgICAgICAgIHdpdGhUaWVyc1JvdyA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJzU2VsZWN0Q29udGFpbmVyLCB7IGNvbXBvbmVudElkOiBgJHtwbGFuLmlkfV8ke2ZlYXR1cmVJZH1fdGllcmAsIHRpZXJzOiB0aWVycywgdGllclVuaXRzOiB0aWVyVW5pdHMsIHNlbGVjdGVkVGllcjogc2VsZWN0ZWRUaWVyLCBoYW5kbGVUaWVyQ2hhbmdlOiBoYW5kbGVUaWVyQ2hhbmdlIH0pKSA6IG51bGwpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBsYW5QcmljZS5qcy5tYXAiXX0= */",
|
|
1288
1289
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
1289
1290
|
});
|
|
1290
1291
|
|
|
@@ -1299,7 +1300,7 @@ var UnitSpan = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "produc
|
|
|
1299
1300
|
} : {
|
|
1300
1301
|
name: "1bmnxg7",
|
|
1301
1302
|
styles: "white-space:nowrap",
|
|
1302
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
1303
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9DIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IGdldFBsYW5QcmljZSB9IGZyb20gJy4uL3V0aWxzL2dldFBsYW5QcmljZSc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IFRpZXJzU2VsZWN0Q29udGFpbmVyIH0gZnJvbSAnLi4vY29tbW9uL1RpZXJzU2VsZWN0Q29udGFpbmVyJztcclxuY29uc3QgRU1QVFlfQ0hBUiA9ICfigI4nO1xyXG5jb25zdCBQbGFuUHJpY2VDb250YWluZXIgPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3b3JkLWJyZWFrOiBicmVhay13b3JkO1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmNvbnN0IFVuaXRTcGFuID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbmA7XHJcbmNvbnN0IFByaWNlU3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3JtYWw7XG4gIG1pbi1oZWlnaHQ6IDM5cHg7XG5gO1xyXG5mdW5jdGlvbiBQcmljZUJpbGxpbmdQZXJpb2QoeyBwbGFuLCBiaWxsaW5nUGVyaW9kLCBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2UsIHBheXdhbGxMb2NhbGUsIH0pIHtcclxuICAgIGNvbnN0IGhhc1ByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IGJpbGxpbmdQZXJpb2QpO1xyXG4gICAgbGV0IGNvbnRlbnQgPSBFTVBUWV9DSEFSO1xyXG4gICAgaWYgKGhhc1ByaWNlICYmIGhhc01vbnRobHlQcmljZSAmJiBoYXNBbm51YWxseVByaWNlKSB7XHJcbiAgICAgICAgY29udGVudCA9IHBheXdhbGxMb2NhbGUucHJpY2UuYmlsbGluZ1BlcmlvZD8uKGJpbGxpbmdQZXJpb2QpIHx8IGAsIGJpbGxlZCAke2JpbGxpbmdQZXJpb2QudG9Mb3dlckNhc2UoKX1gO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgc3BhbjogdHJ1ZSwgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLWJpbGxpbmctcGVyaW9kLXRleHRcIiwgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjb250ZW50KSk7XHJcbn1cclxuZXhwb3J0IGNvbnN0IFBsYW5QcmljZSA9ICh7IHNob3dTdGFydGluZ0F0LCB3aXRoVW5pdFByaWNlUm93LCB3aXRoU3RhcnRpbmdBdFJvdywgd2l0aFRpZXJzUm93LCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUsIHNldFNlbGVjdGVkVGllckJ5RmVhdHVyZSwgcGxhbiwgYmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2UsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgcHJpY2UsIHVuaXQsIHRpZXJzLCB0aWVyVW5pdHMgfSA9IGdldFBsYW5QcmljZShwbGFuLCBiaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSwgc2VsZWN0ZWRUaWVyQnlGZWF0dXJlKTtcclxuICAgIC8vIFdlIGN1cnJlbnRseSBvbmx5IHN1cHBvcnQgcHJpY2VzIHdpdGggb25lIHRpZXIgLSBzbyB3ZSBzZWxlY3QgdGhlIGZpcnN0IG9uZVxyXG4gICAgY29uc3QgdGllcmVkUHJpY2UgPSBwbGFuLnByaWNlUG9pbnRzLmZpbmQoKHBsYW5QcmljZSkgPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2UuYmlsbGluZ1BlcmlvZCA9PT0gYmlsbGluZ1BlcmlvZCAmJiBwbGFuUHJpY2UuaXNUaWVyZWRQcmljZTtcclxuICAgIH0pO1xyXG4gICAgY29uc3QgZmVhdHVyZUlkID0gdGllcmVkUHJpY2UgPyB0aWVyZWRQcmljZS5mZWF0dXJlLmZlYXR1cmVJZCA6IHVuZGVmaW5lZDtcclxuICAgIGNvbnN0IHNlbGVjdGVkVGllciA9IGZlYXR1cmVJZCA/IHNlbGVjdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaGFuZGxlVGllckNoYW5nZSA9ICh0aWVyKSA9PiB7XHJcbiAgICAgICAgaWYgKCFmZWF0dXJlSWQpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUoKHByZXZTdGF0ZSkgPT4gKHtcclxuICAgICAgICAgICAgLi4ucHJldlN0YXRlLFxyXG4gICAgICAgICAgICBbZmVhdHVyZUlkXTogdGllcixcclxuICAgICAgICB9KSk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5QcmljZUNvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGV4dFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgd2l0aFN0YXJ0aW5nQXRSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzdHlsZTogeyBtaW5IZWlnaHQ6ICcyMHB4JyB9LCBjbGFzc05hbWU6IFwic3RpZ2ctc3RhcnRpbmctYXQtdGV4dFwiLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHNob3dTdGFydGluZ0F0ID8gcGF5d2FsbExvY2FsZS5wcmljZS5zdGFydGluZ0F0Q2FwdGlvbiA6IEVNUFRZX0NIQVIpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQcmljZVNwYW4sIHsgdmFyaWFudDogXCJoMVwiIH0sIHByaWNlKSxcclxuICAgICAgICAgICAgd2l0aFVuaXRQcmljZVJvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS11bml0LWFuZC1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHN0eWxlOiB7IG1pbkhlaWdodDogJzQ4cHgnIH0gfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVW5pdFNwYW4sIHsgc3BhbjogdHJ1ZSwgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCB1bml0KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VCaWxsaW5nUGVyaW9kLCB7IHBsYW46IHBsYW4sIGJpbGxpbmdQZXJpb2Q6IGJpbGxpbmdQZXJpb2QsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlLCBwYXl3YWxsTG9jYWxlOiBwYXl3YWxsTG9jYWxlIH0pKSksXHJcbiAgICAgICAgICAgIHdpdGhUaWVyc1JvdyA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJzU2VsZWN0Q29udGFpbmVyLCB7IGNvbXBvbmVudElkOiBgJHtwbGFuLmlkfV8ke2ZlYXR1cmVJZH1fdGllcmAsIHRpZXJzOiB0aWVycywgdGllclVuaXRzOiB0aWVyVW5pdHMsIHNlbGVjdGVkVGllcjogc2VsZWN0ZWRUaWVyLCBoYW5kbGVUaWVyQ2hhbmdlOiBoYW5kbGVUaWVyQ2hhbmdlIH0pKSA6IG51bGwpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBsYW5QcmljZS5qcy5tYXAiXX0= */",
|
|
1303
1304
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
1304
1305
|
});
|
|
1305
1306
|
|
|
@@ -1314,7 +1315,7 @@ var PriceSpan = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "produ
|
|
|
1314
1315
|
} : {
|
|
1315
1316
|
name: "nurf5y",
|
|
1316
1317
|
styles: "white-space:normal;min-height:39px",
|
|
1317
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
1318
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYXFDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QgZnJvbSAncmVhY3QnO1xyXG5pbXBvcnQgc3R5bGVkIGZyb20gJ0BlbW90aW9uL3N0eWxlZC9tYWNybyc7XHJcbmltcG9ydCB7IGdldFBsYW5QcmljZSB9IGZyb20gJy4uL3V0aWxzL2dldFBsYW5QcmljZSc7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IFRpZXJzU2VsZWN0Q29udGFpbmVyIH0gZnJvbSAnLi4vY29tbW9uL1RpZXJzU2VsZWN0Q29udGFpbmVyJztcclxuY29uc3QgRU1QVFlfQ0hBUiA9ICfigI4nO1xyXG5jb25zdCBQbGFuUHJpY2VDb250YWluZXIgPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3b3JkLWJyZWFrOiBicmVhay13b3JkO1xuICB3aWR0aDogMTAwJTtcbmA7XHJcbmNvbnN0IFVuaXRTcGFuID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd2hpdGUtc3BhY2U6IG5vd3JhcDtcbmA7XHJcbmNvbnN0IFByaWNlU3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3JtYWw7XG4gIG1pbi1oZWlnaHQ6IDM5cHg7XG5gO1xyXG5mdW5jdGlvbiBQcmljZUJpbGxpbmdQZXJpb2QoeyBwbGFuLCBiaWxsaW5nUGVyaW9kLCBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2UsIHBheXdhbGxMb2NhbGUsIH0pIHtcclxuICAgIGNvbnN0IGhhc1ByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKChwcmljZVBvaW50KSA9PiBwcmljZVBvaW50LmJpbGxpbmdQZXJpb2QgPT09IGJpbGxpbmdQZXJpb2QpO1xyXG4gICAgbGV0IGNvbnRlbnQgPSBFTVBUWV9DSEFSO1xyXG4gICAgaWYgKGhhc1ByaWNlICYmIGhhc01vbnRobHlQcmljZSAmJiBoYXNBbm51YWxseVByaWNlKSB7XHJcbiAgICAgICAgY29udGVudCA9IHBheXdhbGxMb2NhbGUucHJpY2UuYmlsbGluZ1BlcmlvZD8uKGJpbGxpbmdQZXJpb2QpIHx8IGAsIGJpbGxlZCAke2JpbGxpbmdQZXJpb2QudG9Mb3dlckNhc2UoKX1gO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgc3BhbjogdHJ1ZSwgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLWJpbGxpbmctcGVyaW9kLXRleHRcIiwgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCBjb250ZW50KSk7XHJcbn1cclxuZXhwb3J0IGNvbnN0IFBsYW5QcmljZSA9ICh7IHNob3dTdGFydGluZ0F0LCB3aXRoVW5pdFByaWNlUm93LCB3aXRoU3RhcnRpbmdBdFJvdywgd2l0aFRpZXJzUm93LCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUsIHNldFNlbGVjdGVkVGllckJ5RmVhdHVyZSwgcGxhbiwgYmlsbGluZ1BlcmlvZCwgcGF5d2FsbExvY2FsZSwgbG9jYWxlLCBoYXNNb250aGx5UHJpY2UsIGhhc0FubnVhbGx5UHJpY2UsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgcHJpY2UsIHVuaXQsIHRpZXJzLCB0aWVyVW5pdHMgfSA9IGdldFBsYW5QcmljZShwbGFuLCBiaWxsaW5nUGVyaW9kLCBwYXl3YWxsTG9jYWxlLCBsb2NhbGUsIGhhc01vbnRobHlQcmljZSwgc2VsZWN0ZWRUaWVyQnlGZWF0dXJlKTtcclxuICAgIC8vIFdlIGN1cnJlbnRseSBvbmx5IHN1cHBvcnQgcHJpY2VzIHdpdGggb25lIHRpZXIgLSBzbyB3ZSBzZWxlY3QgdGhlIGZpcnN0IG9uZVxyXG4gICAgY29uc3QgdGllcmVkUHJpY2UgPSBwbGFuLnByaWNlUG9pbnRzLmZpbmQoKHBsYW5QcmljZSkgPT4ge1xyXG4gICAgICAgIHJldHVybiBwbGFuUHJpY2UuYmlsbGluZ1BlcmlvZCA9PT0gYmlsbGluZ1BlcmlvZCAmJiBwbGFuUHJpY2UuaXNUaWVyZWRQcmljZTtcclxuICAgIH0pO1xyXG4gICAgY29uc3QgZmVhdHVyZUlkID0gdGllcmVkUHJpY2UgPyB0aWVyZWRQcmljZS5mZWF0dXJlLmZlYXR1cmVJZCA6IHVuZGVmaW5lZDtcclxuICAgIGNvbnN0IHNlbGVjdGVkVGllciA9IGZlYXR1cmVJZCA/IHNlbGVjdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdIDogdW5kZWZpbmVkO1xyXG4gICAgY29uc3QgaGFuZGxlVGllckNoYW5nZSA9ICh0aWVyKSA9PiB7XHJcbiAgICAgICAgaWYgKCFmZWF0dXJlSWQpIHtcclxuICAgICAgICAgICAgcmV0dXJuO1xyXG4gICAgICAgIH1cclxuICAgICAgICBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUoKHByZXZTdGF0ZSkgPT4gKHtcclxuICAgICAgICAgICAgLi4ucHJldlN0YXRlLFxyXG4gICAgICAgICAgICBbZmVhdHVyZUlkXTogdGllcixcclxuICAgICAgICB9KSk7XHJcbiAgICB9O1xyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KFBsYW5QcmljZUNvbnRhaW5lciwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGV4dFwiIH0sXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChSZWFjdC5GcmFnbWVudCwgbnVsbCxcclxuICAgICAgICAgICAgd2l0aFN0YXJ0aW5nQXRSb3cgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBzdHlsZTogeyBtaW5IZWlnaHQ6ICcyMHB4JyB9LCBjbGFzc05hbWU6IFwic3RpZ2ctc3RhcnRpbmctYXQtdGV4dFwiLCB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHNob3dTdGFydGluZ0F0ID8gcGF5d2FsbExvY2FsZS5wcmljZS5zdGFydGluZ0F0Q2FwdGlvbiA6IEVNUFRZX0NIQVIpKSxcclxuICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQcmljZVNwYW4sIHsgdmFyaWFudDogXCJoMVwiIH0sIHByaWNlKSxcclxuICAgICAgICAgICAgd2l0aFVuaXRQcmljZVJvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS11bml0LWFuZC1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHN0eWxlOiB7IG1pbkhlaWdodDogJzQ4cHgnIH0gfSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVW5pdFNwYW4sIHsgc3BhbjogdHJ1ZSwgdmFyaWFudDogXCJoNlwiLCBjb2xvcjogXCJzZWNvbmRhcnlcIiB9LCB1bml0KSxcclxuICAgICAgICAgICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoUHJpY2VCaWxsaW5nUGVyaW9kLCB7IHBsYW46IHBsYW4sIGJpbGxpbmdQZXJpb2Q6IGJpbGxpbmdQZXJpb2QsIGhhc0FubnVhbGx5UHJpY2U6IGhhc0FubnVhbGx5UHJpY2UsIGhhc01vbnRobHlQcmljZTogaGFzTW9udGhseVByaWNlLCBwYXl3YWxsTG9jYWxlOiBwYXl3YWxsTG9jYWxlIH0pKSksXHJcbiAgICAgICAgICAgIHdpdGhUaWVyc1JvdyA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJzU2VsZWN0Q29udGFpbmVyLCB7IGNvbXBvbmVudElkOiBgJHtwbGFuLmlkfV8ke2ZlYXR1cmVJZH1fdGllcmAsIHRpZXJzOiB0aWVycywgdGllclVuaXRzOiB0aWVyVW5pdHMsIHNlbGVjdGVkVGllcjogc2VsZWN0ZWRUaWVyLCBoYW5kbGVUaWVyQ2hhbmdlOiBoYW5kbGVUaWVyQ2hhbmdlIH0pKSA6IG51bGwpKSk7XHJcbn07XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVBsYW5QcmljZS5qcy5tYXAiXX0= */",
|
|
1318
1319
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$3
|
|
1319
1320
|
});
|
|
1320
1321
|
|
|
@@ -1358,32 +1359,28 @@ var PlanPrice = function PlanPrice(_ref2) {
|
|
|
1358
1359
|
var _getPlanPrice = getPlanPrice(plan, billingPeriod, paywallLocale, locale, hasMonthlyPrice, selectedTierByFeature),
|
|
1359
1360
|
price = _getPlanPrice.price,
|
|
1360
1361
|
unit = _getPlanPrice.unit,
|
|
1361
|
-
tiers = _getPlanPrice.tiers
|
|
1362
|
-
|
|
1363
|
-
var _useState = useState(),
|
|
1364
|
-
selectedTier = _useState[0],
|
|
1365
|
-
setSelectedTier = _useState[1]; // We currently only support prices with one tier - so we select the first one
|
|
1362
|
+
tiers = _getPlanPrice.tiers,
|
|
1363
|
+
tierUnits = _getPlanPrice.tierUnits; // We currently only support prices with one tier - so we select the first one
|
|
1366
1364
|
|
|
1367
1365
|
|
|
1368
1366
|
var tieredPrice = plan.pricePoints.find(function (planPrice) {
|
|
1369
1367
|
return planPrice.billingPeriod === billingPeriod && planPrice.isTieredPrice;
|
|
1370
1368
|
});
|
|
1371
1369
|
var featureId = tieredPrice ? tieredPrice.feature.featureId : undefined;
|
|
1372
|
-
|
|
1373
|
-
setSelectedTier(featureId ? selectedTierByFeature[featureId] : undefined);
|
|
1374
|
-
}, [featureId, selectedTierByFeature]);
|
|
1370
|
+
var selectedTier = featureId ? selectedTierByFeature[featureId] : undefined;
|
|
1375
1371
|
|
|
1376
1372
|
var handleTierChange = function handleTierChange(tier) {
|
|
1377
|
-
|
|
1378
|
-
|
|
1379
|
-
|
|
1373
|
+
if (!featureId) {
|
|
1374
|
+
return;
|
|
1375
|
+
}
|
|
1376
|
+
|
|
1377
|
+
setSelectedTierByFeature(function (prevState) {
|
|
1378
|
+
var _extends2;
|
|
1379
|
+
|
|
1380
|
+
return _extends({}, prevState, (_extends2 = {}, _extends2[featureId] = tier, _extends2));
|
|
1381
|
+
});
|
|
1380
1382
|
};
|
|
1381
1383
|
|
|
1382
|
-
useEffect(function () {
|
|
1383
|
-
if (tiers) {
|
|
1384
|
-
handleTierChange(selectedTierByFeature[featureId]);
|
|
1385
|
-
}
|
|
1386
|
-
}, []);
|
|
1387
1384
|
return React__default.createElement(PlanPriceContainer, {
|
|
1388
1385
|
className: "stigg-price-text"
|
|
1389
1386
|
}, React__default.createElement(React__default.Fragment, null, withStartingAtRow && React__default.createElement(Typography, {
|
|
@@ -1413,6 +1410,7 @@ var PlanPrice = function PlanPrice(_ref2) {
|
|
|
1413
1410
|
})), withTiersRow ? React__default.createElement(TiersSelectContainer, {
|
|
1414
1411
|
componentId: plan.id + "_" + featureId + "_tier",
|
|
1415
1412
|
tiers: tiers,
|
|
1413
|
+
tierUnits: tierUnits,
|
|
1416
1414
|
selectedTier: selectedTier,
|
|
1417
1415
|
handleTierChange: handleTierChange
|
|
1418
1416
|
}) : null));
|
|
@@ -3044,6 +3042,25 @@ function calculateTrialDaysLeft(trialEndDate) {
|
|
|
3044
3042
|
return moment.utc(trialEndDate).diff(moment.utc(), 'days', false) + 1;
|
|
3045
3043
|
}
|
|
3046
3044
|
|
|
3045
|
+
var defaultCheckoutTypography = {
|
|
3046
|
+
h1: {
|
|
3047
|
+
fontSize: 24,
|
|
3048
|
+
fontWeight: FontWeight$1.Bold
|
|
3049
|
+
},
|
|
3050
|
+
h2: {
|
|
3051
|
+
fontSize: 16,
|
|
3052
|
+
fontWeight: FontWeight$1.Normal
|
|
3053
|
+
},
|
|
3054
|
+
h3: {
|
|
3055
|
+
fontSize: 16,
|
|
3056
|
+
fontWeight: FontWeight$1.Normal
|
|
3057
|
+
},
|
|
3058
|
+
body: {
|
|
3059
|
+
fontSize: 14,
|
|
3060
|
+
fontWeight: FontWeight$1.Normal
|
|
3061
|
+
}
|
|
3062
|
+
};
|
|
3063
|
+
|
|
3047
3064
|
function addCssUnits(value, unit) {
|
|
3048
3065
|
if (unit === void 0) {
|
|
3049
3066
|
unit = 'px';
|
|
@@ -3073,26 +3090,26 @@ function mapFontWeight$1(defaultValue, fontWeight) {
|
|
|
3073
3090
|
}
|
|
3074
3091
|
}
|
|
3075
3092
|
|
|
3076
|
-
function mapTypography(typography) {
|
|
3077
|
-
var _typography$h, _typography$h2, _typography$h3,
|
|
3093
|
+
function mapTypography(typography, defaultTypography) {
|
|
3094
|
+
var _typography$h, _defaultTypography$h, _typography$h2, _defaultTypography$h2, _typography$h3, _defaultTypography$h3, _defaultTypography$h4, _typography$h4, _defaultTypography$h5, _typography$h5, _defaultTypography$h6, _typography$body, _defaultTypography$bo, _typography$body2, _defaultTypography$bo2;
|
|
3078
3095
|
|
|
3079
3096
|
return {
|
|
3080
3097
|
fontFamilyUrl: (typography == null ? void 0 : typography.fontFamily) || undefined,
|
|
3081
3098
|
h1: {
|
|
3082
|
-
fontSize: addCssUnits(typography == null ? void 0 : (_typography$h = typography.h1) == null ? void 0 : _typography$h.fontSize),
|
|
3083
|
-
fontWeight: mapFontWeight$1('bold', typography == null ? void 0 : (_typography$h2 = typography.h1) == null ? void 0 : _typography$h2.fontWeight)
|
|
3099
|
+
fontSize: addCssUnits((typography == null ? void 0 : (_typography$h = typography.h1) == null ? void 0 : _typography$h.fontSize) || (defaultTypography == null ? void 0 : (_defaultTypography$h = defaultTypography.h1) == null ? void 0 : _defaultTypography$h.fontSize)),
|
|
3100
|
+
fontWeight: mapFontWeight$1('bold', (typography == null ? void 0 : (_typography$h2 = typography.h1) == null ? void 0 : _typography$h2.fontWeight) || (defaultTypography == null ? void 0 : (_defaultTypography$h2 = defaultTypography.h1) == null ? void 0 : _defaultTypography$h2.fontWeight))
|
|
3084
3101
|
},
|
|
3085
3102
|
h2: {
|
|
3086
|
-
fontSize: addCssUnits(typography == null ? void 0 : (_typography$h3 = typography.h2) == null ? void 0 : _typography$h3.fontSize),
|
|
3087
|
-
fontWeight: mapFontWeight$1('normal',
|
|
3103
|
+
fontSize: addCssUnits((typography == null ? void 0 : (_typography$h3 = typography.h2) == null ? void 0 : _typography$h3.fontSize) || (defaultTypography == null ? void 0 : (_defaultTypography$h3 = defaultTypography.h2) == null ? void 0 : _defaultTypography$h3.fontSize)),
|
|
3104
|
+
fontWeight: mapFontWeight$1('normal', defaultTypography == null ? void 0 : (_defaultTypography$h4 = defaultTypography.h2) == null ? void 0 : _defaultTypography$h4.fontWeight)
|
|
3088
3105
|
},
|
|
3089
3106
|
h3: {
|
|
3090
|
-
fontSize: addCssUnits(typography == null ? void 0 : (_typography$
|
|
3091
|
-
fontWeight: mapFontWeight$1('normal', typography == null ? void 0 : (_typography$
|
|
3107
|
+
fontSize: addCssUnits((typography == null ? void 0 : (_typography$h4 = typography.h3) == null ? void 0 : _typography$h4.fontSize) || (defaultTypography == null ? void 0 : (_defaultTypography$h5 = defaultTypography.h3) == null ? void 0 : _defaultTypography$h5.fontSize)),
|
|
3108
|
+
fontWeight: mapFontWeight$1('normal', (typography == null ? void 0 : (_typography$h5 = typography.h3) == null ? void 0 : _typography$h5.fontWeight) || (defaultTypography == null ? void 0 : (_defaultTypography$h6 = defaultTypography.h3) == null ? void 0 : _defaultTypography$h6.fontWeight))
|
|
3092
3109
|
},
|
|
3093
3110
|
body: {
|
|
3094
|
-
fontSize: addCssUnits(typography == null ? void 0 : (_typography$body = typography.body) == null ? void 0 : _typography$body.fontSize),
|
|
3095
|
-
fontWeight: mapFontWeight$1('normal', typography == null ? void 0 : (_typography$body2 = typography.body) == null ? void 0 : _typography$body2.fontWeight)
|
|
3111
|
+
fontSize: addCssUnits((typography == null ? void 0 : (_typography$body = typography.body) == null ? void 0 : _typography$body.fontSize) || (defaultTypography == null ? void 0 : (_defaultTypography$bo = defaultTypography.body) == null ? void 0 : _defaultTypography$bo.fontSize)),
|
|
3112
|
+
fontWeight: mapFontWeight$1('normal', (typography == null ? void 0 : (_typography$body2 = typography.body) == null ? void 0 : _typography$body2.fontWeight) || (defaultTypography == null ? void 0 : (_defaultTypography$bo2 = defaultTypography.body) == null ? void 0 : _defaultTypography$bo2.fontWeight))
|
|
3096
3113
|
}
|
|
3097
3114
|
};
|
|
3098
3115
|
}
|
|
@@ -3176,7 +3193,7 @@ function mapCheckoutConfiguration(configuration) {
|
|
|
3176
3193
|
},
|
|
3177
3194
|
backgroundHighlight: (palette == null ? void 0 : palette.summaryBackgroundColor) || undefined
|
|
3178
3195
|
},
|
|
3179
|
-
typography: mapTypography(typography)
|
|
3196
|
+
typography: mapTypography(typography, defaultCheckoutTypography)
|
|
3180
3197
|
};
|
|
3181
3198
|
}
|
|
3182
3199
|
|
|
@@ -7581,7 +7598,9 @@ function CheckoutProvider(_ref2) {
|
|
|
7581
7598
|
checkout = _useLoadCheckout.checkout,
|
|
7582
7599
|
isLoading = _useLoadCheckout.isLoading;
|
|
7583
7600
|
|
|
7584
|
-
var configuration = checkout != null && checkout.configuration ? mapCheckoutConfiguration(checkout.configuration) :
|
|
7601
|
+
var configuration = checkout != null && checkout.configuration ? mapCheckoutConfiguration(checkout.configuration) : {
|
|
7602
|
+
typography: mapTypography(defaultCheckoutTypography)
|
|
7603
|
+
};
|
|
7585
7604
|
var globalTheme = useStiggTheme(configuration);
|
|
7586
7605
|
var initialState = useMemo(function () {
|
|
7587
7606
|
var _billingInformation$t, _checkout$resource;
|
|
@@ -8071,11 +8090,11 @@ var StyledPlusIcon = /*#__PURE__*/_styled(SvgPlusIcon, process.env.NODE_ENV ===
|
|
|
8071
8090
|
},
|
|
8072
8091
|
target: "e3hfkj90",
|
|
8073
8092
|
label: "StyledPlusIcon"
|
|
8074
|
-
})("path{stroke:", function (_ref) {
|
|
8093
|
+
})("margin-right:8px;path{stroke:", function (_ref) {
|
|
8075
8094
|
var theme = _ref.theme,
|
|
8076
8095
|
$disabled = _ref.$disabled;
|
|
8077
8096
|
return $disabled ? theme.stigg.palette.text.disabled : theme.stigg.palette.primary;
|
|
8078
|
-
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
8097
|
+
}, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFkZFByb21vdGlvbkNvZGVCdXR0b24udHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUtnRyIsImZpbGUiOiJBZGRQcm9tb3Rpb25Db2RlQnV0dG9uLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCBmcm9tICdyZWFjdCc7XHJcbmltcG9ydCBzdHlsZWQgZnJvbSAnQGVtb3Rpb24vc3R5bGVkL21hY3JvJztcclxuaW1wb3J0IFBsdXNJY29uIGZyb20gJy4uLy4uLy4uL2Fzc2V0cy9wbHVzLWljb24uc3ZnJztcclxuaW1wb3J0IHsgVHlwb2dyYXBoeSB9IGZyb20gJy4uLy4uL2NvbW1vbi9UeXBvZ3JhcGh5JztcclxuaW1wb3J0IHsgQnV0dG9uIH0gZnJvbSAnLi4vY29tcG9uZW50cyc7XHJcbmNvbnN0IFN0eWxlZFBsdXNJY29uID0gc3R5bGVkKFBsdXNJY29uLCB7IHNob3VsZEZvcndhcmRQcm9wOiAocHJvcCkgPT4gIXByb3Auc3RhcnRzV2l0aCgnJCcpIH0pIGBcbiAgbWFyZ2luLXJpZ2h0OiA4cHg7XG4gIHBhdGgge1xuICAgIHN0cm9rZTogJHsoeyB0aGVtZSwgJGRpc2FibGVkIH0pID0+ICgkZGlzYWJsZWQgPyB0aGVtZS5zdGlnZy5wYWxldHRlLnRleHQuZGlzYWJsZWQgOiB0aGVtZS5zdGlnZy5wYWxldHRlLnByaW1hcnkpfTtcbiAgfVxuYDtcclxuZXhwb3J0IGNvbnN0IEFkZFByb21vdGlvbkNvZGVCdXR0b24gPSAoeyBvbkFkZENsaWNrLCBjaGVja291dExvY2FsaXphdGlvbiwgZGlzYWJsZWQgfSkgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQnV0dG9uLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgZnVsbFdpZHRoOiB0cnVlLCBjbGFzc05hbWU6IFwic3RpZ2ctY2hlY2tvdXQtc3VtbWFyeS1hZGQtY291cG9uLWNvZGUtYnV0dG9uXCIsIHN4OiB7XHJcbiAgICAgICAgdGV4dFRyYW5zZm9ybTogJ25vbmUnLFxyXG4gICAgICAgIGp1c3RpZnlDb250ZW50OiAnZmxleC1zdGFydCcsXHJcbiAgICAgICAgY29sb3I6IGRpc2FibGVkID8gJ3RleHQuZGlzYWJsZWQnIDogJ3ByaW1hcnkubWFpbicsXHJcbiAgICB9LCB2YXJpYW50OiBcInRleHRcIiwgc2l6ZTogXCJtZWRpdW1cIiwgb25DbGljazogb25BZGRDbGljayB9LFxyXG4gICAgUmVhY3QuY3JlYXRlRWxlbWVudChTdHlsZWRQbHVzSWNvbiwgeyBcIiRkaXNhYmxlZFwiOiBkaXNhYmxlZCwgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LXN1bW1hcnktYWRkLWNvdXBvbi1jb2RlLWJ1dHRvbi1pY29uXCIgfSksXHJcbiAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLWNoZWNrb3V0LWNoYW5nZS1wbGFuLWJ1dHRvbi10ZXh0XCIsIGNvbG9yOiBkaXNhYmxlZCA/ICdkaXNhYmxlZCcgOiAncHJpbWFyeS5tYWluJywgc3R5bGU6IHsgbGluZUhlaWdodDogJzI0cHgnIH0sIHZhcmlhbnQ6IFwiaDNcIiB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LmFkZENvdXBvbkNvZGVUZXh0KSkpO1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1BZGRQcm9tb3Rpb25Db2RlQnV0dG9uLmpzLm1hcCJdfQ== */"));
|
|
8079
8098
|
|
|
8080
8099
|
var AddPromotionCodeButton = function AddPromotionCodeButton(_ref2) {
|
|
8081
8100
|
var onAddClick = _ref2.onAddClick,
|
|
@@ -8102,7 +8121,7 @@ var AddPromotionCodeButton = function AddPromotionCodeButton(_ref2) {
|
|
|
8102
8121
|
style: {
|
|
8103
8122
|
lineHeight: '24px'
|
|
8104
8123
|
},
|
|
8105
|
-
variant: "
|
|
8124
|
+
variant: "h3"
|
|
8106
8125
|
}, checkoutLocalization.summary.addCouponCodeText));
|
|
8107
8126
|
};
|
|
8108
8127
|
|
|
@@ -12172,7 +12191,7 @@ var NextBillingCaption = function NextBillingCaption(_ref3) {
|
|
|
12172
12191
|
|
|
12173
12192
|
text += totalAmountText + "for this subscription every " + billingPeriodText + " on " + nextBillingDate + ", unless you cancel.";
|
|
12174
12193
|
return React__default.createElement(Typography, {
|
|
12175
|
-
variant: "
|
|
12194
|
+
variant: "body1",
|
|
12176
12195
|
style: {
|
|
12177
12196
|
marginTop: 14
|
|
12178
12197
|
}
|
|
@@ -12422,7 +12441,7 @@ var SummaryContainer = /*#__PURE__*/_styled(Box$1, process.env.NODE_ENV === "pro
|
|
|
12422
12441
|
} : {
|
|
12423
12442
|
name: "kj9yp4",
|
|
12424
12443
|
styles: "max-width:470px;flex:1.5",
|
|
12425
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAmB4C","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h6\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12444
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAmB4C","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12426
12445
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12427
12446
|
});
|
|
12428
12447
|
var SummaryCard = /*#__PURE__*/_styled(Paper, process.env.NODE_ENV === "production" ? {
|
|
@@ -12433,7 +12452,7 @@ var SummaryCard = /*#__PURE__*/_styled(Paper, process.env.NODE_ENV === "producti
|
|
|
12433
12452
|
})("border-radius:10px;background:", function (_ref) {
|
|
12434
12453
|
var theme = _ref.theme;
|
|
12435
12454
|
return theme.stigg.palette.backgroundHighlight;
|
|
12436
|
-
}, ";padding:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAuByC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h6\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */"));
|
|
12455
|
+
}, ";padding:16px;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAuByC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */"));
|
|
12437
12456
|
SummaryCard.defaultProps = {
|
|
12438
12457
|
elevation: 0
|
|
12439
12458
|
};
|
|
@@ -12449,7 +12468,7 @@ var SummaryTitle = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "pr
|
|
|
12449
12468
|
} : {
|
|
12450
12469
|
name: "1jcocwa",
|
|
12451
12470
|
styles: "margin-bottom:16px;font-weight:500",
|
|
12452
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA+BwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h6\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12471
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AA+BwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12453
12472
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12454
12473
|
});
|
|
12455
12474
|
|
|
@@ -12464,7 +12483,7 @@ var StyledDivider$1 = /*#__PURE__*/_styled(Divider$1, process.env.NODE_ENV === "
|
|
|
12464
12483
|
} : {
|
|
12465
12484
|
name: "1k6141t",
|
|
12466
12485
|
styles: "margin:16px 0",
|
|
12467
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAmCsC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h6\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12486
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAmCsC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12468
12487
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12469
12488
|
});
|
|
12470
12489
|
|
|
@@ -12479,7 +12498,7 @@ var TotalDueText = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "pr
|
|
|
12479
12498
|
} : {
|
|
12480
12499
|
name: "5bhc30",
|
|
12481
12500
|
styles: "margin-bottom:8px",
|
|
12482
|
-
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAsCwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h6\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12501
|
+
map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["CheckoutSummary.tsx"],"names":[],"mappings":"AAsCwC","file":"CheckoutSummary.tsx","sourcesContent":["import React, { useState } from 'react';\r\nimport partition from 'lodash/partition';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Box, CircularProgress, Divider, Grid, Paper } from '@mui/material';\r\nimport { BillingModel } from '@stigg/js-client-sdk';\r\nimport { PoweredByStigg } from '../../common/PoweredByStigg';\r\nimport { Typography } from '../../common/Typography';\r\nimport { useChargesSort } from '../../hooks/useChargeSort';\r\nimport { currencyPriceFormatter } from '../../utils/currencyUtils';\r\nimport { Button } from '../components';\r\nimport { useCheckoutModel, useProgressBarModel, usePreviewSubscription, useSubscriptionModel, usePaymentStepModel, } from '../hooks';\r\nimport { PromotionCodeSection } from '../promotionCode';\r\nimport { useSubmit } from '../steps/payment/stripe';\r\nimport { CheckoutCaptions } from './components/CheckoutCaptions';\r\nimport { AppliedCreditsLineItem, BilledPriceLineItem, DiscountLineItem, FreeChargeLineItem, LineItemContainer, LineItemRow, TaxLineItem, } from './components/LineItems';\r\nimport { WithSkeleton } from './components/WithSkeleton';\r\nimport { Icon } from '../../common/Icon';\r\nimport { CheckoutSuccess } from './CheckoutSuccess';\r\nimport { getFeatureDisplayNameText } from '../../utils/getFeatureName';\r\nexport const SummaryContainer = styled(Box) `\n  max-width: 470px;\n  flex: 1.5;\n`;\r\nexport const SummaryCard = styled(Paper) `\n  border-radius: 10px;\n  background: ${({ theme }) => theme.stigg.palette.backgroundHighlight};\n  padding: 16px;\n`;\r\nSummaryCard.defaultProps = {\r\n    elevation: 0,\r\n};\r\nconst SummaryTitle = styled(Typography) `\n  margin-bottom: 16px;\n  font-weight: 500;\n`;\r\nconst StyledDivider = styled(Divider) `\n  margin: 16px 0;\n`;\r\nconst TotalDueText = styled(Typography) `\n  margin-bottom: 8px;\n`;\r\nfunction resolveCheckoutButtonText({ isLastStep, checkoutHasChanges, isFreeDowngrade, checkoutLocalization, isPlanUpdate, }) {\r\n    if (!isLastStep) {\r\n        return checkoutLocalization.checkoutButton.nextText;\r\n    }\r\n    if (!checkoutHasChanges) {\r\n        return checkoutLocalization.checkoutButton.noChangesText;\r\n    }\r\n    if (isPlanUpdate) {\r\n        return checkoutLocalization.checkoutButton.updateText;\r\n    }\r\n    if (isFreeDowngrade) {\r\n        return checkoutLocalization.checkoutButton.downgradeToFreeText;\r\n    }\r\n    return checkoutLocalization.checkoutButton.upgradeText;\r\n}\r\nexport const CheckoutSummary = ({ onCheckout, onCheckoutCompleted, disablePromotionCode, disableSuccessAnimation, isFreeDowngrade, onMockCheckoutPreview, }) => {\r\n    const [isCheckoutCompletedSuccessfully, setIsCheckoutCompletedSuccessfully] = useState(false);\r\n    const { setErrorMessage } = usePaymentStepModel();\r\n    const progressBar = useProgressBarModel();\r\n    const subscription = useSubscriptionModel();\r\n    const { checkoutState, checkoutLocalization } = useCheckoutModel();\r\n    const { plan, activeSubscription } = checkoutState || {};\r\n    const planPrices = useChargesSort(plan?.pricePoints?.filter((price) => price.billingPeriod === subscription.billingPeriod) || []);\r\n    const [baseCharges, usageCharges] = partition(planPrices, (price) => price.pricingModel === BillingModel.FlatFee);\r\n    const [baseCharge] = baseCharges || [];\r\n    const isLastStep = isFreeDowngrade || (progressBar.isCheckoutComplete && progressBar.isLastStep);\r\n    const { subscriptionPreview, isFetchingSubscriptionPreview } = usePreviewSubscription({ onMockCheckoutPreview });\r\n    const { handleSubmit, isLoading } = useSubmit({\r\n        disableSuccessAnimation,\r\n        onCheckout,\r\n        onCheckoutCompleted,\r\n        onSuccess: () => {\r\n            setIsCheckoutCompletedSuccessfully(true);\r\n            progressBar.markStepAsCompleted(progressBar.progressBarState.activeStep);\r\n        },\r\n    });\r\n    const handleCheckout = async (e) => {\r\n        if (isCheckoutCompletedSuccessfully) {\r\n            return;\r\n        }\r\n        const { errorMessage } = (await handleSubmit(e)) || {};\r\n        if (errorMessage) {\r\n            setErrorMessage(errorMessage);\r\n            setIsCheckoutCompletedSuccessfully(false);\r\n        }\r\n        else {\r\n            setErrorMessage(undefined);\r\n        }\r\n    };\r\n    const onCheckoutClick = async (e) => {\r\n        if (isLoading) {\r\n            return;\r\n        }\r\n        if (isLastStep) {\r\n            await handleCheckout(e);\r\n        }\r\n        else {\r\n            progressBar.goNext();\r\n        }\r\n    };\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!subscriptionPreview?.recurringSubscription &&\r\n        !!subscriptionPreview?.recurringSubscription?.discountDetails &&\r\n        !isFreeDowngrade;\r\n    const hasDiscounts = showPromotionCodeLine || showDiscountLine;\r\n    const hasPayAsYouGoCharges = usageCharges.some((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const onlyPayAsYouGoCharges = hasPayAsYouGoCharges &&\r\n        !baseCharge &&\r\n        usageCharges.every((price) => price.pricingModel === BillingModel.UsageBased);\r\n    const baseChargeLabel = typeof checkoutLocalization.summary.baseChargeText === 'function'\r\n        ? checkoutLocalization.summary.baseChargeText({ billingPeriod: subscription.billingPeriod })\r\n        : checkoutLocalization.summary.baseChargeText;\r\n    return (React.createElement(SummaryContainer, null,\r\n        React.createElement(SummaryCard, null,\r\n            React.createElement(SummaryTitle, { variant: \"h3\" }, checkoutLocalization.summary.title),\r\n            React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.planName({ plan: plan })),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n            baseCharge && (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, label: baseChargeLabel, quantity: 1, price: baseCharge })),\r\n            !baseCharge && isFreeDowngrade ? React.createElement(FreeChargeLineItem, { label: baseChargeLabel }) : null,\r\n            usageCharges.map((price) => {\r\n                const priceBillableFeature = subscription.billableFeatures?.find((billableFeature) => billableFeature.featureId === price.feature?.featureId);\r\n                return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: price.feature?.featureId, label: getFeatureDisplayNameText(price.feature?.displayName || '', price.feature?.units, price.feature?.unitsPlural), quantity: priceBillableFeature?.quantity || 1, price: price }));\r\n            }),\r\n            !!subscription.addons?.length && (React.createElement(React.Fragment, null,\r\n                React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                    React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.addonsSectionTitle),\r\n                    React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } })),\r\n                subscription.addons.map((addon) => {\r\n                    const addonPrice = addon.addon.pricePoints?.find((price) => price.billingPeriod === subscription.billingPeriod);\r\n                    if (!addonPrice)\r\n                        return null;\r\n                    const addonQuantity = addon.quantity && addon.quantity > 0 ? addon.quantity : 1;\r\n                    return (React.createElement(BilledPriceLineItem, { checkoutLocalization: checkoutLocalization, key: addon?.addon?.id, label: addon.addon.displayName, quantity: addonQuantity, price: addonPrice }));\r\n                }))),\r\n            !hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            hasDiscounts && (React.createElement(Grid, { display: \"flex\", flexDirection: \"row\", alignItems: \"center\", marginY: 2 },\r\n                React.createElement(Typography, { variant: \"h6\", color: \"primary\", style: { paddingRight: '8px' } }, checkoutLocalization.summary.discountsSectionTitle),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\", sx: { flex: 1, margin: '0 !important' } }))),\r\n            showPromotionCodeLine && (React.createElement(PromotionCodeSection, { disabled: isLoading || isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, onMockCheckoutPreview: onMockCheckoutPreview })),\r\n            showDiscountLine && (React.createElement(DiscountLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization })),\r\n            hasDiscounts && React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }),\r\n            React.createElement(TaxLineItem, { tax: subscriptionPreview?.recurringSubscription?.tax, taxDetails: subscriptionPreview?.recurringSubscription?.taxDetails, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            !isFreeDowngrade ? (React.createElement(React.Fragment, null,\r\n                React.createElement(LineItemRow, { style: { marginTop: 16 } },\r\n                    React.createElement(Grid, { display: \"flex\", flexDirection: \"column\", container: true },\r\n                        React.createElement(Grid, { item: true, display: \"flex\", justifyContent: \"space-between\" },\r\n                            React.createElement(Typography, { variant: \"h6\" }, checkoutLocalization.summary.totalText),\r\n                            React.createElement(Typography, { variant: \"h6\" },\r\n                                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview },\r\n                                    onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null,\r\n                                    !onlyPayAsYouGoCharges && hasPayAsYouGoCharges\r\n                                        ? checkoutLocalization.summary.startsAtText\r\n                                        : null,\r\n                                    !onlyPayAsYouGoCharges\r\n                                        ? currencyPriceFormatter({\r\n                                            amount: 0,\r\n                                            ...subscriptionPreview?.recurringSubscription?.total,\r\n                                            minimumFractionDigits: 2,\r\n                                        })\r\n                                        : null))),\r\n                        React.createElement(Grid, { item: true },\r\n                            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.totalBillingPeriodText({ billingPeriod: subscription.billingPeriod }))))),\r\n                React.createElement(StyledDivider, { className: \"stigg-checkout-summary-divider\" }))) : null,\r\n            subscriptionPreview?.subTotal && subscriptionPreview?.subTotal.amount > 0 ? (React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.proratedTotalDueText),\r\n                    React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                            amount: subscriptionPreview?.subTotal.amount + (subscriptionPreview?.tax?.amount || 0),\r\n                            currency: subscriptionPreview?.subTotal.currency,\r\n                            minimumFractionDigits: 2,\r\n                        })))))) : null,\r\n            React.createElement(AppliedCreditsLineItem, { subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization }),\r\n            React.createElement(LineItemContainer, null,\r\n                React.createElement(LineItemRow, null,\r\n                    React.createElement(TotalDueText, { variant: \"h6\" }, checkoutLocalization.summary.totalDueText),\r\n                    React.createElement(TotalDueText, { variant: \"h6\" },\r\n                        React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: 0, ...subscriptionPreview?.total, minimumFractionDigits: 2 }))))),\r\n            React.createElement(CheckoutCaptions, { plan: plan, activeSubscription: activeSubscription, subscriptionPreview: subscriptionPreview, isFetchingSubscriptionPreview: isFetchingSubscriptionPreview, checkoutLocalization: checkoutLocalization, billingPeriod: subscription.billingPeriod }),\r\n            React.createElement(Button, { \"$success\": isCheckoutCompletedSuccessfully, \"$error\": isLastStep && isFreeDowngrade, disabled: isLoading ||\r\n                    isFetchingSubscriptionPreview ||\r\n                    progressBar.progressBarState.isDisabled ||\r\n                    (isLastStep && !checkoutHasChanges), className: \"stigg-checkout-summary-cta-button\", sx: { textTransform: 'none', borderRadius: '10px', marginTop: '24px', height: '36px' }, variant: \"contained\", size: \"medium\", onClick: (e) => {\r\n                    void onCheckoutClick(e);\r\n                }, fullWidth: true },\r\n                React.createElement(Typography, { className: \"stigg-checkout-summary-cta-button-text\", variant: \"h3\", color: \"white\", style: { display: 'flex' } }, isCheckoutCompletedSuccessfully ? (React.createElement(Icon, { icon: \"Check\", style: { display: 'contents' } })) : isLoading || isFetchingSubscriptionPreview ? (React.createElement(CircularProgress, { size: 20, sx: { color: 'white' } })) : (resolveCheckoutButtonText({\r\n                    isLastStep,\r\n                    checkoutHasChanges,\r\n                    isFreeDowngrade,\r\n                    checkoutLocalization,\r\n                    isPlanUpdate: !!activeSubscription && activeSubscription?.plan.id === plan?.id,\r\n                }))))),\r\n        React.createElement(PoweredByStigg, { source: \"checkout\", showWatermark: true, style: { marginTop: 8, display: 'flex', justifyContent: 'center' } }),\r\n        !disableSuccessAnimation && isCheckoutCompletedSuccessfully && (React.createElement(CheckoutSuccess, { checkoutLocalization: checkoutLocalization }))));\r\n};\r\n//# sourceMappingURL=CheckoutSummary.js.map"]} */",
|
|
12483
12502
|
toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
|
|
12484
12503
|
});
|
|
12485
12504
|
|
|
@@ -12679,14 +12698,14 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
12679
12698
|
billingPeriod: subscription.billingPeriod
|
|
12680
12699
|
}) : checkoutLocalization.summary.baseChargeText;
|
|
12681
12700
|
return React__default.createElement(SummaryContainer, null, React__default.createElement(SummaryCard, null, React__default.createElement(SummaryTitle, {
|
|
12682
|
-
variant: "
|
|
12701
|
+
variant: "h3"
|
|
12683
12702
|
}, checkoutLocalization.summary.title), React__default.createElement(Grid, {
|
|
12684
12703
|
display: "flex",
|
|
12685
12704
|
flexDirection: "row",
|
|
12686
12705
|
alignItems: "center",
|
|
12687
12706
|
marginY: 2
|
|
12688
12707
|
}, React__default.createElement(Typography, {
|
|
12689
|
-
variant: "
|
|
12708
|
+
variant: "h6",
|
|
12690
12709
|
color: "primary",
|
|
12691
12710
|
style: {
|
|
12692
12711
|
paddingRight: '8px'
|
|
@@ -12727,7 +12746,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
12727
12746
|
alignItems: "center",
|
|
12728
12747
|
marginY: 2
|
|
12729
12748
|
}, React__default.createElement(Typography, {
|
|
12730
|
-
variant: "
|
|
12749
|
+
variant: "h6",
|
|
12731
12750
|
color: "primary",
|
|
12732
12751
|
style: {
|
|
12733
12752
|
paddingRight: '8px'
|
|
@@ -12761,7 +12780,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
12761
12780
|
alignItems: "center",
|
|
12762
12781
|
marginY: 2
|
|
12763
12782
|
}, React__default.createElement(Typography, {
|
|
12764
|
-
variant: "
|
|
12783
|
+
variant: "h6",
|
|
12765
12784
|
color: "primary",
|
|
12766
12785
|
style: {
|
|
12767
12786
|
paddingRight: '8px'
|
|
@@ -12870,6 +12889,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
|
|
|
12870
12889
|
fullWidth: true
|
|
12871
12890
|
}, React__default.createElement(Typography, {
|
|
12872
12891
|
className: "stigg-checkout-summary-cta-button-text",
|
|
12892
|
+
variant: "h3",
|
|
12873
12893
|
color: "white",
|
|
12874
12894
|
style: {
|
|
12875
12895
|
display: 'flex'
|
|
@@ -13347,7 +13367,7 @@ var ChangePlanButton = function ChangePlanButton(_ref) {
|
|
|
13347
13367
|
}, React__default.createElement(Typography, {
|
|
13348
13368
|
className: "stigg-checkout-change-plan-button-text",
|
|
13349
13369
|
color: "primary.main",
|
|
13350
|
-
variant: "
|
|
13370
|
+
variant: "h3",
|
|
13351
13371
|
style: {
|
|
13352
13372
|
lineHeight: '24px'
|
|
13353
13373
|
}
|
|
@@ -13383,8 +13403,7 @@ function PlanHeader$1(_ref) {
|
|
|
13383
13403
|
justifyContent: 'space-between'
|
|
13384
13404
|
}
|
|
13385
13405
|
}, React__default.createElement(Typography, {
|
|
13386
|
-
variant: "
|
|
13387
|
-
bold: true
|
|
13406
|
+
variant: "h1"
|
|
13388
13407
|
}, plan == null ? void 0 : plan.displayName), allowChangePlan && onChangePlan && React__default.createElement(ChangePlanButton, {
|
|
13389
13408
|
onClick: function onClick() {
|
|
13390
13409
|
onChangePlan({
|
|
@@ -13536,7 +13555,7 @@ var BillingPeriodOption = function BillingPeriodOption(_ref) {
|
|
|
13536
13555
|
marginRight: '8px'
|
|
13537
13556
|
}
|
|
13538
13557
|
}), React__default.createElement(Box$1, null, React__default.createElement(Typography, {
|
|
13539
|
-
variant: "
|
|
13558
|
+
variant: "h3",
|
|
13540
13559
|
color: "primary"
|
|
13541
13560
|
}, formatBillingPeriod(billingPeriod))));
|
|
13542
13561
|
};
|