@ultraviolet/plus 1.0.0-beta.13 → 1.0.0-beta.14

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.
@@ -17,7 +17,7 @@ const NonScrollableContainer = /* @__PURE__ */ _styled__default.default(ui.Stack
17
17
  theme
18
18
  }) => theme.space[3], ";border-top:1px solid ", ({
19
19
  theme
20
- }) => theme.colors.neutral.border, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT3JkZXJTdW1tYXJ5L05vblNjcm9sbGFibGVDb250ZW50LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRNEMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9PcmRlclN1bW1hcnkvTm9uU2Nyb2xsYWJsZUNvbnRlbnQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB7IHVzZUNvbnRleHQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBPcmRlclN1bW1hcnlDb250ZXh0IH0gZnJvbSAnLi9Qcm92aWRlcidcbmltcG9ydCB7IERpc3BsYXlQcmljZSB9IGZyb20gJy4vaGVscGVycydcbmltcG9ydCB0eXBlIHsgUHJpY2VUeXBlU2luZ2xlLCBUaW1lVW5pdCB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IE5vblNjcm9sbGFibGVDb250YWluZXIgPSBzdHlsZWQoU3RhY2spYFxucGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVszXX07XG5ib3JkZXItdG9wOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuYFxuXG50eXBlIE5vblNjcm9sbGFibGVDb250ZW50UHJvcHMgPSB7XG4gIGRpc2NvdW50OiBudW1iZXJcbiAgdG90YWxQcmljZTogUHJpY2VUeXBlU2luZ2xlXG4gIGZvb3RlcjogUmVhY3ROb2RlXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgdG90YWxQcmljZUluZm8/OiBSZWFjdE5vZGVcbiAgdG90YWxQcmljZURlc2NyaXB0aW9uPzogUmVhY3ROb2RlXG4gIGhpZGVEZXRhaWxzOiBib29sZWFuXG4gIHVuaXQ6IFRpbWVVbml0XG59XG5cbmV4cG9ydCBjb25zdCBOb25TY3JvbGxhYmxlQ29udGVudCA9ICh7XG4gIHRvdGFsUHJpY2UsXG4gIGZvb3RlcixcbiAgY2hpbGRyZW4sXG4gIHRvdGFsUHJpY2VJbmZvLFxuICBoaWRlRGV0YWlscyxcbiAgdW5pdCxcbiAgdG90YWxQcmljZURlc2NyaXB0aW9uLFxufTogTm9uU2Nyb2xsYWJsZUNvbnRlbnRQcm9wcykgPT4ge1xuICBjb25zdCB7IGxvY2FsZXMgfSA9IHVzZUNvbnRleHQoT3JkZXJTdW1tYXJ5Q29udGV4dClcblxuICByZXR1cm4gKFxuICAgIDxOb25TY3JvbGxhYmxlQ29udGFpbmVyIGdhcD17M30+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICB7dG90YWxQcmljZUluZm8gPyAoXG4gICAgICAgICAgPFN0YWNrPlxuICAgICAgICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGdhcD17MX0gYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICAgIHByb21pbmVuY2U9XCJzdHJvbmdcIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge2xvY2FsZXNbJ29yZGVyLnN1bW1hcnkudG90YWwnXX06XG4gICAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgICAge3RvdGFsUHJpY2VEZXNjcmlwdGlvbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgICB7dG90YWxQcmljZUluZm99XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgKSA6IChcbiAgICAgICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiYm9keVN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwic3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2xvY2FsZXNbJ29yZGVyLnN1bW1hcnkudG90YWwnXX06XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICB7dG90YWxQcmljZURlc2NyaXB0aW9ufVxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICl9XG4gICAgICAgIHt0b3RhbFByaWNlLnRvdGFsUHJpY2UgPT09IHRvdGFsUHJpY2UudG90YWxQcmljZVdpdGhEaXNjb3VudCA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICBkYXRhLXRlc3RpZD1cInRvdGFsLXByaWNlXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJzdHJvbmdcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxEaXNwbGF5UHJpY2UgcHJpY2U9e3RvdGFsUHJpY2V9IGJlZm9yZU9yQWZ0ZXI9XCJhZnRlclwiIC8+XG4gICAgICAgICAgICB7aGlkZURldGFpbHMgPyBgLyR7dW5pdH1gIDogbnVsbH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGdhcD17MX0gYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHN0cmlrZVRocm91Z2hcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPERpc3BsYXlQcmljZSBwcmljZT17dG90YWxQcmljZX0gYmVmb3JlT3JBZnRlcj1cImJlZm9yZVwiIC8+XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiaGVhZGluZ1NtYWxsU3Ryb25nXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIGRhdGEtdGVzdGlkPVwidG90YWwtcHJpY2VcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwic3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPERpc3BsYXlQcmljZSBwcmljZT17dG90YWxQcmljZX0gYmVmb3JlT3JBZnRlcj1cImFmdGVyXCIgLz5cbiAgICAgICAgICAgICAge2hpZGVEZXRhaWxzID8gYC8ke3VuaXR9YCA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgKX1cbiAgICAgIDwvU3RhY2s+XG4gICAgICB7Zm9vdGVyfVxuICAgIDwvTm9uU2Nyb2xsYWJsZUNvbnRhaW5lcj5cbiAgKVxufVxuIl19 */"));
20
+ }) => theme.colors.neutral.border, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT3JkZXJTdW1tYXJ5L05vblNjcm9sbGFibGVDb250ZW50LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRNEMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9PcmRlclN1bW1hcnkvTm9uU2Nyb2xsYWJsZUNvbnRlbnQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB7IHVzZUNvbnRleHQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBPcmRlclN1bW1hcnlDb250ZXh0IH0gZnJvbSAnLi9Qcm92aWRlcidcbmltcG9ydCB7IERpc3BsYXlQcmljZSB9IGZyb20gJy4vaGVscGVycydcbmltcG9ydCB0eXBlIHsgUHJpY2VUeXBlU2luZ2xlLCBUaW1lVW5pdCB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IE5vblNjcm9sbGFibGVDb250YWluZXIgPSBzdHlsZWQoU3RhY2spYFxucGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVszXX07XG5ib3JkZXItdG9wOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuYFxuXG50eXBlIE5vblNjcm9sbGFibGVDb250ZW50UHJvcHMgPSB7XG4gIGRpc2NvdW50OiBudW1iZXJcbiAgdG90YWxQcmljZTogUHJpY2VUeXBlU2luZ2xlXG4gIGZvb3RlcjogUmVhY3ROb2RlXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgdG90YWxQcmljZUluZm8/OiBSZWFjdE5vZGVcbiAgdG90YWxQcmljZURlc2NyaXB0aW9uPzogUmVhY3ROb2RlXG4gIGFkZGl0aW9uYWxJbmZvPzogc3RyaW5nXG4gIGhpZGVEZXRhaWxzOiBib29sZWFuXG4gIHVuaXQ6IFRpbWVVbml0XG59XG5cbmV4cG9ydCBjb25zdCBOb25TY3JvbGxhYmxlQ29udGVudCA9ICh7XG4gIHRvdGFsUHJpY2UsXG4gIGZvb3RlcixcbiAgY2hpbGRyZW4sXG4gIHRvdGFsUHJpY2VJbmZvLFxuICBoaWRlRGV0YWlscyxcbiAgdW5pdCxcbiAgdG90YWxQcmljZURlc2NyaXB0aW9uLFxuICBhZGRpdGlvbmFsSW5mbyxcbn06IE5vblNjcm9sbGFibGVDb250ZW50UHJvcHMpID0+IHtcbiAgY29uc3QgeyBsb2NhbGVzIH0gPSB1c2VDb250ZXh0KE9yZGVyU3VtbWFyeUNvbnRleHQpXG5cbiAgcmV0dXJuIChcbiAgICA8Tm9uU2Nyb2xsYWJsZUNvbnRhaW5lciBnYXA9ezN9PlxuICAgICAge2NoaWxkcmVufVxuICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAge3RvdGFsUHJpY2VJbmZvID8gKFxuICAgICAgICAgIDxTdGFjaz5cbiAgICAgICAgICAgIDxTdGFjayBkaXJlY3Rpb249XCJyb3dcIiBnYXA9ezF9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgICBwcm9taW5lbmNlPVwic3Ryb25nXCJcbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtsb2NhbGVzWydvcmRlci5zdW1tYXJ5LnRvdGFsJ119OlxuICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgIHt0b3RhbFByaWNlRGVzY3JpcHRpb259XG4gICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgICAge3RvdGFsUHJpY2VJbmZvfVxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGdhcD17MX0gYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgcHJvbWluZW5jZT1cInN0cm9uZ1wiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsb2NhbGVzWydvcmRlci5zdW1tYXJ5LnRvdGFsJ119XG4gICAgICAgICAgICAgIHthZGRpdGlvbmFsSW5mbyA/IGAgJHthZGRpdGlvbmFsSW5mb31gIDogbnVsbH06XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICB7dG90YWxQcmljZURlc2NyaXB0aW9ufVxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICl9XG4gICAgICAgIHt0b3RhbFByaWNlLnRvdGFsUHJpY2UgPT09IHRvdGFsUHJpY2UudG90YWxQcmljZVdpdGhEaXNjb3VudCA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICBkYXRhLXRlc3RpZD1cInRvdGFsLXByaWNlXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJzdHJvbmdcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxEaXNwbGF5UHJpY2UgcHJpY2U9e3RvdGFsUHJpY2V9IGJlZm9yZU9yQWZ0ZXI9XCJhZnRlclwiIC8+XG4gICAgICAgICAgICB7aGlkZURldGFpbHMgPyBgLyR7dW5pdH1gIDogbnVsbH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGdhcD17MX0gYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHN0cmlrZVRocm91Z2hcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPERpc3BsYXlQcmljZSBwcmljZT17dG90YWxQcmljZX0gYmVmb3JlT3JBZnRlcj1cImJlZm9yZVwiIC8+XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiaGVhZGluZ1NtYWxsU3Ryb25nXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIGRhdGEtdGVzdGlkPVwidG90YWwtcHJpY2VcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwic3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPERpc3BsYXlQcmljZSBwcmljZT17dG90YWxQcmljZX0gYmVmb3JlT3JBZnRlcj1cImFmdGVyXCIgLz5cbiAgICAgICAgICAgICAge2hpZGVEZXRhaWxzID8gYC8ke3VuaXR9YCA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgKX1cbiAgICAgIDwvU3RhY2s+XG4gICAgICB7Zm9vdGVyfVxuICAgIDwvTm9uU2Nyb2xsYWJsZUNvbnRhaW5lcj5cbiAgKVxufVxuIl19 */"));
21
21
  const NonScrollableContent = ({
22
22
  totalPrice,
23
23
  footer,
@@ -25,7 +25,8 @@ const NonScrollableContent = ({
25
25
  totalPriceInfo,
26
26
  hideDetails,
27
27
  unit,
28
- totalPriceDescription
28
+ totalPriceDescription,
29
+ additionalInfo
29
30
  }) => {
30
31
  const {
31
32
  locales
@@ -45,6 +46,7 @@ const NonScrollableContent = ({
45
46
  ] }) : /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { direction: "row", gap: 1, alignItems: "center", children: [
46
47
  /* @__PURE__ */ jsxRuntime.jsxs(ui.Text, { as: "span", variant: "bodyStrong", sentiment: "neutral", prominence: "strong", children: [
47
48
  locales["order.summary.total"],
49
+ additionalInfo ? ` ${additionalInfo}` : null,
48
50
  ":"
49
51
  ] }),
50
52
  totalPriceDescription
@@ -7,8 +7,9 @@ type NonScrollableContentProps = {
7
7
  children: ReactNode;
8
8
  totalPriceInfo?: ReactNode;
9
9
  totalPriceDescription?: ReactNode;
10
+ additionalInfo?: string;
10
11
  hideDetails: boolean;
11
12
  unit: TimeUnit;
12
13
  };
13
- export declare const NonScrollableContent: ({ totalPrice, footer, children, totalPriceInfo, hideDetails, unit, totalPriceDescription, }: NonScrollableContentProps) => import("@emotion/react/jsx-runtime").JSX.Element;
14
+ export declare const NonScrollableContent: ({ totalPrice, footer, children, totalPriceInfo, hideDetails, unit, totalPriceDescription, additionalInfo, }: NonScrollableContentProps) => import("@emotion/react/jsx-runtime").JSX.Element;
14
15
  export {};
@@ -13,7 +13,7 @@ const NonScrollableContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_E
13
13
  theme
14
14
  }) => theme.space[3], ";border-top:1px solid ", ({
15
15
  theme
16
- }) => theme.colors.neutral.border, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT3JkZXJTdW1tYXJ5L05vblNjcm9sbGFibGVDb250ZW50LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRNEMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9PcmRlclN1bW1hcnkvTm9uU2Nyb2xsYWJsZUNvbnRlbnQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB7IHVzZUNvbnRleHQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBPcmRlclN1bW1hcnlDb250ZXh0IH0gZnJvbSAnLi9Qcm92aWRlcidcbmltcG9ydCB7IERpc3BsYXlQcmljZSB9IGZyb20gJy4vaGVscGVycydcbmltcG9ydCB0eXBlIHsgUHJpY2VUeXBlU2luZ2xlLCBUaW1lVW5pdCB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IE5vblNjcm9sbGFibGVDb250YWluZXIgPSBzdHlsZWQoU3RhY2spYFxucGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVszXX07XG5ib3JkZXItdG9wOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuYFxuXG50eXBlIE5vblNjcm9sbGFibGVDb250ZW50UHJvcHMgPSB7XG4gIGRpc2NvdW50OiBudW1iZXJcbiAgdG90YWxQcmljZTogUHJpY2VUeXBlU2luZ2xlXG4gIGZvb3RlcjogUmVhY3ROb2RlXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgdG90YWxQcmljZUluZm8/OiBSZWFjdE5vZGVcbiAgdG90YWxQcmljZURlc2NyaXB0aW9uPzogUmVhY3ROb2RlXG4gIGhpZGVEZXRhaWxzOiBib29sZWFuXG4gIHVuaXQ6IFRpbWVVbml0XG59XG5cbmV4cG9ydCBjb25zdCBOb25TY3JvbGxhYmxlQ29udGVudCA9ICh7XG4gIHRvdGFsUHJpY2UsXG4gIGZvb3RlcixcbiAgY2hpbGRyZW4sXG4gIHRvdGFsUHJpY2VJbmZvLFxuICBoaWRlRGV0YWlscyxcbiAgdW5pdCxcbiAgdG90YWxQcmljZURlc2NyaXB0aW9uLFxufTogTm9uU2Nyb2xsYWJsZUNvbnRlbnRQcm9wcykgPT4ge1xuICBjb25zdCB7IGxvY2FsZXMgfSA9IHVzZUNvbnRleHQoT3JkZXJTdW1tYXJ5Q29udGV4dClcblxuICByZXR1cm4gKFxuICAgIDxOb25TY3JvbGxhYmxlQ29udGFpbmVyIGdhcD17M30+XG4gICAgICB7Y2hpbGRyZW59XG4gICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIganVzdGlmeUNvbnRlbnQ9XCJzcGFjZS1iZXR3ZWVuXCIgYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICB7dG90YWxQcmljZUluZm8gPyAoXG4gICAgICAgICAgPFN0YWNrPlxuICAgICAgICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGdhcD17MX0gYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICAgIGFzPVwic3BhblwiXG4gICAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICAgIHByb21pbmVuY2U9XCJzdHJvbmdcIlxuICAgICAgICAgICAgICA+XG4gICAgICAgICAgICAgICAge2xvY2FsZXNbJ29yZGVyLnN1bW1hcnkudG90YWwnXX06XG4gICAgICAgICAgICAgIDwvVGV4dD5cbiAgICAgICAgICAgICAge3RvdGFsUHJpY2VEZXNjcmlwdGlvbn1cbiAgICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICAgICB7dG90YWxQcmljZUluZm99XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgKSA6IChcbiAgICAgICAgICA8U3RhY2sgZGlyZWN0aW9uPVwicm93XCIgZ2FwPXsxfSBhbGlnbkl0ZW1zPVwiY2VudGVyXCI+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiYm9keVN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwic3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAge2xvY2FsZXNbJ29yZGVyLnN1bW1hcnkudG90YWwnXX06XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICB7dG90YWxQcmljZURlc2NyaXB0aW9ufVxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICl9XG4gICAgICAgIHt0b3RhbFByaWNlLnRvdGFsUHJpY2UgPT09IHRvdGFsUHJpY2UudG90YWxQcmljZVdpdGhEaXNjb3VudCA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICBkYXRhLXRlc3RpZD1cInRvdGFsLXByaWNlXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJzdHJvbmdcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxEaXNwbGF5UHJpY2UgcHJpY2U9e3RvdGFsUHJpY2V9IGJlZm9yZU9yQWZ0ZXI9XCJhZnRlclwiIC8+XG4gICAgICAgICAgICB7aGlkZURldGFpbHMgPyBgLyR7dW5pdH1gIDogbnVsbH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGdhcD17MX0gYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHN0cmlrZVRocm91Z2hcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPERpc3BsYXlQcmljZSBwcmljZT17dG90YWxQcmljZX0gYmVmb3JlT3JBZnRlcj1cImJlZm9yZVwiIC8+XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiaGVhZGluZ1NtYWxsU3Ryb25nXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIGRhdGEtdGVzdGlkPVwidG90YWwtcHJpY2VcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwic3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPERpc3BsYXlQcmljZSBwcmljZT17dG90YWxQcmljZX0gYmVmb3JlT3JBZnRlcj1cImFmdGVyXCIgLz5cbiAgICAgICAgICAgICAge2hpZGVEZXRhaWxzID8gYC8ke3VuaXR9YCA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgKX1cbiAgICAgIDwvU3RhY2s+XG4gICAgICB7Zm9vdGVyfVxuICAgIDwvTm9uU2Nyb2xsYWJsZUNvbnRhaW5lcj5cbiAgKVxufVxuIl19 */"));
16
+ }) => theme.colors.neutral.border, ";" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT3JkZXJTdW1tYXJ5L05vblNjcm9sbGFibGVDb250ZW50LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFRNEMiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9PcmRlclN1bW1hcnkvTm9uU2Nyb2xsYWJsZUNvbnRlbnQudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCB9IGZyb20gJ0B1bHRyYXZpb2xldC91aSdcbmltcG9ydCB7IHVzZUNvbnRleHQgfSBmcm9tICdyZWFjdCdcbmltcG9ydCB0eXBlIHsgUmVhY3ROb2RlIH0gZnJvbSAncmVhY3QnXG5pbXBvcnQgeyBPcmRlclN1bW1hcnlDb250ZXh0IH0gZnJvbSAnLi9Qcm92aWRlcidcbmltcG9ydCB7IERpc3BsYXlQcmljZSB9IGZyb20gJy4vaGVscGVycydcbmltcG9ydCB0eXBlIHsgUHJpY2VUeXBlU2luZ2xlLCBUaW1lVW5pdCB9IGZyb20gJy4vdHlwZXMnXG5cbmNvbnN0IE5vblNjcm9sbGFibGVDb250YWluZXIgPSBzdHlsZWQoU3RhY2spYFxucGFkZGluZzogJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5zcGFjZVszXX07XG5ib3JkZXItdG9wOiAxcHggc29saWQgJHsoeyB0aGVtZSB9KSA9PiB0aGVtZS5jb2xvcnMubmV1dHJhbC5ib3JkZXJ9O1xuYFxuXG50eXBlIE5vblNjcm9sbGFibGVDb250ZW50UHJvcHMgPSB7XG4gIGRpc2NvdW50OiBudW1iZXJcbiAgdG90YWxQcmljZTogUHJpY2VUeXBlU2luZ2xlXG4gIGZvb3RlcjogUmVhY3ROb2RlXG4gIGNoaWxkcmVuOiBSZWFjdE5vZGVcbiAgdG90YWxQcmljZUluZm8/OiBSZWFjdE5vZGVcbiAgdG90YWxQcmljZURlc2NyaXB0aW9uPzogUmVhY3ROb2RlXG4gIGFkZGl0aW9uYWxJbmZvPzogc3RyaW5nXG4gIGhpZGVEZXRhaWxzOiBib29sZWFuXG4gIHVuaXQ6IFRpbWVVbml0XG59XG5cbmV4cG9ydCBjb25zdCBOb25TY3JvbGxhYmxlQ29udGVudCA9ICh7XG4gIHRvdGFsUHJpY2UsXG4gIGZvb3RlcixcbiAgY2hpbGRyZW4sXG4gIHRvdGFsUHJpY2VJbmZvLFxuICBoaWRlRGV0YWlscyxcbiAgdW5pdCxcbiAgdG90YWxQcmljZURlc2NyaXB0aW9uLFxuICBhZGRpdGlvbmFsSW5mbyxcbn06IE5vblNjcm9sbGFibGVDb250ZW50UHJvcHMpID0+IHtcbiAgY29uc3QgeyBsb2NhbGVzIH0gPSB1c2VDb250ZXh0KE9yZGVyU3VtbWFyeUNvbnRleHQpXG5cbiAgcmV0dXJuIChcbiAgICA8Tm9uU2Nyb2xsYWJsZUNvbnRhaW5lciBnYXA9ezN9PlxuICAgICAge2NoaWxkcmVufVxuICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGp1c3RpZnlDb250ZW50PVwic3BhY2UtYmV0d2VlblwiIGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAge3RvdGFsUHJpY2VJbmZvID8gKFxuICAgICAgICAgIDxTdGFjaz5cbiAgICAgICAgICAgIDxTdGFjayBkaXJlY3Rpb249XCJyb3dcIiBnYXA9ezF9IGFsaWduSXRlbXM9XCJjZW50ZXJcIj5cbiAgICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICAgIHZhcmlhbnQ9XCJib2R5U3Ryb25nXCJcbiAgICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgICBwcm9taW5lbmNlPVwic3Ryb25nXCJcbiAgICAgICAgICAgICAgPlxuICAgICAgICAgICAgICAgIHtsb2NhbGVzWydvcmRlci5zdW1tYXJ5LnRvdGFsJ119OlxuICAgICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICAgIHt0b3RhbFByaWNlRGVzY3JpcHRpb259XG4gICAgICAgICAgICA8L1N0YWNrPlxuICAgICAgICAgICAge3RvdGFsUHJpY2VJbmZvfVxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGdhcD17MX0gYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTdHJvbmdcIlxuICAgICAgICAgICAgICBzZW50aW1lbnQ9XCJuZXV0cmFsXCJcbiAgICAgICAgICAgICAgcHJvbWluZW5jZT1cInN0cm9uZ1wiXG4gICAgICAgICAgICA+XG4gICAgICAgICAgICAgIHtsb2NhbGVzWydvcmRlci5zdW1tYXJ5LnRvdGFsJ119XG4gICAgICAgICAgICAgIHthZGRpdGlvbmFsSW5mbyA/IGAgJHthZGRpdGlvbmFsSW5mb31gIDogbnVsbH06XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICB7dG90YWxQcmljZURlc2NyaXB0aW9ufVxuICAgICAgICAgIDwvU3RhY2s+XG4gICAgICAgICl9XG4gICAgICAgIHt0b3RhbFByaWNlLnRvdGFsUHJpY2UgPT09IHRvdGFsUHJpY2UudG90YWxQcmljZVdpdGhEaXNjb3VudCA/IChcbiAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgIHZhcmlhbnQ9XCJoZWFkaW5nU21hbGxTdHJvbmdcIlxuICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICBkYXRhLXRlc3RpZD1cInRvdGFsLXByaWNlXCJcbiAgICAgICAgICAgIHByb21pbmVuY2U9XCJzdHJvbmdcIlxuICAgICAgICAgID5cbiAgICAgICAgICAgIDxEaXNwbGF5UHJpY2UgcHJpY2U9e3RvdGFsUHJpY2V9IGJlZm9yZU9yQWZ0ZXI9XCJhZnRlclwiIC8+XG4gICAgICAgICAgICB7aGlkZURldGFpbHMgPyBgLyR7dW5pdH1gIDogbnVsbH1cbiAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICkgOiAoXG4gICAgICAgICAgPFN0YWNrIGRpcmVjdGlvbj1cInJvd1wiIGdhcD17MX0gYWxpZ25JdGVtcz1cImNlbnRlclwiPlxuICAgICAgICAgICAgPFRleHRcbiAgICAgICAgICAgICAgYXM9XCJzcGFuXCJcbiAgICAgICAgICAgICAgdmFyaWFudD1cImJvZHlTbWFsbFN0cm9uZ1wiXG4gICAgICAgICAgICAgIHNlbnRpbWVudD1cIm5ldXRyYWxcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwid2Vha1wiXG4gICAgICAgICAgICAgIHN0cmlrZVRocm91Z2hcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPERpc3BsYXlQcmljZSBwcmljZT17dG90YWxQcmljZX0gYmVmb3JlT3JBZnRlcj1cImJlZm9yZVwiIC8+XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgICA8VGV4dFxuICAgICAgICAgICAgICBhcz1cInNwYW5cIlxuICAgICAgICAgICAgICB2YXJpYW50PVwiaGVhZGluZ1NtYWxsU3Ryb25nXCJcbiAgICAgICAgICAgICAgc2VudGltZW50PVwibmV1dHJhbFwiXG4gICAgICAgICAgICAgIGRhdGEtdGVzdGlkPVwidG90YWwtcHJpY2VcIlxuICAgICAgICAgICAgICBwcm9taW5lbmNlPVwic3Ryb25nXCJcbiAgICAgICAgICAgID5cbiAgICAgICAgICAgICAgPERpc3BsYXlQcmljZSBwcmljZT17dG90YWxQcmljZX0gYmVmb3JlT3JBZnRlcj1cImFmdGVyXCIgLz5cbiAgICAgICAgICAgICAge2hpZGVEZXRhaWxzID8gYC8ke3VuaXR9YCA6IG51bGx9XG4gICAgICAgICAgICA8L1RleHQ+XG4gICAgICAgICAgPC9TdGFjaz5cbiAgICAgICAgKX1cbiAgICAgIDwvU3RhY2s+XG4gICAgICB7Zm9vdGVyfVxuICAgIDwvTm9uU2Nyb2xsYWJsZUNvbnRhaW5lcj5cbiAgKVxufVxuIl19 */"));
17
17
  const NonScrollableContent = ({
18
18
  totalPrice,
19
19
  footer,
@@ -21,7 +21,8 @@ const NonScrollableContent = ({
21
21
  totalPriceInfo,
22
22
  hideDetails,
23
23
  unit,
24
- totalPriceDescription
24
+ totalPriceDescription,
25
+ additionalInfo
25
26
  }) => {
26
27
  const {
27
28
  locales
@@ -41,6 +42,7 @@ const NonScrollableContent = ({
41
42
  ] }) : /* @__PURE__ */ jsxs(Stack, { direction: "row", gap: 1, alignItems: "center", children: [
42
43
  /* @__PURE__ */ jsxs(Text, { as: "span", variant: "bodyStrong", sentiment: "neutral", prominence: "strong", children: [
43
44
  locales["order.summary.total"],
45
+ additionalInfo ? ` ${additionalInfo}` : null,
44
46
  ":"
45
47
  ] }),
46
48
  totalPriceDescription
@@ -21,7 +21,7 @@ const Container = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env
21
21
  theme
22
22
  }) => theme.colors.neutral.backgroundWeak, ";height:100%;width:20rem;@media (min-width: ", ({
23
23
  theme
24
- }) => theme.breakpoints.large, "){width:27.5rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
24
+ }) => theme.breakpoints.large, "){width:27.5rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n          additionalInfo={additionalInfo}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
25
25
  const HeaderContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
26
26
  target: "e14yhwy31"
27
27
  } : {
@@ -35,7 +35,7 @@ const HeaderContainer = /* @__PURE__ */ _styled__default.default(ui.Stack, proce
35
35
  theme
36
36
  }) => theme.space[2], ';&[data-hidedetails="false"]{border-bottom:1px solid ', ({
37
37
  theme
38
- }) => theme.colors.neutral.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAqBsE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
38
+ }) => theme.colors.neutral.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAqBsE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n          additionalInfo={additionalInfo}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
39
39
  const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
