@ultraviolet/plus 3.0.0-beta.1 → 3.0.0-beta.10

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.
Files changed (49) hide show
  1. package/README.md +24 -3
  2. package/dist/components/CodeEditor/CodeEditor.cjs +4 -54
  3. package/dist/components/CodeEditor/CodeEditor.js +6 -55
  4. package/dist/components/CodeEditor/styles.css.cjs +9 -0
  5. package/dist/components/CodeEditor/styles.css.d.ts +3 -0
  6. package/dist/components/CodeEditor/styles.css.js +9 -0
  7. package/dist/components/ContentCard/Skeleton.cjs +7 -28
  8. package/dist/components/ContentCard/Skeleton.js +7 -26
  9. package/dist/components/ContentCard/index.cjs +11 -109
  10. package/dist/components/ContentCard/index.js +11 -107
  11. package/dist/components/ContentCard/styles.css.cjs +27 -0
  12. package/dist/components/ContentCard/styles.css.d.ts +12 -0
  13. package/dist/components/ContentCard/styles.css.js +27 -0
  14. package/dist/components/ContentCardGroup/Card.cjs +4 -69
  15. package/dist/components/ContentCardGroup/Card.js +5 -68
  16. package/dist/components/ContentCardGroup/SkeletonCard.cjs +3 -23
  17. package/dist/components/ContentCardGroup/SkeletonCard.js +3 -21
  18. package/dist/components/ContentCardGroup/index.cjs +2 -16
  19. package/dist/components/ContentCardGroup/index.js +2 -14
  20. package/dist/components/ContentCardGroup/styles.css.cjs +18 -0
  21. package/dist/components/ContentCardGroup/styles.css.d.ts +7 -0
  22. package/dist/components/ContentCardGroup/styles.css.js +18 -0
  23. package/dist/components/EstimateCost/componentStyle.d.ts +6 -6
  24. package/dist/components/FAQ/index.cjs +2 -12
  25. package/dist/components/FAQ/index.js +3 -11
  26. package/dist/components/FAQ/styles.css.cjs +5 -0
  27. package/dist/components/FAQ/styles.css.d.ts +1 -0
  28. package/dist/components/FAQ/styles.css.js +5 -0
  29. package/dist/components/InfoTable/InfoTable.cjs +5 -3
  30. package/dist/components/InfoTable/InfoTable.d.ts +3 -1
  31. package/dist/components/InfoTable/InfoTable.js +5 -3
  32. package/dist/components/InfoTable/components/Row.d.ts +5 -5
  33. package/dist/components/Navigation/NavigationContent.cjs +7 -6
  34. package/dist/components/Navigation/NavigationContent.d.ts +1 -1
  35. package/dist/components/Navigation/NavigationContent.js +7 -6
  36. package/dist/components/Navigation/components/PinnedItems.cjs +9 -9
  37. package/dist/components/Navigation/components/PinnedItems.js +4 -4
  38. package/dist/components/Navigation/types.d.ts +1 -0
  39. package/dist/components/OfferList/OfferList.cjs +5 -3
  40. package/dist/components/OfferList/OfferList.d.ts +4 -2
  41. package/dist/components/OfferList/OfferList.js +5 -3
  42. package/dist/components/OrderSummary/ScrollableContent.cjs +8 -5
  43. package/dist/components/OrderSummary/ScrollableContent.js +8 -5
  44. package/dist/components/OrderSummary/index.cjs +10 -8
  45. package/dist/components/OrderSummary/index.d.ts +1 -1
  46. package/dist/components/OrderSummary/index.js +10 -8
  47. package/dist/components/OrderSummary/types.d.ts +3 -0
  48. package/dist/plus.css +1 -0
  49. package/package.json +14 -11
@@ -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,
@@ -36,4 +36,5 @@ export type NavigationProps = {
36
36
  * This function will be called when the user toggle the expand/collapse button or with the slider.
37
37
  */
38
38
  onToggleExpand?: (expanded: boolean) => void;
39
+ 'data-testid'?: string;
39
40
  };
