@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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT3JkZXJTdW1tYXJ5L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9PcmRlclN1bW1hcnkvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCwgVW5pdElucHV0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VNZW1vLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgVW5pdHMgfSBmcm9tICcuL2NvbnN0YW50cydcbmltcG9ydCB7IGNhbGN1bGF0ZUNhdGVnb3J5UHJpY2UgfSBmcm9tICcuL2hlbHBlcnMnXG5pbXBvcnQgb3JkZXJTdW1tYXJ5TG9jYWxlcyBmcm9tICcuL2xvY2FsZXMvZW4nXG5pbXBvcnQgeyBOb25TY3JvbGxhYmxlQ29udGVudCB9IGZyb20gJy4vTm9uU2Nyb2xsYWJsZUNvbnRlbnQnXG5pbXBvcnQgeyBPcmRlclN1bW1hcnlDb250ZXh0IH0gZnJvbSAnLi9Qcm92aWRlcidcbmltcG9ydCB7IFNjcm9sbGFibGVDb250ZW50IH0gZnJvbSAnLi9TY3JvbGxhYmxlQ29udGVudCdcbmltcG9ydCB0eXBlIHsgT3JkZXJTdW1tYXJ5UHJvcHMsIFByaWNlVHlwZSwgVGltZVVuaXQgfSBmcm9tICcuL3R5cGVzJ1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQoU3RhY2spYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+
|
|
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,
|
|
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,
|
|
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,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT3JkZXJTdW1tYXJ5L2luZGV4LnRzeCJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFXK0IiLCJmaWxlIjoiL2hvbWUvcnVubmVyL3dvcmsvdWx0cmF2aW9sZXQvdWx0cmF2aW9sZXQvcGFja2FnZXMvcGx1cy9zcmMvY29tcG9uZW50cy9PcmRlclN1bW1hcnkvaW5kZXgudHN4Iiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBTdGFjaywgVGV4dCwgVW5pdElucHV0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VNZW1vLCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgVW5pdHMgfSBmcm9tICcuL2NvbnN0YW50cydcbmltcG9ydCB7IGNhbGN1bGF0ZUNhdGVnb3J5UHJpY2UgfSBmcm9tICcuL2hlbHBlcnMnXG5pbXBvcnQgb3JkZXJTdW1tYXJ5TG9jYWxlcyBmcm9tICcuL2xvY2FsZXMvZW4nXG5pbXBvcnQgeyBOb25TY3JvbGxhYmxlQ29udGVudCB9IGZyb20gJy4vTm9uU2Nyb2xsYWJsZUNvbnRlbnQnXG5pbXBvcnQgeyBPcmRlclN1bW1hcnlDb250ZXh0IH0gZnJvbSAnLi9Qcm92aWRlcidcbmltcG9ydCB7IFNjcm9sbGFibGVDb250ZW50IH0gZnJvbSAnLi9TY3JvbGxhYmxlQ29udGVudCdcbmltcG9ydCB0eXBlIHsgT3JkZXJTdW1tYXJ5UHJvcHMsIFByaWNlVHlwZSwgVGltZVVuaXQgfSBmcm9tICcuL3R5cGVzJ1xuXG5jb25zdCBDb250YWluZXIgPSBzdHlsZWQoU3RhY2spYFxuICBiYWNrZ3JvdW5kLWNvbG9yOiAkeyh7IHRoZW1lIH0pID0+
|
|
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,
|
|
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,
|
|
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.
|
|
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.
|
|
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.
|
|
69
|
+
"@ultraviolet/ui": "3.0.0-beta.11",
|
|
70
70
|
"@utils/test": "0.0.1"
|
|
71
71
|
},
|
|
72
72
|
"dependencies": {
|