40
40
  target: "e14yhwy30"
41
41
  } : {
@@ -45,7 +45,7 @@ const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.e
45
45
  theme
46
46
  }) => theme.colors.neutral.background, ";width:10rem;@media (min-width: ", ({
47
47
  theme
48
- }) => theme.breakpoints.large, "){width:11rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AA+BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
48
+ }) => theme.breakpoints.large, "){width:11rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AA+BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n          additionalInfo={additionalInfo}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
49
49
  const OrderSummary = ({
50
50
  header,
51
51
  hideTimeUnit = false,
@@ -64,7 +64,8 @@ const OrderSummary = ({
64
64
  hideDetails = false,
65
65
  onChange,
66
66
  onChangeUnitInput,
67
- totalPriceDescription
67
+ totalPriceDescription,
68
+ additionalInfo
68
69
  }) => {
69
70
  const [timePeriodUnit, setTimePeriodUnit] = react.useState(unitUnitInput);
70
71
  const [timePeriodAmount, setTimePeriodAmount] = react.useState(valueUnitInput);
@@ -128,7 +129,7 @@ const OrderSummary = ({
128
129
  }, value: valueUnitInput, unitValue: unitUnitInput, size: "small", dropdownAlign: "center" }) }) : null
129
130
  ] }) : null,
