@dbcdk/react-components 0.0.4 → 0.0.5

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 (223) hide show
  1. package/dist/assets/logo.cjs +10 -10
  2. package/dist/assets/logo.js +10 -10
  3. package/dist/components/__stories__/story-components/Colors.cjs +159 -0
  4. package/dist/components/__stories__/story-components/Colors.d.ts +10 -0
  5. package/dist/components/__stories__/story-components/Colors.js +151 -0
  6. package/dist/components/__stories__/story-components/Colors.module.css +27 -0
  7. package/dist/components/__stories__/story-components/Spacing.cjs +190 -0
  8. package/dist/components/__stories__/story-components/Spacing.d.ts +1 -0
  9. package/dist/components/__stories__/story-components/Spacing.js +184 -0
  10. package/dist/components/__stories__/story-components/Spacing.module.css +154 -0
  11. package/dist/components/app-header/AppHeader.module.css +10 -15
  12. package/dist/components/attribute-chip/AttributeChip.cjs +22 -0
  13. package/dist/components/attribute-chip/AttributeChip.d.ts +8 -0
  14. package/dist/components/attribute-chip/AttributeChip.js +16 -0
  15. package/dist/components/attribute-chip/AttributeChip.module.css +65 -0
  16. package/dist/components/avatar/Avatar.cjs +38 -4
  17. package/dist/components/avatar/Avatar.d.ts +4 -2
  18. package/dist/components/avatar/Avatar.js +39 -5
  19. package/dist/components/avatar/Avatar.module.css +27 -0
  20. package/dist/components/breadcrumbs/Breadcrumbs.cjs +1 -2
  21. package/dist/components/breadcrumbs/Breadcrumbs.js +1 -2
  22. package/dist/components/breadcrumbs/Breadcrumbs.module.css +19 -22
  23. package/dist/components/button/Button.cjs +20 -12
  24. package/dist/components/button/Button.d.ts +4 -1
  25. package/dist/components/button/Button.js +20 -12
  26. package/dist/components/button/Button.module.css +118 -55
  27. package/dist/components/card/Card.cjs +53 -13
  28. package/dist/components/card/Card.d.ts +21 -6
  29. package/dist/components/card/Card.js +54 -14
  30. package/dist/components/card/Card.module.css +148 -44
  31. package/dist/components/card-container/CardContainer.cjs +6 -5
  32. package/dist/components/card-container/CardContainer.d.ts +5 -2
  33. package/dist/components/card-container/CardContainer.js +6 -5
  34. package/dist/components/card-container/CardContainer.module.css +40 -0
  35. package/dist/components/checkbox/Checkbox.cjs +3 -4
  36. package/dist/components/checkbox/Checkbox.d.ts +1 -1
  37. package/dist/components/checkbox/Checkbox.js +3 -4
  38. package/dist/components/checkbox/Checkbox.module.css +10 -10
  39. package/dist/components/chip/Chip.cjs +2 -1
  40. package/dist/components/chip/Chip.d.ts +2 -1
  41. package/dist/components/chip/Chip.js +2 -1
  42. package/dist/components/chip/Chip.module.css +42 -27
  43. package/dist/components/circle/Circle.module.css +11 -11
  44. package/dist/components/clear-button/ClearButton.cjs +3 -3
  45. package/dist/components/clear-button/ClearButton.js +3 -3
  46. package/dist/components/clear-button/ClearButton.module.css +8 -7
  47. package/dist/components/code-block/CodeBlock.cjs +18 -0
  48. package/dist/components/code-block/CodeBlock.d.ts +6 -0
  49. package/dist/components/code-block/CodeBlock.js +12 -0
  50. package/dist/components/code-block/CodeBlock.module.css +60 -0
  51. package/dist/components/copy-button/CopyButton.cjs +35 -0
  52. package/dist/components/copy-button/CopyButton.d.ts +9 -0
  53. package/dist/components/copy-button/CopyButton.js +29 -0
  54. package/dist/components/copy-button/CopyButton.module.css +6 -0
  55. package/dist/components/datetime-picker/DateTimePicker.cjs +504 -0
  56. package/dist/components/datetime-picker/DateTimePicker.d.ts +39 -0
  57. package/dist/components/datetime-picker/DateTimePicker.js +498 -0
  58. package/dist/components/datetime-picker/DateTimePicker.module.css +144 -0
  59. package/dist/components/filter-field/FilterField.cjs +34 -19
  60. package/dist/components/filter-field/FilterField.d.ts +2 -2
  61. package/dist/components/filter-field/FilterField.js +35 -20
  62. package/dist/components/filter-field/FilterField.module.css +14 -20
  63. package/dist/components/headline/Headline.cjs +10 -4
  64. package/dist/components/headline/Headline.d.ts +9 -1
  65. package/dist/components/headline/Headline.js +10 -4
  66. package/dist/components/headline/Headline.module.css +32 -7
  67. package/dist/components/icon/Icon.module.css +10 -9
  68. package/dist/components/input/Input.cjs +60 -19
  69. package/dist/components/input/Input.d.ts +7 -2
  70. package/dist/components/input/Input.js +60 -19
  71. package/dist/components/input/Input.module.css +90 -43
  72. package/dist/components/link/Link.cjs +46 -0
  73. package/dist/components/link/Link.d.ts +9 -0
  74. package/dist/components/link/Link.js +21 -0
  75. package/dist/components/link/Link.module.css +32 -0
  76. package/dist/components/menu/Menu.module.css +10 -32
  77. package/dist/components/meta-bar/MetaBar.cjs +29 -0
  78. package/dist/components/meta-bar/MetaBar.d.ts +11 -0
  79. package/dist/components/meta-bar/MetaBar.js +22 -0
  80. package/dist/components/meta-bar/MetaBar.module.css +12 -0
  81. package/dist/components/modal/Modal.cjs +134 -0
  82. package/dist/components/modal/Modal.d.ts +21 -0
  83. package/dist/components/modal/Modal.js +128 -0
  84. package/dist/components/modal/Modal.module.css +66 -0
  85. package/dist/components/modal/provider/ModalProvider.cjs +80 -0
  86. package/dist/components/modal/provider/ModalProvider.d.ts +21 -0
  87. package/dist/components/modal/provider/ModalProvider.js +77 -0
  88. package/dist/components/multi-select/MultiSelect.cjs +12 -1
  89. package/dist/components/multi-select/MultiSelect.js +12 -1
  90. package/dist/components/nav-bar/NavBar.module.css +11 -16
  91. package/dist/components/page/Page.module.css +2 -2
  92. package/dist/components/page-layout/PageLayout.cjs +5 -22
  93. package/dist/components/page-layout/PageLayout.d.ts +1 -8
  94. package/dist/components/page-layout/PageLayout.js +5 -22
  95. package/dist/components/page-layout/PageLayout.module.css +4 -80
  96. package/dist/components/page-layout/components/page-layout-hero/PageLayoutHero.cjs +32 -0
  97. package/dist/components/page-layout/components/page-layout-hero/PageLayoutHero.d.ts +11 -0
  98. package/dist/components/page-layout/components/page-layout-hero/PageLayoutHero.js +25 -0
  99. package/dist/components/page-layout/components/page-layout-hero/PageLayoutHero.module.css +84 -0
  100. package/dist/components/pagination/Pagination.cjs +83 -67
  101. package/dist/components/pagination/Pagination.d.ts +3 -1
  102. package/dist/components/pagination/Pagination.js +84 -68
  103. package/dist/components/pagination/Pagination.module.css +11 -3
  104. package/dist/components/panel/Panel.module.css +5 -7
  105. package/dist/components/popover/Popover.cjs +25 -8
  106. package/dist/components/popover/Popover.d.ts +2 -1
  107. package/dist/components/popover/Popover.js +25 -8
  108. package/dist/components/popover/Popover.module.css +4 -6
  109. package/dist/components/search-box/SearchBox.cjs +50 -37
  110. package/dist/components/search-box/SearchBox.d.ts +10 -7
  111. package/dist/components/search-box/SearchBox.js +50 -37
  112. package/dist/components/search-box/SearchBox.module.css +0 -1
  113. package/dist/components/segmented-progress-bar/SegmentedProgressBar.cjs +12 -6
  114. package/dist/components/segmented-progress-bar/SegmentedProgressBar.js +12 -6
  115. package/dist/components/segmented-progress-bar/SegmentedProgressBar.module.css +5 -1
  116. package/dist/components/select/Select.cjs +82 -13
  117. package/dist/components/select/Select.d.ts +2 -1
  118. package/dist/components/select/Select.js +83 -14
  119. package/dist/components/sidebar/Sidebar.cjs +3 -30
  120. package/dist/components/sidebar/Sidebar.d.ts +2 -1
  121. package/dist/components/sidebar/Sidebar.js +4 -26
  122. package/dist/components/sidebar/components/SidebarItem.cjs +3 -1
  123. package/dist/components/sidebar/components/SidebarItem.js +3 -1
  124. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.cjs +40 -14
  125. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.d.ts +3 -1
  126. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.js +40 -14
  127. package/dist/components/sidebar/components/expandable-sidebar-item/ExpandableSidebarItem.module.css +9 -38
  128. package/dist/components/sidebar/components/sidebar-container/SidebarContainer.cjs +50 -0
  129. package/dist/components/sidebar/components/sidebar-container/SidebarContainer.d.ts +8 -0
  130. package/dist/components/sidebar/components/sidebar-container/SidebarContainer.js +43 -0
  131. package/dist/components/sidebar/components/sidebar-container/SidebarContainer.module.css +155 -0
  132. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.cjs +16 -9
  133. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.d.ts +2 -1
  134. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.js +16 -9
  135. package/dist/components/sidebar/components/sidebar-item-content/SidebarItemContent.module.css +25 -12
  136. package/dist/components/sidebar/components/sidebar-items/SidebarItems.cjs +2 -1
  137. package/dist/components/sidebar/components/sidebar-items/SidebarItems.d.ts +1 -1
  138. package/dist/components/sidebar/components/sidebar-items/SidebarItems.js +2 -1
  139. package/dist/components/sidebar/components/sidenav-filteirng/SidenavFiltering.cjs +29 -2
  140. package/dist/components/sidebar/components/sidenav-filteirng/SidenavFiltering.js +25 -2
  141. package/dist/components/sidebar/providers/SidebarProvider.cjs +108 -10
  142. package/dist/components/sidebar/providers/SidebarProvider.d.ts +7 -3
  143. package/dist/components/sidebar/providers/SidebarProvider.js +109 -11
  144. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.cjs +1 -1
  145. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.js +1 -1
  146. package/dist/components/skeleton-loader/skeleton-loader-item/SkeletonLoaderItem.module.css +0 -12
  147. package/dist/components/split-pane/SplitPane.cjs +123 -0
  148. package/dist/components/split-pane/SplitPane.d.ts +34 -0
  149. package/dist/components/split-pane/SplitPane.js +114 -0
  150. package/dist/components/split-pane/SplitPane.module.css +106 -0
  151. package/dist/components/split-pane/provider/SplitPaneContext.cjs +87 -0
  152. package/dist/components/split-pane/provider/SplitPaneContext.d.ts +23 -0
  153. package/dist/components/split-pane/provider/SplitPaneContext.js +79 -0
  154. package/dist/components/table/Table.cjs +180 -112
  155. package/dist/components/table/Table.d.ts +22 -6
  156. package/dist/components/table/Table.js +181 -113
  157. package/dist/components/table/Table.module.css +74 -47
  158. package/dist/components/table/components/empty-state/EmptyState.cjs +52 -0
  159. package/dist/components/table/components/empty-state/EmptyState.d.ts +40 -0
  160. package/dist/components/table/components/empty-state/EmptyState.js +46 -0
  161. package/dist/components/table/components/empty-state/EmptyState.module.css +16 -0
  162. package/dist/components/table/components/table-settings/TableSettings.cjs +32 -0
  163. package/dist/components/table/components/table-settings/TableSettings.d.ts +7 -0
  164. package/dist/components/table/components/table-settings/TableSettings.js +30 -0
  165. package/dist/{tanstack.cjs → components/table/tanstack.cjs} +61 -99
  166. package/dist/components/table/tanstack.d.ts +14 -0
  167. package/dist/{tanstack.js → components/table/tanstack.js} +61 -99
  168. package/dist/components/tabs/Tabs.cjs +33 -17
  169. package/dist/components/tabs/Tabs.d.ts +6 -3
  170. package/dist/components/tabs/Tabs.js +33 -17
  171. package/dist/components/tabs/Tabs.module.css +9 -9
  172. package/dist/components/toast/Toast.cjs +47 -0
  173. package/dist/components/toast/Toast.d.ts +14 -0
  174. package/dist/components/toast/Toast.js +41 -0
  175. package/dist/components/toast/Toast.module.css +101 -0
  176. package/dist/components/toast/provider/ToastProvider.cjs +98 -0
  177. package/dist/components/toast/provider/ToastProvider.d.ts +23 -0
  178. package/dist/components/toast/provider/ToastProvider.js +91 -0
  179. package/dist/components/tooltip/Tooltip.cjs +134 -29
  180. package/dist/components/tooltip/Tooltip.js +135 -30
  181. package/dist/components/tooltip/Tooltip.module.css +25 -43
  182. package/dist/components/user-display/UserDisplay.module.css +2 -2
  183. package/dist/constants/severity.cjs +12 -12
  184. package/dist/constants/severity.js +12 -12
  185. package/dist/constants/sizes.cjs +1 -0
  186. package/dist/constants/sizes.d.ts +1 -1
  187. package/dist/constants/sizes.js +1 -0
  188. package/dist/hooks/usePagination.cjs +88 -0
  189. package/dist/hooks/usePagination.d.ts +33 -0
  190. package/dist/hooks/usePagination.js +86 -0
  191. package/dist/hooks/useSorting.cjs +118 -0
  192. package/dist/hooks/useSorting.d.ts +49 -0
  193. package/dist/hooks/useSorting.js +116 -0
  194. package/dist/hooks/useTableData.cjs +52 -0
  195. package/dist/hooks/useTableData.d.ts +40 -0
  196. package/dist/hooks/useTableData.js +50 -0
  197. package/dist/hooks/useTableSelection.cjs +130 -0
  198. package/dist/hooks/useTableSelection.d.ts +25 -0
  199. package/dist/hooks/useTableSelection.js +128 -0
  200. package/dist/hooks/useTableSettings.cjs +28 -0
  201. package/dist/hooks/useTableSettings.d.ts +7 -0
  202. package/dist/hooks/useTableSettings.js +26 -0
  203. package/dist/hooks/useTimeDuration.cjs +39 -0
  204. package/dist/hooks/useTimeDuration.d.ts +22 -0
  205. package/dist/hooks/useTimeDuration.js +37 -0
  206. package/dist/hooks/useViewportFill.js +1 -1
  207. package/dist/index.cjs +119 -0
  208. package/dist/index.d.ts +17 -0
  209. package/dist/index.js +17 -0
  210. package/dist/src/styles/styles.css +101 -8
  211. package/dist/styles/css-helper-classes/flex.css +97 -0
  212. package/dist/styles/css-helper-classes/typography.css +7 -0
  213. package/dist/styles/styles.css +101 -8
  214. package/dist/styles/themes/dbc/dark.css +206 -99
  215. package/dist/styles/themes/dbc/light.css +183 -89
  216. package/dist/types/sizes.types.d.ts +2 -2
  217. package/package.json +17 -11
  218. package/dist/components/data-summary/DataSummary.cjs +0 -49
  219. package/dist/components/data-summary/DataSummary.d.ts +0 -19
  220. package/dist/components/data-summary/DataSummary.js +0 -43
  221. package/dist/components/data-summary/DataSummary.module.css +0 -51
  222. package/dist/components/sidebar/Sidebar.module.css +0 -66
  223. package/dist/tanstack.d.ts +0 -25
