@ultraviolet/plus 3.0.0-beta.8 → 3.0.0-beta.9

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.
@@ -1,5 +1,6 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
+ ;/* empty css */
3
4
  ;/* empty css */
4
5
  var subContainerHeightVar = "var(--uv_plus_u4r1ts0)";
5
6
  var skeletonHeightVar = "var(--uv_plus_u4r1ts1)";
@@ -1,3 +1,4 @@
1
+ /* empty css */
1
2
  /* empty css */
2
3
  var subContainerHeightVar = "var(--uv_plus_u4r1ts0)";
3
4
  var skeletonHeightVar = "var(--uv_plus_u4r1ts1)";
@@ -1,6 +1,5 @@
1
1
  "use strict";
2
2
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
3
- ;/* empty css */
4
3
  ;/* empty css */
5
4
  var faq = "uv_plus_5imqkb0";
6
5
  exports.faq = faq;
@@ -1,4 +1,3 @@
1
- /* empty css */
2
1
  /* empty css */
3
2
  var faq = "uv_plus_5imqkb0";
4
3
  export {
@@ -3,10 +3,10 @@
3
3
  Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" });
4
4
  const jsxRuntime = require("@emotion/react/jsx-runtime");
5
5
  const _styled = require("@emotion/styled/base");
6
- const react = require("@emotion/react");
7
6
  const category = require("@ultraviolet/icons/category");
7
+ const themes = require("@ultraviolet/themes");
8
8
  const ui = require("@ultraviolet/ui");
9
- const react$1 = require("react");
9
+ const react = require("react");
10
10
  const NavigationProvider = require("../NavigationProvider.cjs");
11
11
  const Item = require("./Item.cjs");
12
12
  const _interopDefaultCompat = (e) => e && typeof e === "object" && "default" in e ? e : { default: e };
@@ -23,7 +23,7 @@ const DropableArea = /* @__PURE__ */ _styled__default.default("div", process.env
23
23
  theme
24
24
  }) => theme.space["0.5"], " 0;&::before{content:'';position:absolute;left:0;top:-4px;height:0px;width:0px;border:3px solid;border-color:inherit;border-radius:", ({
25
25
  theme
26
- }) => theme.radii.circle, ";}" + (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/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAY+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */"));
26
+ }) => theme.radii.circle, ";}" + (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/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAY+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { useTheme } from '@ultraviolet/themes'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */"));
27
27
  const RelativeDiv = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
28
28
  target: "e5ys0ny1"
29
29
  } : {
@@ -34,7 +34,7 @@ const RelativeDiv = /* @__PURE__ */ _styled__default.default("div", process.env.
34
34
  styles: "position:relative"
35
35
  } : {
36
36
  name: "bjn8wh",
37
- styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAmC8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */",
37
+ styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAmC8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { useTheme } from '@ultraviolet/themes'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */",
38
38
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
39
39
  });