130
131
  !hideDetails ? /* @__PURE__ */ jsxRuntime.jsx(ScrollableContent.ScrollableContent, {}) : null,
131
- /* @__PURE__ */ jsxRuntime.jsx(NonScrollableContent.NonScrollableContent, { totalPrice, discount, footer, totalPriceInfo, hideDetails, unit: unitUnitInput, totalPriceDescription, children })
132
+ /* @__PURE__ */ jsxRuntime.jsx(NonScrollableContent.NonScrollableContent, { totalPrice, discount, footer, totalPriceInfo, hideDetails, unit: unitUnitInput, totalPriceDescription, additionalInfo, children })
132
133
  ] }) });
133
134
  };
134
135
  exports.OrderSummary = OrderSummary;
@@ -1,2 +1,2 @@
1
1
  import type { OrderSummaryProps } from './types';
2
- export declare const OrderSummary: ({ header, hideTimeUnit, periodOptions, valueUnitInput, unitUnitInput, items, locales, currency, localeFormat, footer, children, discount, totalPriceInfo, fractionDigits, hideDetails, onChange, onChangeUnitInput, totalPriceDescription, }: OrderSummaryProps) => import("@emotion/react/jsx-runtime").JSX.Element;
2
+ export declare const OrderSummary: ({ header, hideTimeUnit, periodOptions, valueUnitInput, unitUnitInput, items, locales, currency, localeFormat, footer, children, discount, totalPriceInfo, fractionDigits, hideDetails, onChange, onChangeUnitInput, totalPriceDescription, additionalInfo, }: OrderSummaryProps) => import("@emotion/react/jsx-runtime").JSX.Element;
@@ -17,7 +17,7 @@ const Container = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "produ
17
17
  theme
