@stigg/react-sdk 4.4.5 → 4.5.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -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+IHRoZW1lLnN0aWdnLnBhbGV0dGUucHJpbWFyeX0gIWltcG9ydGFudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFRpZXJzU2VsZWN0Q29udGFpbmVyKHsgY29tcG9uZW50SWQsIHRpZXJzLCBzZWxlY3RlZFRpZXIsIGhhbmRsZVRpZXJDaGFuZ2UsIH0pIHtcclxuICAgIGNvbnN0IGhhbmRsZUNoYW5nZSA9IChldmVudCwgXykgPT4ge1xyXG4gICAgICAgIGlmICghdGllcnMpXHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICBoYW5kbGVUaWVyQ2hhbmdlKGdldFRpZXJCeVF1YW50aXR5KHRpZXJzLCBldmVudC50YXJnZXQudmFsdWUpKTtcclxuICAgIH07XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGllci1zZWxlY3RcIiwgc3R5bGU6IHsgbWluSGVpZ2h0OiAnNDZweCcgfSB9LCB0aWVycyA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJTZWxlY3QsIHsgdmFsdWU6IHNlbGVjdGVkVGllciA/IHNlbGVjdGVkVGllci51cFRvLnRvU3RyaW5nKCkgOiB0aWVyc1swXS51cFRvLnRvU3RyaW5nKCksIGZ1bGxXaWR0aDogdHJ1ZSwgb25DaGFuZ2U6IGhhbmRsZUNoYW5nZSwgaWQ6IGNvbXBvbmVudElkLCBpbnB1dDogUmVhY3QuY3JlYXRlRWxlbWVudChUaWVySW5wdXQsIG51bGwpLCBNZW51UHJvcHM6IHtcclxuICAgICAgICAgICAgTWVudUxpc3RQcm9wczogeyBkaXNhYmxlUGFkZGluZzogdHJ1ZSB9LFxyXG4gICAgICAgICAgICBQYXBlclByb3BzOiB7XHJcbiAgICAgICAgICAgICAgICBzeDogeyBtYXJnaW5Ub3A6ICc0cHgnLCBib3JkZXJSYWRpdXM6ICcxMHB4JyB9LFxyXG4gICAgICAgICAgICB9LFxyXG4gICAgICAgIH0gfSwgbWFwKHRpZXJzLCAodGllcikgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTWVudUl0ZW0sIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRpZXItbWVudS1pdGVtLXRleHRcIiwga2V5OiB0aWVyLnVwVG8sIHZhbHVlOiB0aWVyLnVwVG8udG9TdHJpbmcoKSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInByaW1hcnlcIiwgc3R5bGU6IHsgbGluZUhlaWdodDogJ3Vuc2V0JyB9IH0sIHRpZXIudXBUbykpKSkpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRpZXJzU2VsZWN0Q29udGFpbmVyLmpzLm1hcCJdfQ== */"));
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+IHRoZW1lLnN0aWdnLnBhbGV0dGUucHJpbWFyeX0gIWltcG9ydGFudDtcbiAgfVxuYDtcclxuZXhwb3J0IGZ1bmN0aW9uIFRpZXJzU2VsZWN0Q29udGFpbmVyKHsgY29tcG9uZW50SWQsIHRpZXJzLCBzZWxlY3RlZFRpZXIsIGhhbmRsZVRpZXJDaGFuZ2UsIH0pIHtcclxuICAgIGNvbnN0IGhhbmRsZUNoYW5nZSA9IChldmVudCwgXykgPT4ge1xyXG4gICAgICAgIGlmICghdGllcnMpXHJcbiAgICAgICAgICAgIHJldHVybjtcclxuICAgICAgICBoYW5kbGVUaWVyQ2hhbmdlKGdldFRpZXJCeVF1YW50aXR5KHRpZXJzLCBldmVudC50YXJnZXQudmFsdWUpKTtcclxuICAgIH07XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyBjbGFzc05hbWU6IFwic3RpZ2ctcHJpY2UtdGllci1zZWxlY3RcIiwgc3R5bGU6IHsgbWluSGVpZ2h0OiAnNDZweCcgfSB9LCB0aWVycyA/IChSZWFjdC5jcmVhdGVFbGVtZW50KFRpZXJTZWxlY3QsIHsgdmFsdWU6IHNlbGVjdGVkVGllciA/IHNlbGVjdGVkVGllci51cFRvLnRvU3RyaW5nKCkgOiB0aWVyc1swXS51cFRvLnRvU3RyaW5nKCksIGZ1bGxXaWR0aDogdHJ1ZSwgb25DaGFuZ2U6IGhhbmRsZUNoYW5nZSwgaWQ6IGNvbXBvbmVudElkLCBpbnB1dDogUmVhY3QuY3JlYXRlRWxlbWVudChUaWVySW5wdXQsIG51bGwpLCBNZW51UHJvcHM6IHtcclxuICAgICAgICAgICAgTWVudUxpc3RQcm9wczogeyBkaXNhYmxlUGFkZGluZzogdHJ1ZSB9LFxyXG4gICAgICAgICAgICBQYXBlclByb3BzOiB7XHJcbiAgICAgICAgICAgICAgICBzeDogeyBtYXJnaW5Ub3A6ICc0cHgnLCBib3JkZXJSYWRpdXM6ICcxMHB4JyB9LFxyXG4gICAgICAgICAgICB9LFxyXG4gICAgICAgIH0gfSwgbWFwKHRpZXJzLCAodGllcikgPT4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoTWVudUl0ZW0sIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXRpZXItbWVudS1pdGVtLXRleHRcIiwga2V5OiB0aWVyLnVwVG8sIHZhbHVlOiB0aWVyLnVwVG8udG9TdHJpbmcoKSB9LFxyXG4gICAgICAgIFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcInByaW1hcnlcIiwgc3R5bGU6IHsgbGluZUhlaWdodDogJ3Vuc2V0JyB9IH0sIHRpZXIudXBUbykpKSkpKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KFwiZGl2XCIsIG51bGwpKSkpO1xyXG59XHJcbi8vIyBzb3VyY2VNYXBwaW5nVVJMPVRpZXJzU2VsZWN0Q29udGFpbmVyLmpzLm1hcCJdfQ== */"));
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBTThDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBUaWVyc1NlbGVjdENvbnRhaW5lciB9IGZyb20gJy4uL2NvbW1vbi9UaWVyc1NlbGVjdENvbnRhaW5lcic7XHJcbmNvbnN0IEVNUFRZX0NIQVIgPSAn4oCOJztcclxuY29uc3QgUGxhblByaWNlQ29udGFpbmVyID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBVbml0U3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xyXG5jb25zdCBQcmljZVNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICBtaW4taGVpZ2h0OiAzOXB4O1xuYDtcclxuZnVuY3Rpb24gUHJpY2VCaWxsaW5nUGVyaW9kKHsgcGxhbiwgYmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCBwYXl3YWxsTG9jYWxlLCB9KSB7XHJcbiAgICBjb25zdCBoYXNQcmljZSA9IHBsYW4ucHJpY2VQb2ludHMuZmluZCgocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kKTtcclxuICAgIGxldCBjb250ZW50ID0gRU1QVFlfQ0hBUjtcclxuICAgIGlmIChoYXNQcmljZSAmJiBoYXNNb250aGx5UHJpY2UgJiYgaGFzQW5udWFsbHlQcmljZSkge1xyXG4gICAgICAgIGNvbnRlbnQgPSBwYXl3YWxsTG9jYWxlLnByaWNlLmJpbGxpbmdQZXJpb2Q/LihiaWxsaW5nUGVyaW9kKSB8fCBgLCBiaWxsZWQgJHtiaWxsaW5nUGVyaW9kLnRvTG93ZXJDYXNlKCl9YDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHNwYW46IHRydWUsIGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY29udGVudCkpO1xyXG59XHJcbmV4cG9ydCBjb25zdCBQbGFuUHJpY2UgPSAoeyBzaG93U3RhcnRpbmdBdCwgd2l0aFVuaXRQcmljZVJvdywgd2l0aFN0YXJ0aW5nQXRSb3csIHdpdGhUaWVyc1Jvdywgc2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUsIHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHByaWNlLCB1bml0LCB0aWVycyB9ID0gZ2V0UGxhblByaWNlKHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgY29uc3QgW3NlbGVjdGVkVGllciwgc2V0U2VsZWN0ZWRUaWVyXSA9IHVzZVN0YXRlKCk7XHJcbiAgICAvLyBXZSBjdXJyZW50bHkgb25seSBzdXBwb3J0IHByaWNlcyB3aXRoIG9uZSB0aWVyIC0gc28gd2Ugc2VsZWN0IHRoZSBmaXJzdCBvbmVcclxuICAgIGNvbnN0IHRpZXJlZFByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKChwbGFuUHJpY2UpID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlLmJpbGxpbmdQZXJpb2QgPT09IGJpbGxpbmdQZXJpb2QgJiYgcGxhblByaWNlLmlzVGllcmVkUHJpY2U7XHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGZlYXR1cmVJZCA9IHRpZXJlZFByaWNlID8gdGllcmVkUHJpY2UuZmVhdHVyZS5mZWF0dXJlSWQgOiB1bmRlZmluZWQ7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllcihmZWF0dXJlSWQgPyBzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSA6IHVuZGVmaW5lZCk7XHJcbiAgICB9LCBbZmVhdHVyZUlkLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmVdKTtcclxuICAgIGNvbnN0IGhhbmRsZVRpZXJDaGFuZ2UgPSAodGllcikgPT4ge1xyXG4gICAgICAgIGNvbnN0IHVwZGF0ZWRUaWVyQnlGZWF0dXJlID0ge307XHJcbiAgICAgICAgdXBkYXRlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSA9IHRpZXI7XHJcbiAgICAgICAgc2V0U2VsZWN0ZWRUaWVyQnlGZWF0dXJlKHVwZGF0ZWRUaWVyQnlGZWF0dXJlKTtcclxuICAgIH07XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGlmICh0aWVycykge1xyXG4gICAgICAgICAgICBoYW5kbGVUaWVyQ2hhbmdlKHNlbGVjdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdKTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbXSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhblByaWNlQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS10ZXh0XCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgICAgICB3aXRoU3RhcnRpbmdBdFJvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHN0eWxlOiB7IG1pbkhlaWdodDogJzIwcHgnIH0sIGNsYXNzTmFtZTogXCJzdGlnZy1zdGFydGluZy1hdC10ZXh0XCIsIHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgc2hvd1N0YXJ0aW5nQXQgPyBwYXl3YWxsTG9jYWxlLnByaWNlLnN0YXJ0aW5nQXRDYXB0aW9uIDogRU1QVFlfQ0hBUikpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFByaWNlU3BhbiwgeyB2YXJpYW50OiBcImgxXCIgfSwgcHJpY2UpLFxyXG4gICAgICAgICAgICB3aXRoVW5pdFByaWNlUm93ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXVuaXQtYW5kLWJpbGxpbmctcGVyaW9kLXRleHRcIiwgc3R5bGU6IHsgbWluSGVpZ2h0OiAnNDhweCcgfSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChVbml0U3BhbiwgeyBzcGFuOiB0cnVlLCB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHVuaXQpLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQcmljZUJpbGxpbmdQZXJpb2QsIHsgcGxhbjogcGxhbiwgYmlsbGluZ1BlcmlvZDogYmlsbGluZ1BlcmlvZCwgaGFzQW5udWFsbHlQcmljZTogaGFzQW5udWFsbHlQcmljZSwgaGFzTW9udGhseVByaWNlOiBoYXNNb250aGx5UHJpY2UsIHBheXdhbGxMb2NhbGU6IHBheXdhbGxMb2NhbGUgfSkpKSxcclxuICAgICAgICAgICAgd2l0aFRpZXJzUm93ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllcnNTZWxlY3RDb250YWluZXIsIHsgY29tcG9uZW50SWQ6IGAke3BsYW4uaWR9XyR7ZmVhdHVyZUlkfV90aWVyYCwgdGllcnM6IHRpZXJzLCBzZWxlY3RlZFRpZXI6IHNlbGVjdGVkVGllciwgaGFuZGxlVGllckNoYW5nZTogaGFuZGxlVGllckNoYW5nZSB9KSkgOiBudWxsKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QbGFuUHJpY2UuanMubWFwIl19 */",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVW9DIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBUaWVyc1NlbGVjdENvbnRhaW5lciB9IGZyb20gJy4uL2NvbW1vbi9UaWVyc1NlbGVjdENvbnRhaW5lcic7XHJcbmNvbnN0IEVNUFRZX0NIQVIgPSAn4oCOJztcclxuY29uc3QgUGxhblByaWNlQ29udGFpbmVyID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBVbml0U3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xyXG5jb25zdCBQcmljZVNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICBtaW4taGVpZ2h0OiAzOXB4O1xuYDtcclxuZnVuY3Rpb24gUHJpY2VCaWxsaW5nUGVyaW9kKHsgcGxhbiwgYmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCBwYXl3YWxsTG9jYWxlLCB9KSB7XHJcbiAgICBjb25zdCBoYXNQcmljZSA9IHBsYW4ucHJpY2VQb2ludHMuZmluZCgocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kKTtcclxuICAgIGxldCBjb250ZW50ID0gRU1QVFlfQ0hBUjtcclxuICAgIGlmIChoYXNQcmljZSAmJiBoYXNNb250aGx5UHJpY2UgJiYgaGFzQW5udWFsbHlQcmljZSkge1xyXG4gICAgICAgIGNvbnRlbnQgPSBwYXl3YWxsTG9jYWxlLnByaWNlLmJpbGxpbmdQZXJpb2Q/LihiaWxsaW5nUGVyaW9kKSB8fCBgLCBiaWxsZWQgJHtiaWxsaW5nUGVyaW9kLnRvTG93ZXJDYXNlKCl9YDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHNwYW46IHRydWUsIGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY29udGVudCkpO1xyXG59XHJcbmV4cG9ydCBjb25zdCBQbGFuUHJpY2UgPSAoeyBzaG93U3RhcnRpbmdBdCwgd2l0aFVuaXRQcmljZVJvdywgd2l0aFN0YXJ0aW5nQXRSb3csIHdpdGhUaWVyc1Jvdywgc2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUsIHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHByaWNlLCB1bml0LCB0aWVycyB9ID0gZ2V0UGxhblByaWNlKHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgY29uc3QgW3NlbGVjdGVkVGllciwgc2V0U2VsZWN0ZWRUaWVyXSA9IHVzZVN0YXRlKCk7XHJcbiAgICAvLyBXZSBjdXJyZW50bHkgb25seSBzdXBwb3J0IHByaWNlcyB3aXRoIG9uZSB0aWVyIC0gc28gd2Ugc2VsZWN0IHRoZSBmaXJzdCBvbmVcclxuICAgIGNvbnN0IHRpZXJlZFByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKChwbGFuUHJpY2UpID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlLmJpbGxpbmdQZXJpb2QgPT09IGJpbGxpbmdQZXJpb2QgJiYgcGxhblByaWNlLmlzVGllcmVkUHJpY2U7XHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGZlYXR1cmVJZCA9IHRpZXJlZFByaWNlID8gdGllcmVkUHJpY2UuZmVhdHVyZS5mZWF0dXJlSWQgOiB1bmRlZmluZWQ7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllcihmZWF0dXJlSWQgPyBzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSA6IHVuZGVmaW5lZCk7XHJcbiAgICB9LCBbZmVhdHVyZUlkLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmVdKTtcclxuICAgIGNvbnN0IGhhbmRsZVRpZXJDaGFuZ2UgPSAodGllcikgPT4ge1xyXG4gICAgICAgIGNvbnN0IHVwZGF0ZWRUaWVyQnlGZWF0dXJlID0ge307XHJcbiAgICAgICAgdXBkYXRlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSA9IHRpZXI7XHJcbiAgICAgICAgc2V0U2VsZWN0ZWRUaWVyQnlGZWF0dXJlKHVwZGF0ZWRUaWVyQnlGZWF0dXJlKTtcclxuICAgIH07XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGlmICh0aWVycykge1xyXG4gICAgICAgICAgICBoYW5kbGVUaWVyQ2hhbmdlKHNlbGVjdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdKTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbXSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhblByaWNlQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS10ZXh0XCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgICAgICB3aXRoU3RhcnRpbmdBdFJvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHN0eWxlOiB7IG1pbkhlaWdodDogJzIwcHgnIH0sIGNsYXNzTmFtZTogXCJzdGlnZy1zdGFydGluZy1hdC10ZXh0XCIsIHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgc2hvd1N0YXJ0aW5nQXQgPyBwYXl3YWxsTG9jYWxlLnByaWNlLnN0YXJ0aW5nQXRDYXB0aW9uIDogRU1QVFlfQ0hBUikpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFByaWNlU3BhbiwgeyB2YXJpYW50OiBcImgxXCIgfSwgcHJpY2UpLFxyXG4gICAgICAgICAgICB3aXRoVW5pdFByaWNlUm93ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXVuaXQtYW5kLWJpbGxpbmctcGVyaW9kLXRleHRcIiwgc3R5bGU6IHsgbWluSGVpZ2h0OiAnNDhweCcgfSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChVbml0U3BhbiwgeyBzcGFuOiB0cnVlLCB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHVuaXQpLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQcmljZUJpbGxpbmdQZXJpb2QsIHsgcGxhbjogcGxhbiwgYmlsbGluZ1BlcmlvZDogYmlsbGluZ1BlcmlvZCwgaGFzQW5udWFsbHlQcmljZTogaGFzQW5udWFsbHlQcmljZSwgaGFzTW9udGhseVByaWNlOiBoYXNNb250aGx5UHJpY2UsIHBheXdhbGxMb2NhbGU6IHBheXdhbGxMb2NhbGUgfSkpKSxcclxuICAgICAgICAgICAgd2l0aFRpZXJzUm93ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllcnNTZWxlY3RDb250YWluZXIsIHsgY29tcG9uZW50SWQ6IGAke3BsYW4uaWR9XyR7ZmVhdHVyZUlkfV90aWVyYCwgdGllcnM6IHRpZXJzLCBzZWxlY3RlZFRpZXI6IHNlbGVjdGVkVGllciwgaGFuZGxlVGllckNoYW5nZTogaGFuZGxlVGllckNoYW5nZSB9KSkgOiBudWxsKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QbGFuUHJpY2UuanMubWFwIl19 */",
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIlBsYW5QcmljZS50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBYXFDIiwiZmlsZSI6IlBsYW5QcmljZS50c3giLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgUmVhY3QsIHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBnZXRQbGFuUHJpY2UgfSBmcm9tICcuLi91dGlscy9nZXRQbGFuUHJpY2UnO1xyXG5pbXBvcnQgeyBUeXBvZ3JhcGh5IH0gZnJvbSAnLi4vY29tbW9uL1R5cG9ncmFwaHknO1xyXG5pbXBvcnQgeyBUaWVyc1NlbGVjdENvbnRhaW5lciB9IGZyb20gJy4uL2NvbW1vbi9UaWVyc1NlbGVjdENvbnRhaW5lcic7XHJcbmNvbnN0IEVNUFRZX0NIQVIgPSAn4oCOJztcclxuY29uc3QgUGxhblByaWNlQ29udGFpbmVyID0gc3R5bGVkKFR5cG9ncmFwaHkpIGBcbiAgd29yZC1icmVhazogYnJlYWstd29yZDtcbiAgd2lkdGg6IDEwMCU7XG5gO1xyXG5jb25zdCBVbml0U3BhbiA9IHN0eWxlZChUeXBvZ3JhcGh5KSBgXG4gIHdoaXRlLXNwYWNlOiBub3dyYXA7XG5gO1xyXG5jb25zdCBQcmljZVNwYW4gPSBzdHlsZWQoVHlwb2dyYXBoeSkgYFxuICB3aGl0ZS1zcGFjZTogbm9ybWFsO1xuICBtaW4taGVpZ2h0OiAzOXB4O1xuYDtcclxuZnVuY3Rpb24gUHJpY2VCaWxsaW5nUGVyaW9kKHsgcGxhbiwgYmlsbGluZ1BlcmlvZCwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCBwYXl3YWxsTG9jYWxlLCB9KSB7XHJcbiAgICBjb25zdCBoYXNQcmljZSA9IHBsYW4ucHJpY2VQb2ludHMuZmluZCgocHJpY2VQb2ludCkgPT4gcHJpY2VQb2ludC5iaWxsaW5nUGVyaW9kID09PSBiaWxsaW5nUGVyaW9kKTtcclxuICAgIGxldCBjb250ZW50ID0gRU1QVFlfQ0hBUjtcclxuICAgIGlmIChoYXNQcmljZSAmJiBoYXNNb250aGx5UHJpY2UgJiYgaGFzQW5udWFsbHlQcmljZSkge1xyXG4gICAgICAgIGNvbnRlbnQgPSBwYXl3YWxsTG9jYWxlLnByaWNlLmJpbGxpbmdQZXJpb2Q/LihiaWxsaW5nUGVyaW9kKSB8fCBgLCBiaWxsZWQgJHtiaWxsaW5nUGVyaW9kLnRvTG93ZXJDYXNlKCl9YDtcclxuICAgIH1cclxuICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHNwYW46IHRydWUsIGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS1iaWxsaW5nLXBlcmlvZC10ZXh0XCIsIHZhcmlhbnQ6IFwiaDZcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgY29udGVudCkpO1xyXG59XHJcbmV4cG9ydCBjb25zdCBQbGFuUHJpY2UgPSAoeyBzaG93U3RhcnRpbmdBdCwgd2l0aFVuaXRQcmljZVJvdywgd2l0aFN0YXJ0aW5nQXRSb3csIHdpdGhUaWVyc1Jvdywgc2VsZWN0ZWRUaWVyQnlGZWF0dXJlLCBzZXRTZWxlY3RlZFRpZXJCeUZlYXR1cmUsIHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBoYXNBbm51YWxseVByaWNlLCB9KSA9PiB7XHJcbiAgICBjb25zdCB7IHByaWNlLCB1bml0LCB0aWVycyB9ID0gZ2V0UGxhblByaWNlKHBsYW4sIGJpbGxpbmdQZXJpb2QsIHBheXdhbGxMb2NhbGUsIGxvY2FsZSwgaGFzTW9udGhseVByaWNlLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmUpO1xyXG4gICAgY29uc3QgW3NlbGVjdGVkVGllciwgc2V0U2VsZWN0ZWRUaWVyXSA9IHVzZVN0YXRlKCk7XHJcbiAgICAvLyBXZSBjdXJyZW50bHkgb25seSBzdXBwb3J0IHByaWNlcyB3aXRoIG9uZSB0aWVyIC0gc28gd2Ugc2VsZWN0IHRoZSBmaXJzdCBvbmVcclxuICAgIGNvbnN0IHRpZXJlZFByaWNlID0gcGxhbi5wcmljZVBvaW50cy5maW5kKChwbGFuUHJpY2UpID0+IHtcclxuICAgICAgICByZXR1cm4gcGxhblByaWNlLmJpbGxpbmdQZXJpb2QgPT09IGJpbGxpbmdQZXJpb2QgJiYgcGxhblByaWNlLmlzVGllcmVkUHJpY2U7XHJcbiAgICB9KTtcclxuICAgIGNvbnN0IGZlYXR1cmVJZCA9IHRpZXJlZFByaWNlID8gdGllcmVkUHJpY2UuZmVhdHVyZS5mZWF0dXJlSWQgOiB1bmRlZmluZWQ7XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIHNldFNlbGVjdGVkVGllcihmZWF0dXJlSWQgPyBzZWxlY3RlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSA6IHVuZGVmaW5lZCk7XHJcbiAgICB9LCBbZmVhdHVyZUlkLCBzZWxlY3RlZFRpZXJCeUZlYXR1cmVdKTtcclxuICAgIGNvbnN0IGhhbmRsZVRpZXJDaGFuZ2UgPSAodGllcikgPT4ge1xyXG4gICAgICAgIGNvbnN0IHVwZGF0ZWRUaWVyQnlGZWF0dXJlID0ge307XHJcbiAgICAgICAgdXBkYXRlZFRpZXJCeUZlYXR1cmVbZmVhdHVyZUlkXSA9IHRpZXI7XHJcbiAgICAgICAgc2V0U2VsZWN0ZWRUaWVyQnlGZWF0dXJlKHVwZGF0ZWRUaWVyQnlGZWF0dXJlKTtcclxuICAgIH07XHJcbiAgICB1c2VFZmZlY3QoKCkgPT4ge1xyXG4gICAgICAgIGlmICh0aWVycykge1xyXG4gICAgICAgICAgICBoYW5kbGVUaWVyQ2hhbmdlKHNlbGVjdGVkVGllckJ5RmVhdHVyZVtmZWF0dXJlSWRdKTtcclxuICAgICAgICB9XHJcbiAgICB9LCBbXSk7XHJcbiAgICByZXR1cm4gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoUGxhblByaWNlQ29udGFpbmVyLCB7IGNsYXNzTmFtZTogXCJzdGlnZy1wcmljZS10ZXh0XCIgfSxcclxuICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFJlYWN0LkZyYWdtZW50LCBudWxsLFxyXG4gICAgICAgICAgICB3aXRoU3RhcnRpbmdBdFJvdyAmJiAoUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHN0eWxlOiB7IG1pbkhlaWdodDogJzIwcHgnIH0sIGNsYXNzTmFtZTogXCJzdGlnZy1zdGFydGluZy1hdC10ZXh0XCIsIHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IFwic2Vjb25kYXJ5XCIgfSwgc2hvd1N0YXJ0aW5nQXQgPyBwYXl3YWxsTG9jYWxlLnByaWNlLnN0YXJ0aW5nQXRDYXB0aW9uIDogRU1QVFlfQ0hBUikpLFxyXG4gICAgICAgICAgICBSZWFjdC5jcmVhdGVFbGVtZW50KFByaWNlU3BhbiwgeyB2YXJpYW50OiBcImgxXCIgfSwgcHJpY2UpLFxyXG4gICAgICAgICAgICB3aXRoVW5pdFByaWNlUm93ICYmIChSZWFjdC5jcmVhdGVFbGVtZW50KFR5cG9ncmFwaHksIHsgY2xhc3NOYW1lOiBcInN0aWdnLXByaWNlLXVuaXQtYW5kLWJpbGxpbmctcGVyaW9kLXRleHRcIiwgc3R5bGU6IHsgbWluSGVpZ2h0OiAnNDhweCcgfSB9LFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChVbml0U3BhbiwgeyBzcGFuOiB0cnVlLCB2YXJpYW50OiBcImg2XCIsIGNvbG9yOiBcInNlY29uZGFyeVwiIH0sIHVuaXQpLFxyXG4gICAgICAgICAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChQcmljZUJpbGxpbmdQZXJpb2QsIHsgcGxhbjogcGxhbiwgYmlsbGluZ1BlcmlvZDogYmlsbGluZ1BlcmlvZCwgaGFzQW5udWFsbHlQcmljZTogaGFzQW5udWFsbHlQcmljZSwgaGFzTW9udGhseVByaWNlOiBoYXNNb250aGx5UHJpY2UsIHBheXdhbGxMb2NhbGU6IHBheXdhbGxMb2NhbGUgfSkpKSxcclxuICAgICAgICAgICAgd2l0aFRpZXJzUm93ID8gKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVGllcnNTZWxlY3RDb250YWluZXIsIHsgY29tcG9uZW50SWQ6IGAke3BsYW4uaWR9XyR7ZmVhdHVyZUlkfV90aWVyYCwgdGllcnM6IHRpZXJzLCBzZWxlY3RlZFRpZXI6IHNlbGVjdGVkVGllciwgaGFuZGxlVGllckNoYW5nZTogaGFuZGxlVGllckNoYW5nZSB9KSkgOiBudWxsKSkpO1xyXG59O1xyXG4vLyMgc291cmNlTWFwcGluZ1VSTD1QbGFuUHJpY2UuanMubWFwIl19 */",
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
- useEffect(function () {
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
- var updatedTierByFeature = {};
1378
- updatedTierByFeature[featureId] = tier;
1379
- setSelectedTierByFeature(updatedTierByFeature);
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));
@@ -8135,7 +8133,7 @@ var CouponCodeAddButton = /*#__PURE__*/_styled(Button, process.env.NODE_ENV ===
8135
8133
  })("padding:4px 10px;min-width:unset;border-radius:", function (_ref) {
8136
8134
  var theme = _ref.theme;
8137
8135
  return theme.stigg.border.radius;
8138
- }, ";display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFkZFByb21vdGlvbkNvZGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVMyQyIsImZpbGUiOiJBZGRQcm9tb3Rpb25Db2RlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBDaXJjdWxhclByb2dyZXNzLCBHcmlkIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmltcG9ydCB7IEljb24gfSBmcm9tICcuLi8uLi9jb21tb24vSWNvbic7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IEJ1dHRvbiwgSW5wdXRGaWVsZCB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyB1c2VQcmV2aWV3U3Vic2NyaXB0aW9uQWN0aW9uIH0gZnJvbSAnLi4vaG9va3MnO1xyXG5pbXBvcnQgeyB1c2VQcm9tb3Rpb25Db2RlTW9kZWwgfSBmcm9tICcuLi9ob29rcy91c2VDb3Vwb25Nb2RlbCc7XHJcbmltcG9ydCB7IEFkZFByb21vdGlvbkNvZGVCdXR0b24gfSBmcm9tICcuL0FkZFByb21vdGlvbkNvZGVCdXR0b24nO1xyXG5jb25zdCBDb3Vwb25Db2RlQWRkQnV0dG9uID0gc3R5bGVkKEJ1dHRvbikgYFxuICBwYWRkaW5nOiA0cHggMTBweDtcbiAgbWluLXdpZHRoOiB1bnNldDtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5ib3JkZXIucmFkaXVzfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XHJcbmV4cG9ydCBjb25zdCBBZGRQcm9tb3Rpb25Db2RlID0gKHsgZGlzYWJsZWQsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCBvbk1vY2tDaGVja291dFByZXZpZXcsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgc2V0UHJvbW90aW9uQ29kZTogcGVyc2lzdFByb21vdGlvbkNvZGUgfSA9IHVzZVByb21vdGlvbkNvZGVNb2RlbCgpO1xyXG4gICAgY29uc3QgW3Nob3dJbnB1dCwgc2V0U2hvd0lucHV0XSA9IHVzZVN0YXRlKGZhbHNlKTtcclxuICAgIGNvbnN0IFtwcm9tb3Rpb25Db2RlLCBzZXRQcm9tb3Rpb25Db2RlXSA9IFJlYWN0LnVzZVN0YXRlKCcnKTtcclxuICAgIGNvbnN0IFtpc0xvYWRpbmcsIHNldElzTG9hZGluZ10gPSBSZWFjdC51c2VTdGF0ZShmYWxzZSk7XHJcbiAgICBjb25zdCBbZXJyb3JNZXNzYWdlLCBzZXRFcnJvck1lc3NhZ2VdID0gUmVhY3QudXNlU3RhdGUoJycpO1xyXG4gICAgY29uc3QgeyBwcmV2aWV3U3Vic2NyaXB0aW9uQWN0aW9uIH0gPSB1c2VQcmV2aWV3U3Vic2NyaXB0aW9uQWN0aW9uKHsgb25Nb2NrQ2hlY2tvdXRQcmV2aWV3IH0pO1xyXG4gICAgY29uc3QgaGFuZGxlUHJvbW90aW9uQ29kZSA9IGFzeW5jICgpID0+IHtcclxuICAgICAgICBzZXRJc0xvYWRpbmcodHJ1ZSk7XHJcbiAgICAgICAgc2V0RXJyb3JNZXNzYWdlKCcnKTtcclxuICAgICAgICBjb25zdCB7IHN1YnNjcmlwdGlvblByZXZpZXcsIGVycm9yTWVzc2FnZSB9ID0gYXdhaXQgcHJldmlld1N1YnNjcmlwdGlvbkFjdGlvbih7IHByb21vdGlvbkNvZGUgfSk7XHJcbiAgICAgICAgaWYgKCFlcnJvck1lc3NhZ2UgJiYgc3Vic2NyaXB0aW9uUHJldmlldz8uZGlzY291bnREZXRhaWxzKSB7XHJcbiAgICAgICAgICAgIHBlcnNpc3RQcm9tb3Rpb25Db2RlKHByb21vdGlvbkNvZGUudG9VcHBlckNhc2UoKSk7XHJcbiAgICAgICAgICAgIHNldFNob3dJbnB1dChmYWxzZSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2UgaWYgKGVycm9yTWVzc2FnZSkge1xyXG4gICAgICAgICAgICBzZXRFcnJvck1lc3NhZ2UoZXJyb3JNZXNzYWdlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgc2V0SXNMb2FkaW5nKGZhbHNlKTtcclxuICAgIH07XHJcbiAgICBpZiAoIXNob3dJbnB1dCkge1xyXG4gICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChBZGRQcm9tb3Rpb25Db2RlQnV0dG9uLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgb25BZGRDbGljazogKCkgPT4gc2V0U2hvd0lucHV0KHRydWUpLCBjaGVja291dExvY2FsaXphdGlvbjogY2hlY2tvdXRMb2NhbGl6YXRpb24gfSkpO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IGVycm9yTWVzc2FnZSA/ICdlcnJvcicgOiBkaXNhYmxlZCA/ICdkaXNhYmxlZCcgOiAncHJpbWFyeS5tYWluJyB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LmNvdXBvbkNvZGVUaXRsZSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dEZpZWxkLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgYXV0b0ZvY3VzOiB0cnVlLCB2YXJpYW50OiBcIm91dGxpbmVkXCIsIGZ1bGxXaWR0aDogdHJ1ZSwgZXJyb3I6ICEhZXJyb3JNZXNzYWdlLCB2YWx1ZTogcHJvbW90aW9uQ29kZSwgb25DaGFuZ2U6IChlKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBzZXRQcm9tb3Rpb25Db2RlKGUudGFyZ2V0LnZhbHVlKTtcclxuICAgICAgICAgICAgfSwgaW5wdXRQcm9wczogeyBtYXhMZW5ndGg6IDIwIH0sIG9uS2V5RG93bjogKGUpID0+IHtcclxuICAgICAgICAgICAgICAgIGlmIChlLmtleSA9PT0gJ0VudGVyJykge1xyXG4gICAgICAgICAgICAgICAgICAgIHZvaWQgaGFuZGxlUHJvbW90aW9uQ29kZSgpO1xyXG4gICAgICAgICAgICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfSwgXHJcbiAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC9qc3gtbm8tZHVwbGljYXRlLXByb3BzXHJcbiAgICAgICAgICAgIElucHV0UHJvcHM6IHtcclxuICAgICAgICAgICAgICAgIGVuZEFkb3JubWVudDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ291cG9uQ29kZUFkZEJ1dHRvbiwgeyB2YXJpYW50OiBcImNvbnRhaW5lZFwiLCBkaXNhYmxlZDogZGlzYWJsZWQsIG9uQ2xpY2s6ICgpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgdm9pZCBoYW5kbGVQcm9tb3Rpb25Db2RlKCk7XHJcbiAgICAgICAgICAgICAgICAgICAgfSB9LCBpc0xvYWRpbmcgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChDaXJjdWxhclByb2dyZXNzLCB7IHNpemU6IDE4LCBzeDogeyBjb2xvcjogJ3doaXRlJyB9IH0pKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KEljb24sIHsgc3R5bGU6IHsgZGlzcGxheTogJ2ZsZXgnIH0sIGljb246IFwiQXJyb3dGb3J3YXJkXCIgfSkpKSksXHJcbiAgICAgICAgICAgIH0gfSksXHJcbiAgICAgICAgISFlcnJvck1lc3NhZ2UgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcImVycm9yXCIgfSwgZXJyb3JNZXNzYWdlKSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9QWRkUHJvbW90aW9uQ29kZS5qcy5tYXAiXX0= */"));
8136
+ }, ";display:flex;align-items:center;" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIkFkZFByb21vdGlvbkNvZGUudHN4Il0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQVMyQyIsImZpbGUiOiJBZGRQcm9tb3Rpb25Db2RlLnRzeCIsInNvdXJjZXNDb250ZW50IjpbImltcG9ydCBSZWFjdCwgeyB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0JztcclxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQvbWFjcm8nO1xyXG5pbXBvcnQgeyBDaXJjdWxhclByb2dyZXNzLCBHcmlkIH0gZnJvbSAnQG11aS9tYXRlcmlhbCc7XHJcbmltcG9ydCB7IEljb24gfSBmcm9tICcuLi8uLi9jb21tb24vSWNvbic7XHJcbmltcG9ydCB7IFR5cG9ncmFwaHkgfSBmcm9tICcuLi8uLi9jb21tb24vVHlwb2dyYXBoeSc7XHJcbmltcG9ydCB7IEJ1dHRvbiwgSW5wdXRGaWVsZCB9IGZyb20gJy4uL2NvbXBvbmVudHMnO1xyXG5pbXBvcnQgeyB1c2VQcmV2aWV3U3Vic2NyaXB0aW9uQWN0aW9uIH0gZnJvbSAnLi4vaG9va3MnO1xyXG5pbXBvcnQgeyB1c2VQcm9tb3Rpb25Db2RlTW9kZWwgfSBmcm9tICcuLi9ob29rcy91c2VDb3Vwb25Nb2RlbCc7XHJcbmltcG9ydCB7IEFkZFByb21vdGlvbkNvZGVCdXR0b24gfSBmcm9tICcuL0FkZFByb21vdGlvbkNvZGVCdXR0b24nO1xyXG5jb25zdCBDb3Vwb25Db2RlQWRkQnV0dG9uID0gc3R5bGVkKEJ1dHRvbikgYFxuICBwYWRkaW5nOiA0cHggMTBweDtcbiAgbWluLXdpZHRoOiB1bnNldDtcbiAgYm9yZGVyLXJhZGl1czogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zdGlnZy5ib3JkZXIucmFkaXVzfTtcbiAgZGlzcGxheTogZmxleDtcbiAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbmA7XHJcbmV4cG9ydCBjb25zdCBBZGRQcm9tb3Rpb25Db2RlID0gKHsgZGlzYWJsZWQsIGNoZWNrb3V0TG9jYWxpemF0aW9uLCBvbk1vY2tDaGVja291dFByZXZpZXcsIH0pID0+IHtcclxuICAgIGNvbnN0IHsgc2V0UHJvbW90aW9uQ29kZTogcGVyc2lzdFByb21vdGlvbkNvZGUgfSA9IHVzZVByb21vdGlvbkNvZGVNb2RlbCgpO1xyXG4gICAgY29uc3QgW3Nob3dJbnB1dCwgc2V0U2hvd0lucHV0XSA9IHVzZVN0YXRlKGZhbHNlKTtcclxuICAgIGNvbnN0IFtwcm9tb3Rpb25Db2RlLCBzZXRQcm9tb3Rpb25Db2RlXSA9IFJlYWN0LnVzZVN0YXRlKCcnKTtcclxuICAgIGNvbnN0IFtpc0xvYWRpbmcsIHNldElzTG9hZGluZ10gPSBSZWFjdC51c2VTdGF0ZShmYWxzZSk7XHJcbiAgICBjb25zdCBbZXJyb3JNZXNzYWdlLCBzZXRFcnJvck1lc3NhZ2VdID0gUmVhY3QudXNlU3RhdGUoJycpO1xyXG4gICAgY29uc3QgeyBwcmV2aWV3U3Vic2NyaXB0aW9uQWN0aW9uIH0gPSB1c2VQcmV2aWV3U3Vic2NyaXB0aW9uQWN0aW9uKHsgb25Nb2NrQ2hlY2tvdXRQcmV2aWV3IH0pO1xyXG4gICAgY29uc3QgaGFuZGxlUHJvbW90aW9uQ29kZSA9IGFzeW5jICgpID0+IHtcclxuICAgICAgICBzZXRJc0xvYWRpbmcodHJ1ZSk7XHJcbiAgICAgICAgc2V0RXJyb3JNZXNzYWdlKCcnKTtcclxuICAgICAgICBjb25zdCB7IHN1YnNjcmlwdGlvblByZXZpZXcsIGVycm9yTWVzc2FnZSB9ID0gYXdhaXQgcHJldmlld1N1YnNjcmlwdGlvbkFjdGlvbih7IHByb21vdGlvbkNvZGUgfSk7XHJcbiAgICAgICAgaWYgKCFlcnJvck1lc3NhZ2UgJiYgc3Vic2NyaXB0aW9uUHJldmlldz8uaW1tZWRpYXRlSW52b2ljZT8uZGlzY291bnREZXRhaWxzKSB7XHJcbiAgICAgICAgICAgIHBlcnNpc3RQcm9tb3Rpb25Db2RlKHByb21vdGlvbkNvZGUudG9VcHBlckNhc2UoKSk7XHJcbiAgICAgICAgICAgIHNldFNob3dJbnB1dChmYWxzZSk7XHJcbiAgICAgICAgfVxyXG4gICAgICAgIGVsc2UgaWYgKGVycm9yTWVzc2FnZSkge1xyXG4gICAgICAgICAgICBzZXRFcnJvck1lc3NhZ2UoZXJyb3JNZXNzYWdlKTtcclxuICAgICAgICB9XHJcbiAgICAgICAgc2V0SXNMb2FkaW5nKGZhbHNlKTtcclxuICAgIH07XHJcbiAgICBpZiAoIXNob3dJbnB1dCkge1xyXG4gICAgICAgIHJldHVybiAoUmVhY3QuY3JlYXRlRWxlbWVudChBZGRQcm9tb3Rpb25Db2RlQnV0dG9uLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgb25BZGRDbGljazogKCkgPT4gc2V0U2hvd0lucHV0KHRydWUpLCBjaGVja291dExvY2FsaXphdGlvbjogY2hlY2tvdXRMb2NhbGl6YXRpb24gfSkpO1xyXG4gICAgfVxyXG4gICAgcmV0dXJuIChSZWFjdC5jcmVhdGVFbGVtZW50KEdyaWQsIG51bGwsXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChUeXBvZ3JhcGh5LCB7IHZhcmlhbnQ6IFwiYm9keTFcIiwgY29sb3I6IGVycm9yTWVzc2FnZSA/ICdlcnJvcicgOiBkaXNhYmxlZCA/ICdkaXNhYmxlZCcgOiAncHJpbWFyeS5tYWluJyB9LCBjaGVja291dExvY2FsaXphdGlvbi5zdW1tYXJ5LmNvdXBvbkNvZGVUaXRsZSksXHJcbiAgICAgICAgUmVhY3QuY3JlYXRlRWxlbWVudChJbnB1dEZpZWxkLCB7IGRpc2FibGVkOiBkaXNhYmxlZCwgYXV0b0ZvY3VzOiB0cnVlLCB2YXJpYW50OiBcIm91dGxpbmVkXCIsIGZ1bGxXaWR0aDogdHJ1ZSwgZXJyb3I6ICEhZXJyb3JNZXNzYWdlLCB2YWx1ZTogcHJvbW90aW9uQ29kZSwgb25DaGFuZ2U6IChlKSA9PiB7XHJcbiAgICAgICAgICAgICAgICBzZXRQcm9tb3Rpb25Db2RlKGUudGFyZ2V0LnZhbHVlKTtcclxuICAgICAgICAgICAgfSwgaW5wdXRQcm9wczogeyBtYXhMZW5ndGg6IDIwIH0sIG9uS2V5RG93bjogKGUpID0+IHtcclxuICAgICAgICAgICAgICAgIGlmIChlLmtleSA9PT0gJ0VudGVyJykge1xyXG4gICAgICAgICAgICAgICAgICAgIHZvaWQgaGFuZGxlUHJvbW90aW9uQ29kZSgpO1xyXG4gICAgICAgICAgICAgICAgICAgIGUucHJldmVudERlZmF1bHQoKTtcclxuICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgfSwgXHJcbiAgICAgICAgICAgIC8vIGVzbGludC1kaXNhYmxlLW5leHQtbGluZSByZWFjdC9qc3gtbm8tZHVwbGljYXRlLXByb3BzXHJcbiAgICAgICAgICAgIElucHV0UHJvcHM6IHtcclxuICAgICAgICAgICAgICAgIGVuZEFkb3JubWVudDogKFJlYWN0LmNyZWF0ZUVsZW1lbnQoQ291cG9uQ29kZUFkZEJ1dHRvbiwgeyB2YXJpYW50OiBcImNvbnRhaW5lZFwiLCBkaXNhYmxlZDogZGlzYWJsZWQsIG9uQ2xpY2s6ICgpID0+IHtcclxuICAgICAgICAgICAgICAgICAgICAgICAgdm9pZCBoYW5kbGVQcm9tb3Rpb25Db2RlKCk7XHJcbiAgICAgICAgICAgICAgICAgICAgfSB9LCBpc0xvYWRpbmcgPyAoUmVhY3QuY3JlYXRlRWxlbWVudChDaXJjdWxhclByb2dyZXNzLCB7IHNpemU6IDE4LCBzeDogeyBjb2xvcjogJ3doaXRlJyB9IH0pKSA6IChSZWFjdC5jcmVhdGVFbGVtZW50KEljb24sIHsgc3R5bGU6IHsgZGlzcGxheTogJ2ZsZXgnIH0sIGljb246IFwiQXJyb3dGb3J3YXJkXCIgfSkpKSksXHJcbiAgICAgICAgICAgIH0gfSksXHJcbiAgICAgICAgISFlcnJvck1lc3NhZ2UgJiYgKFJlYWN0LmNyZWF0ZUVsZW1lbnQoVHlwb2dyYXBoeSwgeyB2YXJpYW50OiBcImJvZHkxXCIsIGNvbG9yOiBcImVycm9yXCIgfSwgZXJyb3JNZXNzYWdlKSkpKTtcclxufTtcclxuLy8jIHNvdXJjZU1hcHBpbmdVUkw9QWRkUHJvbW90aW9uQ29kZS5qcy5tYXAiXX0= */"));
8139
8137
 
