@ultraviolet/plus 1.0.0-beta.12 → 1.0.0-beta.13
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.
|
@@ -33,10 +33,11 @@ export declare const Navigation: {
|
|
|
33
33
|
disabled?: boolean;
|
|
34
34
|
'data-testid'?: string;
|
|
35
35
|
}) => import("@emotion/react/jsx-runtime").JSX.Element | null>;
|
|
36
|
-
PinnedItems: ({ toggle, onReorder, onToggle, }: {
|
|
36
|
+
PinnedItems: ({ toggle, onReorder, onToggle, itemWrapper, }: {
|
|
37
37
|
toggle?: boolean;
|
|
38
38
|
onToggle?: (toggle: boolean) => void;
|
|
39
39
|
onReorder?: (pinnedItems: string[]) => void;
|
|
40
|
+
itemWrapper?: (item: import("react").ReactElement, itemId: string) => import("react").ReactElement;
|
|
40
41
|
}) => import("@emotion/react/jsx-runtime").JSX.Element | null;
|
|
41
42
|
Separator: () => import("@emotion/react/jsx-runtime").JSX.Element;
|
|
42
43
|
};
|
|
@@ -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,
|
|
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          label={locales['navigation.pinned.item.group.label']}\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          type=\"pinnedGroup\"\n          id=\"pinned-group\"\n          data-testid=\"pinned-group\"\n          toggle={toggle}\n          onToggle={onToggle}\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    label={items[itemId].label}\n                    type=\"pinned\"\n                    index={index}\n                    toggle={toggle}\n                    onToggle={items[itemId]?.onToggle}\n                    id={itemId}\n                    active={items[itemId]?.active ?? false}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragOver={onDragOver}\n                      onDragLeave={onDragLeave}\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                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragOver={onDragOver}\n              onDragLeave={onDragLeave}\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,
|
|
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          label={locales['navigation.pinned.item.group.label']}\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          type=\"pinnedGroup\"\n          id=\"pinned-group\"\n          data-testid=\"pinned-group\"\n          toggle={toggle}\n          onToggle={onToggle}\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    label={items[itemId].label}\n                    type=\"pinned\"\n                    index={index}\n                    toggle={toggle}\n                    onToggle={items[itemId]?.onToggle}\n                    id={itemId}\n                    active={items[itemId]?.active ?? false}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragOver={onDragOver}\n                      onDragLeave={onDragLeave}\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                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragOver={onDragOver}\n              onDragLeave={onDragLeave}\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,11 +48,12 @@ 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,
|
|
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          label={locales['navigation.pinned.item.group.label']}\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          type=\"pinnedGroup\"\n          id=\"pinned-group\"\n          data-testid=\"pinned-group\"\n          toggle={toggle}\n          onToggle={onToggle}\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    label={items[itemId].label}\n                    type=\"pinned\"\n                    index={index}\n                    toggle={toggle}\n                    onToggle={items[itemId]?.onToggle}\n                    id={itemId}\n                    active={items[itemId]?.active ?? false}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragOver={onDragOver}\n                      onDragLeave={onDragLeave}\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                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragOver={onDragOver}\n              onDragLeave={onDragLeave}\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,
|
|
55
|
-
onToggle
|
|
55
|
+
onToggle,
|
|
56
|
+
itemWrapper
|
|
56
57
|
}) => {
|
|
57
58
|
const context = NavigationProvider.useNavigation();
|
|
58
59
|
if (!context) {
|
|
@@ -97,10 +98,16 @@ const PinnedItems = ({
|
|
|
97
98
|
return /* @__PURE__ */ jsxRuntime.jsx("div", { style: {
|
|
98
99
|
width: animation ? "100%" : void 0
|
|
99
100
|
}, children: /* @__PURE__ */ jsxRuntime.jsxs(Item.Item, { label: locales["navigation.pinned.item.group.label"], categoryIcon: /* @__PURE__ */ jsxRuntime.jsx(category.PinCategoryIcon, { variant: "neutral" }), type: "pinnedGroup", id: "pinned-group", "data-testid": "pinned-group", toggle, onToggle, children: [
|
|
100
|
-
pinnedItems.length > 0 ? pinnedItems.map((itemId, index) =>
|
|
101
|
-
|
|
102
|
-
|
|
103
|
-
|
|
101
|
+
pinnedItems.length > 0 ? pinnedItems.map((itemId, index) => {
|
|
102
|
+
if (items[itemId]?.label) {
|
|
103
|
+
const itemElement = /* @__PURE__ */ jsxRuntime.jsx(Item.Item, { label: items[itemId].label, type: "pinned", index, toggle, onToggle: items[itemId]?.onToggle, id: itemId, active: items[itemId]?.active ?? false, onClickPinUnpin: items[itemId]?.onClickPinUnpin ?? void 0 });
|
|
104
|
+
return /* @__PURE__ */ jsxRuntime.jsxs(RelativeDiv, { children: [
|
|
105
|
+
/* @__PURE__ */ jsxRuntime.jsx(DropableArea, { onDragOver, onDragLeave, onDrop: (event) => onDrop(event, index) }),
|
|
106
|
+
itemWrapper ? itemWrapper(itemElement, itemId) : itemElement
|
|
107
|
+
] }, itemId);
|
|
108
|
+
}
|
|
109
|
+
return null;
|
|
110
|
+
}) : /* @__PURE__ */ jsxRuntime.jsx(TextContainer, { "data-expanded": expanded, children: /* @__PURE__ */ jsxRuntime.jsx(ui.Text, { as: "p", variant: "caption", prominence: "weak", sentiment: "neutral", children: locales["navigation.pinned.item.group.empty"] }) }),
|
|
104
111
|
/* @__PURE__ */ jsxRuntime.jsx(RelativeDiv, { children: /* @__PURE__ */ jsxRuntime.jsx(DropableArea, { onDragOver, onDragLeave, onDrop: (event) => onDrop(event, pinnedItems.length) }) })
|
|
105
112
|
] }) });
|
|
106
113
|
}
|
|
@@ -1,3 +1,4 @@
|
|
|
1
|
+
import type { ReactElement } from 'react';
|
|
1
2
|
type PinnedItemsProps = {
|
|
2
3
|
/**
|
|
3
4
|
* This prop is used to control if the item is expanded or collapsed
|
|
@@ -12,6 +13,10 @@ type PinnedItemsProps = {
|
|
|
12
13
|
* This function will be called when the user reorder the pinned items
|
|
13
14
|
*/
|
|
14
15
|
onReorder?: (pinnedItems: string[]) => void;
|
|
16
|
+
/**
|
|
17
|
+
* Use this prop if it is needed to wrap each PinnedItem component into another component (eg NavLink)
|
|
18
|
+
*/
|
|
19
|
+
itemWrapper?: (item: ReactElement, itemId: string) => ReactElement;
|
|
15
20
|
};
|
|
16
|
-
export declare const PinnedItems: ({ toggle, onReorder, onToggle, }: PinnedItemsProps) => import("@emotion/react/jsx-runtime").JSX.Element | null;
|
|
21
|
+
export declare const PinnedItems: ({ toggle, onReorder, onToggle, itemWrapper, }: PinnedItemsProps) => import("@emotion/react/jsx-runtime").JSX.Element | null;
|
|
17
22
|
export {};
|
|
@@ -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,
|
|
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          label={locales['navigation.pinned.item.group.label']}\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          type=\"pinnedGroup\"\n          id=\"pinned-group\"\n          data-testid=\"pinned-group\"\n          toggle={toggle}\n          onToggle={onToggle}\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    label={items[itemId].label}\n                    type=\"pinned\"\n                    index={index}\n                    toggle={toggle}\n                    onToggle={items[itemId]?.onToggle}\n                    id={itemId}\n                    active={items[itemId]?.active ?? false}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragOver={onDragOver}\n                      onDragLeave={onDragLeave}\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                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragOver={onDragOver}\n              onDragLeave={onDragLeave}\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,
|
|
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          label={locales['navigation.pinned.item.group.label']}\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          type=\"pinnedGroup\"\n          id=\"pinned-group\"\n          data-testid=\"pinned-group\"\n          toggle={toggle}\n          onToggle={onToggle}\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    label={items[itemId].label}\n                    type=\"pinned\"\n                    index={index}\n                    toggle={toggle}\n                    onToggle={items[itemId]?.onToggle}\n                    id={itemId}\n                    active={items[itemId]?.active ?? false}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragOver={onDragOver}\n                      onDragLeave={onDragLeave}\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                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragOver={onDragOver}\n              onDragLeave={onDragLeave}\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,11 +44,12 @@ 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,
|
|
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          label={locales['navigation.pinned.item.group.label']}\n          categoryIcon={<PinCategoryIcon variant=\"neutral\" />}\n          type=\"pinnedGroup\"\n          id=\"pinned-group\"\n          data-testid=\"pinned-group\"\n          toggle={toggle}\n          onToggle={onToggle}\n        >\n          {pinnedItems.length > 0 ? (\n            pinnedItems.map((itemId, index) => {\n              if (items[itemId]?.label) {\n                const itemElement = (\n                  <Item\n                    label={items[itemId].label}\n                    type=\"pinned\"\n                    index={index}\n                    toggle={toggle}\n                    onToggle={items[itemId]?.onToggle}\n                    id={itemId}\n                    active={items[itemId]?.active ?? false}\n                    onClickPinUnpin={\n                      items[itemId]?.onClickPinUnpin ?? undefined\n                    }\n                  />\n                )\n\n                return (\n                  <RelativeDiv key={itemId}>\n                    <DropableArea\n                      onDragOver={onDragOver}\n                      onDragLeave={onDragLeave}\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                variant=\"caption\"\n                prominence=\"weak\"\n                sentiment=\"neutral\"\n              >\n                {locales['navigation.pinned.item.group.empty']}\n              </Text>\n            </TextContainer>\n          )}\n\n          <RelativeDiv>\n            <DropableArea\n              onDragOver={onDragOver}\n              onDragLeave={onDragLeave}\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,
|
|
51
|
-
onToggle
|
|
51
|
+
onToggle,
|
|
52
|
+
itemWrapper
|
|
52
53
|
}) => {
|
|
53
54
|
const context = useNavigation();
|
|
54
55
|
if (!context) {
|
|
@@ -93,10 +94,16 @@ const PinnedItems = ({
|
|
|
93
94
|
return /* @__PURE__ */ jsx("div", { style: {
|
|
94
95
|
width: animation ? "100%" : void 0
|
|
95
96
|
}, children: /* @__PURE__ */ jsxs(Item, { label: locales["navigation.pinned.item.group.label"], categoryIcon: /* @__PURE__ */ jsx(PinCategoryIcon, { variant: "neutral" }), type: "pinnedGroup", id: "pinned-group", "data-testid": "pinned-group", toggle, onToggle, children: [
|
|
96
|
-
pinnedItems.length > 0 ? pinnedItems.map((itemId, index) =>
|
|
97
|
-
|
|
98
|
-
|
|
99
|
-
|
|
97
|
+
pinnedItems.length > 0 ? pinnedItems.map((itemId, index) => {
|
|
98
|
+
if (items[itemId]?.label) {
|
|
99
|
+
const itemElement = /* @__PURE__ */ jsx(Item, { label: items[itemId].label, type: "pinned", index, toggle, onToggle: items[itemId]?.onToggle, id: itemId, active: items[itemId]?.active ?? false, onClickPinUnpin: items[itemId]?.onClickPinUnpin ?? void 0 });
|
|
100
|
+
return /* @__PURE__ */ jsxs(RelativeDiv, { children: [
|
|
101
|
+
/* @__PURE__ */ jsx(DropableArea, { onDragOver, onDragLeave, onDrop: (event) => onDrop(event, index) }),
|
|
102
|
+
itemWrapper ? itemWrapper(itemElement, itemId) : itemElement
|
|
103
|
+
] }, itemId);
|
|
104
|
+
}
|
|
105
|
+
return null;
|
|
106
|
+
}) : /* @__PURE__ */ jsx(TextContainer, { "data-expanded": expanded, children: /* @__PURE__ */ jsx(Text, { as: "p", variant: "caption", prominence: "weak", sentiment: "neutral", children: locales["navigation.pinned.item.group.empty"] }) }),
|
|
100
107
|
/* @__PURE__ */ jsx(RelativeDiv, { children: /* @__PURE__ */ jsx(DropableArea, { onDragOver, onDragLeave, onDrop: (event) => onDrop(event, pinnedItems.length) }) })
|
|
101
108
|
] }) });
|
|
102
109
|
}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@ultraviolet/plus",
|
|
3
|
-
"version": "1.0.0-beta.
|
|
3
|
+
"version": "1.0.0-beta.13",
|
|
4
4
|
"description": "Ultraviolet Plus",
|
|
5
5
|
"homepage": "https://github.com/scaleway/ultraviolet#readme",
|
|
6
6
|
"repository": {
|
|
@@ -55,7 +55,7 @@
|
|
|
55
55
|
"@emotion/styled": "11.14.0",
|
|
56
56
|
"react": "18.x || 19.x",
|
|
57
57
|
"react-dom": "18.x || 19.x",
|
|
58
|
-
"@ultraviolet/ui": "2.0.0-beta.
|
|
58
|
+
"@ultraviolet/ui": "2.0.0-beta.13"
|
|
59
59
|
},
|
|
60
60
|
"devDependencies": {
|
|
61
61
|
"@babel/core": "7.27.4",
|
|
@@ -66,8 +66,8 @@
|
|
|
66
66
|
"react": "19.1.0",
|
|
67
67
|
"react-dom": "19.1.0",
|
|
68
68
|
"@ultraviolet/illustrations": "5.0.0-beta.3",
|
|
69
|
-
"@
|
|
70
|
-
"@
|
|
69
|
+
"@utils/test": "0.0.1",
|
|
70
|
+
"@ultraviolet/ui": "2.0.0-beta.13"
|
|
71
71
|
},
|
|
72
72
|
"dependencies": {
|
|
73
73
|
"@uiw/codemirror-extensions-langs": "4.23.13",
|