18
18
  }) => theme.colors.neutral.backgroundWeak, ";height:100%;width:20rem;@media (min-width: ", ({
19
19
  theme
20
- }) => theme.breakpoints.large, "){width:27.5rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
20
+ }) => theme.breakpoints.large, "){width:27.5rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAW+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n          additionalInfo={additionalInfo}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
21
21
  const HeaderContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
22
22
  target: "e14yhwy31"
23
23
  } : {
@@ -31,7 +31,7 @@ const HeaderContainer = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV ===
31
31
  theme
32
32
  }) => theme.space[2], ';&[data-hidedetails="false"]{border-bottom:1px solid ', ({
33
33
  theme
34
- }) => theme.colors.neutral.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAqBsE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
34
+ }) => theme.colors.neutral.border, ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AAqBsE","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n          additionalInfo={additionalInfo}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
35
35
  const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
36
36
  target: "e14yhwy30"
37
37
  } : {
@@ -41,7 +41,7 @@ const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "pro
41
41
  theme
42
42
  }) => theme.colors.neutral.background, ";width:10rem;@media (min-width: ", ({
43
43
  theme
44
- }) => theme.breakpoints.large, "){width:11rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AA+BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
44
+ }) => theme.breakpoints.large, "){width:11rem;}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx"],"names":[],"mappings":"AA+BiC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/index.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { Stack, Text, UnitInput } from '@ultraviolet/ui'\nimport { useEffect, useMemo, useState } from 'react'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 27.5rem;\n  }\n`\n\nconst HeaderContainer = styled(Stack)<{ 'data-hidedetails': boolean }>`\n  height: ${({ theme }) => theme.sizing[900]};\n  padding: ${({ theme }) => theme.space[3]};\n  padding-bottom: ${({ theme }) => theme.space[2]};\n\n  &[data-hidedetails=\"false\"] {\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n  }\n`\n\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n  width: 10rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    width: 11rem;\n  }\n\n`\n\nexport const OrderSummary = ({\n  header,\n  hideTimeUnit = false,\n  periodOptions = Units,\n  valueUnitInput = 1,\n  unitUnitInput = 'hours',\n  items,\n  locales = orderSummaryLocales,\n  currency = 'EUR',\n  localeFormat = 'en-US',\n  footer,\n  children,\n  discount = 0,\n  totalPriceInfo,\n  fractionDigits,\n  hideDetails = false,\n  onChange,\n  onChangeUnitInput,\n  totalPriceDescription,\n  additionalInfo,\n}: OrderSummaryProps) => {\n  const [timePeriodUnit, setTimePeriodUnit] = useState<TimeUnit>(unitUnitInput)\n  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput)\n\n  const categoriesPrice = useMemo(\n    () =>\n      items.reduce<PriceType>((acc, category) => {\n        const { categoryPrice, discountedPrice } = calculateCategoryPrice(\n          category,\n          hideTimeUnit,\n          timePeriodAmount,\n          timePeriodUnit,\n        )\n\n        return {\n          ...acc,\n          [category.category]: {\n            maxPrice: categoryPrice[1],\n            maxPriceWithDiscount: discountedPrice[1],\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\n            timeUnit: unitUnitInput,\n          },\n        }\n      }, {}),\n    [hideTimeUnit, items, timePeriodAmount, timePeriodUnit, unitUnitInput],\n  )\n\n  const totalPrice = useMemo(() => {\n    const price = Object.values(categoriesPrice).reduce<[number, number]>(\n      (acc, categoryPrice) => [\n        acc[0] + categoryPrice.totalPriceWithDiscount,\n        acc[1] + categoryPrice.maxPriceWithDiscount,\n      ],\n      [0, 0],\n    )\n\n    const computedPrice = {\n      maxPrice: Math.max(price[1], 0),\n      maxPriceWithDiscount: Math.max(\n        price[1] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      totalPrice: Math.max(price[0], 0),\n      totalPriceWithDiscount: Math.max(\n        price[0] * (discount < 1 ? 1 - discount : 1) -\n          (discount >= 1 ? Math.abs(discount) : 0),\n        0,\n      ),\n      timeUnit: unitUnitInput,\n    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    }),\n    [\n      currency,\n      localeFormat,\n      items,\n      categoriesPrice,\n      hideTimeUnit,\n      timePeriodUnit,\n      timePeriodAmount,\n      locales,\n      fractionDigits,\n    ],\n  )\n\n  const computePeriodOptions = useMemo(() => {\n    const computedPeriodOptions: { label: string; value: string }[] = []\n\n    periodOptions.forEach(option =>\n      computedPeriodOptions.push({\n        value: option,\n        label: locales[`order.summary.units.${option}.label` as const],\n      }),\n    )\n\n    return computedPeriodOptions\n  }, [periodOptions, locales])\n\n  useEffect(() => {\n    onChange?.(categoriesPrice, totalPrice)\n  }, [categoriesPrice, totalPrice, onChange])\n\n  return (\n    <OrderSummaryContext.Provider value={valueContext}>\n      <Container justifyContent={hideDetails ? 'flex-start' : 'space-between'}>\n        {header ? (\n          <HeaderContainer\n            direction=\"row\"\n            justifyContent=\"space-between\"\n            data-hidedetails={hideDetails}\n          >\n            <Text\n              as=\"h3\"\n              variant=\"headingSmallStrong\"\n              sentiment=\"neutral\"\n              prominence=\"strong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  width=\"100%\"\n                  selectInputWidth=\"fit-content\"\n                  options={computePeriodOptions}\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  value={valueUnitInput}\n                  unitValue={unitUnitInput}\n                  size=\"small\"\n                  dropdownAlign=\"center\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          totalPrice={totalPrice}\n          discount={discount}\n          footer={footer}\n          totalPriceInfo={totalPriceInfo}\n          hideDetails={hideDetails}\n          unit={unitUnitInput}\n          totalPriceDescription={totalPriceDescription}\n          additionalInfo={additionalInfo}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
45
45
  const OrderSummary = ({
46
46
  header,
47
47
  hideTimeUnit = false,
@@ -60,7 +60,8 @@ const OrderSummary = ({
60
60
  hideDetails = false,
61
61
  onChange,
62
62
  onChangeUnitInput,
63
- totalPriceDescription
63
+ totalPriceDescription,
64
+ additionalInfo
64
65
  }) => {
65
66
  const [timePeriodUnit, setTimePeriodUnit] = useState(unitUnitInput);
66
67
  const [timePeriodAmount, setTimePeriodAmount] = useState(valueUnitInput);
@@ -124,7 +125,7 @@ const OrderSummary = ({
124
125
  }, value: valueUnitInput, unitValue: unitUnitInput, size: "small", dropdownAlign: "center" }) }) : null