8140
8138
  var AddPromotionCode = function AddPromotionCode(_ref2) {
8141
8139
  var disabled = _ref2.disabled,
@@ -8168,6 +8166,8 @@ var AddPromotionCode = function AddPromotionCode(_ref2) {
8168
8166
 
8169
8167
  var handlePromotionCode = /*#__PURE__*/function () {
8170
8168
  var _ref3 = _asyncToGenerator( /*#__PURE__*/runtime_1.mark(function _callee() {
8169
+ var _subscriptionPreview$;
8170
+
8171
8171
  var _yield$previewSubscri, subscriptionPreview, errorMessage;
8172
8172
 
8173
8173
  return runtime_1.wrap(function _callee$(_context) {
@@ -8186,7 +8186,7 @@ var AddPromotionCode = function AddPromotionCode(_ref2) {
8186
8186
  subscriptionPreview = _yield$previewSubscri.subscriptionPreview;
8187
8187
  errorMessage = _yield$previewSubscri.errorMessage;
8188
8188
 
8189
- if (!errorMessage && subscriptionPreview != null && subscriptionPreview.discountDetails) {
8189
+ if (!errorMessage && subscriptionPreview != null && (_subscriptionPreview$ = subscriptionPreview.immediateInvoice) != null && _subscriptionPreview$.discountDetails) {
8190
8190
  persistPromotionCode(promotionCode.toUpperCase());
8191
8191
  setShowInput(false);
8192
8192
  } else if (errorMessage) {
@@ -12086,20 +12086,23 @@ var WithSkeleton = function WithSkeleton(_ref) {
12086
12086
  };
12087
12087
 
12088
12088
  var RemainingCreditsCaption = function RemainingCreditsCaption(_ref) {
12089
- var _subscriptionPreview$, _subscriptionPreview$2, _subscriptionPreview$3, _subscriptionPreview$4;
12089
+ var _immediateInvoice$pro, _immediateInvoice$pro2, _immediateInvoice$pro3, _immediateInvoice$pro4;
12090
12090
 
12091
12091
  var subscriptionPreview = _ref.subscriptionPreview,
12092
12092
  isFetchingSubscriptionPreview = _ref.isFetchingSubscriptionPreview,
12093
12093
  checkoutLocalization = _ref.checkoutLocalization;
12094
12094
 
12095
- if (!(subscriptionPreview != null && (_subscriptionPreview$ = subscriptionPreview.proration) != null && (_subscriptionPreview$2 = _subscriptionPreview$.netAmount) != null && _subscriptionPreview$2.amount) || (subscriptionPreview == null ? void 0 : (_subscriptionPreview$3 = subscriptionPreview.proration) == null ? void 0 : (_subscriptionPreview$4 = _subscriptionPreview$3.netAmount) == null ? void 0 : _subscriptionPreview$4.amount) >= 0) {
12095
+ var _ref2 = subscriptionPreview || {},
12096
+ immediateInvoice = _ref2.immediateInvoice;
12097
+
12098
+ if (!(immediateInvoice != null && (_immediateInvoice$pro = immediateInvoice.proration) != null && (_immediateInvoice$pro2 = _immediateInvoice$pro.netAmount) != null && _immediateInvoice$pro2.amount) || (immediateInvoice == null ? void 0 : (_immediateInvoice$pro3 = immediateInvoice.proration) == null ? void 0 : (_immediateInvoice$pro4 = _immediateInvoice$pro3.netAmount) == null ? void 0 : _immediateInvoice$pro4.amount) >= 0) {
12096
12099
  return null;
12097
12100
  }
12098
12101
 
12099
- var positiveAmount = subscriptionPreview.proration.netAmount.amount * -1;
12102
+ var positiveAmount = immediateInvoice.proration.netAmount.amount * -1;
12100
12103
  var credits = currencyPriceFormatter({
12101
12104
  amount: positiveAmount,
12102
- currency: subscriptionPreview.proration.netAmount.currency,
12105
+ currency: immediateInvoice.proration.netAmount.currency,
12103
12106
  minimumFractionDigits: 2
12104
12107
  });
12105
12108
  return React__default.createElement(Typography, {
@@ -12115,11 +12118,11 @@ var RemainingCreditsCaption = function RemainingCreditsCaption(_ref) {
12115
12118
  })));
12116
12119
  };
12117
12120
 
12118
- var ScheduledUpdatesCaption = function ScheduledUpdatesCaption(_ref2) {
12119
- var subscriptionPreview = _ref2.subscriptionPreview,
12120
- activeSubscription = _ref2.activeSubscription,
12121
- isFetchingSubscriptionPreview = _ref2.isFetchingSubscriptionPreview,
12122
- checkoutLocalization = _ref2.checkoutLocalization;
12121
+ var ScheduledUpdatesCaption = function ScheduledUpdatesCaption(_ref3) {
12122
+ var subscriptionPreview = _ref3.subscriptionPreview,
12123
+ activeSubscription = _ref3.activeSubscription,
12124
+ isFetchingSubscriptionPreview = _ref3.isFetchingSubscriptionPreview,
12125
+ checkoutLocalization = _ref3.checkoutLocalization;
12123
12126
 
12124
12127
  if (!(subscriptionPreview != null && subscriptionPreview.hasScheduledUpdates) || !(activeSubscription != null && activeSubscription.currentBillingPeriodEnd)) {
12125
12128
  return null;
@@ -12140,21 +12143,22 @@ var ScheduledUpdatesCaption = function ScheduledUpdatesCaption(_ref2) {
12140
12143
  }, changesWillApplyText));
12141
12144
  };
12142
12145
 
12143
- var NextBillingCaption = function NextBillingCaption(_ref3) {
12144
- var _subscriptionPreview$5;
12146
+ var NextBillingCaption = function NextBillingCaption(_ref4) {
12147
+ var subscriptionPreview = _ref4.subscriptionPreview,
12148
+ activeSubscription = _ref4.activeSubscription,
12149
+ plan = _ref4.plan,
12150
+ isFetchingSubscriptionPreview = _ref4.isFetchingSubscriptionPreview,
12151
+ billingPeriod = _ref4.billingPeriod;
12145
12152
 
12146
- var subscriptionPreview = _ref3.subscriptionPreview,
12147
- activeSubscription = _ref3.activeSubscription,
12148
- plan = _ref3.plan,
12149
- isFetchingSubscriptionPreview = _ref3.isFetchingSubscriptionPreview,
12150
- billingPeriod = _ref3.billingPeriod;
12153
+ var _ref5 = subscriptionPreview || {},
12154
+ recurringInvoice = _ref5.recurringInvoice;
12151
12155
 
12152
- if (!(subscriptionPreview != null && (_subscriptionPreview$5 = subscriptionPreview.recurringSubscription) != null && _subscriptionPreview$5.total.amount)) {
12156
+ if (!subscriptionPreview || !(recurringInvoice != null && recurringInvoice.total.amount)) {
12153
12157
  return null;
12154
12158
  }
12155
12159
 
12156
12160
  var currentBillingPeriodEnd = subscriptionPreview.hasScheduledUpdates ? activeSubscription == null ? void 0 : activeSubscription.currentBillingPeriodEnd : subscriptionPreview == null ? void 0 : subscriptionPreview.billingPeriodRange.end;
12157
- var total = currencyPriceFormatter(_extends({}, subscriptionPreview == null ? void 0 : subscriptionPreview.recurringSubscription.total, {
12161
+ var total = currencyPriceFormatter(_extends({}, recurringInvoice.total, {
12158
12162
  minimumFractionDigits: 2
12159
12163
  }));
12160
12164
  var hasUnitBasedPricing = plan == null ? void 0 : plan.pricePoints.some(function (price) {
@@ -12219,7 +12223,7 @@ var LineItemContainer = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "pr
12219
12223
  } : {
12220
12224
  name: "rdmn2i",
12221
12225
  styles: "&+&{margin-top:8px;}",
12222
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAW4C","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Grid } from '@mui/material';\r\nimport { BillingModel, BillingPeriod } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount: quantity * amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { discount, discountDetails } = subscriptionPreview.recurringSubscription || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: subscriptionPreview.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { credits } = subscriptionPreview || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12226
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAW4C","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Grid } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount: quantity * amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12223
12227
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
12224
12228
  });
12225
12229
  var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "production" ? {
@@ -12233,7 +12237,7 @@ var LineItemRow = /*#__PURE__*/_styled("div", process.env.NODE_ENV === "producti
12233
12237
  } : {
12234
12238
  name: "bcffy2",
12235
12239
  styles: "display:flex;align-items:center;justify-content:space-between",
12236
- map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAgBsC","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Grid } from '@mui/material';\r\nimport { BillingModel, BillingPeriod } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount: quantity * amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { discount, discountDetails } = subscriptionPreview.recurringSubscription || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: subscriptionPreview.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { credits } = subscriptionPreview || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12240
+ map: "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["LineItems.tsx"],"names":[],"mappings":"AAgBsC","file":"LineItems.tsx","sourcesContent":["import React from 'react';\r\nimport styled from '@emotion/styled/macro';\r\nimport { Grid } from '@mui/material';\r\nimport { BillingModel, BillingPeriod, } from '@stigg/js-client-sdk';\r\nimport { Typography } from '../../../common/Typography';\r\nimport { currencyPriceFormatter } from '../../../utils/currencyUtils';\r\nimport { getTierByQuantity } from '../../../utils/priceTierUtils';\r\nimport { WithSkeleton } from './WithSkeleton';\r\nimport { Skeleton } from '../../components/Skeletons.style';\r\nimport { Icon } from '../../../common/Icon';\r\nimport { InformationTooltip } from '../../../common/InformationTooltip';\r\nexport const LineItemContainer = styled.div `\n  & + & {\n    margin-top: 8px;\n  }\n`;\r\nexport const LineItemRow = styled.div `\n  display: flex;\n  align-items: center;\n  justify-content: space-between;\n`;\r\nexport const getPriceString = ({ amount, price, quantity }) => {\r\n    const { billingPeriod } = price;\r\n    let billingPeriodString = null;\r\n    if (billingPeriod === BillingPeriod.Annually) {\r\n        amount /= 12;\r\n        billingPeriodString = '12 months';\r\n    }\r\n    const addonPriceFormat = currencyPriceFormatter({ amount, currency: price.currency, minimumFractionDigits: 2 });\r\n    return `${quantity > 1 ? `${quantity} x ${addonPriceFormat} each` : addonPriceFormat}${billingPeriodString ? ` x ${billingPeriodString}` : ''}`;\r\n};\r\nconst PayAsYouGoPriceTooltip = ({ checkoutLocalization }) => {\r\n    const title = React.createElement(Typography, { variant: \"body1\" }, checkoutLocalization.summary.payAsYouGoTooltipText);\r\n    return (React.createElement(InformationTooltip, { placement: \"left\", title: title },\r\n        React.createElement(Icon, { icon: \"PayAsYouGoCharge\", style: { display: 'flex' } })));\r\n};\r\nexport const BilledPriceLineItem = ({ checkoutLocalization, label, quantity, price, }) => {\r\n    const { billingPeriod } = price;\r\n    const isPayAsYouGo = price.pricingModel === BillingModel.UsageBased;\r\n    let amount;\r\n    if (price.isTieredPrice) {\r\n        const tier = getTierByQuantity(price.tiers, quantity);\r\n        amount = tier.unitPrice.amount;\r\n    }\r\n    else {\r\n        amount = price.amount;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-start' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label),\r\n                (quantity > 1 || billingPeriod === BillingPeriod.Annually) && (React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, getPriceString({ amount, price, quantity })))),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                isPayAsYouGo && React.createElement(PayAsYouGoPriceTooltip, { checkoutLocalization: checkoutLocalization }),\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } },\r\n                    currencyPriceFormatter({ amount: quantity * amount, currency: price.currency, minimumFractionDigits: 2 }),\r\n                    isPayAsYouGo && ' / unit')))));\r\n};\r\nexport const FreeChargeLineItem = ({ label }) => {\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, { style: { alignItems: 'flex-end' } },\r\n            React.createElement(Grid, { item: true },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, label)),\r\n            React.createElement(Grid, { item: true, display: \"flex\", gap: 1, alignItems: \"center\" },\r\n                React.createElement(Typography, { variant: \"body1\", color: \"secondary\", style: { wordBreak: 'break-word' } }, \"Free\")))));\r\n};\r\nexport const DiscountLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice, recurringInvoice } = subscriptionPreview;\r\n    const { discount, discountDetails } = recurringInvoice || {};\r\n    if (!discount || !discountDetails) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.discountText({\r\n                discountDetails,\r\n                currency: immediateInvoice.total.currency,\r\n            })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, isFetchingSubscriptionPreview ? (React.createElement(Skeleton, { width: 50, height: 16 })) : (currencyPriceFormatter({\r\n                amount: discount.amount,\r\n                currency: discount.currency,\r\n                minimumFractionDigits: 2,\r\n            }))))));\r\n};\r\nexport const AppliedCreditsLineItem = ({ subscriptionPreview, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    const { immediateInvoice } = subscriptionPreview || {};\r\n    const { credits } = immediateInvoice || {};\r\n    if (!credits || !credits.used || credits.used.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.appliedCreditsTitle),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({\r\n                    amount: -1 * credits.used.amount,\r\n                    currency: credits.used.currency,\r\n                    minimumFractionDigits: 2,\r\n                }))))));\r\n};\r\nexport const TaxLineItem = ({ tax, taxDetails, isFetchingSubscriptionPreview, checkoutLocalization, }) => {\r\n    if (!taxDetails || !tax || tax?.amount <= 0) {\r\n        return null;\r\n    }\r\n    return (React.createElement(LineItemContainer, null,\r\n        React.createElement(LineItemRow, null,\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" }, checkoutLocalization.summary.taxTitle({ taxDetails })),\r\n            React.createElement(Typography, { variant: \"body1\", color: \"secondary\" },\r\n                React.createElement(WithSkeleton, { isLoading: isFetchingSubscriptionPreview }, currencyPriceFormatter({ amount: tax?.amount, currency: tax?.currency, minimumFractionDigits: 2 }))))));\r\n};\r\n//# sourceMappingURL=LineItems.js.map"]} */",
12237
12241
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$n
12238
12242
  });
12239
12243
  var getPriceString = function getPriceString(_ref) {
@@ -12351,8 +12355,10 @@ var DiscountLineItem = function DiscountLineItem(_ref5) {
12351
12355
  var subscriptionPreview = _ref5.subscriptionPreview,
12352
12356
  isFetchingSubscriptionPreview = _ref5.isFetchingSubscriptionPreview,
12353
12357
  checkoutLocalization = _ref5.checkoutLocalization;
12358
+ var immediateInvoice = subscriptionPreview.immediateInvoice,
12359
+ recurringInvoice = subscriptionPreview.recurringInvoice;
12354
12360
 
12355
- var _ref6 = subscriptionPreview.recurringSubscription || {},
12361
+ var _ref6 = recurringInvoice || {},
12356
12362
  discount = _ref6.discount,
12357
12363
  discountDetails = _ref6.discountDetails;
12358
12364
 
@@ -12365,7 +12371,7 @@ var DiscountLineItem = function DiscountLineItem(_ref5) {
12365
12371
  color: "secondary"
12366
12372
  }, checkoutLocalization.summary.discountText({
12367
12373
  discountDetails: discountDetails,
12368
- currency: subscriptionPreview.total.currency
12374
+ currency: immediateInvoice.total.currency
12369
12375
  })), React__default.createElement(Typography, {
12370
12376
  variant: "body1",
12371
12377
  color: "secondary"
@@ -12384,7 +12390,10 @@ var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref7) {
12384
12390
  checkoutLocalization = _ref7.checkoutLocalization;
12385
12391
 
12386
12392
  var _ref8 = subscriptionPreview || {},
12387
- credits = _ref8.credits;
12393
+ immediateInvoice = _ref8.immediateInvoice;
12394
+
12395
+ var _ref9 = immediateInvoice || {},
12396
+ credits = _ref9.credits;
12388
12397
 
12389
12398
  if (!credits || !credits.used || credits.used.amount <= 0) {
12390
12399
  return null;
@@ -12404,11 +12413,11 @@ var AppliedCreditsLineItem = function AppliedCreditsLineItem(_ref7) {
12404
12413
  minimumFractionDigits: 2
12405
12414
  })))));
12406
12415
  };
12407
- var TaxLineItem = function TaxLineItem(_ref9) {
12408
- var tax = _ref9.tax,
12409
- taxDetails = _ref9.taxDetails,
12410
- isFetchingSubscriptionPreview = _ref9.isFetchingSubscriptionPreview,
12411
- checkoutLocalization = _ref9.checkoutLocalization;
12416
+ var TaxLineItem = function TaxLineItem(_ref10) {
12417
+ var tax = _ref10.tax,
12418
+ taxDetails = _ref10.taxDetails,
12419
+ isFetchingSubscriptionPreview = _ref10.isFetchingSubscriptionPreview,
12420
+ checkoutLocalization = _ref10.checkoutLocalization;
12412
12421
 
12413
12422
  if (!taxDetails || !tax || (tax == null ? void 0 : tax.amount) <= 0) {
12414
12423
  return null;
@@ -12443,7 +12452,7 @@ var SummaryContainer = /*#__PURE__*/_styled(Box$1, process.env.NODE_ENV === "pro
12443
12452
  } : {
12444
12453
  name: "kj9yp4",
12445
12454
  styles: "max-width:470px;flex:1.5",
12446
- 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"]} */",
12455
+ 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 { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice && !!recurringInvoice?.discountDetails && !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: recurringInvoice?.tax, taxDetails: recurringInvoice?.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                                            ...recurringInvoice?.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            immediateInvoice?.subTotal && immediateInvoice?.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: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.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, ...immediateInvoice?.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"]} */",
12447
12456
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12448
12457
  });
12449
12458
  var SummaryCard = /*#__PURE__*/_styled(Paper, process.env.NODE_ENV === "production" ? {
@@ -12454,7 +12463,7 @@ var SummaryCard = /*#__PURE__*/_styled(Paper, process.env.NODE_ENV === "producti
12454
12463
  })("border-radius:10px;background:", function (_ref) {
12455
12464
  var theme = _ref.theme;
12456
12465
  return theme.stigg.palette.backgroundHighlight;
12457
- }, ";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"]} */"));
12466
+ }, ";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 { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice && !!recurringInvoice?.discountDetails && !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: recurringInvoice?.tax, taxDetails: recurringInvoice?.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                                            ...recurringInvoice?.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            immediateInvoice?.subTotal && immediateInvoice?.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: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.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, ...immediateInvoice?.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"]} */"));
12458
12467
  SummaryCard.defaultProps = {
12459
12468
  elevation: 0
12460
12469
  };
@@ -12470,7 +12479,7 @@ var SummaryTitle = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "pr
12470
12479
  } : {
12471
12480
  name: "1jcocwa",
12472
12481
  styles: "margin-bottom:16px;font-weight:500",
12473
- 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"]} */",
12482
+ 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 { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice && !!recurringInvoice?.discountDetails && !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: recurringInvoice?.tax, taxDetails: recurringInvoice?.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                                            ...recurringInvoice?.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            immediateInvoice?.subTotal && immediateInvoice?.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: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.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, ...immediateInvoice?.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"]} */",
12474
12483
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12475
12484
  });
12476
12485
 
@@ -12485,7 +12494,7 @@ var StyledDivider$1 = /*#__PURE__*/_styled(Divider$1, process.env.NODE_ENV === "
12485
12494
  } : {
12486
12495
  name: "1k6141t",
12487
12496
  styles: "margin:16px 0",
12488
- 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"]} */",
12497
+ 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 { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice && !!recurringInvoice?.discountDetails && !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: recurringInvoice?.tax, taxDetails: recurringInvoice?.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                                            ...recurringInvoice?.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            immediateInvoice?.subTotal && immediateInvoice?.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: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.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, ...immediateInvoice?.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"]} */",
12489
12498
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12490
12499
  });
12491
12500
 
@@ -12500,7 +12509,7 @@ var TotalDueText = /*#__PURE__*/_styled(Typography, process.env.NODE_ENV === "pr
12500
12509
  } : {
12501
12510
  name: "5bhc30",
12502
12511
  styles: "margin-bottom:8px",
12503
- 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"]} */",
12512
+ 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 { immediateInvoice, recurringInvoice } = subscriptionPreview || {};\r\n    const checkoutHasChanges = !!subscriptionPreview && (!!immediateInvoice?.proration || !!subscriptionPreview.hasScheduledUpdates);\r\n    const showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;\r\n    const showDiscountLine = !!recurringInvoice && !!recurringInvoice?.discountDetails && !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: recurringInvoice?.tax, taxDetails: recurringInvoice?.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                                            ...recurringInvoice?.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            immediateInvoice?.subTotal && immediateInvoice?.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: immediateInvoice?.subTotal?.amount + (immediateInvoice?.tax?.amount || 0),\r\n                            currency: immediateInvoice?.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, ...immediateInvoice?.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"]} */",
12504
12513
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__$o
12505
12514
  });
12506
12515
 
@@ -12531,7 +12540,7 @@ function resolveCheckoutButtonText(_ref2) {
12531
12540
  }
12532
12541
 
12533
12542
  var CheckoutSummary = function CheckoutSummary(_ref3) {
12534
- var _plan$pricePoints, _subscriptionPreview$, _subscription$addons, _subscriptionPreview$2, _subscriptionPreview$3, _subscriptionPreview$4, _subscriptionPreview$5;
12543
+ var _plan$pricePoints, _subscription$addons, _immediateInvoice$sub, _immediateInvoice$tax;
12535
12544
 
12536
12545
  var onCheckout = _ref3.onCheckout,
12537
12546
  onCheckoutCompleted = _ref3.onCheckoutCompleted,
@@ -12686,9 +12695,13 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
12686
12695
  };
12687
12696
  }();
12688
12697
 
12689
- var checkoutHasChanges = !!subscriptionPreview && (!!subscriptionPreview.proration || !!subscriptionPreview.hasScheduledUpdates);
12698
+ var _ref9 = subscriptionPreview || {},
12699
+ immediateInvoice = _ref9.immediateInvoice,
12700
+ recurringInvoice = _ref9.recurringInvoice;
12701
+
12702
+ var checkoutHasChanges = !!subscriptionPreview && (!!(immediateInvoice != null && immediateInvoice.proration) || !!subscriptionPreview.hasScheduledUpdates);
12690
12703
  var showPromotionCodeLine = !disablePromotionCode && !isFreeDowngrade;
12691
- var showDiscountLine = !!(subscriptionPreview != null && subscriptionPreview.recurringSubscription) && !!(subscriptionPreview != null && (_subscriptionPreview$ = subscriptionPreview.recurringSubscription) != null && _subscriptionPreview$.discountDetails) && !isFreeDowngrade;
12704
+ var showDiscountLine = !!recurringInvoice && !!(recurringInvoice != null && recurringInvoice.discountDetails) && !isFreeDowngrade;
12692
12705
  var hasDiscounts = showPromotionCodeLine || showDiscountLine;
12693
12706
  var hasPayAsYouGoCharges = usageCharges.some(function (price) {
12694
12707
  return price.pricingModel === BillingModel.UsageBased;
@@ -12804,8 +12817,8 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
12804
12817
  }), hasDiscounts && React__default.createElement(StyledDivider$1, {
12805
12818
  className: "stigg-checkout-summary-divider"
12806
12819
  }), React__default.createElement(TaxLineItem, {
12807
- tax: subscriptionPreview == null ? void 0 : (_subscriptionPreview$2 = subscriptionPreview.recurringSubscription) == null ? void 0 : _subscriptionPreview$2.tax,
12808
- taxDetails: subscriptionPreview == null ? void 0 : (_subscriptionPreview$3 = subscriptionPreview.recurringSubscription) == null ? void 0 : _subscriptionPreview$3.taxDetails,
12820
+ tax: recurringInvoice == null ? void 0 : recurringInvoice.tax,
12821
+ taxDetails: recurringInvoice == null ? void 0 : recurringInvoice.taxDetails,
12809
12822
  isFetchingSubscriptionPreview: isFetchingSubscriptionPreview,
12810
12823
  checkoutLocalization: checkoutLocalization
12811
12824
  }), !isFreeDowngrade ? React__default.createElement(React__default.Fragment, null, React__default.createElement(LineItemRow, {
@@ -12828,7 +12841,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
12828
12841
  isLoading: isFetchingSubscriptionPreview
12829
12842
  }, onlyPayAsYouGoCharges ? checkoutLocalization.summary.onlyPayAsYouGoText : null, !onlyPayAsYouGoCharges && hasPayAsYouGoCharges ? checkoutLocalization.summary.startsAtText : null, !onlyPayAsYouGoCharges ? currencyPriceFormatter(_extends({
12830
12843
  amount: 0
12831
- }, subscriptionPreview == null ? void 0 : (_subscriptionPreview$4 = subscriptionPreview.recurringSubscription) == null ? void 0 : _subscriptionPreview$4.total, {
12844
+ }, recurringInvoice == null ? void 0 : recurringInvoice.total, {
12832
12845
  minimumFractionDigits: 2
12833
12846
  })) : null))), React__default.createElement(Grid, {
12834
12847
  item: true
@@ -12839,7 +12852,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
12839
12852
  billingPeriod: subscription.billingPeriod
12840
12853
  }))))), React__default.createElement(StyledDivider$1, {
12841
12854
  className: "stigg-checkout-summary-divider"
12842
- })) : null, subscriptionPreview != null && subscriptionPreview.subTotal && (subscriptionPreview == null ? void 0 : subscriptionPreview.subTotal.amount) > 0 ? React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, null, React__default.createElement(Typography, {
12855
+ })) : null, immediateInvoice != null && immediateInvoice.subTotal && (immediateInvoice == null ? void 0 : immediateInvoice.subTotal.amount) > 0 ? React__default.createElement(LineItemContainer, null, React__default.createElement(LineItemRow, null, React__default.createElement(Typography, {
12843
12856
  variant: "body1",
12844
12857
  color: "secondary"
12845
12858
  }, checkoutLocalization.summary.proratedTotalDueText), React__default.createElement(Typography, {
@@ -12848,8 +12861,8 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
12848
12861
  }, React__default.createElement(WithSkeleton, {
12849
12862
  isLoading: isFetchingSubscriptionPreview
12850
12863
  }, currencyPriceFormatter({
12851
- amount: (subscriptionPreview == null ? void 0 : subscriptionPreview.subTotal.amount) + ((subscriptionPreview == null ? void 0 : (_subscriptionPreview$5 = subscriptionPreview.tax) == null ? void 0 : _subscriptionPreview$5.amount) || 0),
12852
- currency: subscriptionPreview == null ? void 0 : subscriptionPreview.subTotal.currency,
12864
+ amount: (immediateInvoice == null ? void 0 : (_immediateInvoice$sub = immediateInvoice.subTotal) == null ? void 0 : _immediateInvoice$sub.amount) + ((immediateInvoice == null ? void 0 : (_immediateInvoice$tax = immediateInvoice.tax) == null ? void 0 : _immediateInvoice$tax.amount) || 0),
12865
+ currency: immediateInvoice == null ? void 0 : immediateInvoice.subTotal.currency,
12853
12866
  minimumFractionDigits: 2
12854
12867
  }))))) : null, React__default.createElement(AppliedCreditsLineItem, {
12855
12868
  subscriptionPreview: subscriptionPreview,
@@ -12863,7 +12876,7 @@ var CheckoutSummary = function CheckoutSummary(_ref3) {
12863
12876
  isLoading: isFetchingSubscriptionPreview
12864
12877
  }, currencyPriceFormatter(_extends({
12865
12878
  amount: 0
12866
- }, subscriptionPreview == null ? void 0 : subscriptionPreview.total, {
12879
+ }, immediateInvoice == null ? void 0 : immediateInvoice.total, {
12867
12880
  minimumFractionDigits: 2
12868
12881
  })))))), React__default.createElement(CheckoutCaptions, {
12869
12882
  plan: plan,