40
40
  const TextContainer = /* @__PURE__ */ _styled__default.default("div", process.env.NODE_ENV === "production" ? {
@@ -48,7 +48,7 @@ const TextContainer = /* @__PURE__ */ _styled__default.default("div", process.en
48
48
  theme
49
49
  }) => theme.space["4"], ";margin-left:", ({
50
50
  theme
51
- }) => theme.space["0.5"], ";}" + (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/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAuCgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */"));
51
+ }) => theme.space["0.5"], ";}" + (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/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAuCgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { useTheme } from '@ultraviolet/themes'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */"));
52
52
  const PinnedItems = ({
53
53
  toggle = true,
54
54
  onReorder,
@@ -68,8 +68,8 @@ const PinnedItems = ({
68
68
  items,
69
69
  animation
70
70
  } = context;
71
- const theme = react.useTheme();
72
- const onDrop = react$1.useCallback((event, index) => {
71
+ const theme = themes.useTheme();
72
+ const onDrop = react.useCallback((event, index) => {
73
73
  event.preventDefault();
74
74
  if (event?.dataTransfer) {
75
75
  event.currentTarget.style.borderColor = "transparent";
@@ -83,11 +83,11 @@ const PinnedItems = ({
83
83
  onReorder?.(newItems);
84
84
  }
85
85
  }, [onReorder, reorderItems]);
86
- const onDragOver = react$1.useCallback((event) => {
86
+ const onDragOver = react.useCallback((event) => {
87
87
  event.preventDefault();
88
88
  event.currentTarget.style.borderColor = theme.colors.primary.border;
89
89
  }, [theme.colors.primary.border]);
90
- const onDragLeave = react$1.useCallback((event) => {
90
+ const onDragLeave = react.useCallback((event) => {
91
91
  event.preventDefault();
92
92
  event.currentTarget.style.borderColor = "transparent";
93
93
  }, []);
@@ -1,8 +1,8 @@
1
1
  "use client";
2
2
  import { jsx, jsxs } from "@emotion/react/jsx-runtime";
3
3
  import _styled from "@emotion/styled/base";
4
- import { useTheme } from "@emotion/react";
5
4
  import { PinCategoryIcon } from "@ultraviolet/icons/category";
5
+ import { useTheme } from "@ultraviolet/themes";
6
6
  import { Text } from "@ultraviolet/ui";
7
7
  import { useCallback } from "react";
8
8
  import { useNavigation } from "../NavigationProvider.js";
@@ -19,7 +19,7 @@ const DropableArea = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "pr
19
19
  theme
20
20
  }) => theme.space["0.5"], " 0;&::before{content:'';position:absolute;left:0;top:-4px;height:0px;width:0px;border:3px solid;border-color:inherit;border-radius:", ({
21
21
  theme
22
- }) => theme.radii.circle, ";}" + (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/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAY+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */"));
22
+ }) => theme.radii.circle, ";}" + (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/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAY+B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { useTheme } from '@ultraviolet/themes'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */"));
23
23
  const RelativeDiv = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
24
24
  target: "e5ys0ny1"
25
25
  } : {
@@ -30,7 +30,7 @@ const RelativeDiv = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "pro
30
30
  styles: "position:relative"
31
31
  } : {
32
32
  name: "bjn8wh",
33
- styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAmC8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */",
33
+ styles: "position:relative/*# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAmC8B","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { useTheme } from '@ultraviolet/themes'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */",
34
34
  toString: _EMOTION_STRINGIFIED_CSS_ERROR__
35
35
  });
36
36
  const TextContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "production" ? {
@@ -44,7 +44,7 @@ const TextContainer = /* @__PURE__ */ _styled("div", process.env.NODE_ENV === "p
44
44
  theme
45
45
  }) => theme.space["4"], ";margin-left:", ({
46
46
  theme
47
- }) => theme.space["0.5"], ";}" + (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/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAuCgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport { useTheme } from '@emotion/react'\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */"));
47
+ }) => theme.space["0.5"], ";}" + (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/Navigation/components/PinnedItems.tsx"],"names":[],"mappings":"AAuCgC","file":"/home/runner/work/ultraviolet/ultraviolet/packages/plus/src/components/Navigation/components/PinnedItems.tsx","sourcesContent":["'use client'\n\nimport styled from '@emotion/styled'\nimport { PinCategoryIcon } from '@ultraviolet/icons/category'\nimport { useTheme } from '@ultraviolet/themes'\nimport { Text } from '@ultraviolet/ui'\nimport type { DragEvent, ReactElement } from 'react'\nimport { useCallback } from 'react'\nimport { useNavigation } from '../NavigationProvider'\nimport type { DragNDropData } from '../types'\nimport { Item } from './Item'\n\nconst DropableArea = styled.div`\n  position: absolute;\n  right: 0;\n  left: 0;\n  top: 0;\n  height: 2px;\n  border-top: 2px solid;\n  border-color: transparent;\n  padding: ${({ theme }) => theme.space['0.5']} 0;\n\n  &::before {\n    content: '';\n    position: absolute;\n    left: 0;\n    top: -4px;\n    height: 0px;\n    width: 0px;\n    border: 3px solid;\n    border-color: inherit;\n    border-radius: ${({ theme }) => theme.radii.circle};\n  }\n`\n\nconst RelativeDiv = styled.div`\n  position: relative;\n`\n\nconst TextContainer = styled.div`\n  padding: ${({ theme }) => theme.space['1']} 0;\n\n  &[data-expanded='true'] {\n    padding-left: ${({ theme }) => theme.space['4']};\n    margin-left: ${({ theme }) => theme.space['0.5']};\n  }\n`\n\ntype PinnedItemsProps = {\n  /**\n   * This prop is used to control if the item is expanded or collapsed\n   */\n  toggle?: boolean\n  /**\n   * This function will be triggered on click of the item. If the item is expandable\n   * toggle will be passed with it.\n   */\n  onToggle?: (toggle: boolean) => void\n  /**\n   * This function will be called when the user reorder the pinned items\n   */\n  onReorder?: (pinnedItems: string[]) => void\n  /**\n   * Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)\n   */\n  itemWrapper?: (item: ReactElement, itemId: string) => ReactElement\n}\n\nexport const PinnedItems = ({\n  toggle = true,\n  onReorder,\n  onToggle,\n  itemWrapper,\n}: PinnedItemsProps) => {\n  const context = useNavigation()\n\n  if (!context) {\n    throw new Error(\n      'Navigation.PinnedItems can only be used inside a NavigationProvider.',\n    )\n  }\n\n  const {\n    locales,\n    pinnedItems,\n    pinnedFeature,\n    reorderItems,\n    expanded,\n    items,\n    animation,\n  } = context\n  const theme = useTheme()\n\n  const onDrop = useCallback(\n    (event: DragEvent<HTMLDivElement>, index: number) => {\n      event.preventDefault()\n      if (event?.dataTransfer) {\n        // eslint-disable-next-line no-param-reassign\n        event.currentTarget.style.borderColor = 'transparent'\n        const data = JSON.parse(\n          event.dataTransfer.getData('text'),\n        ) as DragNDropData\n        if (data.index === index - 1 || index > data.index) {\n          const newItems = reorderItems(data.index, index - 1)\n          onReorder?.(newItems)\n\n          return\n        }\n        const newItems = reorderItems(data.index, index)\n        onReorder?.(newItems)\n      }\n    },\n    [onReorder, reorderItems],\n  )\n\n  const onDragOver = useCallback(\n    (event: DragEvent<HTMLDivElement>) => {\n      event.preventDefault()\n      // eslint-disable-next-line no-param-reassign\n      event.currentTarget.style.borderColor = theme.colors.primary.border\n    },\n    [theme.colors.primary.border],\n  )\n\n  const onDragLeave = useCallback((event: DragEvent<HTMLDivElement>) => {\n    event.preventDefault()\n    // eslint-disable-next-line no-param-reassign\n    event.currentTarget.style.borderColor = 'transparent'\n  }, [])\n\n  if (Object.keys(items).length === 0) {\n    return null\n  }\n\n  if (pinnedFeature) {\n    return (\n      <div style={{ width: animation ? '100%' : undefined }}>\n        <Item\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          data-testid=\"pinned-group\"\n          id=\"pinned-group\"\n          label={locales['navigation.pinned.item.group.label']}\n          onToggle={onToggle}\n          toggle={toggle}\n          type=\"pinnedGroup\"\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    active={items[itemId]?.active ?? false}\n                    id={itemId}\n                    index={index}\n                    label={items[itemId].label}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                    onToggle={items[itemId]?.onToggle}\n                    toggle={toggle}\n                    type=\"pinned\"\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragLeave={onDragLeave}\n                      onDragOver={onDragOver}\n                      onDrop={event => onDrop(event, index)}\n                    />\n                    {itemWrapper\n                      ? itemWrapper(itemElement, itemId)\n                      : itemElement}\n                  </RelativeDiv>\n                )\n              }\n\n              return null\n            })\n          ) : (\n            <TextContainer data-expanded={expanded}>\n              <Text\n                as=\"p\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n                variant=\"caption\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragLeave={onDragLeave}\n              onDragOver={onDragOver}\n              onDrop={event => onDrop(event, pinnedItems.length)}\n            />\n          </RelativeDiv>\n        </Item>\n      </div>\n    )\n  }\n\n  return null\n}\n"]} */"));
48
48
  const PinnedItems = ({
49
49
  toggle = true,
50
50
  onReorder,
@@ -21,7 +21,7 @@ export declare const OfferList: {
21
21
  expandable?: import("react").ReactNode;
22
22
  selectDisabled?: boolean | string;
23
23
  disabled?: boolean;
24
- sentiment?: "danger" | "info" | "neutral" | "success" | "primary" | "warning" | "secondary";
24
+ sentiment?: "primary" | "secondary" | "neutral" | "success" | "danger" | "warning" | "info";
25
25
  expanded?: boolean;
26
26
  className?: string;
27
27
  expandablePadding?: "0" | "1" | "0.5" | "0.25" | "1.5" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9" | "10";
@@ -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)`\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"]} */"));
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.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              {subCategory.title}\n            </Text>\n            <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n              {subCategory.additionalInfo}\n            </Text>\n          </Stack>\n        ) : (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        )}\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], ";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"]} */"));
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.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              {subCategory.title}\n            </Text>\n            <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n              {subCategory.additionalInfo}\n            </Text>\n          </Stack>\n        ) : (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        )}\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":"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"]} */"));
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.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              {subCategory.title}\n            </Text>\n            <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n              {subCategory.additionalInfo}\n            </Text>\n          </Stack>\n        ) : (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        )}\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":"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"]} */"));
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.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              {subCategory.title}\n            </Text>\n            <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n              {subCategory.additionalInfo}\n            </Text>\n          </Stack>\n        ) : (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        )}\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
  }) => {
@@ -83,7 +83,10 @@ const SubCategory = ({
83
83
  const subCategoryPrice = helpers.calculateSubCategoryPrice(subCategory, hideTimeUnit, timePeriodAmount, timePeriodUnit);
84
84
  return /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { direction: "column", gap: 1, children: [
85
85
  /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { alignItems: "center", direction: "row", justifyContent: "space-between", children: [
86
- subCategory.title ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodySmallStrong", children: subCategory.title }) : null,
86
+ subCategory.additionalInfo ? /* @__PURE__ */ jsxRuntime.jsxs(ui.Stack, { alignItems: "center", direction: "row", gap: 1, children: [
87
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodyStrong", children: subCategory.title }),
88
+ /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", italic: true, sentiment: "primary", variant: "bodySmall", children: subCategory.additionalInfo })
89
+ ] }) : /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodySmallStrong", children: subCategory.title }),
87
90
  subCategory.customContent ? /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodySmallStrong", children: subCategory.customContent }) : null,
88
91
  subCategory.numberInput ? /* @__PURE__ */ jsxRuntime.jsx(StyledNumberInputV2, { controls: subCategory.numberInputControls, onChange: subCategory.onChangeInput, size: "small", unit: subCategory.numberInputUnit, value: subCategory.numberInputValue }) : null,
89
92
  subCategory.price !== void 0 && !subCategory.hidePrice ? /* @__PURE__ */ jsxRuntime.jsxs(ui.Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodySmallStrong", children: [
@@ -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)`\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"]} */"));
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.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              {subCategory.title}\n            </Text>\n            <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n              {subCategory.additionalInfo}\n            </Text>\n          </Stack>\n        ) : (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        )}\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], ";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"]} */"));
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.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              {subCategory.title}\n            </Text>\n            <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n              {subCategory.additionalInfo}\n            </Text>\n          </Stack>\n        ) : (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        )}\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":"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"]} */"));
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.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              {subCategory.title}\n            </Text>\n            <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n              {subCategory.additionalInfo}\n            </Text>\n          </Stack>\n        ) : (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        )}\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":"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"]} */"));
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.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              {subCategory.title}\n            </Text>\n            <Text as=\"span\" italic sentiment=\"primary\" variant=\"bodySmall\">\n              {subCategory.additionalInfo}\n            </Text>\n          </Stack>\n        ) : (\n          <Text\n            as=\"span\"\n            prominence=\"strong\"\n            sentiment=\"neutral\"\n            variant=\"bodySmallStrong\"\n          >\n            {subCategory.title}\n          </Text>\n        )}\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
  }) => {
@@ -79,7 +79,10 @@ const SubCategory = ({
79
79
  const subCategoryPrice = calculateSubCategoryPrice(subCategory, hideTimeUnit, timePeriodAmount, timePeriodUnit);
80
80
  return /* @__PURE__ */ jsxs(Stack, { direction: "column", gap: 1, children: [
81
81
  /* @__PURE__ */ jsxs(Stack, { alignItems: "center", direction: "row", justifyContent: "space-between", children: [
82
- subCategory.title ? /* @__PURE__ */ jsx(Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodySmallStrong", children: subCategory.title }) : null,
82
+ subCategory.additionalInfo ? /* @__PURE__ */ jsxs(Stack, { alignItems: "center", direction: "row", gap: 1, children: [
83
+ /* @__PURE__ */ jsx(Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodyStrong", children: subCategory.title }),
84
+ /* @__PURE__ */ jsx(Text, { as: "span", italic: true, sentiment: "primary", variant: "bodySmall", children: subCategory.additionalInfo })
85
+ ] }) : /* @__PURE__ */ jsx(Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodySmallStrong", children: subCategory.title }),
83
86
  subCategory.customContent ? /* @__PURE__ */ jsx(Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodySmallStrong", children: subCategory.customContent }) : null,
84
87
  subCategory.numberInput ? /* @__PURE__ */ jsx(StyledNumberInputV2, { controls: subCategory.numberInputControls, onChange: subCategory.onChangeInput, size: "small", unit: subCategory.numberInputUnit, value: subCategory.numberInputValue }) : null,
85
88
  subCategory.price !== void 0 && !subCategory.hidePrice ? /* @__PURE__ */ jsxs(Text, { as: "span", prominence: "strong", sentiment: "neutral", variant: "bodySmallStrong", children: [
@@ -39,6 +39,7 @@ export type PriceTypeSingle = {
39
39
  export type PriceType = Record<string, PriceTypeSingle>;
40
40
  export type SubCategoryType = {
41
41
  title?: string;
42
+ additionalInfo?: ReactNode;
42
43
  price?: number;
43
44
  /**
44
45
  * List of elements to be displayed in the subcategory
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ultraviolet/plus",
3
- "version": "3.0.0-beta.8",
3
+ "version": "3.0.0-beta.9",
4
4
  "description": "Ultraviolet Plus",
5
5
  "homepage": "https://github.com/scaleway/ultraviolet#readme",
6
6
  "repository": {
@@ -56,7 +56,7 @@
56
56
  "@emotion/styled": "11.14.1",
57
57
  "react": "18.x || 19.x",
58
58
  "react-dom": "18.x || 19.x",
59
- "@ultraviolet/ui": "3.0.0-beta.19"
59
+ "@ultraviolet/ui": "3.0.0-beta.20"
60
60
  },
61
61
  "devDependencies": {
62
62
  "@babel/core": "7.28.4",
@@ -66,8 +66,8 @@
66
66
  "@types/react-dom": "19.1.9",
67
67
  "react": "19.1.1",
68
68
  "react-dom": "19.1.1",
69
- "@ultraviolet/illustrations": "6.0.0-beta.1",
70
- "@ultraviolet/ui": "3.0.0-beta.19",
69
+ "@ultraviolet/illustrations": "6.0.0-beta.2",
70
+ "@ultraviolet/ui": "3.0.0-beta.20",
71
71
  "@utils/test": "0.0.1"
72
72
  },
73
73
  "dependencies": {
@@ -78,8 +78,8 @@
78
78
  "@vanilla-extract/dynamic": "2.1.5",
79
79
  "csstype": "3.1.3",
80
80
  "react-intersection-observer": "9.16.0",
81
- "@ultraviolet/icons": "5.0.0-beta.5",
82
- "@ultraviolet/themes": "3.0.0-beta.1"
81
+ "@ultraviolet/icons": "5.0.0-beta.6",
82
+ "@ultraviolet/themes": "3.0.0-beta.2"
83
83
  },
84
84
  "scripts": {
85
85
  "type:generate": "tsc --declaration -p tsconfig.build.json",