@@ -21,7 +21,7 @@ const StyledList = /* @__PURE__ */ _styled__default.default(ui.List, process.env
21
21
  theme
22
22
  }) => theme.sizing[700], ";max-width:", ({
23
23
  theme
24
- }) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfSBcbmBcblxudHlwZSBPZmZlckxpc3RQcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0PixcbiAgJ3NlbGVjdGFibGUnIHwgJ29uU2VsZWN0ZWRDaGFuZ2UnXG4+ICYge1xuICAvKipcbiAgICogTWFrZSBvZmZlckxpc3Qgc2VsZWN0YWJsZSBieSBjaG9vc2luZyBpdHMgdHlwZVxuICAgKi9cbiAgdHlwZT86ICdyYWRpbycgfCAnY2hlY2tib3gnXG4gIG9uQ2hhbmdlU2VsZWN0PzogKHNlbGVjdGVkOiBzdHJpbmcgfCBzdHJpbmdbXSkgPT4gdm9pZFxuICAvKipcbiAgICogUHJlLXNlbGVjdGVkIHJvd3MgKHVzaW5nIHRoZWlyIG9mZmVyTmFtZSkuIE11c3QgYmUgYW4gYXJyYXkgd2hlbiBgdHlwZSA9IFwiY2hlY2tib3hcImAuXG4gICAqL1xuICBzZWxlY3RlZD86IHN0cmluZyB8IHN0cmluZ1tdXG59XG5cbmV4cG9ydCBjb25zdCBPZmZlckxpc3QgPSAoe1xuICBleHBhbmRhYmxlLFxuICB0eXBlID0gJ3JhZGlvJyxcbiAgY29sdW1ucyxcbiAgY2hpbGRyZW4sXG4gIGxvYWRpbmcsXG4gIGF1dG9Db2xsYXBzZSxcbiAgc2VsZWN0ZWQsXG4gIG9uQ2hhbmdlU2VsZWN0LFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjb2x1bW5zPXtjb21wdXRlZENvbHVtbnN9XG4gICAgICAgIGV4cGFuZGFibGU9e2ZhbHNlfVxuICAgICAgICBzZWxlY3RhYmxlPXtmYWxzZX1cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9TdHlsZWRMaXN0PlxuICAgIDwvT2ZmZXJMaXN0UHJvdmlkZXI+XG4gIClcbn1cblxuT2ZmZXJMaXN0LlJvdyA9IFJvd1xuT2ZmZXJMaXN0LkNlbGwgPSBDZWxsXG4iXX0= */"));
24
+ }) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfVxuYFxuXG50eXBlIE9mZmVyTGlzdFByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3Q+LFxuICAnc2VsZWN0YWJsZScgfCAnb25TZWxlY3RlZENoYW5nZSdcbj4gJiB7XG4gIC8qKlxuICAgKiBNYWtlIG9mZmVyTGlzdCBzZWxlY3RhYmxlIGJ5IGNob29zaW5nIGl0cyB0eXBlXG4gICAqL1xuICB0eXBlPzogJ3JhZGlvJyB8ICdjaGVja2JveCdcbiAgb25DaGFuZ2VTZWxlY3Q/OiAoc2VsZWN0ZWQ6IHN0cmluZyB8IHN0cmluZ1tdKSA9PiB2b2lkXG4gIC8qKlxuICAgKiBQcmUtc2VsZWN0ZWQgcm93cyAodXNpbmcgdGhlaXIgb2ZmZXJOYW1lKS4gTXVzdCBiZSBhbiBhcnJheSB3aGVuIGB0eXBlID0gXCJjaGVja2JveFwiYC5cbiAgICovXG4gIHNlbGVjdGVkPzogc3RyaW5nIHwgc3RyaW5nW11cbiAgWydkYXRhLXRlc3RpZCddPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgT2ZmZXJMaXN0ID0gKHtcbiAgZXhwYW5kYWJsZSxcbiAgdHlwZSA9ICdyYWRpbycsXG4gIGNvbHVtbnMsXG4gIGNoaWxkcmVuLFxuICBsb2FkaW5nLFxuICBhdXRvQ29sbGFwc2UsXG4gIHNlbGVjdGVkLFxuICBvbkNoYW5nZVNlbGVjdCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgY29sdW1ucz17Y29tcHV0ZWRDb2x1bW5zfVxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgZXhwYW5kYWJsZT17ZmFsc2V9XG4gICAgICAgIHNlbGVjdGFibGU9e2ZhbHNlfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZExpc3Q+XG4gICAgPC9PZmZlckxpc3RQcm92aWRlcj5cbiAgKVxufVxuXG5PZmZlckxpc3QuUm93ID0gUm93XG5PZmZlckxpc3QuQ2VsbCA9IENlbGxcbiJdfQ== */"));
25
25
  const OfferList = ({
26
26
  expandable,
27
27
  type = "radio",
@@ -30,7 +30,9 @@ const OfferList = ({
30
30
  loading,
31
31
  autoCollapse,
32
32
  selected,
33
- onChangeSelect
33
+ onChangeSelect,
34
+ className,
35
+ "data-testid": dataTestId
34
36
  }) => {
35
37
  const [radioSelectedRow, setRadioSelectedRow] = react.useState(typeof selected === "string" ? selected : void 0);
36
38
  const [checkboxSelectedRows, setCheckboxSelectedRows] = react.useState(Array.isArray(selected) ? selected : []);
@@ -49,7 +51,7 @@ const OfferList = ({
49
51
  }
50
52
  }
51
53
  }, [type, selected]);
52
- return /* @__PURE__ */ jsxRuntime.jsx(OfferListProvider.OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsxRuntime.jsx(StyledList, { autoCollapse, columns: computedColumns, expandable: false, selectable: false, children }) });
54
+ return /* @__PURE__ */ jsxRuntime.jsx(OfferListProvider.OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsxRuntime.jsx(StyledList, { autoCollapse, className, columns: computedColumns, "data-testid": dataTestId, expandable: false, selectable: false, children }) });
53
55
  };
