@mihcm/ui 0.14.1 → 0.15.0

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 (300) hide show
  1. package/dist/CheckboxGrid.native.d.ts.map +1 -1
  2. package/dist/CheckboxGrid.native.js +2 -1
  3. package/dist/CheckboxGrid.native.js.map +1 -1
  4. package/dist/Combobox.native.d.ts.map +1 -1
  5. package/dist/Combobox.native.js +2 -1
  6. package/dist/Combobox.native.js.map +1 -1
  7. package/dist/DataTable/column-filter.d.ts +8 -0
  8. package/dist/DataTable/column-filter.d.ts.map +1 -0
  9. package/dist/DataTable/column-filter.js +67 -0
  10. package/dist/DataTable/column-filter.js.map +1 -0
  11. package/dist/DataTable/column-header.d.ts +16 -0
  12. package/dist/DataTable/column-header.d.ts.map +1 -0
  13. package/dist/DataTable/column-header.js +11 -0
  14. package/dist/DataTable/column-header.js.map +1 -0
  15. package/dist/DataTable/column-visibility.d.ts +7 -0
  16. package/dist/DataTable/column-visibility.d.ts.map +1 -0
  17. package/dist/DataTable/column-visibility.js +35 -0
  18. package/dist/DataTable/column-visibility.js.map +1 -0
  19. package/dist/DataTable/index.d.ts +5 -0
  20. package/dist/DataTable/index.d.ts.map +1 -0
  21. package/dist/DataTable/index.js +5 -0
  22. package/dist/DataTable/index.js.map +1 -0
  23. package/dist/DataTable/pinning.d.ts +13 -0
  24. package/dist/DataTable/pinning.d.ts.map +1 -0
  25. package/dist/DataTable/pinning.js +29 -0
  26. package/dist/DataTable/pinning.js.map +1 -0
  27. package/dist/DataTable.d.ts +3 -7
  28. package/dist/DataTable.d.ts.map +1 -1
  29. package/dist/DataTable.js +7 -126
  30. package/dist/DataTable.js.map +1 -1
  31. package/dist/Dialog.native.d.ts +3 -1
  32. package/dist/Dialog.native.d.ts.map +1 -1
  33. package/dist/Dialog.native.js +2 -2
  34. package/dist/Dialog.native.js.map +1 -1
  35. package/dist/Form/building-blocks.d.ts +26 -0
  36. package/dist/Form/building-blocks.d.ts.map +1 -0
  37. package/dist/Form/building-blocks.js +29 -0
  38. package/dist/Form/building-blocks.js.map +1 -0
  39. package/dist/Form/fields-choice.d.ts +72 -0
  40. package/dist/Form/fields-choice.d.ts.map +1 -0
  41. package/dist/Form/fields-choice.js +69 -0
  42. package/dist/Form/fields-choice.js.map +1 -0
  43. package/dist/Form/fields-complex.d.ts +28 -0
  44. package/dist/Form/fields-complex.d.ts.map +1 -0
  45. package/dist/Form/fields-complex.js +38 -0
  46. package/dist/Form/fields-complex.js.map +1 -0
  47. package/dist/Form/fields-date.d.ts +46 -0
  48. package/dist/Form/fields-date.d.ts.map +1 -0
  49. package/dist/Form/fields-date.js +41 -0
  50. package/dist/Form/fields-date.js.map +1 -0
  51. package/dist/Form/fields-text.d.ts +47 -0
  52. package/dist/Form/fields-text.d.ts.map +1 -0
  53. package/dist/Form/fields-text.js +46 -0
  54. package/dist/Form/fields-text.js.map +1 -0
  55. package/dist/Form/fields-toggle.d.ts +24 -0
  56. package/dist/Form/fields-toggle.d.ts.map +1 -0
  57. package/dist/Form/fields-toggle.js +32 -0
  58. package/dist/Form/fields-toggle.js.map +1 -0
  59. package/dist/Form/helpers.d.ts +66 -0
  60. package/dist/Form/helpers.d.ts.map +1 -0
  61. package/dist/Form/helpers.js +44 -0
  62. package/dist/Form/helpers.js.map +1 -0
  63. package/dist/Form/types.d.ts +25 -0
  64. package/dist/Form/types.d.ts.map +1 -0
  65. package/dist/Form/types.js +8 -0
  66. package/dist/Form/types.js.map +1 -0
  67. package/dist/Form.d.ts +24 -298
  68. package/dist/Form.d.ts.map +1 -1
  69. package/dist/Form.js +30 -246
  70. package/dist/Form.js.map +1 -1
  71. package/dist/IconSidebar.d.ts +6 -46
  72. package/dist/IconSidebar.d.ts.map +1 -1
  73. package/dist/IconSidebar.js +6 -116
  74. package/dist/IconSidebar.js.map +1 -1
  75. package/dist/MainSidebar/back-button.d.ts +14 -0
  76. package/dist/MainSidebar/back-button.d.ts.map +1 -0
  77. package/dist/MainSidebar/back-button.js +14 -0
  78. package/dist/MainSidebar/back-button.js.map +1 -0
  79. package/dist/MainSidebar/breadcrumb.d.ts +10 -0
  80. package/dist/MainSidebar/breadcrumb.d.ts.map +1 -0
  81. package/dist/MainSidebar/breadcrumb.js +24 -0
  82. package/dist/MainSidebar/breadcrumb.js.map +1 -0
  83. package/dist/MainSidebar/columns.d.ts +3 -0
  84. package/dist/MainSidebar/columns.d.ts.map +1 -0
  85. package/dist/MainSidebar/columns.js +198 -0
  86. package/dist/MainSidebar/columns.js.map +1 -0
  87. package/dist/MainSidebar/command.d.ts +3 -0
  88. package/dist/MainSidebar/command.d.ts.map +1 -0
  89. package/dist/MainSidebar/command.js +193 -0
  90. package/dist/MainSidebar/command.js.map +1 -0
  91. package/dist/MainSidebar/drilldown.d.ts +3 -0
  92. package/dist/MainSidebar/drilldown.d.ts.map +1 -0
  93. package/dist/MainSidebar/drilldown.js +154 -0
  94. package/dist/MainSidebar/drilldown.js.map +1 -0
  95. package/dist/MainSidebar/expanded.d.ts +7 -0
  96. package/dist/MainSidebar/expanded.d.ts.map +1 -0
  97. package/dist/MainSidebar/expanded.js +102 -0
  98. package/dist/MainSidebar/expanded.js.map +1 -0
  99. package/dist/MainSidebar/floating.d.ts +3 -0
  100. package/dist/MainSidebar/floating.d.ts.map +1 -0
  101. package/dist/MainSidebar/floating.js +116 -0
  102. package/dist/MainSidebar/floating.js.map +1 -0
  103. package/dist/MainSidebar/helpers.d.ts +50 -0
  104. package/dist/MainSidebar/helpers.d.ts.map +1 -0
  105. package/dist/MainSidebar/helpers.js +148 -0
  106. package/dist/MainSidebar/helpers.js.map +1 -0
  107. package/dist/MainSidebar/hover.d.ts +3 -0
  108. package/dist/MainSidebar/hover.d.ts.map +1 -0
  109. package/dist/MainSidebar/hover.js +177 -0
  110. package/dist/MainSidebar/hover.js.map +1 -0
  111. package/dist/MainSidebar/index.d.ts +6 -0
  112. package/dist/MainSidebar/index.d.ts.map +1 -0
  113. package/dist/MainSidebar/index.js +108 -0
  114. package/dist/MainSidebar/index.js.map +1 -0
  115. package/dist/MainSidebar/mobile.d.ts +29 -0
  116. package/dist/MainSidebar/mobile.d.ts.map +1 -0
  117. package/dist/MainSidebar/mobile.js +38 -0
  118. package/dist/MainSidebar/mobile.js.map +1 -0
  119. package/dist/MainSidebar/motion.d.ts +23 -0
  120. package/dist/MainSidebar/motion.d.ts.map +1 -0
  121. package/dist/MainSidebar/motion.js +40 -0
  122. package/dist/MainSidebar/motion.js.map +1 -0
  123. package/dist/MainSidebar/rail.d.ts +24 -0
  124. package/dist/MainSidebar/rail.d.ts.map +1 -0
  125. package/dist/MainSidebar/rail.js +29 -0
  126. package/dist/MainSidebar/rail.js.map +1 -0
  127. package/dist/MainSidebar/search.d.ts +19 -0
  128. package/dist/MainSidebar/search.d.ts.map +1 -0
  129. package/dist/MainSidebar/search.js +33 -0
  130. package/dist/MainSidebar/search.js.map +1 -0
  131. package/dist/MainSidebar/types.d.ts +161 -0
  132. package/dist/MainSidebar/types.d.ts.map +1 -0
  133. package/dist/MainSidebar/types.js +2 -0
  134. package/dist/MainSidebar/types.js.map +1 -0
  135. package/dist/MainSidebar.d.ts +6 -1
  136. package/dist/MainSidebar.d.ts.map +1 -1
  137. package/dist/MainSidebar.js +6 -1
  138. package/dist/MainSidebar.js.map +1 -1
  139. package/dist/NavigationMenu.js +1 -1
  140. package/dist/NavigationMenu.js.map +1 -1
  141. package/dist/RichTextEditor/theme.d.ts +44 -0
  142. package/dist/RichTextEditor/theme.d.ts.map +1 -0
  143. package/dist/RichTextEditor/theme.js +41 -0
  144. package/dist/RichTextEditor/theme.js.map +1 -0
  145. package/dist/RichTextEditor/toolbar-icons.d.ts +21 -0
  146. package/dist/RichTextEditor/toolbar-icons.d.ts.map +1 -0
  147. package/dist/RichTextEditor/toolbar-icons.js +21 -0
  148. package/dist/RichTextEditor/toolbar-icons.js.map +1 -0
  149. package/dist/RichTextEditor/toolbar.d.ts +5 -0
  150. package/dist/RichTextEditor/toolbar.d.ts.map +1 -0
  151. package/dist/RichTextEditor/toolbar.js +116 -0
  152. package/dist/RichTextEditor/toolbar.js.map +1 -0
  153. package/dist/RichTextEditor.d.ts +16 -9
  154. package/dist/RichTextEditor.d.ts.map +1 -1
  155. package/dist/RichTextEditor.js +18 -164
  156. package/dist/RichTextEditor.js.map +1 -1
  157. package/dist/Select/content.d.ts +9 -0
  158. package/dist/Select/content.d.ts.map +1 -0
  159. package/dist/Select/content.js +80 -0
  160. package/dist/Select/content.js.map +1 -0
  161. package/dist/Select/context.d.ts +27 -0
  162. package/dist/Select/context.d.ts.map +1 -0
  163. package/dist/Select/context.js +35 -0
  164. package/dist/Select/context.js.map +1 -0
  165. package/dist/Select/item.d.ts +13 -0
  166. package/dist/Select/item.d.ts.map +1 -0
  167. package/dist/Select/item.js +39 -0
  168. package/dist/Select/item.js.map +1 -0
  169. package/dist/Select/parts.d.ts +14 -0
  170. package/dist/Select/parts.d.ts.map +1 -0
  171. package/dist/Select/parts.js +17 -0
  172. package/dist/Select/parts.js.map +1 -0
  173. package/dist/Select/react-select.d.ts +25 -0
  174. package/dist/Select/react-select.d.ts.map +1 -0
  175. package/dist/Select/react-select.js +66 -0
  176. package/dist/Select/react-select.js.map +1 -0
  177. package/dist/Select/root.d.ts +15 -0
  178. package/dist/Select/root.d.ts.map +1 -0
  179. package/dist/Select/root.js +41 -0
  180. package/dist/Select/root.js.map +1 -0
  181. package/dist/Select/trigger.d.ts +15 -0
  182. package/dist/Select/trigger.d.ts.map +1 -0
  183. package/dist/Select/trigger.js +61 -0
  184. package/dist/Select/trigger.js.map +1 -0
  185. package/dist/Select.d.ts +14 -62
  186. package/dist/Select.d.ts.map +1 -1
  187. package/dist/Select.js +14 -293
  188. package/dist/Select.js.map +1 -1
  189. package/dist/Sidebar/context.d.ts +28 -0
  190. package/dist/Sidebar/context.d.ts.map +1 -0
  191. package/dist/Sidebar/context.js +37 -0
  192. package/dist/Sidebar/context.js.map +1 -0
  193. package/dist/Sidebar/group.d.ts +13 -0
  194. package/dist/Sidebar/group.d.ts.map +1 -0
  195. package/dist/Sidebar/group.js +20 -0
  196. package/dist/Sidebar/group.js.map +1 -0
  197. package/dist/Sidebar/icons.d.ts +7 -0
  198. package/dist/Sidebar/icons.d.ts.map +1 -0
  199. package/dist/Sidebar/icons.js +12 -0
  200. package/dist/Sidebar/icons.js.map +1 -0
  201. package/dist/Sidebar/layout.d.ts +9 -0
  202. package/dist/Sidebar/layout.d.ts.map +1 -0
  203. package/dist/Sidebar/layout.js +21 -0
  204. package/dist/Sidebar/layout.js.map +1 -0
  205. package/dist/Sidebar/menu.d.ts +29 -0
  206. package/dist/Sidebar/menu.d.ts.map +1 -0
  207. package/dist/Sidebar/menu.js +55 -0
  208. package/dist/Sidebar/menu.js.map +1 -0
  209. package/dist/Sidebar/provider.d.ts +33 -0
  210. package/dist/Sidebar/provider.d.ts.map +1 -0
  211. package/dist/Sidebar/provider.js +110 -0
  212. package/dist/Sidebar/provider.js.map +1 -0
  213. package/dist/Sidebar/sidebar.d.ts +17 -0
  214. package/dist/Sidebar/sidebar.d.ts.map +1 -0
  215. package/dist/Sidebar/sidebar.js +51 -0
  216. package/dist/Sidebar/sidebar.js.map +1 -0
  217. package/dist/Sidebar/submenu.d.ts +13 -0
  218. package/dist/Sidebar/submenu.d.ts.map +1 -0
  219. package/dist/Sidebar/submenu.js +17 -0
  220. package/dist/Sidebar/submenu.js.map +1 -0
  221. package/dist/Sidebar/trigger.d.ts +9 -0
  222. package/dist/Sidebar/trigger.d.ts.map +1 -0
  223. package/dist/Sidebar/trigger.js +33 -0
  224. package/dist/Sidebar/trigger.js.map +1 -0
  225. package/dist/Sidebar.d.ts +14 -104
  226. package/dist/Sidebar.d.ts.map +1 -1
  227. package/dist/Sidebar.js +14 -300
  228. package/dist/Sidebar.js.map +1 -1
  229. package/dist/StatCard.d.ts +67 -9
  230. package/dist/StatCard.d.ts.map +1 -1
  231. package/dist/StatCard.js +111 -9
  232. package/dist/StatCard.js.map +1 -1
  233. package/dist/TransferList.native.d.ts.map +1 -1
  234. package/dist/TransferList.native.js +2 -1
  235. package/dist/TransferList.native.js.map +1 -1
  236. package/package.json +2 -2
  237. package/src/CheckboxGrid.native.tsx +2 -1
  238. package/src/Combobox.native.tsx +2 -1
  239. package/src/DataTable/column-filter.tsx +134 -0
  240. package/src/DataTable/column-header.tsx +67 -0
  241. package/src/DataTable/column-visibility.tsx +87 -0
  242. package/src/DataTable/index.ts +4 -0
  243. package/src/DataTable/pinning.ts +40 -0
  244. package/src/DataTable.tsx +14 -297
  245. package/src/Dialog.native.tsx +4 -2
  246. package/src/Form/building-blocks.tsx +97 -0
  247. package/src/Form/fields-choice.tsx +312 -0
  248. package/src/Form/fields-complex.tsx +195 -0
  249. package/src/Form/fields-date.tsx +195 -0
  250. package/src/Form/fields-text.tsx +218 -0
  251. package/src/Form/fields-toggle.tsx +123 -0
  252. package/src/Form/helpers.tsx +189 -0
  253. package/src/Form/types.ts +26 -0
  254. package/src/Form.tsx +91 -1308
  255. package/src/IconSidebar.tsx +20 -442
  256. package/src/MainSidebar/back-button.tsx +58 -0
  257. package/src/MainSidebar/breadcrumb.tsx +53 -0
  258. package/src/MainSidebar/columns.tsx +350 -0
  259. package/src/MainSidebar/command.tsx +404 -0
  260. package/src/MainSidebar/drilldown.tsx +373 -0
  261. package/src/MainSidebar/expanded.tsx +414 -0
  262. package/src/MainSidebar/floating.tsx +268 -0
  263. package/src/MainSidebar/helpers.ts +164 -0
  264. package/src/MainSidebar/hover.tsx +334 -0
  265. package/src/MainSidebar/index.tsx +191 -0
  266. package/src/MainSidebar/mobile.tsx +117 -0
  267. package/src/MainSidebar/motion.ts +64 -0
  268. package/src/MainSidebar/rail.tsx +137 -0
  269. package/src/MainSidebar/search.tsx +99 -0
  270. package/src/MainSidebar/types.ts +208 -0
  271. package/src/MainSidebar.tsx +15 -4
  272. package/src/NavigationMenu.tsx +1 -1
  273. package/src/RichTextEditor/theme.ts +43 -0
  274. package/src/RichTextEditor/toolbar-icons.tsx +40 -0
  275. package/src/RichTextEditor/toolbar.tsx +271 -0
  276. package/src/RichTextEditor.tsx +23 -371
  277. package/src/Select/content.tsx +111 -0
  278. package/src/Select/context.tsx +66 -0
  279. package/src/Select/item.tsx +97 -0
  280. package/src/Select/parts.tsx +43 -0
  281. package/src/Select/react-select.tsx +216 -0
  282. package/src/Select/root.tsx +75 -0
  283. package/src/Select/trigger.tsx +122 -0
  284. package/src/Select.tsx +34 -692
  285. package/src/Sidebar/context.tsx +72 -0
  286. package/src/Sidebar/group.tsx +69 -0
  287. package/src/Sidebar/icons.tsx +42 -0
  288. package/src/Sidebar/layout.tsx +64 -0
  289. package/src/Sidebar/menu.tsx +171 -0
  290. package/src/Sidebar/provider.tsx +224 -0
  291. package/src/Sidebar/sidebar.tsx +178 -0
  292. package/src/Sidebar/submenu.tsx +58 -0
  293. package/src/Sidebar/trigger.tsx +104 -0
  294. package/src/Sidebar.tsx +44 -927
  295. package/src/StatCard.tsx +365 -20
  296. package/src/TransferList.native.tsx +2 -1
  297. package/dist/TiptapEditor.d.ts +0 -24
  298. package/dist/TiptapEditor.d.ts.map +0 -1
  299. package/dist/TiptapEditor.js +0 -84
  300. package/dist/TiptapEditor.js.map +0 -1
