@ultraviolet/plus 2.0.0-beta.10 → 2.0.0-beta.11

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.
@@ -15,7 +15,7 @@ const StyledNumberInputV2 = /* @__PURE__ */ _styled__default.default(ui.NumberIn
15
15
  label: "StyledNumberInputV2"
16
16
  })("max-width:12.5rem;background-color:", ({
17
17
  theme
18
- }) => theme.colors.neutral.background, ";" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAW+C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
18
+ }) => theme.colors.neutral.background, ";" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAW+C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
19
19
  const ContainerScrollable = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
20
20
  target: "e3ux9t2"
21
21
  } : {
@@ -23,7 +23,7 @@ const ContainerScrollable = /* @__PURE__ */ _styled__default.default(ui.Stack, p
23
23
  label: "ContainerScrollable"
24
24
  })("overflow-y:scroll;padding:", ({
25
25
  theme
26
- }) => theme.space[3], ";height:100%;" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAeyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
26
+ }) => theme.space[3], ";min-height:10rem;height:100%;" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAeyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
27
27
  const DetailsStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
28
28
  target: "e3ux9t1"
29
29
  } : {
@@ -31,7 +31,7 @@ const DetailsStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.
31
31
  label: "DetailsStack"
32
32
  })("padding-left:", ({
33
33
  theme
34
- }) => theme.space[1], ";" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAqBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
34
+ }) => theme.space[1], ";" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAsBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
35
35
  const CategoryStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env.NODE_ENV === "production" ? {
36
36
  target: "e3ux9t0"
37
37
  } : {
@@ -41,7 +41,7 @@ const CategoryStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process
41
41
  theme
42
42
  }) => theme.colors.neutral.border, ";padding-bottom:", ({
43
43
  theme
44
- }) => theme.space[3], ";}" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAwBmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
44
+ }) => theme.space[3], ";}" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAyBmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
45
45
  const CategoryName = ({
46
46
  category
47
47
  }) => {
@@ -11,7 +11,7 @@ const StyledNumberInputV2 = /* @__PURE__ */ _styled(NumberInput, process.env.NOD
11
11
  label: "StyledNumberInputV2"
12
12
  })("max-width:12.5rem;background-color:", ({
13
13
  theme
14
- }) => theme.colors.neutral.background, ";" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAW+C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
14
+ }) => theme.colors.neutral.background, ";" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAW+C","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
15
15
  const ContainerScrollable = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
16
16
  target: "e3ux9t2"
17
17
  } : {
@@ -19,7 +19,7 @@ const ContainerScrollable = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV
19
19
  label: "ContainerScrollable"
20
20
  })("overflow-y:scroll;padding:", ({
21
21
  theme
22
- }) => theme.space[3], ";height:100%;" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAeyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
22
+ }) => theme.space[3], ";min-height:10rem;height:100%;" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAeyC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
23
23
  const DetailsStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
24
24
  target: "e3ux9t1"
