@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.
- package/dist/CheckboxGrid.native.d.ts.map +1 -1
- package/dist/CheckboxGrid.native.js +2 -1
- package/dist/CheckboxGrid.native.js.map +1 -1
- package/dist/Combobox.native.d.ts.map +1 -1
- package/dist/Combobox.native.js +2 -1
- package/dist/Combobox.native.js.map +1 -1
- package/dist/DataTable/column-filter.d.ts +8 -0
- package/dist/DataTable/column-filter.d.ts.map +1 -0
- package/dist/DataTable/column-filter.js +67 -0
- package/dist/DataTable/column-filter.js.map +1 -0
- package/dist/DataTable/column-header.d.ts +16 -0
- package/dist/DataTable/column-header.d.ts.map +1 -0
- package/dist/DataTable/column-header.js +11 -0
- package/dist/DataTable/column-header.js.map +1 -0
- package/dist/DataTable/column-visibility.d.ts +7 -0
- package/dist/DataTable/column-visibility.d.ts.map +1 -0
- package/dist/DataTable/column-visibility.js +35 -0
- package/dist/DataTable/column-visibility.js.map +1 -0
- package/dist/DataTable/index.d.ts +5 -0
- package/dist/DataTable/index.d.ts.map +1 -0
- package/dist/DataTable/index.js +5 -0
- package/dist/DataTable/index.js.map +1 -0
- package/dist/DataTable/pinning.d.ts +13 -0
- package/dist/DataTable/pinning.d.ts.map +1 -0
- package/dist/DataTable/pinning.js +29 -0
- package/dist/DataTable/pinning.js.map +1 -0
- package/dist/DataTable.d.ts +3 -7
- package/dist/DataTable.d.ts.map +1 -1
- package/dist/DataTable.js +7 -126
- package/dist/DataTable.js.map +1 -1
- package/dist/Dialog.native.d.ts +3 -1
- package/dist/Dialog.native.d.ts.map +1 -1
- package/dist/Dialog.native.js +2 -2
- package/dist/Dialog.native.js.map +1 -1
- package/dist/Form/building-blocks.d.ts +26 -0
- package/dist/Form/building-blocks.d.ts.map +1 -0
- package/dist/Form/building-blocks.js +29 -0
- package/dist/Form/building-blocks.js.map +1 -0
- package/dist/Form/fields-choice.d.ts +72 -0
- package/dist/Form/fields-choice.d.ts.map +1 -0
- package/dist/Form/fields-choice.js +69 -0
- package/dist/Form/fields-choice.js.map +1 -0
- package/dist/Form/fields-complex.d.ts +28 -0
- package/dist/Form/fields-complex.d.ts.map +1 -0
- package/dist/Form/fields-complex.js +38 -0
- package/dist/Form/fields-complex.js.map +1 -0
- package/dist/Form/fields-date.d.ts +46 -0
- package/dist/Form/fields-date.d.ts.map +1 -0
- package/dist/Form/fields-date.js +41 -0
- package/dist/Form/fields-date.js.map +1 -0
- package/dist/Form/fields-text.d.ts +47 -0
- package/dist/Form/fields-text.d.ts.map +1 -0
- package/dist/Form/fields-text.js +46 -0
- package/dist/Form/fields-text.js.map +1 -0
- package/dist/Form/fields-toggle.d.ts +24 -0
- package/dist/Form/fields-toggle.d.ts.map +1 -0
- package/dist/Form/fields-toggle.js +32 -0
- package/dist/Form/fields-toggle.js.map +1 -0
- package/dist/Form/helpers.d.ts +66 -0
- package/dist/Form/helpers.d.ts.map +1 -0
- package/dist/Form/helpers.js +44 -0
- package/dist/Form/helpers.js.map +1 -0
- package/dist/Form/types.d.ts +25 -0
- package/dist/Form/types.d.ts.map +1 -0
- package/dist/Form/types.js +8 -0
- package/dist/Form/types.js.map +1 -0
- package/dist/Form.d.ts +24 -298
- package/dist/Form.d.ts.map +1 -1
- package/dist/Form.js +30 -246
- package/dist/Form.js.map +1 -1
- package/dist/IconSidebar.d.ts +6 -46
- package/dist/IconSidebar.d.ts.map +1 -1
- package/dist/IconSidebar.js +6 -116
- package/dist/IconSidebar.js.map +1 -1
- package/dist/MainSidebar/back-button.d.ts +14 -0
- package/dist/MainSidebar/back-button.d.ts.map +1 -0
- package/dist/MainSidebar/back-button.js +14 -0
- package/dist/MainSidebar/back-button.js.map +1 -0
- package/dist/MainSidebar/breadcrumb.d.ts +10 -0
- package/dist/MainSidebar/breadcrumb.d.ts.map +1 -0
- package/dist/MainSidebar/breadcrumb.js +24 -0
- package/dist/MainSidebar/breadcrumb.js.map +1 -0
- package/dist/MainSidebar/columns.d.ts +3 -0
- package/dist/MainSidebar/columns.d.ts.map +1 -0
- package/dist/MainSidebar/columns.js +198 -0
- package/dist/MainSidebar/columns.js.map +1 -0
- package/dist/MainSidebar/command.d.ts +3 -0
- package/dist/MainSidebar/command.d.ts.map +1 -0
- package/dist/MainSidebar/command.js +193 -0
- package/dist/MainSidebar/command.js.map +1 -0
- package/dist/MainSidebar/drilldown.d.ts +3 -0
- package/dist/MainSidebar/drilldown.d.ts.map +1 -0
- package/dist/MainSidebar/drilldown.js +154 -0
- package/dist/MainSidebar/drilldown.js.map +1 -0
- package/dist/MainSidebar/expanded.d.ts +7 -0
- package/dist/MainSidebar/expanded.d.ts.map +1 -0
- package/dist/MainSidebar/expanded.js +102 -0
- package/dist/MainSidebar/expanded.js.map +1 -0
- package/dist/MainSidebar/floating.d.ts +3 -0
- package/dist/MainSidebar/floating.d.ts.map +1 -0
- package/dist/MainSidebar/floating.js +116 -0
- package/dist/MainSidebar/floating.js.map +1 -0
- package/dist/MainSidebar/helpers.d.ts +50 -0
- package/dist/MainSidebar/helpers.d.ts.map +1 -0
- package/dist/MainSidebar/helpers.js +150 -0
- package/dist/MainSidebar/helpers.js.map +1 -0
- package/dist/MainSidebar/hover.d.ts +3 -0
- package/dist/MainSidebar/hover.d.ts.map +1 -0
- package/dist/MainSidebar/hover.js +177 -0
- package/dist/MainSidebar/hover.js.map +1 -0
- package/dist/MainSidebar/index.d.ts +6 -0
- package/dist/MainSidebar/index.d.ts.map +1 -0
- package/dist/MainSidebar/index.js +108 -0
- package/dist/MainSidebar/index.js.map +1 -0
- package/dist/MainSidebar/mobile.d.ts +29 -0
- package/dist/MainSidebar/mobile.d.ts.map +1 -0
- package/dist/MainSidebar/mobile.js +38 -0
- package/dist/MainSidebar/mobile.js.map +1 -0
- package/dist/MainSidebar/motion.d.ts +23 -0
- package/dist/MainSidebar/motion.d.ts.map +1 -0
- package/dist/MainSidebar/motion.js +40 -0
- package/dist/MainSidebar/motion.js.map +1 -0
- package/dist/MainSidebar/rail.d.ts +24 -0
- package/dist/MainSidebar/rail.d.ts.map +1 -0
- package/dist/MainSidebar/rail.js +29 -0
- package/dist/MainSidebar/rail.js.map +1 -0
- package/dist/MainSidebar/search.d.ts +19 -0
- package/dist/MainSidebar/search.d.ts.map +1 -0
- package/dist/MainSidebar/search.js +33 -0
- package/dist/MainSidebar/search.js.map +1 -0
- package/dist/MainSidebar/types.d.ts +161 -0
- package/dist/MainSidebar/types.d.ts.map +1 -0
- package/dist/MainSidebar/types.js +2 -0
- package/dist/MainSidebar/types.js.map +1 -0
- package/dist/MainSidebar.d.ts +6 -1
- package/dist/MainSidebar.d.ts.map +1 -1
- package/dist/MainSidebar.js +6 -1
- package/dist/MainSidebar.js.map +1 -1
- package/dist/NavigationMenu.js +1 -1
- package/dist/NavigationMenu.js.map +1 -1
- package/dist/RichTextEditor/theme.d.ts +44 -0
- package/dist/RichTextEditor/theme.d.ts.map +1 -0
- package/dist/RichTextEditor/theme.js +41 -0
- package/dist/RichTextEditor/theme.js.map +1 -0
- package/dist/RichTextEditor/toolbar-icons.d.ts +21 -0
- package/dist/RichTextEditor/toolbar-icons.d.ts.map +1 -0
- package/dist/RichTextEditor/toolbar-icons.js +21 -0
- package/dist/RichTextEditor/toolbar-icons.js.map +1 -0
- package/dist/RichTextEditor/toolbar.d.ts +5 -0
- package/dist/RichTextEditor/toolbar.d.ts.map +1 -0
- package/dist/RichTextEditor/toolbar.js +116 -0
- package/dist/RichTextEditor/toolbar.js.map +1 -0
- package/dist/RichTextEditor.d.ts +16 -9
- package/dist/RichTextEditor.d.ts.map +1 -1
- package/dist/RichTextEditor.js +18 -164
- package/dist/RichTextEditor.js.map +1 -1
- package/dist/Select/content.d.ts +9 -0
- package/dist/Select/content.d.ts.map +1 -0
- package/dist/Select/content.js +80 -0
- package/dist/Select/content.js.map +1 -0
- package/dist/Select/context.d.ts +27 -0
- package/dist/Select/context.d.ts.map +1 -0
- package/dist/Select/context.js +35 -0
- package/dist/Select/context.js.map +1 -0
- package/dist/Select/item.d.ts +13 -0
- package/dist/Select/item.d.ts.map +1 -0
- package/dist/Select/item.js +39 -0
- package/dist/Select/item.js.map +1 -0
- package/dist/Select/parts.d.ts +14 -0
- package/dist/Select/parts.d.ts.map +1 -0
- package/dist/Select/parts.js +17 -0
- package/dist/Select/parts.js.map +1 -0
- package/dist/Select/react-select.d.ts +25 -0
- package/dist/Select/react-select.d.ts.map +1 -0
- package/dist/Select/react-select.js +66 -0
- package/dist/Select/react-select.js.map +1 -0
- package/dist/Select/root.d.ts +15 -0
- package/dist/Select/root.d.ts.map +1 -0
- package/dist/Select/root.js +41 -0
- package/dist/Select/root.js.map +1 -0
- package/dist/Select/trigger.d.ts +15 -0
- package/dist/Select/trigger.d.ts.map +1 -0
- package/dist/Select/trigger.js +61 -0
- package/dist/Select/trigger.js.map +1 -0
- package/dist/Select.d.ts +14 -62
- package/dist/Select.d.ts.map +1 -1
- package/dist/Select.js +14 -293
- package/dist/Select.js.map +1 -1
- package/dist/Sidebar/context.d.ts +28 -0
- package/dist/Sidebar/context.d.ts.map +1 -0
- package/dist/Sidebar/context.js +37 -0
- package/dist/Sidebar/context.js.map +1 -0
- package/dist/Sidebar/group.d.ts +13 -0
- package/dist/Sidebar/group.d.ts.map +1 -0
- package/dist/Sidebar/group.js +20 -0
- package/dist/Sidebar/group.js.map +1 -0
- package/dist/Sidebar/icons.d.ts +7 -0
- package/dist/Sidebar/icons.d.ts.map +1 -0
- package/dist/Sidebar/icons.js +12 -0
- package/dist/Sidebar/icons.js.map +1 -0
- package/dist/Sidebar/layout.d.ts +9 -0
- package/dist/Sidebar/layout.d.ts.map +1 -0
- package/dist/Sidebar/layout.js +21 -0
- package/dist/Sidebar/layout.js.map +1 -0
- package/dist/Sidebar/menu.d.ts +29 -0
- package/dist/Sidebar/menu.d.ts.map +1 -0
- package/dist/Sidebar/menu.js +55 -0
- package/dist/Sidebar/menu.js.map +1 -0
- package/dist/Sidebar/provider.d.ts +33 -0
- package/dist/Sidebar/provider.d.ts.map +1 -0
- package/dist/Sidebar/provider.js +110 -0
- package/dist/Sidebar/provider.js.map +1 -0
- package/dist/Sidebar/sidebar.d.ts +17 -0
- package/dist/Sidebar/sidebar.d.ts.map +1 -0
- package/dist/Sidebar/sidebar.js +51 -0
- package/dist/Sidebar/sidebar.js.map +1 -0
- package/dist/Sidebar/submenu.d.ts +13 -0
- package/dist/Sidebar/submenu.d.ts.map +1 -0
- package/dist/Sidebar/submenu.js +17 -0
- package/dist/Sidebar/submenu.js.map +1 -0
- package/dist/Sidebar/trigger.d.ts +9 -0
- package/dist/Sidebar/trigger.d.ts.map +1 -0
- package/dist/Sidebar/trigger.js +33 -0
- package/dist/Sidebar/trigger.js.map +1 -0
- package/dist/Sidebar.d.ts +14 -104
- package/dist/Sidebar.d.ts.map +1 -1
- package/dist/Sidebar.js +14 -300
- package/dist/Sidebar.js.map +1 -1
- package/dist/StatCard.d.ts +67 -9
- package/dist/StatCard.d.ts.map +1 -1
- package/dist/StatCard.js +111 -9
- package/dist/StatCard.js.map +1 -1
- package/dist/TransferList.native.d.ts.map +1 -1
- package/dist/TransferList.native.js +2 -1
- package/dist/TransferList.native.js.map +1 -1
- package/package.json +2 -2
- package/src/CheckboxGrid.native.tsx +2 -1
- package/src/Combobox.native.tsx +2 -1
- package/src/DataTable/column-filter.tsx +134 -0
- package/src/DataTable/column-header.tsx +67 -0
- package/src/DataTable/column-visibility.tsx +87 -0
- package/src/DataTable/index.ts +4 -0
- package/src/DataTable/pinning.ts +40 -0
- package/src/DataTable.tsx +14 -297
- package/src/Dialog.native.tsx +4 -2
- package/src/Form/building-blocks.tsx +97 -0
- package/src/Form/fields-choice.tsx +312 -0
- package/src/Form/fields-complex.tsx +195 -0
- package/src/Form/fields-date.tsx +195 -0
- package/src/Form/fields-text.tsx +218 -0
- package/src/Form/fields-toggle.tsx +123 -0
- package/src/Form/helpers.tsx +189 -0
- package/src/Form/types.ts +26 -0
- package/src/Form.tsx +91 -1308
- package/src/IconSidebar.tsx +20 -442
- package/src/MainSidebar/back-button.tsx +58 -0
- package/src/MainSidebar/breadcrumb.tsx +53 -0
- package/src/MainSidebar/columns.tsx +350 -0
- package/src/MainSidebar/command.tsx +404 -0
- package/src/MainSidebar/drilldown.tsx +373 -0
- package/src/MainSidebar/expanded.tsx +414 -0
- package/src/MainSidebar/floating.tsx +268 -0
- package/src/MainSidebar/helpers.ts +166 -0
- package/src/MainSidebar/hover.tsx +334 -0
- package/src/MainSidebar/index.tsx +191 -0
- package/src/MainSidebar/mobile.tsx +117 -0
- package/src/MainSidebar/motion.ts +64 -0
- package/src/MainSidebar/rail.tsx +137 -0
- package/src/MainSidebar/search.tsx +99 -0
- package/src/MainSidebar/types.ts +208 -0
- package/src/MainSidebar.tsx +15 -4
- package/src/NavigationMenu.tsx +1 -1
- package/src/RichTextEditor/theme.ts +43 -0
- package/src/RichTextEditor/toolbar-icons.tsx +40 -0
- package/src/RichTextEditor/toolbar.tsx +271 -0
- package/src/RichTextEditor.tsx +23 -371
- package/src/Select/content.tsx +111 -0
- package/src/Select/context.tsx +66 -0
- package/src/Select/item.tsx +97 -0
- package/src/Select/parts.tsx +43 -0
- package/src/Select/react-select.tsx +216 -0
- package/src/Select/root.tsx +75 -0
- package/src/Select/trigger.tsx +122 -0
- package/src/Select.tsx +34 -692
- package/src/Sidebar/context.tsx +72 -0
- package/src/Sidebar/group.tsx +69 -0
- package/src/Sidebar/icons.tsx +42 -0
- package/src/Sidebar/layout.tsx +64 -0
- package/src/Sidebar/menu.tsx +171 -0
- package/src/Sidebar/provider.tsx +224 -0
- package/src/Sidebar/sidebar.tsx +178 -0
- package/src/Sidebar/submenu.tsx +58 -0
- package/src/Sidebar/trigger.tsx +104 -0
- package/src/Sidebar.tsx +44 -927
- package/src/StatCard.tsx +365 -20
- package/src/TransferList.native.tsx +2 -1
- package/dist/TiptapEditor.d.ts +0 -24
- package/dist/TiptapEditor.d.ts.map +0 -1
- package/dist/TiptapEditor.js +0 -84
- 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 @@
|
|
|
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"}
|