@@ -0,0 +1,178 @@
1
+ 'use client';
2
+
3
+ /**
4
+ * Sidebar — the visual container. Three modes selected per context:
5
+ * - `collapsible="none"` → static `<nav>` at the configured width.
6
+ * - mobile → wrapped in the Sheet primitive.
7
+ * - desktop `contained` / `fixed` → either takes space in flow or is fixed
8
+ * to the viewport edge, with width transitions and offcanvas handling.
9
+ */
10
+ import { forwardRef, type HTMLAttributes } from 'react';
11
+ import { cn } from '../internal/cn.js';
12
+ import { Sheet, SheetContent } from '../Sheet.js';
13
+ import {
14
+ useSidebar,
15
+ type SidebarCollapsible,
16
+ type SidebarPosition,
17
+ type SidebarSide,
18
+ type SidebarVariant,
19
+ } from './context.js';
20
+
21
+ export interface SidebarProps extends HTMLAttributes<HTMLElement> {
22
+ side?: SidebarSide;
23
+ variant?: SidebarVariant;
24
+ collapsible?: SidebarCollapsible;
25
+ position?: SidebarPosition;
26
+ }
27
+
28
+ export const Sidebar = forwardRef<HTMLElement, SidebarProps>(function Sidebar(
29
+ { side, variant, collapsible, position, className, children, ...props },
30
+ ref,
31
+ ) {
32
+ const context = useSidebar();
33
+ const { isMobile, state, openMobile, setOpenMobile } = context;
34
+ const currentSide = side ?? context.side;
35
+ const currentVariant = variant ?? context.variant;
36
+ const currentCollapsible = collapsible ?? context.collapsible;
37
+ const currentPosition = position ?? context.position;
38
+ const isCollapsed = state === 'collapsed';
39
+ const isFloating = currentVariant === 'floating' || currentVariant === 'inset';
40
+ const isOffcanvasCollapsed = isCollapsed && currentCollapsible === 'offcanvas';
41
+ const isIconCollapsed = isCollapsed && currentCollapsible === 'icon';
42
+ const sidebarEdgeBorder = currentSide === 'right'
43
+ ? 'border-l border-sidebar-border'
44
+ : 'border-r border-sidebar-border';
45
+
46
+ if (currentCollapsible === 'none') {
47
+ return (
48
+ <nav
49
+ ref={ref}
50
+ aria-label={props['aria-label'] ?? 'Sidebar'}
51
+ data-sidebar="sidebar"
52
+ data-state={state}
53
+ data-collapsible=""
54
+ data-variant={currentVariant}
55
+ data-side={currentSide}
56
+ data-position={currentPosition}
57
+ className={cn(
58
+ 'flex h-full w-(--sidebar-width) flex-col bg-sidebar text-sidebar-foreground',
59
+ isFloating ? 'rounded-lg border border-sidebar-border shadow' : sidebarEdgeBorder,
60
+ className,
61
+ )}
62
+ {...props}
63
+ >
64
+ {children}
65
+ </nav>
66
+ );
67
+ }
68
+
69
+ if (isMobile) {
70
+ return (
71
+ <Sheet open={openMobile} onOpenChange={setOpenMobile}>
72
+ <SheetContent
73
+ data-sidebar="sidebar"
74
+ data-mobile="true"
75
+ className={cn(
76
+ 'w-(--sidebar-width-mobile) bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden',
77
+ className,
78
+ )}
79
+ side={currentSide}
80
+ {...props}
81
+ >
82
+ <nav aria-label={props['aria-label'] ?? 'Sidebar'} className="flex h-full w-full flex-col">
83
+ {children}
84
+ </nav>
85
+ </SheetContent>
86
+ </Sheet>
87
+ );
88
+ }
89
+
90
+ if (currentPosition === 'contained') {
91
+ return (
92
+ <div
93
+ data-sidebar="sidebar-container"
94
+ className={cn(
95
+ 'group peer relative hidden h-full shrink-0 overflow-hidden text-sidebar-foreground transition-[width] duration-200 ease-linear md:flex',
96
+ isOffcanvasCollapsed
97
+ ? 'w-0'
98
+ : isIconCollapsed
99
+ ? isFloating
100
+ ? 'w-[calc(var(--sidebar-width-icon)+theme(spacing.4))]'
101
+ : 'w-(--sidebar-width-icon)'
102
+ : 'w-(--sidebar-width)',
103
+ isFloating && !isOffcanvasCollapsed && 'p-2',
104
+ className,
105
+ )}
106
+ data-state={state}
107
+ data-collapsible={isCollapsed ? currentCollapsible : ''}
108
+ data-variant={currentVariant}
109
+ data-side={currentSide}
110
+ data-position={currentPosition}
111
+ >
112
+ <nav
113
+ ref={ref}
114
+ aria-label={props['aria-label'] ?? 'Sidebar'}
115
+ data-sidebar="sidebar"
116
+ className={cn(
117
+ 'flex h-full w-full min-w-0 flex-col bg-sidebar',
118
+ isFloating ? 'rounded-lg border border-sidebar-border shadow' : sidebarEdgeBorder,
119
+ )}
120
+ {...props}
121
+ >
122
+ {children}
123
+ </nav>
124
+ </div>
125
+ );
126
+ }
127
+
128
+ return (
129
+ <div
130
+ data-sidebar="sidebar-container"
131
+ className="group peer hidden md:block text-sidebar-foreground"
132
+ data-state={state}
133
+ data-collapsible={isCollapsed ? currentCollapsible : ''}
134
+ data-variant={currentVariant}
135
+ data-side={currentSide}
136
+ data-position={currentPosition}
137
+ >
138
+ <div
139
+ className={cn(
140
+ 'relative w-(--sidebar-width) bg-transparent transition-[width] duration-200 ease-linear',
141
+ 'group-data-[collapsible=offcanvas]:w-0',
142
+ 'group-data-[side=right]:rotate-180',
143
+ isFloating
144
+ ? 'group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+theme(spacing.4))]'
145
+ : 'group-data-[collapsible=icon]:w-(--sidebar-width-icon)',
146
+ )}
147
+ />
148
+ <div
149
+ className={cn(
150
+ 'fixed inset-y-0 z-10 hidden h-svh w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear md:flex',
151
+ currentSide === 'left'
152
+ ? 'left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]'
153
+ : 'right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]',
154
+ isFloating
155
+ ? 'p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+theme(spacing.4)+2px)]'
156
+ : cn(
157
+ 'group-data-[collapsible=icon]:w-(--sidebar-width-icon)',
158
+ 'border-sidebar-border',
159
+ currentSide === 'right' ? 'group-data-[variant=sidebar]:border-l' : 'group-data-[variant=sidebar]:border-r',
160
+ ),
161
+ className,
162
+ )}
163
+ {...props}
164
+ >
165
+ <nav
166
+ ref={ref}
167
+ aria-label={props['aria-label'] ?? 'Sidebar'}
168
+ data-sidebar="sidebar"
169
+ className={cn(
170
+ 'flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow',
171
+ )}
172
+ >
173
+ {children}
174
+ </nav>
175
+ </div>
176
+ </div>
177
+ );
178
+ });
@@ -0,0 +1,58 @@
1
+ 'use client';
2
+
3
+ /**
4
+ * Sub-menu pieces: SidebarMenuSub, SidebarMenuSubItem, SidebarMenuSubButton.
5
+ */
6
+ import { forwardRef, type AnchorHTMLAttributes, type HTMLAttributes } from 'react';
7
+ import { cn } from '../internal/cn.js';
8
+
9
+ export const SidebarMenuSub = forwardRef<HTMLUListElement, HTMLAttributes<HTMLUListElement>>(
10
+ function SidebarMenuSub({ className, ...props }, ref) {
11
+ return (
12
+ <ul
13
+ ref={ref}
14
+ data-sidebar="menu-sub"
15
+ className={cn(
16
+ 'mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5',
17
+ 'group-data-[collapsible=icon]:hidden',
18
+ className,
19
+ )}
20
+ {...props}
21
+ />
22
+ );
23
+ },
24
+ );
25
+
26
+ export const SidebarMenuSubItem = forwardRef<HTMLLIElement, HTMLAttributes<HTMLLIElement>>(
27
+ function SidebarMenuSubItem({ ...props }, ref) {
28
+ return <li ref={ref} {...props} />;
29
+ },
30
+ );
31
+
32
+ export interface SidebarMenuSubButtonProps extends AnchorHTMLAttributes<HTMLAnchorElement> {
33
+ asChild?: boolean;
34
+ size?: 'sm' | 'md';
35
+ isActive?: boolean;
36
+ }
37
+
38
+ export const SidebarMenuSubButton = forwardRef<HTMLAnchorElement, SidebarMenuSubButtonProps>(
39
+ function SidebarMenuSubButton({ asChild: _asChild, size = 'md', isActive, className, ...props }, ref) {
40
+ return (
41
+ <a
42
+ ref={ref}
43
+ data-sidebar="menu-sub-button"
44
+ data-size={size}
45
+ data-active={isActive}
46
+ className={cn(
47
+ 'flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground outline-none ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0',
48
+ 'data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground',
49
+ size === 'sm' && 'text-xs',
50
+ size === 'md' && 'text-sm',
51
+ 'group-data-[collapsible=icon]:hidden',
52
+ className,
53
+ )}
54
+ {...props}
55
+ />
56
+ );
57
+ },
58
+ );
@@ -0,0 +1,104 @@
1
+ 'use client';
2
+
3
+ /**
4
+ * Edge / chrome pieces: SidebarTrigger, SidebarRail, SidebarInset, SidebarInput.
5
+ */
6
+ import { forwardRef, type ComponentProps, type HTMLAttributes } from 'react';
7
+ import { cn } from '../internal/cn.js';
8
+ import { Button } from '../Button.js';
9
+ import { Input } from '../Input.js';
10
+ import { useSidebar } from './context.js';
11
+ import { PanelLeftIcon, PanelRightIcon } from './icons.js';
12
+
13
+ export const SidebarTrigger = forwardRef<
14
+ HTMLButtonElement,
15
+ ComponentProps<typeof Button>
16
+ >(function SidebarTrigger({ className, disabled, onClick, ...props }, ref) {
17
+ const { isMobile, open, openMobile, collapsible, side, toggleSidebar } = useSidebar();
18
+ const expanded = collapsible === 'none' ? true : isMobile ? openMobile : open;
19
+ const isDisabled = disabled || collapsible === 'none';
20
+
21
+ return (
22
+ <Button
23
+ ref={ref}
24
+ data-sidebar="trigger"
25
+ aria-expanded={expanded}
26
+ aria-disabled={isDisabled || undefined}
27
+ disabled={isDisabled}
28
+ variant="ghost"
29
+ size="icon"
30
+ className={cn('size-7', className)}
31
+ onClick={(e) => {
32
+ onClick?.(e);
33
+ if (collapsible === 'none') return;
34
+ toggleSidebar();
35
+ }}
36
+ {...props}
37
+ >
38
+ {side === 'right' ? <PanelRightIcon /> : <PanelLeftIcon />}
39
+ <span className="sr-only">Toggle Sidebar</span>
40
+ </Button>
41
+ );
42
+ });
43
+
44
+ export const SidebarRail = forwardRef<HTMLButtonElement, HTMLAttributes<HTMLButtonElement>>(
45
+ function SidebarRail({ className, ...props }, ref) {
46
+ const { toggleSidebar } = useSidebar();
47
+
48
+ return (
49
+ <button
50
+ ref={ref}
51
+ type="button"
52
+ data-sidebar="rail"
53
+ aria-label="Toggle Sidebar"
54
+ tabIndex={-1}
55
+ onClick={toggleSidebar}
56
+ title="Toggle Sidebar"
57
+ className={cn(
58
+ 'absolute inset-y-0 z-20 hidden w-4 transition-all ease-linear after:absolute after:inset-y-0 after:left-1/2 after:w-[2px] group-data-[side=left]:-right-4 group-data-[side=left]:-translate-x-1/2 group-data-[side=right]:-left-4 group-data-[side=right]:translate-x-1/2 sm:flex',
59
+ 'hover:after:bg-sidebar-border',
60
+ '[[data-side=left]_&]:cursor-w-resize [[data-side=right]_&]:cursor-e-resize',
61
+ '[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize',
62
+ 'group-data-[collapsible=offcanvas]:after:left-full group-data-[collapsible=offcanvas]:hover:bg-sidebar',
63
+ '[[data-side=left][data-collapsible=offcanvas]_&]:-right-2 [[data-side=left][data-collapsible=offcanvas]_&]:translate-x-0',
64
+ '[[data-side=right][data-collapsible=offcanvas]_&]:-left-2 [[data-side=right][data-collapsible=offcanvas]_&]:translate-x-0',
65
+ className,
66
+ )}
67
+ {...props}
68
+ />
69
+ );
70
+ },
71
+ );
72
+
73
+ export const SidebarInset = forwardRef<HTMLDivElement, HTMLAttributes<HTMLDivElement>>(
74
+ function SidebarInset({ className, ...props }, ref) {
75
+ return (
76
+ <main
77
+ ref={ref}
78
+ className={cn(
79
+ 'relative flex min-h-svh flex-1 flex-col bg-background',
80
+ 'peer-data-[variant=inset]:min-h-[calc(100svh-theme(spacing.4))] md:peer-data-[variant=inset]:m-2 md:peer-data-[side=left]:peer-data-[variant=inset]:ml-0 md:peer-data-[side=right]:peer-data-[variant=inset]:mr-0 md:peer-data-[side=left]:peer-data-[state=collapsed]:peer-data-[variant=inset]:ml-2 md:peer-data-[side=right]:peer-data-[state=collapsed]:peer-data-[variant=inset]:mr-2 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow',
81
+ className,
82
+ )}
83
+ {...props}
84
+ />
85
+ );
86
+ },
87
+ );
88
+
89
+ export const SidebarInput = forwardRef<
90
+ HTMLInputElement,
91
+ ComponentProps<typeof Input>
92
+ >(function SidebarInput({ className, ...props }, ref) {
93
+ return (
94
+ <Input
95
+ ref={ref}
96
+ data-sidebar="input"
97
+ className={cn(
98
+ 'h-8 w-full bg-background shadow-none focus-within:ring-2 focus-within:ring-sidebar-ring',
99
+ className,
100
+ )}
101
+ {...props}
102
+ />
103
+ );
104
+ });