54
56
  OfferList.Row = Row.Row;
55
57
  OfferList.Cell = Cell.Cell;
@@ -10,16 +10,18 @@ type OfferListProps = Omit<ComponentProps<typeof List>, 'selectable' | 'onSelect
10
10
  * Pre-selected rows (using their offerName). Must be an array when `type = "checkbox"`.
11
11
  */
12
12
  selected?: string | string[];
13
+ ['data-testid']?: string;
14
+ className?: string;
13
15
  };
14
16
  export declare const OfferList: {
15
- ({ expandable, type, columns, children, loading, autoCollapse, selected, onChangeSelect, }: OfferListProps): import("@emotion/react/jsx-runtime").JSX.Element;
17
+ ({ expandable, type, columns, children, loading, autoCollapse, selected, onChangeSelect, className, "data-testid": dataTestId, }: OfferListProps): import("@emotion/react/jsx-runtime").JSX.Element;
16
18
  Row: ({ children, disabled, id, banner, expandablePadding, offerName, expandable: expandableContent, selectDisabled, highlightAnimation, expanded, className, "data-dragging": dataDragging, "data-testid": dataTestId, style, badge, }: {
17
19
  children: import("react").ReactNode;
18
20
  id: string;
19
21
  expandable?: import("react").ReactNode;
20
22
  selectDisabled?: boolean | string;
21
23
  disabled?: boolean;
22
- sentiment?: "danger" | "info" | "neutral" | "success" | "primary" | "warning" | "secondary";
24
+ sentiment?: "primary" | "secondary" | "neutral" | "success" | "danger" | "warning" | "info";
23
25
  expanded?: boolean;
24
26
  className?: string;
25
27
  expandablePadding?: "0" | "1" | "0.5" | "0.25" | "1.5" | "2" | "3" | "4" | "5" | "6" | "7" | "8" | "9" | "10";
@@ -17,7 +17,7 @@ const StyledList = /* @__PURE__ */ _styled(List, process.env.NODE_ENV === "produ
17
17
  theme
18
18
  }) => theme.sizing[700], ";max-width:", ({
19
19
  theme
20
- }) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfSBcbmBcblxudHlwZSBPZmZlckxpc3RQcm9wcyA9IE9taXQ8XG4gIENvbXBvbmVudFByb3BzPHR5cGVvZiBMaXN0PixcbiAgJ3NlbGVjdGFibGUnIHwgJ29uU2VsZWN0ZWRDaGFuZ2UnXG4+ICYge1xuICAvKipcbiAgICogTWFrZSBvZmZlckxpc3Qgc2VsZWN0YWJsZSBieSBjaG9vc2luZyBpdHMgdHlwZVxuICAgKi9cbiAgdHlwZT86ICdyYWRpbycgfCAnY2hlY2tib3gnXG4gIG9uQ2hhbmdlU2VsZWN0PzogKHNlbGVjdGVkOiBzdHJpbmcgfCBzdHJpbmdbXSkgPT4gdm9pZFxuICAvKipcbiAgICogUHJlLXNlbGVjdGVkIHJvd3MgKHVzaW5nIHRoZWlyIG9mZmVyTmFtZSkuIE11c3QgYmUgYW4gYXJyYXkgd2hlbiBgdHlwZSA9IFwiY2hlY2tib3hcImAuXG4gICAqL1xuICBzZWxlY3RlZD86IHN0cmluZyB8IHN0cmluZ1tdXG59XG5cbmV4cG9ydCBjb25zdCBPZmZlckxpc3QgPSAoe1xuICBleHBhbmRhYmxlLFxuICB0eXBlID0gJ3JhZGlvJyxcbiAgY29sdW1ucyxcbiAgY2hpbGRyZW4sXG4gIGxvYWRpbmcsXG4gIGF1dG9Db2xsYXBzZSxcbiAgc2VsZWN0ZWQsXG4gIG9uQ2hhbmdlU2VsZWN0LFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjb2x1bW5zPXtjb21wdXRlZENvbHVtbnN9XG4gICAgICAgIGV4cGFuZGFibGU9e2ZhbHNlfVxuICAgICAgICBzZWxlY3RhYmxlPXtmYWxzZX1cbiAgICAgID5cbiAgICAgICAge2NoaWxkcmVufVxuICAgICAgPC9TdHlsZWRMaXN0PlxuICAgIDwvT2ZmZXJMaXN0UHJvdmlkZXI+XG4gIClcbn1cblxuT2ZmZXJMaXN0LlJvdyA9IFJvd1xuT2ZmZXJMaXN0LkNlbGwgPSBDZWxsXG4iXX0= */"));
20
+ }) => theme.sizing[700], ";}" + (process.env.NODE_ENV === "production" ? "" : "/*# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6IkFBVStCIiwiZmlsZSI6Ii9ob21lL3J1bm5lci93b3JrL3VsdHJhdmlvbGV0L3VsdHJhdmlvbGV0L3BhY2thZ2VzL3BsdXMvc3JjL2NvbXBvbmVudHMvT2ZmZXJMaXN0L09mZmVyTGlzdC50c3giLCJzb3VyY2VzQ29udGVudCI6WyIndXNlIGNsaWVudCdcblxuaW1wb3J0IHN0eWxlZCBmcm9tICdAZW1vdGlvbi9zdHlsZWQnXG5pbXBvcnQgeyBMaXN0IH0gZnJvbSAnQHVsdHJhdmlvbGV0L3VpJ1xuaW1wb3J0IHR5cGUgeyBDb21wb25lbnRQcm9wcyB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgdXNlRWZmZWN0LCB1c2VTdGF0ZSB9IGZyb20gJ3JlYWN0J1xuaW1wb3J0IHsgQ2VsbCB9IGZyb20gJy4vY29tcG9uZW50cy9DZWxsJ1xuaW1wb3J0IHsgUm93IH0gZnJvbSAnLi9jb21wb25lbnRzL1JvdydcbmltcG9ydCB7IE9mZmVyTGlzdFByb3ZpZGVyIH0gZnJvbSAnLi9PZmZlckxpc3RQcm92aWRlcidcblxuY29uc3QgU3R5bGVkTGlzdCA9IHN0eWxlZChMaXN0KWBcbiAgIHRkOmZpcnN0LWNoaWxkLFxuICAgdGg6Zmlyc3QtY2hpbGQge1xuICAgIHdpZHRoOiAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtaW4td2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgICBtYXgtd2lkdGg6ICAkeyh7IHRoZW1lIH0pID0+IHRoZW1lLnNpemluZ1s3MDBdfTtcbiAgfVxuYFxuXG50eXBlIE9mZmVyTGlzdFByb3BzID0gT21pdDxcbiAgQ29tcG9uZW50UHJvcHM8dHlwZW9mIExpc3Q+LFxuICAnc2VsZWN0YWJsZScgfCAnb25TZWxlY3RlZENoYW5nZSdcbj4gJiB7XG4gIC8qKlxuICAgKiBNYWtlIG9mZmVyTGlzdCBzZWxlY3RhYmxlIGJ5IGNob29zaW5nIGl0cyB0eXBlXG4gICAqL1xuICB0eXBlPzogJ3JhZGlvJyB8ICdjaGVja2JveCdcbiAgb25DaGFuZ2VTZWxlY3Q/OiAoc2VsZWN0ZWQ6IHN0cmluZyB8IHN0cmluZ1tdKSA9PiB2b2lkXG4gIC8qKlxuICAgKiBQcmUtc2VsZWN0ZWQgcm93cyAodXNpbmcgdGhlaXIgb2ZmZXJOYW1lKS4gTXVzdCBiZSBhbiBhcnJheSB3aGVuIGB0eXBlID0gXCJjaGVja2JveFwiYC5cbiAgICovXG4gIHNlbGVjdGVkPzogc3RyaW5nIHwgc3RyaW5nW11cbiAgWydkYXRhLXRlc3RpZCddPzogc3RyaW5nXG4gIGNsYXNzTmFtZT86IHN0cmluZ1xufVxuXG5leHBvcnQgY29uc3QgT2ZmZXJMaXN0ID0gKHtcbiAgZXhwYW5kYWJsZSxcbiAgdHlwZSA9ICdyYWRpbycsXG4gIGNvbHVtbnMsXG4gIGNoaWxkcmVuLFxuICBsb2FkaW5nLFxuICBhdXRvQ29sbGFwc2UsXG4gIHNlbGVjdGVkLFxuICBvbkNoYW5nZVNlbGVjdCxcbiAgY2xhc3NOYW1lLFxuICAnZGF0YS10ZXN0aWQnOiBkYXRhVGVzdElkLFxufTogT2ZmZXJMaXN0UHJvcHMpID0+IHtcbiAgY29uc3QgW3JhZGlvU2VsZWN0ZWRSb3csIHNldFJhZGlvU2VsZWN0ZWRSb3ddID0gdXNlU3RhdGU8c3RyaW5nIHwgdW5kZWZpbmVkPihcbiAgICB0eXBlb2Ygc2VsZWN0ZWQgPT09ICdzdHJpbmcnID8gc2VsZWN0ZWQgOiB1bmRlZmluZWQsXG4gIClcbiAgY29uc3QgW2NoZWNrYm94U2VsZWN0ZWRSb3dzLCBzZXRDaGVja2JveFNlbGVjdGVkUm93c10gPSB1c2VTdGF0ZTxzdHJpbmdbXT4oXG4gICAgQXJyYXkuaXNBcnJheShzZWxlY3RlZCkgPyBzZWxlY3RlZCA6IFtdLFxuICApXG5cbiAgY29uc3QgY29tcHV0ZWRDb2x1bW5zID0gW1xuICAgIHtcbiAgICAgIGxhYmVsOiAnJyxcbiAgICB9LFxuICAgIGV4cGFuZGFibGUgPyB7IGxhYmVsOiAnJyB9IDogbnVsbCxcbiAgICAuLi5jb2x1bW5zLFxuICBdLmZpbHRlcihlbGVtZW50ID0+ICEhZWxlbWVudClcblxuICB1c2VFZmZlY3QoKCkgPT4ge1xuICAgIGlmIChzZWxlY3RlZCkge1xuICAgICAgaWYgKHR5cGVvZiBzZWxlY3RlZCA9PT0gJ3N0cmluZycgJiYgdHlwZSA9PT0gJ3JhZGlvJykge1xuICAgICAgICBzZXRSYWRpb1NlbGVjdGVkUm93KHNlbGVjdGVkKVxuICAgICAgfVxuICAgICAgaWYgKEFycmF5LmlzQXJyYXkoc2VsZWN0ZWQpICYmIHR5cGUgPT09ICdjaGVja2JveCcpIHtcbiAgICAgICAgc2V0Q2hlY2tib3hTZWxlY3RlZFJvd3Moc2VsZWN0ZWQpXG4gICAgICB9XG4gICAgfVxuICB9LCBbdHlwZSwgc2VsZWN0ZWRdKVxuXG4gIHJldHVybiAoXG4gICAgPE9mZmVyTGlzdFByb3ZpZGVyXG4gICAgICBhdXRvQ29sbGFwc2U9e2F1dG9Db2xsYXBzZX1cbiAgICAgIGNoZWNrYm94U2VsZWN0ZWRSb3dzPXtjaGVja2JveFNlbGVjdGVkUm93c31cbiAgICAgIGV4cGFuZGFibGU9e2V4cGFuZGFibGV9XG4gICAgICBsb2FkaW5nPXtsb2FkaW5nfVxuICAgICAgb25DaGFuZ2VTZWxlY3Q9e29uQ2hhbmdlU2VsZWN0fVxuICAgICAgcmFkaW9TZWxlY3RlZFJvdz17cmFkaW9TZWxlY3RlZFJvd31cbiAgICAgIHNlbGVjdGFibGU9e3R5cGV9XG4gICAgICBzZXRDaGVja2JveFNlbGVjdGVkUm93cz17c2V0Q2hlY2tib3hTZWxlY3RlZFJvd3N9XG4gICAgICBzZXRSYWRpb1NlbGVjdGVkUm93PXtzZXRSYWRpb1NlbGVjdGVkUm93fVxuICAgID5cbiAgICAgIDxTdHlsZWRMaXN0XG4gICAgICAgIGF1dG9Db2xsYXBzZT17YXV0b0NvbGxhcHNlfVxuICAgICAgICBjbGFzc05hbWU9e2NsYXNzTmFtZX1cbiAgICAgICAgY29sdW1ucz17Y29tcHV0ZWRDb2x1bW5zfVxuICAgICAgICBkYXRhLXRlc3RpZD17ZGF0YVRlc3RJZH1cbiAgICAgICAgZXhwYW5kYWJsZT17ZmFsc2V9XG4gICAgICAgIHNlbGVjdGFibGU9e2ZhbHNlfVxuICAgICAgPlxuICAgICAgICB7Y2hpbGRyZW59XG4gICAgICA8L1N0eWxlZExpc3Q+XG4gICAgPC9PZmZlckxpc3RQcm92aWRlcj5cbiAgKVxufVxuXG5PZmZlckxpc3QuUm93ID0gUm93XG5PZmZlckxpc3QuQ2VsbCA9IENlbGxcbiJdfQ== */"));
21
21
  const OfferList = ({
22
22
  expandable,
23
23
  type = "radio",
@@ -26,7 +26,9 @@ const OfferList = ({
26
26
  loading,
27
27
  autoCollapse,
28
28
  selected,
29
- onChangeSelect
29
+ onChangeSelect,
30
+ className,
31
+ "data-testid": dataTestId
30
32
  }) => {
31
33
  const [radioSelectedRow, setRadioSelectedRow] = useState(typeof selected === "string" ? selected : void 0);
32
34
  const [checkboxSelectedRows, setCheckboxSelectedRows] = useState(Array.isArray(selected) ? selected : []);
@@ -45,7 +47,7 @@ const OfferList = ({
45
47
  }
46
48
  }
47
49
  }, [type, selected]);
48
- return /* @__PURE__ */ jsx(OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsx(StyledList, { autoCollapse, columns: computedColumns, expandable: false, selectable: false, children }) });
50
+ return /* @__PURE__ */ jsx(OfferListProvider, { autoCollapse, checkboxSelectedRows, expandable, loading, onChangeSelect, radioSelectedRow, selectable: type, setCheckboxSelectedRows, setRadioSelectedRow, children: /* @__PURE__ */ jsx(StyledList, { autoCollapse, className, columns: computedColumns, "data-testid": dataTestId, expandable: false, selectable: false, children }) });
49
51
  };
50
52
  OfferList.Row = Row;
51
53
  OfferList.Cell = Cell;