@mihcm/ui 0.14.1 → 0.15.1

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 +150 -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 +166 -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,154 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ /**
4
+ * MainSidebar — `drilldown` variant.
5
+ *
6
+ * Default. Rail click opens a panel beside the rail; deeper levels replace
7
+ * the current panel; back/breadcrumb to step out. Layout reflows.
8
+ */
9
+ import { forwardRef, useEffect, useMemo, useRef, useState } from 'react';
10
+ import { AnimatePresence, motion, useReducedMotion } from 'motion/react';
11
+ import { cn } from '../internal/cn.js';
12
+ import { Rail } from './rail.js';
13
+ import { MenuSearch } from './search.js';
14
+ import { BackButton, CloseButton } from './back-button.js';
15
+ import { PathBreadcrumb } from './breadcrumb.js';
16
+ import { defaultMatcher, filterLevel, findItem, firstPanelItem, isOnPath, opensPanel, resolvePath, shouldWrapBadge } from './helpers.js';
17
+ import { slideVariants } from './motion.js';
18
+ function PanelRow({ item, active, onClick, showChevron, className, activeClassName }) {
19
+ return (_jsxs("button", { type: "button", onClick: onClick, disabled: item.disabled, "aria-current": active ? 'page' : undefined, className: cn('group flex w-full items-center gap-2.5 rounded-md px-2.5 py-2 text-left text-sm transition-colors', 'hover:bg-card-foreground/10', 'focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring', 'disabled:cursor-not-allowed disabled:opacity-50', active && 'bg-accent text-accent-foreground font-medium hover:bg-accent hover:text-accent-foreground', active && activeClassName, className), children: [item.icon ? (_jsx("span", { className: "grid size-5 shrink-0 place-items-center text-card-foreground/70 group-hover:text-card-foreground [&_svg]:size-full", "aria-hidden": "true", children: item.icon })) : null, _jsx("span", { className: "min-w-0 flex-1 truncate", children: item.label }), item.badge != null && item.badge !== false ? (shouldWrapBadge(item.badge) ? (_jsx("span", { className: "ml-auto inline-flex h-5 min-w-5 items-center justify-center rounded-full bg-current/15 px-1.5 text-xs font-medium text-current", children: item.badge })) : (_jsx("span", { className: "ml-auto inline-flex shrink-0 items-center", children: item.badge }))) : null, showChevron ? (_jsx("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", className: "size-3.5 shrink-0 text-card-foreground/70", "aria-hidden": "true", children: _jsx("path", { d: "m9 18 6-6-6-6", strokeLinecap: "round", strokeLinejoin: "round" }) })) : null] }));
20
+ }
21
+ export const DrilldownSidebar = forwardRef(function DrilldownSidebar({ items, activeKey, expanded, defaultExpanded = false, onExpandedChange, onItemSelect, header, footer, panelHeader, panelFooter, search = false, searchPlaceholder, onSearchChange, side = 'left', density = 'comfortable', panelWidth = 288, motionPreset = 'expressive', closeOnOutsideClick = true, railClassName, panelClassName, itemClassName, activeItemClassName, backLabel = 'Back', expandedLabel = 'Collapse menu', className, ...rest }, ref) {
22
+ const reduceMotion = useReducedMotion();
23
+ const effectivePreset = reduceMotion ? 'subtle' : motionPreset;
24
+ const [internalExpanded, setInternalExpanded] = useState(defaultExpanded);
25
+ const isExpanded = expanded ?? internalExpanded;
26
+ const rootItem = useMemo(() => firstPanelItem(items, activeKey), [activeKey, items]);
27
+ const [pathKeys, setPathKeys] = useState([]);
28
+ const path = useMemo(() => {
29
+ const resolved = resolvePath(items, pathKeys);
30
+ return resolved.length ? resolved : rootItem ? [rootItem] : [];
31
+ }, [items, pathKeys, rootItem]);
32
+ const current = path.at(-1);
33
+ const [query, setQuery] = useState('');
34
+ const searchEnabled = search !== false;
35
+ const searchCfg = typeof search === 'object' ? search : undefined;
36
+ const matcher = searchCfg?.matcher ?? defaultMatcher;
37
+ const currentItems = current?.children ?? items;
38
+ const filtered = filterLevel(currentItems, query, matcher);
39
+ function resetDeepState() {
40
+ setPathKeys([]);
41
+ setQuery('');
42
+ }
43
+ function setExpanded(next) {
44
+ if (expanded === undefined)
45
+ setInternalExpanded(next);
46
+ if (!next)
47
+ resetDeepState();
48
+ onExpandedChange?.(next);
49
+ }
50
+ function closePanel() {
51
+ resetDeepState();
52
+ setExpanded(false);
53
+ }
54
+ const panelRef = useRef(null);
55
+ const railRef = useRef(null);
56
+ /* Esc + outside-click close the panel. */
57
+ useEffect(() => {
58
+ if (!isExpanded)
59
+ return;
60
+ function onKey(e) {
61
+ if (e.key === 'Escape')
62
+ closePanel();
63
+ }
64
+ function onPointerDown(e) {
65
+ if (!closeOnOutsideClick)
66
+ return;
67
+ const target = e.target;
68
+ if (panelRef.current?.contains(target) || railRef.current?.contains(target))
69
+ return;
70
+ closePanel();
71
+ }
72
+ document.addEventListener('keydown', onKey);
73
+ document.addEventListener('pointerdown', onPointerDown);
74
+ return () => {
75
+ document.removeEventListener('keydown', onKey);
76
+ document.removeEventListener('pointerdown', onPointerDown);
77
+ };
78
+ // eslint-disable-next-line react-hooks/exhaustive-deps
79
+ }, [isExpanded, closeOnOutsideClick]);
80
+ /*
81
+ * Move focus into the panel when it opens — but skip the initial
82
+ * mount (covers `defaultExpanded` and SSR hydration). Otherwise the
83
+ * browser scrolls the page to bring the just-focused input into view,
84
+ * landing the user halfway down the docs page. We also pass
85
+ * `preventScroll: true` as a belt-and-braces guard.
86
+ */
87
+ const focusInitialisedRef = useRef(false);
88
+ useEffect(() => {
89
+ if (!isExpanded) {
90
+ focusInitialisedRef.current = true;
91
+ return;
92
+ }
93
+ if (!focusInitialisedRef.current) {
94
+ focusInitialisedRef.current = true;
95
+ return;
96
+ }
97
+ const id = window.setTimeout(() => {
98
+ const focusable = panelRef.current?.querySelector('input, [role="searchbox"], button:not([disabled])');
99
+ focusable?.focus({ preventScroll: true });
100
+ }, 0);
101
+ return () => window.clearTimeout(id);
102
+ }, [isExpanded]);
103
+ function selectRailItem(item) {
104
+ if (item.disabled)
105
+ return;
106
+ onItemSelect?.(item.key, item);
107
+ if (opensPanel(item)) {
108
+ /* Toggle close when clicking the rail icon for the panel that's already open. */
109
+ if (isExpanded && pathKeys[0] === item.key) {
110
+ setExpanded(false);
111
+ return;
112
+ }
113
+ setPathKeys([item.key]);
114
+ setExpanded(true);
115
+ setQuery('');
116
+ }
117
+ else {
118
+ setExpanded(false);
119
+ }
120
+ }
121
+ function selectPanelItem(item) {
122
+ if (item.disabled)
123
+ return;
124
+ onItemSelect?.(item.key, item);
125
+ if (opensPanel(item)) {
126
+ setPathKeys((prev) => (prev.at(-1) === item.key ? prev : [...prev, item.key]));
127
+ setQuery('');
128
+ }
129
+ }
130
+ function goBack() {
131
+ setPathKeys((prev) => prev.slice(0, -1));
132
+ setQuery('');
133
+ }
134
+ function updateQuery(next) {
135
+ setQuery(next);
136
+ onSearchChange?.(next);
137
+ }
138
+ const railOffset = density === 'compact' ? '3rem' : '3.5rem';
139
+ return (_jsxs("div", { ref: ref, className: cn('relative h-full', className), ...rest, children: [_jsx(Rail, { ref: railRef, items: items, activeKey: activeKey, density: density, side: side, header: header, footer: footer, itemClassName: itemClassName, activeItemClassName: activeItemClassName, className: railClassName, onItemSelect: selectRailItem, openPanelKey: isExpanded ? current?.key : undefined }), _jsx(AnimatePresence, { initial: false, mode: "wait", children: isExpanded && current ? (_jsx(motion.aside, { ref: panelRef, variants: slideVariants(effectivePreset, side === 'right' ? 'right' : 'left'), initial: "initial", animate: "animate", exit: "exit", role: "menu", "aria-label": current.label, style: {
140
+ width: typeof panelWidth === 'number' ? `${panelWidth}px` : panelWidth,
141
+ [side === 'right' ? 'right' : 'left']: railOffset,
142
+ }, className: cn('absolute top-0 z-10 flex h-full min-w-0 flex-col bg-card text-card-foreground shadow-xl', side === 'right' ? 'border-l border-border' : 'border-r border-border', panelClassName), children: _jsxs("div", { className: "flex h-full flex-col", children: [_jsxs("div", { className: "border-b border-border px-4 py-3", children: [panelHeader ?? (_jsxs("div", { className: "flex items-start justify-between gap-3", children: [_jsxs("div", { className: "min-w-0", children: [path.length > 1 ? (_jsxs(_Fragment, { children: [_jsx(PathBreadcrumb, { path: path, onJump: (depth) => setPathKeys((prev) => prev.slice(0, depth + 1)), className: "mb-1" }), _jsx(BackButton, { onClick: goBack, label: backLabel, className: "mb-1 -ml-1.5" })] })) : null, _jsx("div", { className: "truncate text-base font-semibold text-card-foreground", children: current.label }), current.description ? (_jsx("p", { className: "mt-0.5 text-xs text-card-foreground/70", children: current.description })) : null] }), _jsx(CloseButton, { onClick: closePanel, label: expandedLabel })] })), searchEnabled ? (_jsx("div", { className: "mt-3", children: _jsx(MenuSearch, { value: query, onValueChange: updateQuery, placeholder: searchCfg?.placeholder ?? searchPlaceholder ?? `Search ${current.label}…`, tone: "onBrand" }) })) : null] }), _jsx(PanelList, { items: filtered, allItems: currentItems, query: query, noResultsLabel: searchCfg?.noResultsLabel, activeKey: activeKey, onItemSelect: selectPanelItem, itemClassName: itemClassName, activeItemClassName: activeItemClassName, pathKeys: pathKeys }), panelFooter ? (_jsx("div", { className: "mt-auto border-t border-border px-4 py-3", children: panelFooter })) : null] }) }, current.key + ':' + path.length)) : null })] }));
143
+ });
144
+ function PanelList({ items, allItems, query, noResultsLabel, activeKey, onItemSelect, itemClassName, activeItemClassName, pathKeys, }) {
145
+ if (items.length === 0 && query) {
146
+ return (_jsx("div", { className: "px-4 py-8 text-center text-sm text-card-foreground/70", children: noResultsLabel ?? `No items match "${query}".` }));
147
+ }
148
+ void allItems;
149
+ return (_jsx("div", { className: "flex-1 overflow-y-auto p-2", children: items.map((item) => {
150
+ const onActivePath = isOnPath(item, activeKey) || pathKeys.includes(item.key);
151
+ return (_jsx(PanelRow, { item: item, active: onActivePath, onClick: () => onItemSelect(item), showChevron: opensPanel(item), className: itemClassName, activeClassName: activeItemClassName }, item.key));
152
+ }) }));
153
+ }
154
+ //# sourceMappingURL=drilldown.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"drilldown.js","sourceRoot":"","sources":["../../src/MainSidebar/drilldown.tsx"],"names":[],"mappings":"AAAA,YAAY,CAAC;;AAEb;;;;;GAKG;AACH,OAAO,EAAE,UAAU,EAAE,SAAS,EAAE,OAAO,EAAE,MAAM,EAAE,QAAQ,EAAkB,MAAM,OAAO,CAAC;AACzF,OAAO,EAAE,eAAe,EAAE,MAAM,EAAE,gBAAgB,EAAE,MAAM,cAAc,CAAC;AACzE,OAAO,EAAE,EAAE,EAAE,MAAM,mBAAmB,CAAC;AACvC,OAAO,EAAE,IAAI,EAAE,MAAM,WAAW,CAAC;AACjC,OAAO,EAAE,UAAU,EAAE,MAAM,aAAa,CAAC;AACzC,OAAO,EAAE,UAAU,EAAE,WAAW,EAAE,MAAM,kBAAkB,CAAC;AAC3D,OAAO,EAAE,cAAc,EAAE,MAAM,iBAAiB,CAAC;AACjD,OAAO,EAAE,cAAc,EAAE,WAAW,EAAE,QAAQ,EAAE,cAAc,EAAE,QAAQ,EAAE,UAAU,EAAE,WAAW,EAAE,eAAe,EAAE,MAAM,cAAc,CAAC;AACzI,OAAO,EAAE,aAAa,EAAE,MAAM,aAAa,CAAC;AAY5C,SAAS,QAAQ,CAAC,EAAE,IAAI,EAAE,MAAM,EAAE,OAAO,EAAE,WAAW,EAAE,SAAS,EAAE,eAAe,EAAiB;IACjG,OAAO,CACL,kBACE,IAAI,EAAC,QAAQ,EACb,OAAO,EAAE,OAAO,EAChB,QAAQ,EAAE,IAAI,CAAC,QAAQ,kBACT,MAAM,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,EACzC,SAAS,EAAE,EAAE,CACX,mGAAmG,EACnG,6BAA6B,EAC7B,yEAAyE,EACzE,iDAAiD,EACjD,MAAM,IAAI,2FAA2F,EACrG,MAAM,IAAI,eAAe,EACzB,SAAS,CACV,aAEA,IAAI,CAAC,IAAI,CAAC,CAAC,CAAC,CACX,eAAM,SAAS,EAAC,oHAAoH,iBAAa,MAAM,YACpJ,IAAI,CAAC,IAAI,GACL,CACR,CAAC,CAAC,CAAC,IAAI,EACR,eAAM,SAAS,EAAC,yBAAyB,YAAE,IAAI,CAAC,KAAK,GAAQ,EAC5D,IAAI,CAAC,KAAK,IAAI,IAAI,IAAI,IAAI,CAAC,KAAK,KAAK,KAAK,CAAC,CAAC,CAAC,CAC5C,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,CAC5B,eAAM,SAAS,EAAC,gIAAgI,YAC7I,IAAI,CAAC,KAAK,GACN,CACR,CAAC,CAAC,CAAC,CACF,eAAM,SAAS,EAAC,2CAA2C,YAAE,IAAI,CAAC,KAAK,GAAQ,CAChF,CACF,CAAC,CAAC,CAAC,IAAI,EACP,WAAW,CAAC,CAAC,CAAC,CACb,cAAK,OAAO,EAAC,WAAW,EAAC,IAAI,EAAC,MAAM,EAAC,MAAM,EAAC,cAAc,EAAC,WAAW,EAAC,GAAG,EAAC,SAAS,EAAC,2CAA2C,iBAAa,MAAM,YACjJ,eAAM,CAAC,EAAC,eAAe,EAAC,aAAa,EAAC,OAAO,EAAC,cAAc,EAAC,OAAO,GAAG,GACnE,CACP,CAAC,CAAC,CAAC,IAAI,IACD,CACV,CAAC;AACJ,CAAC;AAED,MAAM,CAAC,MAAM,gBAAgB,GAAG,UAAU,CAAgC,SAAS,gBAAgB,CACjG,EACE,KAAK,EACL,SAAS,EACT,QAAQ,EACR,eAAe,GAAG,KAAK,EACvB,gBAAgB,EAChB,YAAY,EACZ,MAAM,EACN,MAAM,EACN,WAAW,EACX,WAAW,EACX,MAAM,GAAG,KAAK,EACd,iBAAiB,EACjB,cAAc,EACd,IAAI,GAAG,MAAM,EACb,OAAO,GAAG,aAAa,EACvB,UAAU,GAAG,GAAG,EAChB,YAAY,GAAG,YAAY,EAC3B,mBAAmB,GAAG,IAAI,EAC1B,aAAa,EACb,cAAc,EACd,aAAa,EACb,mBAAmB,EACnB,SAAS,GAAG,MAAM,EAClB,aAAa,GAAG,eAAe,EAC/B,SAAS,EACT,GAAG,IAAI,EACR,EACD,GAAG;IAEH,MAAM,YAAY,GAAG,gBAAgB,EAAE,CAAC;IACxC,MAAM,eAAe,GAAG,YAAY,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,YAAY,CAAC;IAE/D,MAAM,CAAC,gBAAgB,EAAE,mBAAmB,CAAC,GAAG,QAAQ,CAAC,eAAe,CAAC,CAAC;IAC1E,MAAM,UAAU,GAAG,QAAQ,IAAI,gBAAgB,CAAC;IAEhD,MAAM,QAAQ,GAAG,OAAO,CAAC,GAAG,EAAE,CAAC,cAAc,CAAC,KAAK,EAAE,SAAS,CAAC,EAAE,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC;IACrF,MAAM,CAAC,QAAQ,EAAE,WAAW,CAAC,GAAG,QAAQ,CAAW,EAAE,CAAC,CAAC;IACvD,MAAM,IAAI,GAAG,OAAO,CAAC,GAAG,EAAE;QACxB,MAAM,QAAQ,GAAG,WAAW,CAAC,KAAK,EAAE,QAAQ,CAAC,CAAC;QAC9C,OAAO,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC;IACjE,CAAC,EAAE,CAAC,KAAK,EAAE,QAAQ,EAAE,QAAQ,CAAC,CAAC,CAAC;IAEhC,MAAM,OAAO,GAAG,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;IAC5B,MAAM,CAAC,KAAK,EAAE,QAAQ,CAAC,GAAG,QAAQ,CAAC,EAAE,CAAC,CAAC;IACvC,MAAM,aAAa,GAAG,MAAM,KAAK,KAAK,CAAC;IACvC,MAAM,SAAS,GAAG,OAAO,MAAM,KAAK,QAAQ,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,SAAS,CAAC;IAClE,MAAM,OAAO,GAAG,SAAS,EAAE,OAAO,IAAI,cAAc,CAAC;IACrD,MAAM,YAAY,GAAG,OAAO,EAAE,QAAQ,IAAI,KAAK,CAAC;IAChD,MAAM,QAAQ,GAAG,WAAW,CAAC,YAAY,EAAE,KAAK,EAAE,OAAO,CAAC,CAAC;IAE3D,SAAS,cAAc;QACrB,WAAW,CAAC,EAAE,CAAC,CAAC;QAChB,QAAQ,CAAC,EAAE,CAAC,CAAC;IACf,CAAC;IAED,SAAS,WAAW,CAAC,IAAa;QAChC,IAAI,QAAQ,KAAK,SAAS;YAAE,mBAAmB,CAAC,IAAI,CAAC,CAAC;QACtD,IAAI,CAAC,IAAI;YAAE,cAAc,EAAE,CAAC;QAC5B,gBAAgB,EAAE,CAAC,IAAI,CAAC,CAAC;IAC3B,CAAC;IAED,SAAS,UAAU;QACjB,cAAc,EAAE,CAAC;QACjB,WAAW,CAAC,KAAK,CAAC,CAAC;IACrB,CAAC;IAED,MAAM,QAAQ,GAAG,MAAM,CAAc,IAAI,CAAC,CAAC;IAC3C,MAAM,OAAO,GAAG,MAAM,CAAc,IAAI,CAAC,CAAC;IAE1C,0CAA0C;IAC1C,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,UAAU;YAAE,OAAO;QACxB,SAAS,KAAK,CAAC,CAAgB;YAC7B,IAAI,CAAC,CAAC,GAAG,KAAK,QAAQ;gBAAE,UAAU,EAAE,CAAC;QACvC,CAAC;QACD,SAAS,aAAa,CAAC,CAAe;YACpC,IAAI,CAAC,mBAAmB;gBAAE,OAAO;YACjC,MAAM,MAAM,GAAG,CAAC,CAAC,MAAc,CAAC;YAChC,IAAI,QAAQ,CAAC,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC,IAAI,OAAO,CAAC,OAAO,EAAE,QAAQ,CAAC,MAAM,CAAC;gBAAE,OAAO;YACpF,UAAU,EAAE,CAAC;QACf,CAAC;QACD,QAAQ,CAAC,gBAAgB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;QAC5C,QAAQ,CAAC,gBAAgB,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;QACxD,OAAO,GAAG,EAAE;YACV,QAAQ,CAAC,mBAAmB,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC;YAC/C,QAAQ,CAAC,mBAAmB,CAAC,aAAa,EAAE,aAAa,CAAC,CAAC;QAC7D,CAAC,CAAC;QACF,uDAAuD;IACzD,CAAC,EAAE,CAAC,UAAU,EAAE,mBAAmB,CAAC,CAAC,CAAC;IAEtC;;;;;;OAMG;IACH,MAAM,mBAAmB,GAAG,MAAM,CAAC,KAAK,CAAC,CAAC;IAC1C,SAAS,CAAC,GAAG,EAAE;QACb,IAAI,CAAC,UAAU,EAAE,CAAC;YAChB,mBAAmB,CAAC,OAAO,GAAG,IAAI,CAAC;YACnC,OAAO;QACT,CAAC;QACD,IAAI,CAAC,mBAAmB,CAAC,OAAO,EAAE,CAAC;YACjC,mBAAmB,CAAC,OAAO,GAAG,IAAI,CAAC;YACnC,OAAO;QACT,CAAC;QACD,MAAM,EAAE,GAAG,MAAM,CAAC,UAAU,CAAC,GAAG,EAAE;YAChC,MAAM,SAAS,GAAG,QAAQ,CAAC,OAAO,EAAE,aAAa,CAC/C,mDAAmD,CACpD,CAAC;YACF,SAAS,EAAE,KAAK,CAAC,EAAE,aAAa,EAAE,IAAI,EAAE,CAAC,CAAC;QAC5C,CAAC,EAAE,CAAC,CAAC,CAAC;QACN,OAAO,GAAG,EAAE,CAAC,MAAM,CAAC,YAAY,CAAC,EAAE,CAAC,CAAC;IACvC,CAAC,EAAE,CAAC,UAAU,CAAC,CAAC,CAAC;IAEjB,SAAS,cAAc,CAAC,IAAqB;QAC3C,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,YAAY,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QAC/B,IAAI,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACrB,iFAAiF;YACjF,IAAI,UAAU,IAAI,QAAQ,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,GAAG,EAAE,CAAC;gBAC3C,WAAW,CAAC,KAAK,CAAC,CAAC;gBACnB,OAAO;YACT,CAAC;YACD,WAAW,CAAC,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC;YACxB,WAAW,CAAC,IAAI,CAAC,CAAC;YAClB,QAAQ,CAAC,EAAE,CAAC,CAAC;QACf,CAAC;aAAM,CAAC;YACN,WAAW,CAAC,KAAK,CAAC,CAAC;QACrB,CAAC;IACH,CAAC;IAED,SAAS,eAAe,CAAC,IAAqB;QAC5C,IAAI,IAAI,CAAC,QAAQ;YAAE,OAAO;QAC1B,YAAY,EAAE,CAAC,IAAI,CAAC,GAAG,EAAE,IAAI,CAAC,CAAC;QAC/B,IAAI,UAAU,CAAC,IAAI,CAAC,EAAE,CAAC;YACrB,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,KAAK,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC,GAAG,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;YAC/E,QAAQ,CAAC,EAAE,CAAC,CAAC;QACf,CAAC;IACH,CAAC;IAED,SAAS,MAAM;QACb,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,CAAC,CAAC;QACzC,QAAQ,CAAC,EAAE,CAAC,CAAC;IACf,CAAC;IAED,SAAS,WAAW,CAAC,IAAY;QAC/B,QAAQ,CAAC,IAAI,CAAC,CAAC;QACf,cAAc,EAAE,CAAC,IAAI,CAAC,CAAC;IACzB,CAAC;IAED,MAAM,UAAU,GAAG,OAAO,KAAK,SAAS,CAAC,CAAC,CAAC,MAAM,CAAC,CAAC,CAAC,QAAQ,CAAC;IAC7D,OAAO,CACL,eACE,GAAG,EAAE,GAAY,EACjB,SAAS,EAAE,EAAE,CAAC,iBAAiB,EAAE,SAAS,CAAC,KACvC,IAAI,aAER,KAAC,IAAI,IACH,GAAG,EAAE,OAAO,EACZ,KAAK,EAAE,KAAK,EACZ,SAAS,EAAE,SAAS,EACpB,OAAO,EAAE,OAAO,EAChB,IAAI,EAAE,IAAI,EACV,MAAM,EAAE,MAAM,EACd,MAAM,EAAE,MAAM,EACd,aAAa,EAAE,aAAa,EAC5B,mBAAmB,EAAE,mBAAmB,EACxC,SAAS,EAAE,aAAa,EACxB,YAAY,EAAE,cAAc,EAC5B,YAAY,EAAE,UAAU,CAAC,CAAC,CAAC,OAAO,EAAE,GAAG,CAAC,CAAC,CAAC,SAAS,GACnD,EAEF,KAAC,eAAe,IAAC,OAAO,EAAE,KAAK,EAAE,IAAI,EAAC,MAAM,YACzC,UAAU,IAAI,OAAO,CAAC,CAAC,CAAC,CACvB,KAAC,MAAM,CAAC,KAAK,IAEX,GAAG,EAAE,QAAQ,EACb,QAAQ,EAAE,aAAa,CAAC,eAAe,EAAE,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,EAC7E,OAAO,EAAC,SAAS,EACjB,OAAO,EAAC,SAAS,EACjB,IAAI,EAAC,MAAM,EACX,IAAI,EAAC,MAAM,gBACC,OAAO,CAAC,KAAK,EACzB,KAAK,EAAE;wBACL,KAAK,EAAE,OAAO,UAAU,KAAK,QAAQ,CAAC,CAAC,CAAC,GAAG,UAAU,IAAI,CAAC,CAAC,CAAC,UAAU;wBACtE,CAAC,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,EAAE,UAAU;qBAClD,EACD,SAAS,EAAE,EAAE,CACX,yFAAyF,EACzF,IAAI,KAAK,OAAO,CAAC,CAAC,CAAC,wBAAwB,CAAC,CAAC,CAAC,wBAAwB,EACtE,cAAc,CACf,YAED,eAAK,SAAS,EAAC,sBAAsB,aACnC,eAAK,SAAS,EAAC,kCAAkC,aAC9C,WAAW,IAAI,CACd,eAAK,SAAS,EAAC,wCAAwC,aACrD,eAAK,SAAS,EAAC,SAAS,aACrB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,CAAC,CAAC,CACjB,8BACE,KAAC,cAAc,IACb,IAAI,EAAE,IAAI,EACV,MAAM,EAAE,CAAC,KAAK,EAAE,EAAE,CAAC,WAAW,CAAC,CAAC,IAAI,EAAE,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,EAAE,KAAK,GAAG,CAAC,CAAC,CAAC,EAClE,SAAS,EAAC,MAAM,GAChB,EACF,KAAC,UAAU,IAAC,OAAO,EAAE,MAAM,EAAE,KAAK,EAAE,SAAS,EAAE,SAAS,EAAC,cAAc,GAAG,IACzE,CACJ,CAAC,CAAC,CAAC,IAAI,EACR,cAAK,SAAS,EAAC,uDAAuD,YAAE,OAAO,CAAC,KAAK,GAAO,EAC3F,OAAO,CAAC,WAAW,CAAC,CAAC,CAAC,CACrB,YAAG,SAAS,EAAC,wCAAwC,YAAE,OAAO,CAAC,WAAW,GAAK,CAChF,CAAC,CAAC,CAAC,IAAI,IACJ,EACN,KAAC,WAAW,IAAC,OAAO,EAAE,UAAU,EAAE,KAAK,EAAE,aAAa,GAAI,IACtD,CACP,EACA,aAAa,CAAC,CAAC,CAAC,CACf,cAAK,SAAS,EAAC,MAAM,YACnB,KAAC,UAAU,IACT,KAAK,EAAE,KAAK,EACZ,aAAa,EAAE,WAAW,EAC1B,WAAW,EAAE,SAAS,EAAE,WAAW,IAAI,iBAAiB,IAAI,UAAU,OAAO,CAAC,KAAK,GAAG,EAExF,IAAI,EAAC,SAAS,GACZ,GACE,CACP,CAAC,CAAC,CAAC,IAAI,IACJ,EAEN,KAAC,SAAS,IACR,KAAK,EAAE,QAAQ,EACf,QAAQ,EAAE,YAAY,EACtB,KAAK,EAAE,KAAK,EACZ,cAAc,EAAE,SAAS,EAAE,cAAc,EACzC,SAAS,EAAE,SAAS,EACpB,YAAY,EAAE,eAAe,EAC7B,aAAa,EAAE,aAAa,EAC5B,mBAAmB,EAAE,mBAAmB,EACxC,QAAQ,EAAE,QAAQ,GAClB,EAED,WAAW,CAAC,CAAC,CAAC,CACb,cAAK,SAAS,EAAC,0CAA0C,YAAE,WAAW,GAAO,CAC9E,CAAC,CAAC,CAAC,IAAI,IACJ,IArED,OAAO,CAAC,GAAG,GAAG,GAAG,GAAG,IAAI,CAAC,MAAM,CAsEvB,CAChB,CAAC,CAAC,CAAC,IAAI,GACQ,IACd,CACP,CAAC;AACJ,CAAC,CAAC,CAAC;AAEH,SAAS,SAAS,CAAC,EACjB,KAAK,EACL,QAAQ,EACR,KAAK,EACL,cAAc,EACd,SAAS,EACT,YAAY,EACZ,aAAa,EACb,mBAAmB,EACnB,QAAQ,GAWT;IACC,IAAI,KAAK,CAAC,MAAM,KAAK,CAAC,IAAI,KAAK,EAAE,CAAC;QAChC,OAAO,CACL,cAAK,SAAS,EAAC,uDAAuD,YACnE,cAAc,IAAI,mBAAmB,KAAK,IAAI,GAC3C,CACP,CAAC;IACJ,CAAC;IACD,KAAK,QAAQ,CAAC;IACd,OAAO,CACL,cAAK,SAAS,EAAC,4BAA4B,YACxC,KAAK,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,EAAE;YAClB,MAAM,YAAY,GAAG,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,QAAQ,CAAC,QAAQ,CAAC,IAAI,CAAC,GAAG,CAAC,CAAC;YAC9E,OAAO,CACL,KAAC,QAAQ,IAEP,IAAI,EAAE,IAAI,EACV,MAAM,EAAE,YAAY,EACpB,OAAO,EAAE,GAAG,EAAE,CAAC,YAAY,CAAC,IAAI,CAAC,EACjC,WAAW,EAAE,UAAU,CAAC,IAAI,CAAC,EAC7B,SAAS,EAAE,aAAa,EACxB,eAAe,EAAE,mBAAmB,IAN/B,IAAI,CAAC,GAAG,CAOb,CACH,CAAC;QACJ,CAAC,CAAC,GACE,CACP,CAAC;AACJ,CAAC"}
@@ -0,0 +1,7 @@
1
+ import type { MainSidebarProps } from './types.js';
2
+ interface ExpandedSidebarInternalProps extends MainSidebarProps {
3
+ onCollapse: () => void;
4
+ }
5
+ export declare const ExpandedSidebar: import("react").ForwardRefExoticComponent<ExpandedSidebarInternalProps & import("react").RefAttributes<HTMLElement>>;
6
+ export {};
7
+ //# sourceMappingURL=expanded.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"expanded.d.ts","sourceRoot":"","sources":["../../src/MainSidebar/expanded.tsx"],"names":[],"mappings":"AAuBA,OAAO,KAAK,EAEV,gBAAgB,EACjB,MAAM,YAAY,CAAC;AA2KpB,UAAU,4BAA6B,SAAQ,gBAAgB;IAC7D,UAAU,EAAE,MAAM,IAAI,CAAC;CACxB;AAyBD,eAAO,MAAM,eAAe,sHA6L1B,CAAC"}
@@ -0,0 +1,102 @@
1
+ 'use client';
2
+ import { jsx as _jsx, jsxs as _jsxs, Fragment as _Fragment } from "react/jsx-runtime";
3
+ /**
4
+ * MainSidebar — shared "expanded" rendering.
5
+ *
6
+ * When `collapsed` is false, every variant routes through this component:
7
+ * a wide vertical sidebar showing icon + label rows, with inline accordion
8
+ * expansion for parent items. This is the shadcn `collapsible="icon"`
9
+ * expanded shape.
10
+ *
11
+ * When the user toggles the collapse button (or `collapsed` flips to true),
12
+ * the dispatcher swaps this out for the variant's narrow rail rendering.
13
+ */
14
+ import { forwardRef, useMemo, useState } from 'react';
15
+ import { cn } from '../internal/cn.js';
16
+ import { MenuSearch } from './search.js';
17
+ import { defaultMatcher, flatMatchTree, isOnPath, opensPanel, shouldWrapBadge, } from './helpers.js';
18
+ function ExpandedRow({ item, depth, activeKey, onSelect, expandedKeys, toggleExpanded, itemClassName, activeItemClassName, }) {
19
+ const hasChildren = opensPanel(item);
20
+ const onActivePath = isOnPath(item, activeKey);
21
+ const isActive = item.key === activeKey;
22
+ const isExpanded = expandedKeys.has(item.key);
23
+ return (_jsxs(_Fragment, { children: [_jsxs("button", { type: "button", disabled: item.disabled, "aria-current": isActive ? 'page' : undefined, "aria-expanded": hasChildren ? isExpanded : undefined, onClick: () => {
24
+ if (hasChildren)
25
+ toggleExpanded(item.key);
26
+ onSelect(item);
27
+ },
28
+ /*
29
+ * Password-manager browser extensions (Dashlane, 1Password, etc.)
30
+ * decorate form/input buttons with their own `data-*` attributes
31
+ * after server render but before React hydration. That trips
32
+ * React's hydration mismatch warning. We're not rendering an
33
+ * input — just a navigation button — so suppress the diff on
34
+ * unrelated attribute injections.
35
+ */
36
+ suppressHydrationWarning: true, className: cn('group flex w-full items-center gap-2 rounded-md py-2 pl-2.5 pr-2.5 text-left text-sm text-primary-foreground/90 transition-colors', 'hover:bg-primary-foreground/10 hover:text-primary-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-primary-foreground/60', 'disabled:cursor-not-allowed disabled:opacity-50',
37
+ /* Active or breadcrumb-on-path */
38
+ (isActive || onActivePath) && 'bg-accent text-accent-foreground font-medium hover:bg-accent hover:text-accent-foreground', (isActive || onActivePath) && activeItemClassName, itemClassName), children: [item.icon ? (_jsx("span", { className: "grid size-5 shrink-0 place-items-center text-inherit [&_svg]:size-full", "aria-hidden": "true", children: item.icon })) : null, _jsx("span", { className: "min-w-0 flex-1 truncate", children: item.label }), item.badge != null && item.badge !== false ? (shouldWrapBadge(item.badge) ? (_jsx("span", { className: "inline-flex h-5 min-w-5 items-center justify-center rounded-full bg-current/15 px-1.5 text-xs font-medium text-current", children: item.badge })) : (_jsx("span", { className: "inline-flex shrink-0 items-center", children: item.badge }))) : null, hasChildren ? (_jsx("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", className: cn('size-3.5 shrink-0 transition-transform duration-200', isExpanded && 'rotate-90'), "aria-hidden": "true", children: _jsx("path", { d: "m9 18 6-6-6-6", strokeLinecap: "round", strokeLinejoin: "round" }) })) : null] }), hasChildren && isExpanded ? (_jsx("div", { role: "group", "aria-label": `${item.label} sub-items`, className: "ml-[1.0625rem] border-l border-primary-foreground/15 pl-2 py-0.5", children: (item.children ?? []).map((child) => (_jsx(ExpandedRow, { item: child, depth: depth + 1, activeKey: activeKey, onSelect: onSelect, expandedKeys: expandedKeys, toggleExpanded: toggleExpanded, itemClassName: itemClassName, activeItemClassName: activeItemClassName }, child.key))) })) : null] }));
39
+ }
40
+ function ExpandedSearchMatch({ item, breadcrumbs, activeKey, onSelect, itemClassName }) {
41
+ return (_jsxs("button", { type: "button", disabled: item.disabled, onClick: () => onSelect(item), suppressHydrationWarning: true, className: cn('group flex w-full items-center gap-2 rounded-md px-2.5 py-2 text-left text-sm text-primary-foreground/90 transition-colors', 'hover:bg-primary-foreground/10 hover:text-primary-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-inset focus-visible:ring-primary-foreground/60', 'disabled:cursor-not-allowed disabled:opacity-50', item.key === activeKey && 'bg-accent text-accent-foreground font-medium hover:bg-accent hover:text-accent-foreground', itemClassName), children: [item.icon ? (_jsx("span", { className: "grid size-5 shrink-0 place-items-center text-inherit [&_svg]:size-full", "aria-hidden": "true", children: item.icon })) : null, _jsxs("span", { className: "min-w-0 flex-1", children: [_jsx("span", { className: "block truncate", children: item.label }), breadcrumbs.length ? (_jsx("span", { className: "block truncate text-[11px] text-current/60", children: breadcrumbs.join(' › ') })) : null] }), item.badge != null && item.badge !== false ? (shouldWrapBadge(item.badge) ? (_jsx("span", { className: "inline-flex h-5 min-w-5 items-center justify-center rounded-full bg-current/15 px-1.5 text-xs font-medium text-current", children: item.badge })) : (_jsx("span", { className: "inline-flex shrink-0 items-center", children: item.badge }))) : null] }));
42
+ }
43
+ function CollapseChevron({ onClick, label, side, }) {
44
+ return (_jsx("button", { type: "button", onClick: onClick, "aria-label": label, className: "grid size-7 shrink-0 place-items-center rounded-md text-primary-foreground/80 transition-colors hover:bg-primary-foreground/10 hover:text-primary-foreground focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-primary-foreground/60", children: _jsx("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", className: "size-4", "aria-hidden": "true", children: _jsx("path", { d: side === 'right' ? 'm9 18 6-6-6-6' : 'm15 18-6-6 6-6', strokeLinecap: "round", strokeLinejoin: "round" }) }) }));
45
+ }
46
+ export const ExpandedSidebar = forwardRef(function ExpandedSidebar({ items, activeKey, onItemSelect, header, footer, search = false, searchPlaceholder, onSearchChange, side = 'left', expandedWidth = '15rem', showCollapseToggle = true, onCollapse, itemClassName, activeItemClassName, className, style: outerStyle, collapsedLabel = 'Collapse menu',
47
+ /* Strip non-DOM props that come from MainSidebarProps so they don't land on <nav>. */
48
+ variant: _variant, expanded: _expanded, defaultExpanded: _defaultExpanded, onExpandedChange: _onExpandedChange, panelHeader: _panelHeader, panelFooter: _panelFooter, density: _density, panelWidth: _panelWidth, motionPreset: _motionPreset, showLabelsWhenExpanded: _showLabelsWhenExpanded, collapsible: _collapsible, collapsed: _collapsed, defaultCollapsed: _defaultCollapsed, onCollapsedChange: _onCollapsedChange, collapsedWidth: _collapsedWidth, closeOnOutsideClick: _closeOnOutsideClick, columnsMaxVisible: _columnsMaxVisible, hoverDelayMs: _hoverDelayMs, railClassName: _railClassName, panelClassName: _panelClassName, expandedLabel: _expandedLabel, backLabel: _backLabel, mobile: _mobile, ...rest }, ref) {
49
+ void _variant;
50
+ void _expanded;
51
+ void _defaultExpanded;
52
+ void _onExpandedChange;
53
+ void _panelHeader;
54
+ void _panelFooter;
55
+ void _density;
56
+ void _panelWidth;
57
+ void _motionPreset;
58
+ void _showLabelsWhenExpanded;
59
+ void _collapsible;
60
+ void _collapsed;
61
+ void _defaultCollapsed;
62
+ void _onCollapsedChange;
63
+ void _collapsedWidth;
64
+ void _closeOnOutsideClick;
65
+ void _columnsMaxVisible;
66
+ void _hoverDelayMs;
67
+ void _railClassName;
68
+ void _panelClassName;
69
+ void _expandedLabel;
70
+ void _backLabel;
71
+ void _mobile;
72
+ const searchEnabled = search !== false;
73
+ const searchCfg = typeof search === 'object' ? search : undefined;
74
+ const matcher = searchCfg?.matcher ?? defaultMatcher;
75
+ const [query, setQuery] = useState('');
76
+ const searchActive = query.trim().length > 0;
77
+ const matches = useMemo(() => (searchActive ? flatMatchTree(items, query, matcher) : []), [items, query, matcher, searchActive]);
78
+ /* Every parent starts collapsed. The user explicitly opens what they need. */
79
+ const [expandedKeys, setExpandedKeys] = useState(() => new Set());
80
+ function toggleExpanded(key) {
81
+ setExpandedKeys((prev) => {
82
+ const next = new Set(prev);
83
+ if (next.has(key))
84
+ next.delete(key);
85
+ else
86
+ next.add(key);
87
+ return next;
88
+ });
89
+ }
90
+ function onSelect(item) {
91
+ if (item.disabled)
92
+ return;
93
+ onItemSelect?.(item.key, item);
94
+ }
95
+ function updateQuery(next) {
96
+ setQuery(next);
97
+ onSearchChange?.(next);
98
+ }
99
+ const widthValue = typeof expandedWidth === 'number' ? `${expandedWidth}px` : expandedWidth;
100
+ return (_jsxs("nav", { ref: ref, "aria-label": "Main navigation", style: { width: widthValue, ...outerStyle }, className: cn('relative flex h-full shrink-0 flex-col bg-primary text-primary-foreground', side === 'right' ? 'border-l border-primary-700/40' : 'border-r border-primary-700/40', className), ...rest, children: [header ? (_jsxs("div", { className: "flex items-center justify-between gap-2 border-b border-primary-foreground/10 px-3 py-2.5", children: [_jsx("div", { className: "min-w-0 flex-1", children: header }), showCollapseToggle ? (_jsx(CollapseChevron, { onClick: onCollapse, label: collapsedLabel, side: side })) : null] })) : null, (searchEnabled || (!header && showCollapseToggle)) ? (_jsxs("div", { className: "flex items-center gap-2 border-b border-primary-foreground/10 px-3 py-2", children: [searchEnabled ? (_jsx("div", { className: "min-w-0 flex-1", children: _jsx(MenuSearch, { value: query, onValueChange: updateQuery, placeholder: searchCfg?.placeholder ?? searchPlaceholder ?? 'Search menu…', tone: "onBrand" }) })) : null, !header && showCollapseToggle ? (_jsx(CollapseChevron, { onClick: onCollapse, label: collapsedLabel, side: side })) : null] })) : null, _jsx("div", { className: "flex-1 overflow-y-auto p-2", children: searchActive ? (matches.length === 0 ? (_jsx("div", { className: "px-4 py-8 text-center text-sm text-primary-foreground/70", children: searchCfg?.noResultsLabel ?? `No items match "${query}".` })) : (matches.map((m) => (_jsx(ExpandedSearchMatch, { item: m.item, breadcrumbs: m.breadcrumbs, activeKey: activeKey, onSelect: onSelect, itemClassName: itemClassName }, m.item.key + m.breadcrumbs.join('>')))))) : (items.map((item) => (_jsx(ExpandedRow, { item: item, depth: 0, activeKey: activeKey, onSelect: onSelect, expandedKeys: expandedKeys, toggleExpanded: toggleExpanded, itemClassName: itemClassName, activeItemClassName: activeItemClassName }, item.key)))) }), footer ? (_jsx("div", { className: "border-t border-primary-foreground/10 px-3 py-2.5", children: footer })) : null] }));
101
+ });
102
+ //# sourceMappingURL=expanded.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"expanded.js","sourceRoot":"","sources":["../../src/MainSidebar/expanded.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,3 @@
1
+ import type { MainSidebarProps } from './types.js';
2
+ export declare const FloatingSidebar: import("react").ForwardRefExoticComponent<MainSidebarProps & import("react").RefAttributes<HTMLElement>>;
3
+ //# sourceMappingURL=floating.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"floating.d.ts","sourceRoot":"","sources":["../../src/MainSidebar/floating.tsx"],"names":[],"mappings":"AAkBA,OAAO,KAAK,EAAmB,gBAAgB,EAAE,MAAM,YAAY,CAAC;AAEpE,eAAO,MAAM,eAAe,0GAuP1B,CAAC"}
@@ -0,0 +1,116 @@
1
+ 'use client';
2
+ import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
3
+ /**
4
+ * MainSidebar — `floating` variant.
5
+ *
6
+ * Rail click opens an overlay panel beside the rail. The panel floats on top
7
+ * of the page content (does NOT push layout). Dismisses on outside click,
8
+ * Esc, or repeated rail-icon click.
9
+ */
10
+ import { forwardRef, useEffect, useMemo, useRef, useState } from 'react';
11
+ import { AnimatePresence, motion, useReducedMotion } from 'motion/react';
12
+ import { cn } from '../internal/cn.js';
13
+ import { Rail } from './rail.js';
14
+ import { MenuSearch } from './search.js';
15
+ import { BackButton, CloseButton } from './back-button.js';
16
+ import { PathBreadcrumb } from './breadcrumb.js';
17
+ import { defaultMatcher, filterLevel, isOnPath, opensPanel, resolvePath } from './helpers.js';
18
+ import { slideVariants } from './motion.js';
19
+ export const FloatingSidebar = forwardRef(function FloatingSidebar({ items, activeKey, expanded, defaultExpanded = false, onExpandedChange, onItemSelect, header, footer, panelHeader, panelFooter, search = false, searchPlaceholder, onSearchChange, side = 'left', density = 'comfortable', panelWidth = 288, motionPreset = 'expressive', closeOnOutsideClick = true, railClassName, panelClassName, itemClassName, activeItemClassName, backLabel = 'Back', expandedLabel = 'Close menu', className, ...rest }, ref) {
20
+ const reduceMotion = useReducedMotion();
21
+ const effectivePreset = reduceMotion ? 'subtle' : motionPreset;
22
+ const [internalExpanded, setInternalExpanded] = useState(defaultExpanded);
23
+ const isExpanded = expanded ?? internalExpanded;
24
+ const [pathKeys, setPathKeys] = useState([]);
25
+ const path = useMemo(() => resolvePath(items, pathKeys), [items, pathKeys]);
26
+ const current = path.at(-1);
27
+ const [query, setQuery] = useState('');
28
+ const searchEnabled = search !== false;
29
+ const searchCfg = typeof search === 'object' ? search : undefined;
30
+ const matcher = searchCfg?.matcher ?? defaultMatcher;
31
+ const currentItems = current?.children ?? [];
32
+ const filtered = filterLevel(currentItems, query, matcher);
33
+ const panelRef = useRef(null);
34
+ const railRef = useRef(null);
35
+ function resetDeepState() {
36
+ setPathKeys([]);
37
+ setQuery('');
38
+ }
39
+ function setExpanded(next) {
40
+ if (expanded === undefined)
41
+ setInternalExpanded(next);
42
+ if (!next)
43
+ resetDeepState();
44
+ onExpandedChange?.(next);
45
+ }
46
+ function closePanel() {
47
+ resetDeepState();
48
+ setExpanded(false);
49
+ }
50
+ function selectRailItem(item) {
51
+ if (item.disabled)
52
+ return;
53
+ onItemSelect?.(item.key, item);
54
+ if (opensPanel(item)) {
55
+ if (current?.key === item.key && isExpanded) {
56
+ setExpanded(false);
57
+ return;
58
+ }
59
+ setPathKeys([item.key]);
60
+ setExpanded(true);
61
+ setQuery('');
62
+ }
63
+ else {
64
+ setExpanded(false);
65
+ }
66
+ }
67
+ function selectPanelItem(item) {
68
+ if (item.disabled)
69
+ return;
70
+ onItemSelect?.(item.key, item);
71
+ if (opensPanel(item)) {
72
+ setPathKeys((prev) => (prev.at(-1) === item.key ? prev : [...prev, item.key]));
73
+ setQuery('');
74
+ }
75
+ }
76
+ /* Outside-click + Escape */
77
+ useEffect(() => {
78
+ if (!isExpanded)
79
+ return;
80
+ function onPointerDown(e) {
81
+ if (!closeOnOutsideClick)
82
+ return;
83
+ const target = e.target;
84
+ if (panelRef.current?.contains(target) || railRef.current?.contains(target))
85
+ return;
86
+ setExpanded(false);
87
+ }
88
+ function onKey(e) {
89
+ if (e.key === 'Escape')
90
+ closePanel();
91
+ }
92
+ document.addEventListener('pointerdown', onPointerDown);
93
+ document.addEventListener('keydown', onKey);
94
+ return () => {
95
+ document.removeEventListener('pointerdown', onPointerDown);
96
+ document.removeEventListener('keydown', onKey);
97
+ };
98
+ // eslint-disable-next-line react-hooks/exhaustive-deps
99
+ }, [isExpanded, closeOnOutsideClick]);
100
+ function updateQuery(next) {
101
+ setQuery(next);
102
+ onSearchChange?.(next);
103
+ }
104
+ function goBack() {
105
+ setPathKeys((prev) => prev.slice(0, -1));
106
+ setQuery('');
107
+ }
108
+ return (_jsxs("div", { ref: ref, className: cn('relative h-full', className), ...rest, children: [_jsx(Rail, { ref: railRef, items: items, activeKey: activeKey, density: density, side: side, header: header, footer: footer, itemClassName: itemClassName, activeItemClassName: activeItemClassName, className: railClassName, onItemSelect: selectRailItem, openPanelKey: isExpanded ? current?.key : undefined }), _jsx(AnimatePresence, { initial: false, mode: "wait", children: isExpanded && current ? (_jsxs(motion.div, { ref: panelRef, variants: slideVariants(effectivePreset, side === 'right' ? 'right' : 'left'), initial: "initial", animate: "animate", exit: "exit", role: "menu", "aria-label": current.label, style: {
109
+ width: typeof panelWidth === 'number' ? `${panelWidth}px` : panelWidth,
110
+ [side === 'right' ? 'right' : 'left']: density === 'compact' ? '3rem' : '3.5rem',
111
+ }, className: cn('absolute top-0 z-10 flex h-full flex-col rounded-xl border border-border bg-card text-card-foreground shadow-xl', 'm-2', panelClassName), children: [_jsxs("div", { className: "border-b border-border px-4 py-3", children: [panelHeader ?? (_jsxs("div", { className: "flex items-start justify-between gap-3", children: [_jsxs("div", { className: "min-w-0", children: [path.length > 1 ? (_jsxs(_Fragment, { children: [_jsx(PathBreadcrumb, { path: path, onJump: (depth) => setPathKeys((prev) => prev.slice(0, depth + 1)), className: "mb-1" }), _jsx(BackButton, { onClick: goBack, label: backLabel, className: "mb-1 -ml-1.5" })] })) : null, _jsx("div", { className: "truncate text-base font-semibold text-card-foreground", children: current.label }), current.description ? (_jsx("p", { className: "mt-0.5 text-xs text-card-foreground/70", children: current.description })) : null] }), _jsx(CloseButton, { onClick: closePanel, label: expandedLabel })] })), searchEnabled ? (_jsx("div", { className: "mt-3", children: _jsx(MenuSearch, { value: query, onValueChange: updateQuery, placeholder: searchCfg?.placeholder ?? searchPlaceholder ?? `Search ${current.label}…`, tone: "onBrand" }) })) : null] }), _jsx("div", { className: "flex-1 overflow-y-auto p-2", children: filtered.length === 0 && query ? (_jsx("div", { className: "px-4 py-8 text-center text-sm text-card-foreground/70", children: searchCfg?.noResultsLabel ?? `No items match "${query}".` })) : (filtered.map((item) => {
112
+ const onActivePath = isOnPath(item, activeKey) || pathKeys.includes(item.key);
113
+ return (_jsxs("button", { type: "button", onClick: () => selectPanelItem(item), disabled: item.disabled, className: cn('group flex w-full items-center gap-2.5 rounded-md px-2.5 py-2 text-left text-sm text-card-foreground transition-colors', 'hover:bg-card-foreground/10 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring', 'disabled:cursor-not-allowed disabled:opacity-50', onActivePath && 'bg-accent text-accent-foreground font-medium hover:bg-accent hover:text-accent-foreground', itemClassName, onActivePath && activeItemClassName), children: [item.icon ? (_jsx("span", { className: "grid size-5 shrink-0 place-items-center text-card-foreground/70 group-hover:text-card-foreground [&_svg]:size-full", "aria-hidden": "true", children: item.icon })) : null, _jsx("span", { className: "min-w-0 flex-1 truncate", children: item.label }), opensPanel(item) ? (_jsx("svg", { viewBox: "0 0 24 24", fill: "none", stroke: "currentColor", strokeWidth: "2", className: "size-3.5 shrink-0 text-card-foreground/70", "aria-hidden": "true", children: _jsx("path", { d: "m9 18 6-6-6-6", strokeLinecap: "round", strokeLinejoin: "round" }) })) : null] }, item.key));
114
+ })) }), panelFooter ? (_jsx("div", { className: "border-t border-border px-4 py-3", children: panelFooter })) : null] }, current.key + ':' + path.length)) : null })] }));
115
+ });
116
+ //# sourceMappingURL=floating.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"floating.js","sourceRoot":"","sources":["../../src/MainSidebar/floating.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,50 @@
1
+ import { type CSSProperties, type ReactNode } from 'react';
2
+ import type { MainSidebarColorScheme, MainSidebarItem } from './types.js';
3
+ /**
4
+ * `MainSidebarItem.badge` accepts either a primitive (string/number) — in
5
+ * which case the variant wraps it in a default pill — or a fully-styled
6
+ * ReactElement (e.g. `<Badge variant="warning">12</Badge>`), which should
7
+ * render as-is to avoid double backgrounds.
8
+ */
9
+ export declare function isPrimitiveBadge(badge: ReactNode): badge is string | number;
10
+ /**
11
+ * True when the badge should be rendered inside the variant's default pill
12
+ * wrapper. ReactElements bring their own styling and bypass the wrapper.
13
+ */
14
+ export declare function shouldWrapBadge(badge: ReactNode): boolean;
15
+ export declare function findItem(items: MainSidebarItem[], key: string | undefined): MainSidebarItem | undefined;
16
+ /** True if `target` is `item.key` itself, OR appears somewhere in `item`'s subtree. */
17
+ export declare function isOnPath(item: MainSidebarItem, target: string | undefined): boolean;
18
+ export declare function firstPanelItem(items: MainSidebarItem[], activeKey: string | undefined): MainSidebarItem | undefined;
19
+ export declare function opensPanel(item: MainSidebarItem): boolean;
20
+ export declare function defaultMatcher(item: MainSidebarItem, query: string): boolean;
21
+ /** Filter a list non-recursively (used by per-level search). */
22
+ export declare function filterLevel(items: MainSidebarItem[], query: string, matcher?: (item: MainSidebarItem, query: string) => boolean): MainSidebarItem[];
23
+ export interface FlatMatch {
24
+ item: MainSidebarItem;
25
+ /** Parent labels from root → immediate parent (excludes the matched item). */
26
+ breadcrumbs: string[];
27
+ }
28
+ /** Recursively flatten + filter the whole tree (used by command variant). */
29
+ export declare function flatMatchTree(items: MainSidebarItem[], query: string, matcher?: (item: MainSidebarItem, query: string) => boolean): FlatMatch[];
30
+ /**
31
+ * Convert a `MainSidebarColorScheme` into a CSS-variable style payload.
32
+ *
33
+ * Strategy: override the design-system brand variables (`--color-primary`,
34
+ * `--color-accent`, `--color-foreground`, etc.) directly on the sidebar
35
+ * root. Every Tailwind class that resolves through those tokens
36
+ * (`bg-primary`, `text-primary-foreground`, `bg-accent`, …) gets the new
37
+ * colour automatically — no per-element rewrites, and the override applies
38
+ * to nested affordances too (tooltips, breadcrumbs, badges, expanded
39
+ * panel surfaces).
40
+ *
41
+ * Tokens are scoped because the inline style only applies within the
42
+ * sidebar root subtree, so the rest of the page keeps its brand defaults.
43
+ *
44
+ * Omitted tokens are NOT emitted, so the cascade falls through to the
45
+ * page-level defaults.
46
+ */
47
+ export declare function colorSchemeToStyle(scheme: MainSidebarColorScheme | undefined): CSSProperties;
48
+ /** Resolve the active path stack into MainSidebarItem objects (filters missing ids). */
49
+ export declare function resolvePath(items: MainSidebarItem[], pathKeys: string[]): MainSidebarItem[];
50
+ //# sourceMappingURL=helpers.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"helpers.d.ts","sourceRoot":"","sources":["../../src/MainSidebar/helpers.ts"],"names":[],"mappings":"AAAA,OAAO,EAAkB,KAAK,aAAa,EAAE,KAAK,SAAS,EAAE,MAAM,OAAO,CAAC;AAC3E,OAAO,KAAK,EAAE,sBAAsB,EAAE,eAAe,EAAE,MAAM,YAAY,CAAC;AAE1E;;;;;GAKG;AACH,wBAAgB,gBAAgB,CAAC,KAAK,EAAE,SAAS,GAAG,KAAK,IAAI,MAAM,GAAG,MAAM,CAE3E;AAED;;;GAGG;AACH,wBAAgB,eAAe,CAAC,KAAK,EAAE,SAAS,GAAG,OAAO,CAIzD;AAED,wBAAgB,QAAQ,CACtB,KAAK,EAAE,eAAe,EAAE,EACxB,GAAG,EAAE,MAAM,GAAG,SAAS,GACtB,eAAe,GAAG,SAAS,CAQ7B;AAED,uFAAuF;AACvF,wBAAgB,QAAQ,CAAC,IAAI,EAAE,eAAe,EAAE,MAAM,EAAE,MAAM,GAAG,SAAS,GAAG,OAAO,CAInF;AAED,wBAAgB,cAAc,CAC5B,KAAK,EAAE,eAAe,EAAE,EACxB,SAAS,EAAE,MAAM,GAAG,SAAS,+BAK9B;AAED,wBAAgB,UAAU,CAAC,IAAI,EAAE,eAAe,WAE/C;AAED,wBAAgB,cAAc,CAAC,IAAI,EAAE,eAAe,EAAE,KAAK,EAAE,MAAM,WAGlE;AAED,gEAAgE;AAChE,wBAAgB,WAAW,CACzB,KAAK,EAAE,eAAe,EAAE,EACxB,KAAK,EAAE,MAAM,EACb,OAAO,GAAE,CAAC,IAAI,EAAE,eAAe,EAAE,KAAK,EAAE,MAAM,KAAK,OAAwB,qBAI5E;AAED,MAAM,WAAW,SAAS;IACxB,IAAI,EAAE,eAAe,CAAC;IACtB,8EAA8E;IAC9E,WAAW,EAAE,MAAM,EAAE,CAAC;CACvB;AAED,6EAA6E;AAC7E,wBAAgB,aAAa,CAC3B,KAAK,EAAE,eAAe,EAAE,EACxB,KAAK,EAAE,MAAM,EACb,OAAO,GAAE,CAAC,IAAI,EAAE,eAAe,EAAE,KAAK,EAAE,MAAM,KAAK,OAAwB,GAC1E,SAAS,EAAE,CAcb;AAED;;;;;;;;;;;;;;;;GAgBG;AACH,wBAAgB,kBAAkB,CAChC,MAAM,EAAE,sBAAsB,GAAG,SAAS,GACzC,aAAa,CAsCf;AAED,wFAAwF;AACxF,wBAAgB,WAAW,CACzB,KAAK,EAAE,eAAe,EAAE,EACxB,QAAQ,EAAE,MAAM,EAAE,GACjB,eAAe,EAAE,CAInB"}