@mihcm/ui 0.14.1 → 0.15.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- 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 +148 -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 +164 -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,178 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Sidebar — the visual container. Three modes selected per context:
|
|
5
|
+
* - `collapsible="none"` → static `<nav>` at the configured width.
|
|
6
|
+
* - mobile → wrapped in the Sheet primitive.
|
|
7
|
+
* - desktop `contained` / `fixed` → either takes space in flow or is fixed
|
|
8
|
+
* to the viewport edge, with width transitions and offcanvas handling.
|
|
9
|
+
*/
|
|
10
|
+
import { forwardRef, type HTMLAttributes } from 'react';
|
|
11
|
+
import { cn } from '../internal/cn.js';
|
|
12
|
+
import { Sheet, SheetContent } from '../Sheet.js';
|
|
13
|
+
import {
|
|
14
|
+
useSidebar,
|
|
15
|
+
type SidebarCollapsible,
|
|
16
|
+
type SidebarPosition,
|
|
17
|
+
type SidebarSide,
|
|
18
|
+
type SidebarVariant,
|
|
19
|
+
} from './context.js';
|
|
20
|
+
|
|
21
|
+
export interface SidebarProps extends HTMLAttributes<HTMLElement> {
|
|
22
|
+
side?: SidebarSide;
|
|
23
|
+
variant?: SidebarVariant;
|
|
24
|
+
collapsible?: SidebarCollapsible;
|
|
25
|
+
position?: SidebarPosition;
|
|
26
|
+
}
|
|
27
|
+
|
|
28
|
+
export const Sidebar = forwardRef<HTMLElement, SidebarProps>(function Sidebar(
|
|
29
|
+
{ side, variant, collapsible, position, className, children, ...props },
|
|
30
|
+
ref,
|
|
31
|
+
) {
|
|
32
|
+
const context = useSidebar();
|
|
33
|
+
const { isMobile, state, openMobile, setOpenMobile } = context;
|
|
34
|
+
const currentSide = side ?? context.side;
|
|
35
|
+
const currentVariant = variant ?? context.variant;
|
|
36
|
+
const currentCollapsible = collapsible ?? context.collapsible;
|
|
37
|
+
const currentPosition = position ?? context.position;
|
|
38
|
+
const isCollapsed = state === 'collapsed';
|
|
39
|
+
const isFloating = currentVariant === 'floating' || currentVariant === 'inset';
|
|
40
|
+
const isOffcanvasCollapsed = isCollapsed && currentCollapsible === 'offcanvas';
|
|
41
|
+
const isIconCollapsed = isCollapsed && currentCollapsible === 'icon';
|
|
42
|
+
const sidebarEdgeBorder = currentSide === 'right'
|
|
43
|
+
? 'border-l border-sidebar-border'
|
|
44
|
+
: 'border-r border-sidebar-border';
|
|
45
|
+
|
|
46
|
+
if (currentCollapsible === 'none') {
|
|
47
|
+
return (
|
|
48
|
+
<nav
|
|
49
|
+
ref={ref}
|
|
50
|
+
aria-label={props['aria-label'] ?? 'Sidebar'}
|
|
51
|
+
data-sidebar="sidebar"
|
|
52
|
+
data-state={state}
|
|
53
|
+
data-collapsible=""
|
|
54
|
+
data-variant={currentVariant}
|
|
55
|
+
data-side={currentSide}
|
|
56
|
+
data-position={currentPosition}
|
|
57
|
+
className={cn(
|
|
58
|
+
'flex h-full w-(--sidebar-width) flex-col bg-sidebar text-sidebar-foreground',
|
|
59
|
+
isFloating ? 'rounded-lg border border-sidebar-border shadow' : sidebarEdgeBorder,
|
|
60
|
+
className,
|
|
61
|
+
)}
|
|
62
|
+
{...props}
|
|
63
|
+
>
|
|
64
|
+
{children}
|
|
65
|
+
</nav>
|
|
66
|
+
);
|
|
67
|
+
}
|
|
68
|
+
|
|
69
|
+
if (isMobile) {
|
|
70
|
+
return (
|
|
71
|
+
<Sheet open={openMobile} onOpenChange={setOpenMobile}>
|
|
72
|
+
<SheetContent
|
|
73
|
+
data-sidebar="sidebar"
|
|
74
|
+
data-mobile="true"
|
|
75
|
+
className={cn(
|
|
76
|
+
'w-(--sidebar-width-mobile) bg-sidebar p-0 text-sidebar-foreground [&>button]:hidden',
|
|
77
|
+
className,
|
|
78
|
+
)}
|
|
79
|
+
side={currentSide}
|
|
80
|
+
{...props}
|
|
81
|
+
>
|
|
82
|
+
<nav aria-label={props['aria-label'] ?? 'Sidebar'} className="flex h-full w-full flex-col">
|
|
83
|
+
{children}
|
|
84
|
+
</nav>
|
|
85
|
+
</SheetContent>
|
|
86
|
+
</Sheet>
|
|
87
|
+
);
|
|
88
|
+
}
|
|
89
|
+
|
|
90
|
+
if (currentPosition === 'contained') {
|
|
91
|
+
return (
|
|
92
|
+
<div
|
|
93
|
+
data-sidebar="sidebar-container"
|
|
94
|
+
className={cn(
|
|
95
|
+
'group peer relative hidden h-full shrink-0 overflow-hidden text-sidebar-foreground transition-[width] duration-200 ease-linear md:flex',
|
|
96
|
+
isOffcanvasCollapsed
|
|
97
|
+
? 'w-0'
|
|
98
|
+
: isIconCollapsed
|
|
99
|
+
? isFloating
|
|
100
|
+
? 'w-[calc(var(--sidebar-width-icon)+theme(spacing.4))]'
|
|
101
|
+
: 'w-(--sidebar-width-icon)'
|
|
102
|
+
: 'w-(--sidebar-width)',
|
|
103
|
+
isFloating && !isOffcanvasCollapsed && 'p-2',
|
|
104
|
+
className,
|
|
105
|
+
)}
|
|
106
|
+
data-state={state}
|
|
107
|
+
data-collapsible={isCollapsed ? currentCollapsible : ''}
|
|
108
|
+
data-variant={currentVariant}
|
|
109
|
+
data-side={currentSide}
|
|
110
|
+
data-position={currentPosition}
|
|
111
|
+
>
|
|
112
|
+
<nav
|
|
113
|
+
ref={ref}
|
|
114
|
+
aria-label={props['aria-label'] ?? 'Sidebar'}
|
|
115
|
+
data-sidebar="sidebar"
|
|
116
|
+
className={cn(
|
|
117
|
+
'flex h-full w-full min-w-0 flex-col bg-sidebar',
|
|
118
|
+
isFloating ? 'rounded-lg border border-sidebar-border shadow' : sidebarEdgeBorder,
|
|
119
|
+
)}
|
|
120
|
+
{...props}
|
|
121
|
+
>
|
|
122
|
+
{children}
|
|
123
|
+
</nav>
|
|
124
|
+
</div>
|
|
125
|
+
);
|
|
126
|
+
}
|
|
127
|
+
|
|
128
|
+
return (
|
|
129
|
+
<div
|
|
130
|
+
data-sidebar="sidebar-container"
|
|
131
|
+
className="group peer hidden md:block text-sidebar-foreground"
|
|
132
|
+
data-state={state}
|
|
133
|
+
data-collapsible={isCollapsed ? currentCollapsible : ''}
|
|
134
|
+
data-variant={currentVariant}
|
|
135
|
+
data-side={currentSide}
|
|
136
|
+
data-position={currentPosition}
|
|
137
|
+
>
|
|
138
|
+
<div
|
|
139
|
+
className={cn(
|
|
140
|
+
'relative w-(--sidebar-width) bg-transparent transition-[width] duration-200 ease-linear',
|
|
141
|
+
'group-data-[collapsible=offcanvas]:w-0',
|
|
142
|
+
'group-data-[side=right]:rotate-180',
|
|
143
|
+
isFloating
|
|
144
|
+
? 'group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+theme(spacing.4))]'
|
|
145
|
+
: 'group-data-[collapsible=icon]:w-(--sidebar-width-icon)',
|
|
146
|
+
)}
|
|
147
|
+
/>
|
|
148
|
+
<div
|
|
149
|
+
className={cn(
|
|
150
|
+
'fixed inset-y-0 z-10 hidden h-svh w-(--sidebar-width) transition-[left,right,width] duration-200 ease-linear md:flex',
|
|
151
|
+
currentSide === 'left'
|
|
152
|
+
? 'left-0 group-data-[collapsible=offcanvas]:left-[calc(var(--sidebar-width)*-1)]'
|
|
153
|
+
: 'right-0 group-data-[collapsible=offcanvas]:right-[calc(var(--sidebar-width)*-1)]',
|
|
154
|
+
isFloating
|
|
155
|
+
? 'p-2 group-data-[collapsible=icon]:w-[calc(var(--sidebar-width-icon)+theme(spacing.4)+2px)]'
|
|
156
|
+
: cn(
|
|
157
|
+
'group-data-[collapsible=icon]:w-(--sidebar-width-icon)',
|
|
158
|
+
'border-sidebar-border',
|
|
159
|
+
currentSide === 'right' ? 'group-data-[variant=sidebar]:border-l' : 'group-data-[variant=sidebar]:border-r',
|
|
160
|
+
),
|
|
161
|
+
className,
|
|
162
|
+
)}
|
|
163
|
+
{...props}
|
|
164
|
+
>
|
|
165
|
+
<nav
|
|
166
|
+
ref={ref}
|
|
167
|
+
aria-label={props['aria-label'] ?? 'Sidebar'}
|
|
168
|
+
data-sidebar="sidebar"
|
|
169
|
+
className={cn(
|
|
170
|
+
'flex h-full w-full flex-col bg-sidebar group-data-[variant=floating]:rounded-lg group-data-[variant=floating]:border group-data-[variant=floating]:border-sidebar-border group-data-[variant=floating]:shadow',
|
|
171
|
+
)}
|
|
172
|
+
>
|
|
173
|
+
{children}
|
|
174
|
+
</nav>
|
|
175
|
+
</div>
|
|
176
|
+
</div>
|
|
177
|
+
);
|
|
178
|
+
});
|
|
@@ -0,0 +1,58 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Sub-menu pieces: SidebarMenuSub, SidebarMenuSubItem, SidebarMenuSubButton.
|
|
5
|
+
*/
|
|
6
|
+
import { forwardRef, type AnchorHTMLAttributes, type HTMLAttributes } from 'react';
|
|
7
|
+
import { cn } from '../internal/cn.js';
|
|
8
|
+
|
|
9
|
+
export const SidebarMenuSub = forwardRef<HTMLUListElement, HTMLAttributes<HTMLUListElement>>(
|
|
10
|
+
function SidebarMenuSub({ className, ...props }, ref) {
|
|
11
|
+
return (
|
|
12
|
+
<ul
|
|
13
|
+
ref={ref}
|
|
14
|
+
data-sidebar="menu-sub"
|
|
15
|
+
className={cn(
|
|
16
|
+
'mx-3.5 flex min-w-0 translate-x-px flex-col gap-1 border-l border-sidebar-border px-2.5 py-0.5',
|
|
17
|
+
'group-data-[collapsible=icon]:hidden',
|
|
18
|
+
className,
|
|
19
|
+
)}
|
|
20
|
+
{...props}
|
|
21
|
+
/>
|
|
22
|
+
);
|
|
23
|
+
},
|
|
24
|
+
);
|
|
25
|
+
|
|
26
|
+
export const SidebarMenuSubItem = forwardRef<HTMLLIElement, HTMLAttributes<HTMLLIElement>>(
|
|
27
|
+
function SidebarMenuSubItem({ ...props }, ref) {
|
|
28
|
+
return <li ref={ref} {...props} />;
|
|
29
|
+
},
|
|
30
|
+
);
|
|
31
|
+
|
|
32
|
+
export interface SidebarMenuSubButtonProps extends AnchorHTMLAttributes<HTMLAnchorElement> {
|
|
33
|
+
asChild?: boolean;
|
|
34
|
+
size?: 'sm' | 'md';
|
|
35
|
+
isActive?: boolean;
|
|
36
|
+
}
|
|
37
|
+
|
|
38
|
+
export const SidebarMenuSubButton = forwardRef<HTMLAnchorElement, SidebarMenuSubButtonProps>(
|
|
39
|
+
function SidebarMenuSubButton({ asChild: _asChild, size = 'md', isActive, className, ...props }, ref) {
|
|
40
|
+
return (
|
|
41
|
+
<a
|
|
42
|
+
ref={ref}
|
|
43
|
+
data-sidebar="menu-sub-button"
|
|
44
|
+
data-size={size}
|
|
45
|
+
data-active={isActive}
|
|
46
|
+
className={cn(
|
|
47
|
+
'flex h-7 min-w-0 -translate-x-px items-center gap-2 overflow-hidden rounded-md px-2 text-sidebar-foreground outline-none ring-sidebar-ring hover:bg-sidebar-accent hover:text-sidebar-accent-foreground focus-visible:ring-2 active:bg-sidebar-accent active:text-sidebar-accent-foreground disabled:pointer-events-none disabled:opacity-50 aria-disabled:pointer-events-none aria-disabled:opacity-50 [&>span:last-child]:truncate [&>svg]:size-4 [&>svg]:shrink-0',
|
|
48
|
+
'data-[active=true]:bg-sidebar-accent data-[active=true]:text-sidebar-accent-foreground',
|
|
49
|
+
size === 'sm' && 'text-xs',
|
|
50
|
+
size === 'md' && 'text-sm',
|
|
51
|
+
'group-data-[collapsible=icon]:hidden',
|
|
52
|
+
className,
|
|
53
|
+
)}
|
|
54
|
+
{...props}
|
|
55
|
+
/>
|
|
56
|
+
);
|
|
57
|
+
},
|
|
58
|
+
);
|
|
@@ -0,0 +1,104 @@
|
|
|
1
|
+
'use client';
|
|
2
|
+
|
|
3
|
+
/**
|
|
4
|
+
* Edge / chrome pieces: SidebarTrigger, SidebarRail, SidebarInset, SidebarInput.
|
|
5
|
+
*/
|
|
6
|
+
import { forwardRef, type ComponentProps, type HTMLAttributes } from 'react';
|
|
7
|
+
import { cn } from '../internal/cn.js';
|
|
8
|
+
import { Button } from '../Button.js';
|
|
9
|
+
import { Input } from '../Input.js';
|
|
10
|
+
import { useSidebar } from './context.js';
|
|
11
|
+
import { PanelLeftIcon, PanelRightIcon } from './icons.js';
|
|
12
|
+
|
|
13
|
+
export const SidebarTrigger = forwardRef<
|
|
14
|
+
HTMLButtonElement,
|
|
15
|
+
ComponentProps<typeof Button>
|
|
16
|
+
>(function SidebarTrigger({ className, disabled, onClick, ...props }, ref) {
|
|
17
|
+
const { isMobile, open, openMobile, collapsible, side, toggleSidebar } = useSidebar();
|
|
18
|
+
const expanded = collapsible === 'none' ? true : isMobile ? openMobile : open;
|
|
19
|
+
const isDisabled = disabled || collapsible === 'none';
|
|
20
|
+
|
|
21
|
+
return (
|
|
22
|
+
<Button
|
|
23
|
+
ref={ref}
|
|
24
|
+
data-sidebar="trigger"
|
|
25
|
+
aria-expanded={expanded}
|
|
26
|
+
aria-disabled={isDisabled || undefined}
|
|
27
|
+
disabled={isDisabled}
|
|
28
|
+
variant="ghost"
|
|
29
|
+
size="icon"
|
|
30
|
+
className={cn('size-7', className)}
|
|
31
|
+
onClick={(e) => {
|
|
32
|
+
onClick?.(e);
|
|
33
|
+
if (collapsible === 'none') return;
|
|
34
|
+
toggleSidebar();
|
|
35
|
+
}}
|
|
36
|
+
{...props}
|
|
37
|
+
>
|
|
38
|
+
{side === 'right' ? <PanelRightIcon /> : <PanelLeftIcon />}
|
|
39
|
+
<span className="sr-only">Toggle Sidebar</span>
|
|
40
|
+
</Button>
|
|
41
|
+
);
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
export const SidebarRail = forwardRef<HTMLButtonElement, HTMLAttributes<HTMLButtonElement>>(
|
|
45
|
+
function SidebarRail({ className, ...props }, ref) {
|
|
46
|
+
const { toggleSidebar } = useSidebar();
|
|
47
|
+
|
|
48
|
+
return (
|
|
49
|
+
<button
|
|
50
|
+
ref={ref}
|
|
51
|
+
type="button"
|
|
52
|
+
data-sidebar="rail"
|
|
53
|
+
aria-label="Toggle Sidebar"
|
|
54
|
+
tabIndex={-1}
|
|
55
|
+
onClick={toggleSidebar}
|
|
56
|
+
title="Toggle Sidebar"
|
|
57
|
+
className={cn(
|
|
58
|
+
'absolute inset-y-0 z-20 hidden w-4 transition-all ease-linear after:absolute after:inset-y-0 after:left-1/2 after:w-[2px] group-data-[side=left]:-right-4 group-data-[side=left]:-translate-x-1/2 group-data-[side=right]:-left-4 group-data-[side=right]:translate-x-1/2 sm:flex',
|
|
59
|
+
'hover:after:bg-sidebar-border',
|
|
60
|
+
'[[data-side=left]_&]:cursor-w-resize [[data-side=right]_&]:cursor-e-resize',
|
|
61
|
+
'[[data-side=left][data-state=collapsed]_&]:cursor-e-resize [[data-side=right][data-state=collapsed]_&]:cursor-w-resize',
|
|
62
|
+
'group-data-[collapsible=offcanvas]:after:left-full group-data-[collapsible=offcanvas]:hover:bg-sidebar',
|
|
63
|
+
'[[data-side=left][data-collapsible=offcanvas]_&]:-right-2 [[data-side=left][data-collapsible=offcanvas]_&]:translate-x-0',
|
|
64
|
+
'[[data-side=right][data-collapsible=offcanvas]_&]:-left-2 [[data-side=right][data-collapsible=offcanvas]_&]:translate-x-0',
|
|
65
|
+
className,
|
|
66
|
+
)}
|
|
67
|
+
{...props}
|
|
68
|
+
/>
|
|
69
|
+
);
|
|
70
|
+
},
|
|
71
|
+
);
|
|
72
|
+
|
|
73
|
+
export const SidebarInset = forwardRef<HTMLDivElement, HTMLAttributes<HTMLDivElement>>(
|
|
74
|
+
function SidebarInset({ className, ...props }, ref) {
|
|
75
|
+
return (
|
|
76
|
+
<main
|
|
77
|
+
ref={ref}
|
|
78
|
+
className={cn(
|
|
79
|
+
'relative flex min-h-svh flex-1 flex-col bg-background',
|
|
80
|
+
'peer-data-[variant=inset]:min-h-[calc(100svh-theme(spacing.4))] md:peer-data-[variant=inset]:m-2 md:peer-data-[side=left]:peer-data-[variant=inset]:ml-0 md:peer-data-[side=right]:peer-data-[variant=inset]:mr-0 md:peer-data-[side=left]:peer-data-[state=collapsed]:peer-data-[variant=inset]:ml-2 md:peer-data-[side=right]:peer-data-[state=collapsed]:peer-data-[variant=inset]:mr-2 md:peer-data-[variant=inset]:rounded-xl md:peer-data-[variant=inset]:shadow',
|
|
81
|
+
className,
|
|
82
|
+
)}
|
|
83
|
+
{...props}
|
|
84
|
+
/>
|
|
85
|
+
);
|
|
86
|
+
},
|
|
87
|
+
);
|
|
88
|
+
|
|
89
|
+
export const SidebarInput = forwardRef<
|
|
90
|
+
HTMLInputElement,
|
|
91
|
+
ComponentProps<typeof Input>
|
|
92
|
+
>(function SidebarInput({ className, ...props }, ref) {
|
|
93
|
+
return (
|
|
94
|
+
<Input
|
|
95
|
+
ref={ref}
|
|
96
|
+
data-sidebar="input"
|
|
97
|
+
className={cn(
|
|
98
|
+
'h-8 w-full bg-background shadow-none focus-within:ring-2 focus-within:ring-sidebar-ring',
|
|
99
|
+
className,
|
|
100
|
+
)}
|
|
101
|
+
{...props}
|
|
102
|
+
/>
|
|
103
|
+
);
|
|
104
|
+
});
|