@@ -7,7 +7,9 @@ function SidebarItem({
7
7
  icon,
8
8
  href
9
9
  }) {
10
- if (!Component) return null;
10
+ if (!Component) {
11
+ return null;
12
+ }
11
13
  return /* @__PURE__ */ jsx(Component, { children: /* @__PURE__ */ jsx(SidebarItemContent, { icon, label, href }) });
12
14
  }
13
15
 
@@ -7,6 +7,7 @@ var lucideReact = require('lucide-react');
7
7
  var styles = require('./ExpandableSidebarItem.module.css');
8
8
  var SidebarProvider = require('../../providers/SidebarProvider');
9
9
  var SidebarItem = require('../SidebarItem');
10
+ var Button = require('../../../button/Button');
10
11
 
11
12
  function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
12
13
 
@@ -16,15 +17,27 @@ function ExpandableSidebarItem({
16
17
  items,
17
18
  label,
18
19
  icon,
20
+ component: Component,
19
21
  href
20
22
  }) {
21
- const { defaultExpanded, resetExpandAll, activeLink } = SidebarProvider.useSidebar();
23
+ const {
24
+ defaultExpanded,
25
+ resetExpandAll,
26
+ isSidebarCollapsed,
27
+ handleSidebarCollapseChange,
28
+ expandedItems
29
+ } = SidebarProvider.useSidebar();
22
30
  const [expanded, setExpanded] = react.useState(false);
23
31
  const [closing, setClosing] = react.useState(false);
24
32
  const [ready, setReady] = react.useState(false);
25
33
  react.useEffect(() => {
26
34
  setReady(true);
27
35
  }, []);
36
+ react.useEffect(() => {
37
+ if (expandedItems.has(href)) {
38
+ setExpanded(true);
39
+ }
40
+ }, [expandedItems]);
28
41
  react.useEffect(() => {
29
42
  if (defaultExpanded === null) {
30
43
  return;
@@ -37,35 +50,48 @@ function ExpandableSidebarItem({
37
50
  setClosing(false);
38
51
  }
39
52
  }, [closing, ready]);
40
- const toggleAccordion = react.useCallback(() => {
41
- resetExpandAll();
42
- if (!expanded) {
43
- setExpanded(true);
44
- return;
45
- }
46
- setClosing(true);
47
- }, [expanded]);
53
+ const toggleAccordion = react.useCallback(
54
+ (e, onlyExpand = false) => {
55
+ e == null ? void 0 : e.preventDefault();
56
+ e == null ? void 0 : e.stopPropagation();
57
+ resetExpandAll();
58
+ handleSidebarCollapseChange == null ? void 0 : handleSidebarCollapseChange(false);
59
+ if (!expanded) {
60
+ setExpanded(true);
61
+ return;
62
+ }
63
+ if (!isSidebarCollapsed && !onlyExpand) {
64
+ setClosing(true);
65
+ }
66
+ },
67
+ [expanded]
68
+ );
48
69
  if (!items) return null;
70
+ if (!Component) {
71
+ return null;
72
+ }
49
73
  return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: `${styles__default.default.container} ${expanded ? styles__default.default.expanded : ""}`, children: [
50
- /* @__PURE__ */ jsxRuntime.jsx("button", { onClick: toggleAccordion, className: styles__default.default.button, children: /* @__PURE__ */ jsxRuntime.jsx(
74
+ /* @__PURE__ */ jsxRuntime.jsx(Component, { onClick: () => toggleAccordion(void 0, true), children: /* @__PURE__ */ jsxRuntime.jsx(
51
75
  SidebarItemContent.SidebarItemContent,
52
76
  {
53
77
  icon,
54
78
  label,
55
- suffixIcon: /* @__PURE__ */ jsxRuntime.jsx(
79
+ href,
80
+ disableActiveStyles: expanded,
81
+ suffixIcon: isSidebarCollapsed ? null : /* @__PURE__ */ jsxRuntime.jsx(Button.Button, { variant: "outlined", onClick: toggleAccordion, children: /* @__PURE__ */ jsxRuntime.jsx(
56
82
  lucideReact.ChevronDown,
57
83
  {
58
84
  className: `${styles__default.default.chevron} ${expanded ? styles__default.default.chevronExpanded : ""}`
59
85
  }
60
- )
86
+ ) })
61
87
  }
62
88
  ) }),
63
- expanded && /* @__PURE__ */ jsxRuntime.jsx(
89
+ expanded && !isSidebarCollapsed && /* @__PURE__ */ jsxRuntime.jsx(
64
90
  "div",
65
91
  {
66
92
  onAnimationEnd: handleAnimationEnd,
67
93
  className: `${styles__default.default.childrenContainer} ${closing ? "animate--collapse" : ""} ${expanded ? "animate--expand" : "visually-hidden"}`,
68
- children: items.map(({ component: Component, label: label2, icon: icon2, href: href2 }, id) => /* @__PURE__ */ jsxRuntime.jsx(SidebarItem.SidebarItem, { component: Component, label: label2, icon: icon2, href: href2 }, id))
94
+ children: items.map(({ component: Component2, label: label2, icon: icon2, href: href2 }, id) => /* @__PURE__ */ jsxRuntime.jsx(SidebarItem.SidebarItem, { component: Component2, label: label2, icon: icon2, href: href2 }, id))
69
95
  }
70
96
  )
71
97
  ] });
@@ -1,9 +1,11 @@
1
+ import React from 'react';
1
2
  import { NavBarItem } from '@/components/nav-bar/NavBar';
2
3
  interface ExpandableSidebarItemProps {
3
4
  items: NavBarItem[];
4
5
  label: string;
6
+ component?: React.ElementType;
5
7
  icon: React.ReactNode;
6
8
  href?: string;
7
9
  }
8
- export declare function ExpandableSidebarItem({ items, label, icon, href, }: ExpandableSidebarItemProps): React.ReactNode;
10
+ export declare function ExpandableSidebarItem({ items, label, icon, component: Component, href, }: ExpandableSidebarItemProps): React.ReactNode;
9
11
  export {};
@@ -5,20 +5,33 @@ import { ChevronDown } from 'lucide-react';
5
5
  import styles from './ExpandableSidebarItem.module.css';
6
6
  import { useSidebar } from '../../providers/SidebarProvider';
7
7
  import { SidebarItem } from '../SidebarItem';
8
+ import { Button } from '../../../button/Button';
8
9
 
9
10
  function ExpandableSidebarItem({
10
11
  items,
11
12
  label,
12
13
  icon,
14
+ component: Component,
13
15
  href
14
16
  }) {
15
- const { defaultExpanded, resetExpandAll, activeLink } = useSidebar();
17
+ const {
18
+ defaultExpanded,
19
+ resetExpandAll,
20
+ isSidebarCollapsed,
21
+ handleSidebarCollapseChange,
22
+ expandedItems
23
+ } = useSidebar();
16
24
  const [expanded, setExpanded] = useState(false);
17
25
  const [closing, setClosing] = useState(false);
18
26
  const [ready, setReady] = useState(false);
19
27
  useEffect(() => {
20
28
  setReady(true);
21
29
  }, []);
30
+ useEffect(() => {
31
+ if (expandedItems.has(href)) {
32
+ setExpanded(true);
33
+ }
34
+ }, [expandedItems]);
22
35
  useEffect(() => {
23
36
  if (defaultExpanded === null) {
24
37
  return;
@@ -31,35 +44,48 @@ function ExpandableSidebarItem({
31
44
  setClosing(false);
32
45
  }
33
46
  }, [closing, ready]);
34
- const toggleAccordion = useCallback(() => {
35
- resetExpandAll();
36
- if (!expanded) {
37
- setExpanded(true);
38
- return;
39
- }
40
- setClosing(true);
41
- }, [expanded]);
47
+ const toggleAccordion = useCallback(
48
+ (e, onlyExpand = false) => {
49
+ e == null ? void 0 : e.preventDefault();
50
+ e == null ? void 0 : e.stopPropagation();
51
+ resetExpandAll();
52
+ handleSidebarCollapseChange == null ? void 0 : handleSidebarCollapseChange(false);
53
+ if (!expanded) {
54
+ setExpanded(true);
55
+ return;
56
+ }
57
+ if (!isSidebarCollapsed && !onlyExpand) {
58
+ setClosing(true);
59
+ }
60
+ },
61
+ [expanded]
62
+ );
42
63
  if (!items) return null;
64
+ if (!Component) {
65
+ return null;
66
+ }
43
67
  return /* @__PURE__ */ jsxs("div", { className: `${styles.container} ${expanded ? styles.expanded : ""}`, children: [
44
- /* @__PURE__ */ jsx("button", { onClick: toggleAccordion, className: styles.button, children: /* @__PURE__ */ jsx(
68
+ /* @__PURE__ */ jsx(Component, { onClick: () => toggleAccordion(void 0, true), children: /* @__PURE__ */ jsx(
45
69
  SidebarItemContent,
46
70
  {
47
71
  icon,
48
72
  label,
49
- suffixIcon: /* @__PURE__ */ jsx(
73
+ href,
74
+ disableActiveStyles: expanded,
75
+ suffixIcon: isSidebarCollapsed ? null : /* @__PURE__ */ jsx(Button, { variant: "outlined", onClick: toggleAccordion, children: /* @__PURE__ */ jsx(
50
76
  ChevronDown,
51
77
  {
52
78
  className: `${styles.chevron} ${expanded ? styles.chevronExpanded : ""}`
53
79
  }
54
- )
80
+ ) })
55
81
  }
56
82
  ) }),
57
- expanded && /* @__PURE__ */ jsx(
83
+ expanded && !isSidebarCollapsed && /* @__PURE__ */ jsx(
58
84
  "div",
59
85
  {
60
86
  onAnimationEnd: handleAnimationEnd,
61
87
  className: `${styles.childrenContainer} ${closing ? "animate--collapse" : ""} ${expanded ? "animate--expand" : "visually-hidden"}`,
62
- children: items.map(({ component: Component, label: label2, icon: icon2, href: href2 }, id) => /* @__PURE__ */ jsx(SidebarItem, { component: Component, label: label2, icon: icon2, href: href2 }, id))
88
+ children: items.map(({ component: Component2, label: label2, icon: icon2, href: href2 }, id) => /* @__PURE__ */ jsx(SidebarItem, { component: Component2, label: label2, icon: icon2, href: href2 }, id))
63
89
  }
64
90
  )
65
91
  ] });
@@ -1,5 +1,4 @@
1
1
  .button {
2
- color: var(--color-text);
3
2
  }
4
3
 
5
4
  .container {
@@ -9,49 +8,21 @@
9
8
  border-radius: var(--border-radius-default);
10
9
  }
11
10
 
12
- .container.expanded {
11
+ .container button {
12
+ color: var(--color-text);
13
+ min-block-size: 20px !important;
14
+ min-inline-size: 20px !important;
15
+ max-block-size: 20px !important;
16
+ max-inline-size: 20px !important;
17
+ &:hover {
18
+ background-color: var(--color-bg-contextual-subtle) !important;
19
+ }
13
20
  }
14
21
 
15
22
  .childrenContainer {
16
23
  overflow: hidden;
17
-
18
- /* --width: 2px;
19
- --color: var(--opac-bg-default); */
20
- }
21
-
22
- /* .childrenContainer::after {
23
24
  }
24
25
 
25
- .childrenContainer > * {
26
- position: relative;
27
- &::before {
28
- content: '';
29
- position: absolute;
30
- bottom: top;
31
- background-color: var(--color);
32
- left: 0;
33
- height: 100%;
34
- width: var(--width);
35
- left: var(--icon-size);
36
- transform: translateX(-50%);
37
- }
38
- &:last-of-type {
39
- &::before {
40
- height: calc(50% + var(--width));
41
- }
42
- }
43
- &::after {
44
- content: '';
45
- position: absolute;
46
- bottom: 50%;
47
- background-color: var(--color);
48
- height: var(--width);
49
- width: calc(var(--icon-size) / 2 + 5px);
50
- left: calc(var(--icon-size) + var(--width) / 2);
51
- transform: translateY(100%);
52
- }
53
- } */
54
-
55
26
  .chevron {
56
27
  transition: transform 0.3s ease;
57
28
  }
@@ -0,0 +1,50 @@
1
+ 'use strict';
2
+
3
+ var jsxRuntime = require('react/jsx-runtime');
4
+ var Button = require('../../../button/Button');
5
+ var styles = require('./SidebarContainer.module.css');
6
+ var logo = require('../../../../assets/logo');
7
+ var Headline = require('../../../headline/Headline');
8
+ var lucideReact = require('lucide-react');
9
+ var SidebarItems = require('../sidebar-items/SidebarItems');
10
+ var SidenavFiltering = require('../sidenav-filteirng/SidenavFiltering');
11
+ var SidebarProvider = require('../../providers/SidebarProvider');
12
+
13
+ function _interopDefault (e) { return e && e.__esModule ? e : { default: e }; }
14
+
15
+ var styles__default = /*#__PURE__*/_interopDefault(styles);
16
+ var SidenavFiltering__default = /*#__PURE__*/_interopDefault(SidenavFiltering);
17
+
18
+ function SidebarContainer({
19
+ logo: logo$1,
20
+ productName,
21
+ productLogo,
22
+ activeLink
23
+ }) {
24
+ const { isSidebarCollapsed, handleSidebarCollapseChange } = SidebarProvider.useSidebar();
25
+ return /* @__PURE__ */ jsxRuntime.jsxs("div", { className: `${styles__default.default.container} ${isSidebarCollapsed ? styles__default.default.collapsed : ""}`, children: [
26
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles__default.default.header, children: [
27
+ /* @__PURE__ */ jsxRuntime.jsxs("span", { className: styles__default.default.logoContainer, children: [
28
+ /* @__PURE__ */ jsxRuntime.jsx("div", { style: { textAlign: isSidebarCollapsed ? "center" : "right" }, children: /* @__PURE__ */ jsxRuntime.jsx(
29
+ Button.Button,
30
+ {
31
+ size: "sm",
32
+ variant: "inline",
33
+ icon: /* @__PURE__ */ jsxRuntime.jsx(lucideReact.ChevronLeft, { className: isSidebarCollapsed ? styles__default.default.collapsedIcon : "" }),
34
+ onClick: () => handleSidebarCollapseChange(!isSidebarCollapsed)
35
+ }
36
+ ) }),
37
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles__default.default.logo, children: logo$1 != null ? logo$1 : /* @__PURE__ */ jsxRuntime.jsx(logo.Logo, {}) })
38
+ ] }),
39
+ productName && /* @__PURE__ */ jsxRuntime.jsx(Headline.Headline, { disableMargin: true, children: productName }),
40
+ productLogo && /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles__default.default.productLogo, children: productLogo })
41
+ ] }),
42
+ /* @__PURE__ */ jsxRuntime.jsxs("div", { className: styles__default.default.content, children: [
43
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles__default.default.filter, children: /* @__PURE__ */ jsxRuntime.jsx(SidenavFiltering__default.default, {}) }),
44
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: `${styles__default.default.links} hideScrollBar`, children: /* @__PURE__ */ jsxRuntime.jsx(SidebarItems.SidebarItems, { activeLink }) })
45
+ ] }),
46
+ /* @__PURE__ */ jsxRuntime.jsx("div", { className: styles__default.default.footer })
47
+ ] });
48
+ }
49
+
50
+ exports.SidebarContainer = SidebarContainer;
@@ -0,0 +1,8 @@
1
+ interface SidebarContainerProps {
2
+ logo?: React.ReactNode;
3
+ productName?: string;
4
+ productLogo?: React.ReactNode;
5
+ activeLink?: string;
6
+ }
7
+ export declare function SidebarContainer({ logo, productName, productLogo, activeLink, }: SidebarContainerProps): JSX.Element;
8
+ export {};
@@ -0,0 +1,43 @@
1
+ import { jsxs, jsx } from 'react/jsx-runtime';
2
+ import { Button } from '../../../button/Button';
3
+ import styles from './SidebarContainer.module.css';
4
+ import { Logo } from '../../../../assets/logo';
5
+ import { Headline } from '../../../headline/Headline';
6
+ import { ChevronLeft } from 'lucide-react';
7
+ import { SidebarItems } from '../sidebar-items/SidebarItems';
8
+ import SidenavFiltering from '../sidenav-filteirng/SidenavFiltering';
9
+ import { useSidebar } from '../../providers/SidebarProvider';
10
+
11
+ function SidebarContainer({
12
+ logo,
13
+ productName,
14
+ productLogo,
15
+ activeLink
16
+ }) {
17
+ const { isSidebarCollapsed, handleSidebarCollapseChange } = useSidebar();
18
+ return /* @__PURE__ */ jsxs("div", { className: `${styles.container} ${isSidebarCollapsed ? styles.collapsed : ""}`, children: [
19
+ /* @__PURE__ */ jsxs("div", { className: styles.header, children: [
20
+ /* @__PURE__ */ jsxs("span", { className: styles.logoContainer, children: [
21
+ /* @__PURE__ */ jsx("div", { style: { textAlign: isSidebarCollapsed ? "center" : "right" }, children: /* @__PURE__ */ jsx(
22
+ Button,
23
+ {
24
+ size: "sm",
25
+ variant: "inline",
26
+ icon: /* @__PURE__ */ jsx(ChevronLeft, { className: isSidebarCollapsed ? styles.collapsedIcon : "" }),
27
+ onClick: () => handleSidebarCollapseChange(!isSidebarCollapsed)
28
+ }
29
+ ) }),
30
+ /* @__PURE__ */ jsx("div", { className: styles.logo, children: logo != null ? logo : /* @__PURE__ */ jsx(Logo, {}) })
31
+ ] }),
32
+ productName && /* @__PURE__ */ jsx(Headline, { disableMargin: true, children: productName }),
33
+ productLogo && /* @__PURE__ */ jsx("div", { className: styles.productLogo, children: productLogo })
34
+ ] }),
35
+ /* @__PURE__ */ jsxs("div", { className: styles.content, children: [
36
+ /* @__PURE__ */ jsx("div", { className: styles.filter, children: /* @__PURE__ */ jsx(SidenavFiltering, {}) }),
37
+ /* @__PURE__ */ jsx("div", { className: `${styles.links} hideScrollBar`, children: /* @__PURE__ */ jsx(SidebarItems, { activeLink }) })
38
+ ] }),
39
+ /* @__PURE__ */ jsx("div", { className: styles.footer })
40
+ ] });
41
+ }
42
+
43
+ export { SidebarContainer };
@@ -0,0 +1,155 @@
1
+ .container {
2
+ flex-shrink: 1;
3
+ height: 100%;
4
+ overflow: auto;
5
+ display: flex;
6
+ flex-direction: column;
7
+ gap: var(--spacing-lg);
8
+ width: var(--sidebar-width);
9
+ inline-size: var(--sidebar-width);
10
+ box-sizing: border-box;
11
+ border-inline-end: var(--border-width-thin) solid var(--color-border-default);
12
+ padding-bottom: var(--spacing-lg);
13
+ transition:
14
+ width var(--transition-fast) var(--ease-standard),
15
+ inline-size var(--transition-fast) var(--ease-standard);
16
+ }
17
+
18
+ .container.collapsed {
19
+ width: var(--component-size-lg);
20
+ inline-size: var(--component-size-lg);
21
+ box-sizing: content-box;
22
+ gap: var(--spacing-sm);
23
+ .content {
24
+ gap: var(--spacing-2xs);
25
+ }
26
+ }
27
+
28
+ .container .logoContainer button,
29
+ .container .filter button {
30
+ border-radius: 0;
31
+ min-height: var(--component-size-md);
32
+ width: 100%;
33
+ padding: var(--spacing-xs);
34
+ color: var(--color-fg-muted);
35
+ }
36
+
37
+ .container:not(.collapsed) .links,
38
+ .container:not(.collapsed) .filter {
39
+ padding-inline: var(--spacing-sm);
40
+ }
41
+
42
+ .container .logoContainer {
43
+ padding-top: var(--spacing-xs);
44
+ min-block-size: 60px;
45
+ border-bottom: 1px solid var(--color-border-default);
46
+ padding-bottom: var(--spacing-xxs);
47
+ }
48
+
49
+ .container.collapsed .logoContainer {
50
+ display: flex;
51
+ flex-direction: column;
52
+ align-items: center;
53
+ justify-content: center;
54
+ }
55
+
56
+ .container:not(.collapsed) .logoContainer {
57
+ display: flex;
58
+ align-items: center;
59
+ flex-direction: row-reverse;
60
+ justify-content: space-between;
61
+ padding-right: var(--spacing-xxs);
62
+ }
63
+
64
+ .container a {
65
+ text-decoration: none;
66
+ color: inherit;
67
+ }
68
+
69
+ .container .links button {
70
+ background: none;
71
+ border: 0;
72
+ font-size: inherit;
73
+ color: inherit;
74
+ display: inline-flex;
75
+ padding: 0;
76
+ }
77
+
78
+ .container a:focus-visible,
79
+ .container button:focus-visible {
80
+ outline: none;
81
+ box-shadow: var(--focus-ring);
82
+ }
83
+
84
+ .links {
85
+ overflow: auto;
86
+ display: flex;
87
+ flex-grow: 1;
88
+ overflow: auto;
89
+ flex-direction: column;
90
+ gap: 2px;
91
+ font-size: var(--font-size-sm);
92
+ }
93
+
94
+ .container:not(.collapsed) .links {
95
+ padding-inline: var(--spacing-sm);
96
+ }
97
+
98
+ .header {
99
+ flex: 0 0 auto;
100
+ display: flex;
101
+ flex-direction: column;
102
+ }
103
+
104
+ .container:not(.collapsed) .header {
105
+ gap: var(--spacing-sm);
106
+ }
107
+
108
+ .container:not(.collapsed) .logo {
109
+ padding: 0 var(--spacing-sm);
110
+ }
111
+ .container.collapsed .logo {
112
+ display: none;
113
+ }
114
+
115
+ .logo img,
116
+ .logo svg {
117
+ inline-size: 50px;
118
+ max-inline-size: 100%;
119
+ block-size: auto;
120
+ }
121
+
122
+ .container.collapsed .productLogo {
123
+ display: none;
124
+ }
125
+ .productLogo {
126
+ max-inline-size: 100%;
127
+ padding: 0 var(--spacing-sm);
128
+ }
129
+
130
+ .productLogo svg {
131
+ max-inline-size: 100%;
132
+ block-size: auto;
133
+ }
134
+
135
+ .collapsedIcon {
136
+ transform: rotate(180deg);
137
+ transition: transform 0.3s ease;
138
+ }
139
+ .content {
140
+ overflow: auto;
141
+ flex: 1 1 auto;
142
+ overflow-y: visible;
143
+ display: flex;
144
+ flex-direction: column;
145
+ position: relative;
146
+ width: 100%;
147
+ gap: 5px;
148
+ &:not(.collapsed) {
149
+ gap: var(--spacing-md);
150
+ }
151
+ }
152
+
153
+ .footer {
154
+ flex: 0 0 auto;
155
+ }
@@ -12,16 +12,23 @@ function SidebarItemContent({
12
12
  icon,
13
13
  label,
14
14
  suffixIcon,
15
- href
15
+ href,
16
+ disableActiveStyles = false
16
17
  }) {
17
- const { activeLink } = SidebarProvider.useSidebar();
18
- return /* @__PURE__ */ jsxRuntime.jsxs("span", { className: `${styles__default.default.container} ${activeLink === href ? styles__default.default.active : ""}`, children: [
19
- /* @__PURE__ */ jsxRuntime.jsxs("span", { children: [
20
- /* @__PURE__ */ jsxRuntime.jsx("span", { className: styles__default.default.icon, children: icon }),
21
- /* @__PURE__ */ jsxRuntime.jsx("span", { className: styles__default.default.label, children: label })
22
- ] }),
23
- suffixIcon && /* @__PURE__ */ jsxRuntime.jsx("span", { className: styles__default.default.suffixIcon, children: suffixIcon })
24
- ] });
18
+ const { activeLink, isSidebarCollapsed } = SidebarProvider.useSidebar();
19
+ return /* @__PURE__ */ jsxRuntime.jsxs(
20
+ "span",
21
+ {
22
+ className: `${styles__default.default.container} ${!disableActiveStyles && activeLink === href ? styles__default.default.active : ""} ${isSidebarCollapsed ? styles__default.default.collapsed : ""}`,
23
+ children: [
24
+ /* @__PURE__ */ jsxRuntime.jsxs("span", { children: [
25
+ /* @__PURE__ */ jsxRuntime.jsx("span", { className: styles__default.default.icon, children: icon }),
26
+ !isSidebarCollapsed && /* @__PURE__ */ jsxRuntime.jsx("span", { className: styles__default.default.label, children: label })
27
+ ] }),
28
+ suffixIcon && !isSidebarCollapsed && /* @__PURE__ */ jsxRuntime.jsx("span", { className: styles__default.default.suffixIcon, children: suffixIcon })
29
+ ]
30
+ }
31
+ );
25
32
  }
26
33
 
27
34
  exports.SidebarItemContent = SidebarItemContent;
@@ -4,5 +4,6 @@ export interface SidebarItemContentProps {
4
4
  label: React.ReactNode;
5
5
  suffixIcon?: React.ReactNode;
6
6
  href?: string;
7
+ disableActiveStyles?: boolean;
7
8
  }
8
- export declare function SidebarItemContent({ icon, label, suffixIcon, href, }: SidebarItemContentProps): JSX.Element;
9
+ export declare function SidebarItemContent({ icon, label, suffixIcon, href, disableActiveStyles, }: SidebarItemContentProps): JSX.Element;
@@ -6,16 +6,23 @@ function SidebarItemContent({
6
6
  icon,
7
7
  label,
8
8
  suffixIcon,
9
- href
9
+ href,
10
+ disableActiveStyles = false
10
11
  }) {
11
- const { activeLink } = useSidebar();
12
- return /* @__PURE__ */ jsxs("span", { className: `${styles.container} ${activeLink === href ? styles.active : ""}`, children: [
13
- /* @__PURE__ */ jsxs("span", { children: [
14
- /* @__PURE__ */ jsx("span", { className: styles.icon, children: icon }),
15
- /* @__PURE__ */ jsx("span", { className: styles.label, children: label })
16
- ] }),
17
- suffixIcon && /* @__PURE__ */ jsx("span", { className: styles.suffixIcon, children: suffixIcon })
18
- ] });
12
+ const { activeLink, isSidebarCollapsed } = useSidebar();
13
+ return /* @__PURE__ */ jsxs(
14
+ "span",
15
+ {
16
+ className: `${styles.container} ${!disableActiveStyles && activeLink === href ? styles.active : ""} ${isSidebarCollapsed ? styles.collapsed : ""}`,
17
+ children: [
18
+ /* @__PURE__ */ jsxs("span", { children: [
19
+ /* @__PURE__ */ jsx("span", { className: styles.icon, children: icon }),
20
+ !isSidebarCollapsed && /* @__PURE__ */ jsx("span", { className: styles.label, children: label })
21
+ ] }),
22
+ suffixIcon && !isSidebarCollapsed && /* @__PURE__ */ jsx("span", { className: styles.suffixIcon, children: suffixIcon })
23
+ ]
24
+ }
25
+ );
19
26
  }
20
27
 
21
28
  export { SidebarItemContent };