125
126
  ] }) : null,
126
127
  !hideDetails ? /* @__PURE__ */ jsx(ScrollableContent, {}) : null,
127
- /* @__PURE__ */ jsx(NonScrollableContent, { totalPrice, discount, footer, totalPriceInfo, hideDetails, unit: unitUnitInput, totalPriceDescription, children })
128
+ /* @__PURE__ */ jsx(NonScrollableContent, { totalPrice, discount, footer, totalPriceInfo, hideDetails, unit: unitUnitInput, totalPriceDescription, additionalInfo, children })
128
129
  ] }) });
129
130
  };
130
131
  export {
@@ -97,6 +97,7 @@ export type OrderSummaryProps = {
97
97
  children?: ReactNode;
98
98
  totalPriceInfo?: ReactNode;
99
99
  totalPriceDescription?: ReactNode;
100
+ additionalInfo?: string;
100
101
  /**
101
102
  * Number of fraction digit to display in the price details
102
103
  */
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/plus",
3
- "version": "1.0.0-beta.13",
3
+ "version": "1.0.0-beta.14",
4
4
  "description": "Ultraviolet Plus",
5
5
  "homepage": "https://github.com/scaleway/ultraviolet#readme",
6
6
  "repository": {
@@ -55,7 +55,7 @@
55
55
  "@emotion/styled": "11.14.0",
56
56
  "react": "18.x || 19.x",
57
57
  "react-dom": "18.x || 19.x",
58
- "@ultraviolet/ui": "2.0.0-beta.13"
58
+ "@ultraviolet/ui": "2.0.0-beta.14"
59
59
  },
60
60
  "devDependencies": {
61
61
  "@babel/core": "7.27.4",
@@ -66,8 +66,8 @@
66
66
  "react": "19.1.0",
67
67
  "react-dom": "19.1.0",
68
68
  "@ultraviolet/illustrations": "5.0.0-beta.3",
69
- "@utils/test": "0.0.1",
70
- "@ultraviolet/ui": "2.0.0-beta.13"
69
+ "@ultraviolet/ui": "2.0.0-beta.14",
70
+ "@utils/test": "0.0.1"
71
71
  },
72
72
  "dependencies": {
73
73
  "@uiw/codemirror-extensions-langs": "4.23.13",