25
25
  } : {
@@ -27,7 +27,7 @@ const DetailsStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "pr
27
27
  label: "DetailsStack"
28
28
  })("padding-left:", ({
29
29
  theme
30
- }) => theme.space[1], ";" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAqBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
30
+ }) => theme.space[1], ";" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAsBkC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
31
31
  const CategoryStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "production" ? {
32
32
  target: "e3ux9t0"
33
33
  } : {
@@ -37,7 +37,7 @@ const CategoryStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "p
37
37
  theme
38
38
  }) => theme.colors.neutral.border, ";padding-bottom:", ({
39
39
  theme
40
- }) => theme.space[3], ";}" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAwBmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\nmax-width: 12.5rem;\nbackground-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\noverflow-y: scroll;\npadding: ${({ theme }) => theme.space[3]};\nheight: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
40
+ }) => theme.space[3], ";}" + (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/ScrollableContent.tsx"],"names":[],"mappings":"AAyBmC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/OrderSummary/ScrollableContent.tsx","sourcesContent":["import styled from '@emotion/styled'\nimport { NumberInput, Stack, Text } from '@ultraviolet/ui'\nimport { useContext } from 'react'\nimport {\n  calculateSubCategoryPrice,\n  DisplayPrice,\n  formatNumber,\n} from './helpers'\nimport { OrderSummaryContext } from './Provider'\nimport type { ItemsType, SubCategoryType } from './types'\n\nconst StyledNumberInputV2 = styled(NumberInput)`\n  max-width: 12.5rem;\n  background-color: ${({ theme }) => theme.colors.neutral.background};\n`\nconst ContainerScrollable = styled(Stack)`\n  overflow-y: scroll;\n  padding: ${({ theme }) => theme.space[3]};\n  min-height: 10rem;\n  height: 100%;\n`\n\nconst DetailsStack = styled(Stack)`\npadding-left: ${({ theme }) => theme.space[1]};\n`\nconst CategoryStack = styled(Stack)`\n  :not(:last-child){\n    border-bottom: 1px solid ${({ theme }) => theme.colors.neutral.border};\n    padding-bottom: ${({ theme }) => theme.space[3]};\n  }\n`\nconst CategoryName = ({ category }: { category: ItemsType }) => {\n  const { categoriesPrice } = useContext(OrderSummaryContext)\n\n  const categoryPrice = categoriesPrice[category.category] ?? {\n    maxPrice: 0,\n    maxPriceWithDiscount: 0,\n    timeUnit: 'hours',\n    totalPrice: 0,\n    totalPriceWithDiscount: 0,\n  }\n\n  return category.category ? (\n    <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n      {category.additionalInfo ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            {category.category}\n          </Text>\n          <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n            {category.additionalInfo}\n          </Text>\n        </Stack>\n      ) : (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          {category.category}\n        </Text>\n      )}\n      {category.customContent}\n      {category.numberInput ? (\n        <StyledNumberInputV2\n          controls={category.numberInputControls}\n          onChange={category.onChangeInput}\n          size=\"small\"\n          unit={category.numberInputUnit}\n          value={category.numberInputValue}\n        />\n      ) : null}\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice === categoryPrice.totalPriceWithDiscount ? (\n        <Text\n          as=\"span\"\n          prominence=\"strong\"\n          sentiment=\"neutral\"\n          variant=\"bodyStrong\"\n        >\n          <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n        </Text>\n      ) : null}\n\n      {!category.customContent &&\n      !category.numberInput &&\n      categoryPrice.totalPrice !== categoryPrice.totalPriceWithDiscount ? (\n        <Stack alignItems=\"center\" direction=\"row\" gap={1}>\n          <Text\n            as=\"span\"\n            prominence=\"weak\"\n            sentiment=\"neutral\"\n            strikeThrough\n            variant=\"bodySmallStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"before\" price={categoryPrice} />\n          </Text>\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodyStrong\"\n          >\n            <DisplayPrice beforeOrAfter=\"after\" price={categoryPrice} />\n          </Text>\n        </Stack>\n      ) : null}\n    </Stack>\n  ) : null\n}\n\nconst SubCategory = ({ subCategory }: { subCategory: SubCategoryType }) => {\n  const {\n    currency,\n    localeFormat,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n    fractionDigits,\n  } = useContext(OrderSummaryContext)\n  const subCategoryPrice = calculateSubCategoryPrice(\n    subCategory,\n    hideTimeUnit,\n    timePeriodAmount,\n    timePeriodUnit,\n  )\n\n  return (\n    <Stack direction=\"column\" gap={1}>\n      <Stack alignItems=\"center\" direction=\"row\" justifyContent=\"space-between\">\n        {subCategory.title ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        ) : null}\n        {subCategory.customContent ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.customContent}\n          </Text>\n        ) : null}\n        {subCategory.numberInput ? (\n          <StyledNumberInputV2\n            controls={subCategory.numberInputControls}\n            onChange={subCategory.onChangeInput}\n            size=\"small\"\n            unit={subCategory.numberInputUnit}\n            value={subCategory.numberInputValue}\n          />\n        ) : null}\n        {subCategory.price !== undefined && !subCategory.hidePrice ? (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategoryPrice[0] === subCategoryPrice[1] ||\n            subCategory.priceUnit\n              ? formatNumber(\n                  subCategory.priceUnit\n                    ? subCategory.price\n                    : subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )\n              : `${formatNumber(\n                  subCategoryPrice[0],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )} - ${formatNumber(\n                  subCategoryPrice[1],\n                  localeFormat,\n                  currency,\n                  fractionDigits,\n                )}`}\n            {subCategory.priceUnit ? ` /${subCategory.priceUnit}` : ''}\n          </Text>\n        ) : null}\n      </Stack>\n\n      <DetailsStack direction=\"column\" gap={0.5}>\n        {subCategory.details?.map(detail =>\n          detail ? (\n            <Text\n              as=\"span\"\n              key={detail}\n              sentiment=\"neutral\"\n              variant=\"bodySmall\"\n            >\n              {detail}\n            </Text>\n          ) : null,\n        )}\n      </DetailsStack>\n    </Stack>\n  )\n}\n\nexport const ScrollableContent = () => {\n  const { items } = useContext(OrderSummaryContext)\n\n  return (\n    <ContainerScrollable gap={3}>\n      {items.map(category =>\n        Object.keys(category).length > 0 && category.category ? (\n          <CategoryStack gap={1.5} key={category.category}>\n            <CategoryName category={category} />\n            {category.subCategories &&\n            Object.keys(category.subCategories).length > 0 ? (\n              <Stack gap={1}>\n                {category.subCategories.map((subCategory, index) => (\n                  <SubCategory\n                    key={subCategory.title ?? `${index}`}\n                    subCategory={subCategory}\n                  />\n                ))}\n              </Stack>\n            ) : null}\n          </CategoryStack>\n        ) : null,\n      )}\n    </ContainerScrollable>\n  )\n}\n"]} */"));
41
41
  const CategoryName = ({
42
42
  category
43
43
  }) => {
@@ -19,9 +19,9 @@ const Container = /* @__PURE__ */ _styled__default.default(ui.Stack, process.env
19
19
  label: "Container"
20
20
  })("background-color:", ({
21
21
  theme
22
- }) => theme.colors.neutral.backgroundWeak, ";height:100%;width:20rem;@media (min-width: ", ({
22
+ }) => theme.colors.neutral.backgroundWeak, ";height:100%;min-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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
24
+ }) => theme.breakpoints.large, "){min-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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\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
  } : {
@@ -43,7 +43,7 @@ const StyledStack = /* @__PURE__ */ _styled__default.default(ui.Stack, process.e
43
43
  label: "StyledStack"
44
44
  })("background-color:", ({
45
45
  theme
46
- }) => theme.colors.neutral.background, ";" + (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":"AA8BiC","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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
46
+ }) => theme.colors.neutral.background, ";" + (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":"AA8BiC","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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
47
47
  const OrderSummary = ({
48
48
  header,
49
49
  hideTimeUnit = false,
@@ -15,9 +15,9 @@ const Container = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "produ
15
15
  label: "Container"
16
16
  })("background-color:", ({
17
17
  theme
18
- }) => theme.colors.neutral.backgroundWeak, ";height:100%;width:20rem;@media (min-width: ", ({
18
+ }) => theme.colors.neutral.backgroundWeak, ";height:100%;min-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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
20
+ }) => theme.breakpoints.large, "){min-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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\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
  } : {
@@ -39,7 +39,7 @@ const StyledStack = /* @__PURE__ */ _styled(Stack, process.env.NODE_ENV === "pro
39
39
  label: "StyledStack"
40
40
  })("background-color:", ({
41
41
  theme
42
- }) => theme.colors.neutral.background, ";" + (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":"AA8BiC","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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
42
+ }) => theme.colors.neutral.background, ";" + (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":"AA8BiC","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 { Units } from './constants'\nimport { calculateCategoryPrice } from './helpers'\nimport orderSummaryLocales from './locales/en'\nimport { NonScrollableContent } from './NonScrollableContent'\nimport { OrderSummaryContext } from './Provider'\nimport { ScrollableContent } from './ScrollableContent'\nimport type { OrderSummaryProps, PriceType, TimeUnit } from './types'\n\nconst Container = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.backgroundWeak};\n  height: 100%;\n  min-width: 20rem;\n\n  @media (min-width: ${({ theme }) => theme.breakpoints.large}) {\n    min-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`\nconst StyledStack = styled(Stack)`\n  background-color: ${({ theme }) => theme.colors.neutral.background};\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            timeUnit: unitUnitInput,\n            totalPrice: categoryPrice[0],\n            totalPriceWithDiscount: discountedPrice[0],\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      timeUnit: unitUnitInput,\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    }\n\n    return computedPrice\n  }, [categoriesPrice, discount, unitUnitInput])\n\n  const valueContext = useMemo(\n    () => ({\n      categoriesPrice,\n      currency,\n      fractionDigits,\n      hideTimeUnit,\n      items,\n      localeFormat,\n      locales,\n      timePeriodAmount,\n      timePeriodUnit,\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        label: locales[`order.summary.units.${option}.label` as const],\n        value: option,\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            data-hidedetails={hideDetails}\n            direction=\"row\"\n            justifyContent=\"space-between\"\n          >\n            <Text\n              as=\"h3\"\n              prominence=\"strong\"\n              sentiment=\"neutral\"\n              variant=\"headingSmallStrong\"\n            >\n              {header}\n            </Text>\n            {!hideTimeUnit && !hideDetails ? (\n              <StyledStack>\n                <UnitInput\n                  dropdownAlign=\"center\"\n                  onChange={value => {\n                    setTimePeriodAmount(value)\n                  }}\n                  onChangeUnitValue={(val: string) => {\n                    setTimePeriodUnit(val as TimeUnit)\n                    onChangeUnitInput?.(val)\n                  }}\n                  options={computePeriodOptions}\n                  selectInputWidth=\"100%\"\n                  size=\"small\"\n                  templateColumns=\"2fr 3fr\"\n                  unitValue={unitUnitInput}\n                  value={valueUnitInput}\n                  width=\"155px\"\n                />\n              </StyledStack>\n            ) : null}\n          </HeaderContainer>\n        ) : null}\n        {!hideDetails ? <ScrollableContent /> : null}\n        <NonScrollableContent\n          additionalInfo={additionalInfo}\n          discount={discount}\n          footer={footer}\n          hideDetails={hideDetails}\n          totalPrice={totalPrice}\n          totalPriceDescription={totalPriceDescription}\n          totalPriceInfo={totalPriceInfo}\n          unit={unitUnitInput}\n        >\n          {children}\n        </NonScrollableContent>\n      </Container>\n    </OrderSummaryContext.Provider>\n  )\n}\n"]} */"));
43
43
  const OrderSummary = ({
44
44
  header,
45
45
  hideTimeUnit = false,
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/plus",
3
- "version": "2.0.0-beta.10",
3
+ "version": "2.0.0-beta.11",
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.1",
56
56
  "react": "18.x || 19.x",
57
57
  "react-dom": "18.x || 19.x",
58
- "@ultraviolet/ui": "3.0.0-beta.10"
58
+ "@ultraviolet/ui": "3.0.0-beta.11"
59
59
  },
60
60
  "devDependencies": {
61
61
  "@babel/core": "7.28.4",
@@ -66,7 +66,7 @@
66
66
  "react": "19.1.1",
67
67
  "react-dom": "19.1.1",
68
68
  "@ultraviolet/illustrations": "5.1.0-beta.2",
69
- "@ultraviolet/ui": "3.0.0-beta.10",
69
+ "@ultraviolet/ui": "3.0.0-beta.11",
70
70
  "@utils/test": "0.0.1"
71
71
  },
72
72
  "dependencies": {