@maz-ui/mcp 5.0.0-beta.2 → 5.0.0-beta.25
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/README.md +1 -1
- package/dist/mcp.d.mts +22 -9
- package/dist/mcp.d.ts +22 -9
- package/dist/mcp.mjs +160 -83
- package/docs/generated-docs/maz-avatar.doc.md +25 -25
- package/docs/generated-docs/maz-btn.doc.md +1 -1
- package/docs/generated-docs/maz-checkbox.doc.md +16 -17
- package/docs/generated-docs/maz-circular-progress-bar.doc.md +1 -1
- package/docs/generated-docs/maz-code-highlight.doc.md +11 -0
- package/docs/generated-docs/maz-date-picker.doc.md +41 -41
- package/docs/generated-docs/maz-drawer.doc.md +7 -8
- package/docs/generated-docs/maz-expand-animation.doc.md +4 -4
- package/docs/generated-docs/maz-fullscreen-loader.doc.md +5 -5
- package/docs/generated-docs/maz-gallery.doc.md +15 -15
- package/docs/generated-docs/maz-input-code.doc.md +16 -16
- package/docs/generated-docs/maz-input-phone-number.doc.md +42 -38
- package/docs/generated-docs/maz-input-price.doc.md +14 -14
- package/docs/generated-docs/maz-input-tags.doc.md +16 -16
- package/docs/generated-docs/maz-input.doc.md +33 -33
- package/docs/generated-docs/maz-lazy-img.doc.md +14 -14
- package/docs/generated-docs/maz-loading-bar.doc.md +4 -4
- package/docs/generated-docs/maz-markdown-editor.doc.md +65 -0
- package/docs/generated-docs/maz-popover.doc.md +1 -1
- package/docs/generated-docs/maz-pull-to-refresh.doc.md +10 -10
- package/docs/generated-docs/maz-radio-buttons.doc.md +17 -17
- package/docs/generated-docs/maz-radio.doc.md +16 -16
- package/docs/generated-docs/maz-reading-progress-bar.doc.md +4 -4
- package/docs/generated-docs/maz-sidebar-content.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-footer.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-group.doc.md +11 -0
- package/docs/generated-docs/maz-sidebar-header.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-menu-button.doc.md +27 -0
- package/docs/generated-docs/maz-sidebar-menu-item.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-menu-sub.doc.md +16 -0
- package/docs/generated-docs/maz-sidebar-menu.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar-separator.doc.md +0 -0
- package/docs/generated-docs/maz-sidebar-trigger.doc.md +5 -0
- package/docs/generated-docs/maz-sidebar.doc.md +36 -0
- package/docs/generated-docs/maz-slider.doc.md +1 -1
- package/docs/generated-docs/maz-spinner.doc.md +4 -4
- package/docs/generated-docs/maz-switch.doc.md +14 -14
- package/docs/generated-docs/maz-table.doc.md +5 -5
- package/docs/generated-docs/maz-textarea.doc.md +25 -24
- package/docs/generated-docs/maz-ticker.doc.md +1 -1
- package/docs/generated-docs/maz-timeline.doc.md +4 -4
- package/docs/generated-docs/maz-window-mockup.doc.md +23 -0
- package/docs/src/blog/v4.md +1 -1
- package/docs/src/blog/v5.md +5 -7
- package/docs/src/components/maz-btn.md +1 -1
- package/docs/src/components/maz-code-highlight.md +233 -0
- package/docs/src/components/maz-container.md +2 -2
- package/docs/src/components/maz-date-picker.md +1 -1
- package/docs/src/components/maz-dialog.md +46 -0
- package/docs/src/components/maz-icon.md +2 -2
- package/docs/src/components/maz-input-phone-number.md +106 -103
- package/docs/src/components/maz-markdown-editor.md +369 -0
- package/docs/src/components/maz-sidebar.md +719 -0
- package/docs/src/components/maz-textarea.md +27 -1
- package/docs/src/components/maz-timeline.md +60 -0
- package/docs/src/components/maz-window-mockup.md +249 -0
- package/docs/src/directives/click-outside.md +8 -15
- package/docs/src/directives/fullscreen-img.md +1 -1
- package/docs/src/directives/lazy-img.md +5 -5
- package/docs/src/directives/tooltip.md +24 -1
- package/docs/src/directives/zoom-img.md +1 -1
- package/docs/src/ecosystem/eslint-config.md +95 -1
- package/docs/src/{guide/icons.md → ecosystem/icons/index.md} +1 -1
- package/docs/src/ecosystem/node/exec-promise.md +87 -0
- package/docs/src/ecosystem/node/index.md +53 -0
- package/docs/src/ecosystem/node/logger.md +146 -0
- package/docs/src/ecosystem/node/print-banner.md +93 -0
- package/docs/src/{guide → ecosystem}/nuxt.md +81 -47
- package/docs/src/{guide → ecosystem}/themes.md +153 -72
- package/docs/src/{guide → ecosystem}/translations.md +1 -1
- package/docs/src/ecosystem/utils/camel-case.md +31 -0
- package/docs/src/{helpers → ecosystem/utils}/capitalize.md +2 -3
- package/docs/src/ecosystem/utils/check-availability.md +79 -0
- package/docs/src/ecosystem/utils/cookie.md +80 -0
- package/docs/src/{helpers → ecosystem/utils}/currency.md +2 -2
- package/docs/src/{helpers → ecosystem/utils}/date.md +2 -2
- package/docs/src/ecosystem/utils/debounce-callback.md +38 -0
- package/docs/src/ecosystem/utils/debounce-id.md +69 -0
- package/docs/src/ecosystem/utils/debounce.md +65 -0
- package/docs/src/ecosystem/utils/fetch-locale-ip.md +33 -0
- package/docs/src/ecosystem/utils/format-json.md +33 -0
- package/docs/src/ecosystem/utils/format-phone-number.md +37 -0
- package/docs/src/ecosystem/utils/get-browser-locale.md +29 -0
- package/docs/src/ecosystem/utils/get-error-message.md +39 -0
- package/docs/src/ecosystem/utils/idle-timeout.md +90 -0
- package/docs/src/ecosystem/utils/index.md +60 -0
- package/docs/src/ecosystem/utils/is-client.md +32 -0
- package/docs/src/ecosystem/utils/is-equal.md +38 -0
- package/docs/src/ecosystem/utils/is-server.md +31 -0
- package/docs/src/ecosystem/utils/is-standalone-mode.md +43 -0
- package/docs/src/ecosystem/utils/kebab-case.md +36 -0
- package/docs/src/ecosystem/utils/normalize-string.md +77 -0
- package/docs/src/{helpers → ecosystem/utils}/number.md +2 -2
- package/docs/src/ecosystem/utils/pascal-case.md +35 -0
- package/docs/src/ecosystem/utils/script-loader.md +77 -0
- package/docs/src/ecosystem/utils/sleep.md +59 -0
- package/docs/src/ecosystem/utils/snake-case.md +36 -0
- package/docs/src/ecosystem/utils/swipe-handler.md +91 -0
- package/docs/src/ecosystem/utils/textarea-autogrow.md +41 -0
- package/docs/src/ecosystem/utils/throttle-id.md +48 -0
- package/docs/src/ecosystem/utils/throttle.md +57 -0
- package/docs/src/ecosystem/utils/truthy-filter.md +31 -0
- package/docs/src/ecosystem/utils/types/deep-key-of.md +48 -0
- package/docs/src/ecosystem/utils/types/deep-partial.md +42 -0
- package/docs/src/ecosystem/utils/types/deep-required.md +39 -0
- package/docs/src/ecosystem/utils/types/flatten-object-keys.md +44 -0
- package/docs/src/ecosystem/utils/types/generic-instance-type.md +42 -0
- package/docs/src/ecosystem/utils/types/infer-maybe-ref.md +35 -0
- package/docs/src/ecosystem/utils/upper-first.md +32 -0
- package/docs/src/ecosystem/utils/user-visibility.md +69 -0
- package/docs/src/guide/getting-started.md +15 -13
- package/docs/src/guide/global-defaults.md +101 -0
- package/docs/src/guide/maz-ui-provider.md +6 -3
- package/docs/src/guide/migration-v4.md +13 -9
- package/docs/src/guide/migration-v5.md +67 -12
- package/docs/src/guide/resolvers.md +7 -7
- package/docs/src/guide/tailwind.md +4 -0
- package/docs/src/guide/vue.md +4 -4
- package/docs/src/index.md +12 -12
- package/docs/src/plugins/aos.md +1 -1
- package/docs/src/plugins/wait.md +1 -1
- package/package.json +6 -5
- package/docs/src/helpers/camel-case.md +0 -14
- package/docs/src/helpers/check-availability.md +0 -14
- package/docs/src/helpers/debounce-callback.md +0 -14
- package/docs/src/helpers/debounce-id.md +0 -14
- package/docs/src/helpers/debounce.md +0 -14
- package/docs/src/helpers/is-client.md +0 -14
- package/docs/src/helpers/is-equal.md +0 -14
- package/docs/src/helpers/is-standalone-mode.md +0 -14
- package/docs/src/helpers/kebab-case.md +0 -14
- package/docs/src/helpers/normalize-string.md +0 -14
- package/docs/src/helpers/pascal-case.md +0 -14
- package/docs/src/helpers/script-loader.md +0 -14
- package/docs/src/helpers/sleep.md +0 -14
- package/docs/src/helpers/snake-case.md +0 -14
- package/docs/src/helpers/throttle-id.md +0 -14
- package/docs/src/helpers/throttle.md +0 -14
- /package/docs/src/{guide → ecosystem/icons}/icon-set.md +0 -0
- /package/docs/src/{guide → ecosystem}/mcp.md +0 -0
- /package/docs/src/{helpers → ecosystem/utils}/country-code-to-unicode-flag.md +0 -0
- /package/docs/src/{helpers → ecosystem/utils}/get-country-flag-url.md +0 -0
|
@@ -0,0 +1,719 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: MazSidebar
|
|
3
|
+
description: MazSidebar is a composable sidebar system for dashboard, admin, and SaaS applications. It provides a fully accessible, collapsible navigation with multiple display modes.
|
|
4
|
+
---
|
|
5
|
+
|
|
6
|
+
# {{ $frontmatter.title }}
|
|
7
|
+
|
|
8
|
+
{{ $frontmatter.description }}
|
|
9
|
+
|
|
10
|
+
<!--@include: ./../../.vitepress/mixins/getting-started.md-->
|
|
11
|
+
|
|
12
|
+
::: tip
|
|
13
|
+
`MazSidebar` shares its state with all sub-components via Vue's `provide`/`inject`. No separate Provider component is needed. All sub-components must be descendants of `MazSidebar`.
|
|
14
|
+
:::
|
|
15
|
+
|
|
16
|
+
::: warning Deferred features (v1.1)
|
|
17
|
+
The following features are planned for a future release and are **not yet available**:
|
|
18
|
+
- `localStorage` state persistence
|
|
19
|
+
- `Cmd/Ctrl+B` keyboard shortcut
|
|
20
|
+
- Automatic mobile drawer under a breakpoint
|
|
21
|
+
:::
|
|
22
|
+
|
|
23
|
+
## Sub-components
|
|
24
|
+
|
|
25
|
+
| Component | Role |
|
|
26
|
+
|---|---|
|
|
27
|
+
| `MazSidebar` | Root container — provides state context |
|
|
28
|
+
| `MazSidebarHeader` | Fixed top area |
|
|
29
|
+
| `MazSidebarContent` | Scrollable central area |
|
|
30
|
+
| `MazSidebarFooter` | Fixed bottom area |
|
|
31
|
+
| `MazSidebarGroup` | Item grouping with optional label |
|
|
32
|
+
| `MazSidebarSeparator` | Visual divider (`<hr>`) |
|
|
33
|
+
| `MazSidebarMenu` | `<ul>` wrapper with `role="menu"` |
|
|
34
|
+
| `MazSidebarMenuItem` | `<li>` item wrapper |
|
|
35
|
+
| `MazSidebarMenuButton` | Clickable item (link or button), supports icon, label, badge, tooltip |
|
|
36
|
+
| `MazSidebarMenuSub` | Collapsible sub-menu |
|
|
37
|
+
| `MazSidebarTrigger` | Toggle button (must be a descendant of `MazSidebar`) |
|
|
38
|
+
|
|
39
|
+
## Basic usage
|
|
40
|
+
|
|
41
|
+
<ComponentDemo>
|
|
42
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[25rem] maz:flex">
|
|
43
|
+
<MazSidebar v-model:open="basicOpen" class="maz:h-full">
|
|
44
|
+
<MazSidebarHeader>
|
|
45
|
+
<div class="maz:p-4 maz:font-bold">My App</div>
|
|
46
|
+
</MazSidebarHeader>
|
|
47
|
+
<MazSidebarContent>
|
|
48
|
+
<MazSidebarMenu>
|
|
49
|
+
<MazSidebarMenuItem>
|
|
50
|
+
<MazSidebarMenuButton label="Dashboard" :active="true" />
|
|
51
|
+
</MazSidebarMenuItem>
|
|
52
|
+
<MazSidebarMenuItem>
|
|
53
|
+
<MazSidebarMenuButton label="Settings" />
|
|
54
|
+
</MazSidebarMenuItem>
|
|
55
|
+
</MazSidebarMenu>
|
|
56
|
+
</MazSidebarContent>
|
|
57
|
+
<MazSidebarFooter>
|
|
58
|
+
<div class="maz:p-4">Footer</div>
|
|
59
|
+
</MazSidebarFooter>
|
|
60
|
+
</MazSidebar>
|
|
61
|
+
<main class="maz:flex-1 maz:p-4">Main content</main>
|
|
62
|
+
</div>
|
|
63
|
+
|
|
64
|
+
<template #code>
|
|
65
|
+
|
|
66
|
+
```html
|
|
67
|
+
<div class="maz:flex maz:h-screen">
|
|
68
|
+
<MazSidebar v-model:open="isOpen">
|
|
69
|
+
<MazSidebarHeader>
|
|
70
|
+
<div class="maz:p-4 maz:font-bold">My App</div>
|
|
71
|
+
</MazSidebarHeader>
|
|
72
|
+
<MazSidebarContent>
|
|
73
|
+
<MazSidebarMenu>
|
|
74
|
+
<MazSidebarMenuItem>
|
|
75
|
+
<MazSidebarMenuButton label="Dashboard" :active="true" />
|
|
76
|
+
</MazSidebarMenuItem>
|
|
77
|
+
<MazSidebarMenuItem>
|
|
78
|
+
<MazSidebarMenuButton label="Settings" />
|
|
79
|
+
</MazSidebarMenuItem>
|
|
80
|
+
</MazSidebarMenu>
|
|
81
|
+
</MazSidebarContent>
|
|
82
|
+
<MazSidebarFooter>
|
|
83
|
+
<div class="maz:p-4">Footer</div>
|
|
84
|
+
</MazSidebarFooter>
|
|
85
|
+
</MazSidebar>
|
|
86
|
+
<main class="maz:flex-1 maz:p-4">Main content</main>
|
|
87
|
+
</div>
|
|
88
|
+
|
|
89
|
+
<script setup>
|
|
90
|
+
const isOpen = ref(true)
|
|
91
|
+
</script>
|
|
92
|
+
```
|
|
93
|
+
|
|
94
|
+
</template>
|
|
95
|
+
</ComponentDemo>
|
|
96
|
+
|
|
97
|
+
## Groups & dividers
|
|
98
|
+
|
|
99
|
+
<ComponentDemo>
|
|
100
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[25rem] maz:flex">
|
|
101
|
+
<MazSidebar v-model:open="groupsOpen" class="maz:h-full">
|
|
102
|
+
<MazSidebarContent>
|
|
103
|
+
<MazSidebarGroup label="Navigation">
|
|
104
|
+
<MazSidebarMenu>
|
|
105
|
+
<MazSidebarMenuItem>
|
|
106
|
+
<MazSidebarMenuButton label="Dashboard" :active="true" />
|
|
107
|
+
</MazSidebarMenuItem>
|
|
108
|
+
<MazSidebarMenuItem>
|
|
109
|
+
<MazSidebarMenuButton label="Projects" />
|
|
110
|
+
</MazSidebarMenuItem>
|
|
111
|
+
</MazSidebarMenu>
|
|
112
|
+
</MazSidebarGroup>
|
|
113
|
+
<MazSidebarSeparator />
|
|
114
|
+
<MazSidebarGroup label="Settings">
|
|
115
|
+
<MazSidebarMenu>
|
|
116
|
+
<MazSidebarMenuItem>
|
|
117
|
+
<MazSidebarMenuButton label="Profile" />
|
|
118
|
+
</MazSidebarMenuItem>
|
|
119
|
+
<MazSidebarMenuItem>
|
|
120
|
+
<MazSidebarMenuButton label="Billing" />
|
|
121
|
+
</MazSidebarMenuItem>
|
|
122
|
+
</MazSidebarMenu>
|
|
123
|
+
</MazSidebarGroup>
|
|
124
|
+
</MazSidebarContent>
|
|
125
|
+
</MazSidebar>
|
|
126
|
+
<main class="maz:flex-1 maz:p-4">Main content</main>
|
|
127
|
+
</div>
|
|
128
|
+
|
|
129
|
+
<template #code>
|
|
130
|
+
|
|
131
|
+
```html
|
|
132
|
+
<MazSidebar v-model:open="isOpen">
|
|
133
|
+
<MazSidebarContent>
|
|
134
|
+
<MazSidebarGroup label="Navigation">
|
|
135
|
+
<MazSidebarMenu>
|
|
136
|
+
<MazSidebarMenuItem>
|
|
137
|
+
<MazSidebarMenuButton label="Dashboard" :active="true" />
|
|
138
|
+
</MazSidebarMenuItem>
|
|
139
|
+
<MazSidebarMenuItem>
|
|
140
|
+
<MazSidebarMenuButton label="Projects" />
|
|
141
|
+
</MazSidebarMenuItem>
|
|
142
|
+
</MazSidebarMenu>
|
|
143
|
+
</MazSidebarGroup>
|
|
144
|
+
<MazSidebarSeparator />
|
|
145
|
+
<MazSidebarGroup label="Settings">
|
|
146
|
+
<MazSidebarMenu>
|
|
147
|
+
<MazSidebarMenuItem>
|
|
148
|
+
<MazSidebarMenuButton label="Profile" />
|
|
149
|
+
</MazSidebarMenuItem>
|
|
150
|
+
</MazSidebarMenu>
|
|
151
|
+
</MazSidebarGroup>
|
|
152
|
+
</MazSidebarContent>
|
|
153
|
+
</MazSidebar>
|
|
154
|
+
```
|
|
155
|
+
|
|
156
|
+
</template>
|
|
157
|
+
</ComponentDemo>
|
|
158
|
+
|
|
159
|
+
## Sub-menus
|
|
160
|
+
|
|
161
|
+
<ComponentDemo>
|
|
162
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[25rem] maz:flex">
|
|
163
|
+
<MazSidebar v-model:open="submenusOpen" class="maz:h-full">
|
|
164
|
+
<MazSidebarContent>
|
|
165
|
+
<MazSidebarMenu>
|
|
166
|
+
<MazSidebarMenuItem>
|
|
167
|
+
<MazSidebarMenuButton label="Dashboard" :active="true" />
|
|
168
|
+
</MazSidebarMenuItem>
|
|
169
|
+
<MazSidebarMenuItem>
|
|
170
|
+
<MazSidebarMenuSub label="Products" :default-open="true">
|
|
171
|
+
<MazSidebarMenuItem>
|
|
172
|
+
<MazSidebarMenuButton label="All Products" />
|
|
173
|
+
</MazSidebarMenuItem>
|
|
174
|
+
<MazSidebarMenuItem>
|
|
175
|
+
<MazSidebarMenuButton label="Add Product" />
|
|
176
|
+
</MazSidebarMenuItem>
|
|
177
|
+
</MazSidebarMenuSub>
|
|
178
|
+
</MazSidebarMenuItem>
|
|
179
|
+
<MazSidebarMenuItem>
|
|
180
|
+
<MazSidebarMenuSub label="Reports">
|
|
181
|
+
<MazSidebarMenuItem>
|
|
182
|
+
<MazSidebarMenuButton label="Sales" />
|
|
183
|
+
</MazSidebarMenuItem>
|
|
184
|
+
</MazSidebarMenuSub>
|
|
185
|
+
</MazSidebarMenuItem>
|
|
186
|
+
</MazSidebarMenu>
|
|
187
|
+
</MazSidebarContent>
|
|
188
|
+
</MazSidebar>
|
|
189
|
+
<main class="maz:flex-1 maz:p-4">Main content</main>
|
|
190
|
+
</div>
|
|
191
|
+
|
|
192
|
+
<template #code>
|
|
193
|
+
|
|
194
|
+
```html
|
|
195
|
+
<MazSidebar v-model:open="isOpen">
|
|
196
|
+
<MazSidebarContent>
|
|
197
|
+
<MazSidebarMenu>
|
|
198
|
+
<MazSidebarMenuItem>
|
|
199
|
+
<MazSidebarMenuSub label="Products" :default-open="true">
|
|
200
|
+
<MazSidebarMenuItem>
|
|
201
|
+
<MazSidebarMenuButton label="All Products" />
|
|
202
|
+
</MazSidebarMenuItem>
|
|
203
|
+
<MazSidebarMenuItem>
|
|
204
|
+
<MazSidebarMenuButton label="Add Product" />
|
|
205
|
+
</MazSidebarMenuItem>
|
|
206
|
+
</MazSidebarMenuSub>
|
|
207
|
+
</MazSidebarMenuItem>
|
|
208
|
+
</MazSidebarMenu>
|
|
209
|
+
</MazSidebarContent>
|
|
210
|
+
</MazSidebar>
|
|
211
|
+
```
|
|
212
|
+
|
|
213
|
+
</template>
|
|
214
|
+
</ComponentDemo>
|
|
215
|
+
|
|
216
|
+
## Icon mode with tooltips
|
|
217
|
+
|
|
218
|
+
When `collapsible="icon"` and the sidebar is collapsed, labels fade out and only the icons stay visible. To help users identify items in collapsed state, provide a `tooltip` prop on each `MazSidebarMenuButton`: it uses the `v-tooltip` directive and is only shown on hover when the sidebar is collapsed by default.
|
|
219
|
+
|
|
220
|
+
### Controlling when the tooltip appears
|
|
221
|
+
|
|
222
|
+
Both `MazSidebar` and `MazSidebarMenuButton` accept a `tooltip-mode` prop:
|
|
223
|
+
|
|
224
|
+
- `closed` (default on the sidebar) — tooltip only shows on hover when the sidebar is collapsed
|
|
225
|
+
- `always` — tooltip shows on hover regardless of the sidebar state
|
|
226
|
+
|
|
227
|
+
Set it on the sidebar to apply to every descendant button, or override per-button:
|
|
228
|
+
|
|
229
|
+
```html
|
|
230
|
+
<!-- Every button: tooltip visible only when collapsed -->
|
|
231
|
+
<MazSidebar tooltip-mode="closed">
|
|
232
|
+
<MazSidebarMenuButton :icon="MazHome" label="Dashboard" tooltip="Go to Dashboard" />
|
|
233
|
+
</MazSidebar>
|
|
234
|
+
|
|
235
|
+
<!-- This button overrides: tooltip always shown -->
|
|
236
|
+
<MazSidebar tooltip-mode="closed">
|
|
237
|
+
<MazSidebarMenuButton
|
|
238
|
+
:icon="MazCog6Tooth"
|
|
239
|
+
label="Settings"
|
|
240
|
+
tooltip="Open Settings"
|
|
241
|
+
tooltip-mode="always"
|
|
242
|
+
/>
|
|
243
|
+
</MazSidebar>
|
|
244
|
+
```
|
|
245
|
+
|
|
246
|
+
::: tip Performance
|
|
247
|
+
When no `tooltip` prop is provided on a button, the `v-tooltip` directive is not attached at all — no listeners, no popover instance.
|
|
248
|
+
:::
|
|
249
|
+
|
|
250
|
+
<ComponentDemo>
|
|
251
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[25rem] maz:flex">
|
|
252
|
+
<MazSidebar v-model:open="iconModeOpen" collapsible="icon" class="maz:h-full">
|
|
253
|
+
<MazSidebarContent>
|
|
254
|
+
<MazSidebarMenu>
|
|
255
|
+
<MazSidebarMenuItem>
|
|
256
|
+
<MazSidebarMenuButton :icon="MazHome" label="Dashboard" tooltip="Go to Dashboard" :active="true" />
|
|
257
|
+
</MazSidebarMenuItem>
|
|
258
|
+
<MazSidebarMenuItem>
|
|
259
|
+
<MazSidebarMenuButton :icon="MazCog6Tooth" label="Settings" tooltip="Open Settings" />
|
|
260
|
+
</MazSidebarMenuItem>
|
|
261
|
+
</MazSidebarMenu>
|
|
262
|
+
</MazSidebarContent>
|
|
263
|
+
<MazSidebarFooter>
|
|
264
|
+
<MazSidebarTrigger />
|
|
265
|
+
</MazSidebarFooter>
|
|
266
|
+
</MazSidebar>
|
|
267
|
+
<main class="maz:flex-1 maz:flex maz:flex-col maz:gap-4 maz:p-4">
|
|
268
|
+
Click the trigger to collapse/expand
|
|
269
|
+
<MazBtn @click="iconModeOpen = !iconModeOpen">Toggle sidebar</MazBtn>
|
|
270
|
+
</main>
|
|
271
|
+
</div>
|
|
272
|
+
|
|
273
|
+
<template #code>
|
|
274
|
+
|
|
275
|
+
```html
|
|
276
|
+
<script setup>
|
|
277
|
+
import { MazHome } from '@maz-ui/icons/lazy/MazHome'
|
|
278
|
+
import { MazCog6Tooth } from '@maz-ui/icons/lazy/MazCog6Tooth'
|
|
279
|
+
|
|
280
|
+
const isOpen = ref(true)
|
|
281
|
+
</script>
|
|
282
|
+
|
|
283
|
+
<template>
|
|
284
|
+
<MazSidebar v-model:open="isOpen" collapsible="icon">
|
|
285
|
+
<MazSidebarContent>
|
|
286
|
+
<MazSidebarMenu>
|
|
287
|
+
<MazSidebarMenuItem>
|
|
288
|
+
<MazSidebarMenuButton :icon="MazHome" label="Dashboard" tooltip="Go to Dashboard" />
|
|
289
|
+
</MazSidebarMenuItem>
|
|
290
|
+
</MazSidebarMenu>
|
|
291
|
+
</MazSidebarContent>
|
|
292
|
+
<MazSidebarFooter>
|
|
293
|
+
<MazSidebarTrigger />
|
|
294
|
+
</MazSidebarFooter>
|
|
295
|
+
</MazSidebar>
|
|
296
|
+
</template>
|
|
297
|
+
```
|
|
298
|
+
|
|
299
|
+
</template>
|
|
300
|
+
</ComponentDemo>
|
|
301
|
+
|
|
302
|
+
## Hover mode
|
|
303
|
+
|
|
304
|
+
`collapsible="hover"` displays the sidebar in icon-only mode and **automatically expands it when the mouse enters the sidebar (or any descendant) and collapses it when the mouse leaves**. Keyboard focus also expands the sidebar, so users navigating with `Tab` see the full labels.
|
|
305
|
+
|
|
306
|
+
::: tip
|
|
307
|
+
This is a **purely visual** state. The `v-model:open` value is not updated and the persistence cookie is not written when the sidebar expands or collapses through hover. Use this mode when you want the rail-style sidebar of `collapsible="icon"` without exposing a toggle.
|
|
308
|
+
:::
|
|
309
|
+
|
|
310
|
+
<ComponentDemo>
|
|
311
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[22rem] maz:flex">
|
|
312
|
+
<MazSidebar collapsible="hover" class="maz:h-full">
|
|
313
|
+
<MazSidebarContent>
|
|
314
|
+
<MazSidebarMenu>
|
|
315
|
+
<MazSidebarMenuItem>
|
|
316
|
+
<MazSidebarMenuButton :icon="MazHome" label="Dashboard" :active="true" />
|
|
317
|
+
</MazSidebarMenuItem>
|
|
318
|
+
<MazSidebarMenuItem>
|
|
319
|
+
<MazSidebarMenuButton :icon="MazCog6Tooth" label="Settings" />
|
|
320
|
+
</MazSidebarMenuItem>
|
|
321
|
+
</MazSidebarMenu>
|
|
322
|
+
</MazSidebarContent>
|
|
323
|
+
</MazSidebar>
|
|
324
|
+
<main class="maz:flex-1 maz:p-4">Move your cursor over the sidebar to expand it.</main>
|
|
325
|
+
</div>
|
|
326
|
+
|
|
327
|
+
<template #code>
|
|
328
|
+
|
|
329
|
+
```html
|
|
330
|
+
<MazSidebar collapsible="hover">
|
|
331
|
+
<MazSidebarContent>
|
|
332
|
+
<MazSidebarMenu>
|
|
333
|
+
<MazSidebarMenuItem>
|
|
334
|
+
<MazSidebarMenuButton :icon="MazHome" label="Dashboard" />
|
|
335
|
+
</MazSidebarMenuItem>
|
|
336
|
+
<MazSidebarMenuItem>
|
|
337
|
+
<MazSidebarMenuButton :icon="MazCog6Tooth" label="Settings" />
|
|
338
|
+
</MazSidebarMenuItem>
|
|
339
|
+
</MazSidebarMenu>
|
|
340
|
+
</MazSidebarContent>
|
|
341
|
+
</MazSidebar>
|
|
342
|
+
```
|
|
343
|
+
|
|
344
|
+
</template>
|
|
345
|
+
</ComponentDemo>
|
|
346
|
+
|
|
347
|
+
## Offcanvas mode
|
|
348
|
+
|
|
349
|
+
<ComponentDemo>
|
|
350
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[20rem] maz:flex">
|
|
351
|
+
<MazSidebar v-model:open="offcanvasOpen" collapsible="offcanvas" class="maz:h-full">
|
|
352
|
+
<MazSidebarContent>
|
|
353
|
+
<MazSidebarMenu>
|
|
354
|
+
<MazSidebarMenuItem>
|
|
355
|
+
<MazSidebarMenuButton label="Home" :active="true" />
|
|
356
|
+
</MazSidebarMenuItem>
|
|
357
|
+
<MazSidebarMenuItem>
|
|
358
|
+
<MazSidebarMenuButton label="About" />
|
|
359
|
+
</MazSidebarMenuItem>
|
|
360
|
+
</MazSidebarMenu>
|
|
361
|
+
</MazSidebarContent>
|
|
362
|
+
</MazSidebar>
|
|
363
|
+
<main class="maz:flex-1 maz:flex maz:flex-col maz:gap-4 maz:p-4">
|
|
364
|
+
<MazBtn @click="offcanvasOpen = !offcanvasOpen">Toggle sidebar</MazBtn>
|
|
365
|
+
Main content — sidebar disappears completely when closed
|
|
366
|
+
</main>
|
|
367
|
+
</div>
|
|
368
|
+
|
|
369
|
+
<template #code>
|
|
370
|
+
|
|
371
|
+
```html
|
|
372
|
+
<MazSidebar v-model:open="isOpen" collapsible="offcanvas">
|
|
373
|
+
<!-- content -->
|
|
374
|
+
</MazSidebar>
|
|
375
|
+
```
|
|
376
|
+
|
|
377
|
+
</template>
|
|
378
|
+
</ComponentDemo>
|
|
379
|
+
|
|
380
|
+
## Overlay vs push mode
|
|
381
|
+
|
|
382
|
+
In `mode="push"` (default), the sidebar is part of the document flow and pushes the main content.
|
|
383
|
+
In `mode="overlay"`, the sidebar floats over the content with a backdrop, escape key support and focus trapping.
|
|
384
|
+
|
|
385
|
+
<ComponentDemo>
|
|
386
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[20rem] maz:relative">
|
|
387
|
+
<MazBtn class="maz:absolute maz:top-4 maz:left-4 maz:z-1" @click="overlayOpen = !overlayOpen">
|
|
388
|
+
Toggle overlay sidebar
|
|
389
|
+
</MazBtn>
|
|
390
|
+
<MazSidebar v-model:open="overlayOpen" mode="overlay">
|
|
391
|
+
<MazSidebarHeader>
|
|
392
|
+
<div class="maz:p-4 maz:font-bold">Overlay Sidebar</div>
|
|
393
|
+
</MazSidebarHeader>
|
|
394
|
+
<MazSidebarContent>
|
|
395
|
+
<MazSidebarMenu>
|
|
396
|
+
<MazSidebarMenuItem>
|
|
397
|
+
<MazSidebarMenuButton label="Home" :active="true" />
|
|
398
|
+
</MazSidebarMenuItem>
|
|
399
|
+
</MazSidebarMenu>
|
|
400
|
+
</MazSidebarContent>
|
|
401
|
+
<MazSidebarFooter>
|
|
402
|
+
<MazSidebarTrigger />
|
|
403
|
+
</MazSidebarFooter>
|
|
404
|
+
</MazSidebar>
|
|
405
|
+
</div>
|
|
406
|
+
|
|
407
|
+
<template #code>
|
|
408
|
+
|
|
409
|
+
```html
|
|
410
|
+
<!-- Overlay mode: sidebar floats over content -->
|
|
411
|
+
<MazSidebar v-model:open="isOpen" mode="overlay">
|
|
412
|
+
<!-- content -->
|
|
413
|
+
</MazSidebar>
|
|
414
|
+
```
|
|
415
|
+
|
|
416
|
+
</template>
|
|
417
|
+
</ComponentDemo>
|
|
418
|
+
|
|
419
|
+
## Side end (right)
|
|
420
|
+
|
|
421
|
+
<ComponentDemo>
|
|
422
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[20rem] maz:flex">
|
|
423
|
+
<main class="maz:flex-1 maz:p-4">Main content</main>
|
|
424
|
+
<MazSidebar v-model:open="sideEndOpen" side="end" class="maz:h-full">
|
|
425
|
+
<MazSidebarContent>
|
|
426
|
+
<MazSidebarMenu>
|
|
427
|
+
<MazSidebarMenuItem>
|
|
428
|
+
<MazSidebarMenuButton label="Right panel item" />
|
|
429
|
+
</MazSidebarMenuItem>
|
|
430
|
+
</MazSidebarMenu>
|
|
431
|
+
</MazSidebarContent>
|
|
432
|
+
</MazSidebar>
|
|
433
|
+
</div>
|
|
434
|
+
|
|
435
|
+
<template #code>
|
|
436
|
+
|
|
437
|
+
```html
|
|
438
|
+
<div class="maz:flex maz:h-screen">
|
|
439
|
+
<main class="maz:flex-1">Main content</main>
|
|
440
|
+
<MazSidebar v-model:open="isOpen" side="end">
|
|
441
|
+
<!-- content -->
|
|
442
|
+
</MazSidebar>
|
|
443
|
+
</div>
|
|
444
|
+
```
|
|
445
|
+
|
|
446
|
+
</template>
|
|
447
|
+
</ComponentDemo>
|
|
448
|
+
|
|
449
|
+
## Badges
|
|
450
|
+
|
|
451
|
+
`badge` accepts a `string`, a `number`, or a full `MazBadgeProps` object (with an optional `text`) to fine-tune color, size, outlined, etc.
|
|
452
|
+
|
|
453
|
+
<ComponentDemo>
|
|
454
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[22rem] maz:flex">
|
|
455
|
+
<MazSidebar v-model:open="badgesOpen" class="maz:h-full">
|
|
456
|
+
<MazSidebarContent>
|
|
457
|
+
<MazSidebarMenu>
|
|
458
|
+
<MazSidebarMenuItem>
|
|
459
|
+
<MazSidebarMenuButton label="Inbox" :badge="12" :active="true" />
|
|
460
|
+
</MazSidebarMenuItem>
|
|
461
|
+
<MazSidebarMenuItem>
|
|
462
|
+
<MazSidebarMenuButton label="Errors" :badge="{ text: 3, color: 'destructive' }" />
|
|
463
|
+
</MazSidebarMenuItem>
|
|
464
|
+
<MazSidebarMenuItem>
|
|
465
|
+
<MazSidebarMenuButton label="Beta" :badge="{ text: 'NEW', color: 'success', outlined: true }" />
|
|
466
|
+
</MazSidebarMenuItem>
|
|
467
|
+
<MazSidebarMenuItem>
|
|
468
|
+
<MazSidebarMenuButton label="Settings" />
|
|
469
|
+
</MazSidebarMenuItem>
|
|
470
|
+
</MazSidebarMenu>
|
|
471
|
+
</MazSidebarContent>
|
|
472
|
+
</MazSidebar>
|
|
473
|
+
<main class="maz:flex-1 maz:flex maz:flex-col maz:gap-4 maz:p-4">
|
|
474
|
+
Badges are hidden in icon-collapsed mode.
|
|
475
|
+
<MazBtn @click="badgesOpen = !badgesOpen">Toggle sidebar</MazBtn>
|
|
476
|
+
</main>
|
|
477
|
+
</div>
|
|
478
|
+
|
|
479
|
+
<template #code>
|
|
480
|
+
|
|
481
|
+
```html
|
|
482
|
+
<!-- Simple: pass a string or number -->
|
|
483
|
+
<MazSidebarMenuButton label="Inbox" :badge="12" />
|
|
484
|
+
|
|
485
|
+
<!-- Full customisation: pass a MazBadgeProps object -->
|
|
486
|
+
<MazSidebarMenuButton
|
|
487
|
+
label="Errors"
|
|
488
|
+
:badge="{ text: 3, color: 'destructive' }"
|
|
489
|
+
/>
|
|
490
|
+
<MazSidebarMenuButton
|
|
491
|
+
label="Beta"
|
|
492
|
+
:badge="{ text: 'NEW', color: 'success', outlined: true }"
|
|
493
|
+
/>
|
|
494
|
+
```
|
|
495
|
+
|
|
496
|
+
</template>
|
|
497
|
+
</ComponentDemo>
|
|
498
|
+
|
|
499
|
+
## User menu in footer
|
|
500
|
+
|
|
501
|
+
<ComponentDemo>
|
|
502
|
+
<div class="maz:border maz:border-divider maz:overflow-hidden maz:rounded-md maz:h-[22rem] maz:flex">
|
|
503
|
+
<MazSidebar v-model:open="userMenuOpen" class="maz:h-full">
|
|
504
|
+
<MazSidebarContent>
|
|
505
|
+
<MazSidebarMenu>
|
|
506
|
+
<MazSidebarMenuItem>
|
|
507
|
+
<MazSidebarMenuButton label="Dashboard" :active="true" />
|
|
508
|
+
</MazSidebarMenuItem>
|
|
509
|
+
</MazSidebarMenu>
|
|
510
|
+
</MazSidebarContent>
|
|
511
|
+
<MazSidebarFooter>
|
|
512
|
+
<div class="maz:flex maz:items-center maz:gap-3 maz:p-3">
|
|
513
|
+
<MazAvatar src="https://placedog.net/100/100" size="0.8rem" />
|
|
514
|
+
<div class="maz:flex-1 maz:min-w-0">
|
|
515
|
+
<p class="maz:m-0 maz:text-md maz:font-semibold">Jane Doe</p>
|
|
516
|
+
<p class="maz:m-0 maz:text-xs maz:text-muted">jane@example.com</p>
|
|
517
|
+
</div>
|
|
518
|
+
</div>
|
|
519
|
+
</MazSidebarFooter>
|
|
520
|
+
</MazSidebar>
|
|
521
|
+
<main class="maz:flex-1 maz:p-4">Main content</main>
|
|
522
|
+
</div>
|
|
523
|
+
|
|
524
|
+
<template #code>
|
|
525
|
+
|
|
526
|
+
```html
|
|
527
|
+
<MazSidebar v-model:open="isOpen">
|
|
528
|
+
<MazSidebarContent><!-- ... --></MazSidebarContent>
|
|
529
|
+
<MazSidebarFooter>
|
|
530
|
+
<div class="maz:flex maz:items-center maz:gap-3 maz:p-3">
|
|
531
|
+
<MazAvatar src="..." size="0.8rem" />
|
|
532
|
+
<div class="maz:flex-1 maz:min-w-0">
|
|
533
|
+
<p class="maz:m-0 maz:text-md maz:font-semibold">Jane Doe</p>
|
|
534
|
+
<p class="maz:m-0 maz:text-xs maz:text-muted">jane@example.com</p>
|
|
535
|
+
</div>
|
|
536
|
+
</div>
|
|
537
|
+
</MazSidebarFooter>
|
|
538
|
+
</MazSidebar>
|
|
539
|
+
```
|
|
540
|
+
|
|
541
|
+
</template>
|
|
542
|
+
</ComponentDemo>
|
|
543
|
+
|
|
544
|
+
## Mobile (static rendering)
|
|
545
|
+
|
|
546
|
+
::: info
|
|
547
|
+
Automatic mobile drawer (drawer auto under a breakpoint with backdrop) is a **deferred v1.1 feature**. For now, control the sidebar visibility programmatically based on viewport.
|
|
548
|
+
:::
|
|
549
|
+
|
|
550
|
+
```html
|
|
551
|
+
<script setup>
|
|
552
|
+
import { useWindowSize } from 'maz-ui'
|
|
553
|
+
|
|
554
|
+
const { width } = useWindowSize()
|
|
555
|
+
const isMobile = computed(() => width.value < 768)
|
|
556
|
+
const isOpen = ref(!isMobile.value)
|
|
557
|
+
|
|
558
|
+
watch(isMobile, (mobile) => {
|
|
559
|
+
isOpen.value = !mobile
|
|
560
|
+
})
|
|
561
|
+
</script>
|
|
562
|
+
|
|
563
|
+
<template>
|
|
564
|
+
<div class="maz:flex maz:h-screen">
|
|
565
|
+
<MazSidebar v-model:open="isOpen" :mode="isMobile ? 'overlay' : 'push'">
|
|
566
|
+
<!-- content -->
|
|
567
|
+
</MazSidebar>
|
|
568
|
+
<main class="maz:flex-1">
|
|
569
|
+
<MazSidebarTrigger />
|
|
570
|
+
<!-- page content -->
|
|
571
|
+
</main>
|
|
572
|
+
</div>
|
|
573
|
+
</template>
|
|
574
|
+
```
|
|
575
|
+
|
|
576
|
+
## Programmatic control (v-model + composable)
|
|
577
|
+
|
|
578
|
+
Use `v-model:open` for two-way binding, or `useSidebar()` inside any descendant component.
|
|
579
|
+
|
|
580
|
+
```html
|
|
581
|
+
<script setup>
|
|
582
|
+
import { useSidebar } from 'maz-ui'
|
|
583
|
+
|
|
584
|
+
// Inside a child component that is a descendant of MazSidebar:
|
|
585
|
+
const sidebar = useSidebar()
|
|
586
|
+
|
|
587
|
+
// sidebar.open.value → boolean
|
|
588
|
+
// sidebar.state.value → 'expanded' | 'collapsed'
|
|
589
|
+
// sidebar.toggle() → toggle open state
|
|
590
|
+
// sidebar.setOpen(true/false) → set explicitly
|
|
591
|
+
</script>
|
|
592
|
+
|
|
593
|
+
<template>
|
|
594
|
+
<MazSidebar v-model:open="isOpen">
|
|
595
|
+
<MazSidebarContent>
|
|
596
|
+
<MazSidebarMenu>
|
|
597
|
+
<MazSidebarMenuItem>
|
|
598
|
+
<MazSidebarMenuButton label="Dashboard" />
|
|
599
|
+
</MazSidebarMenuItem>
|
|
600
|
+
</MazSidebarMenu>
|
|
601
|
+
</MazSidebarContent>
|
|
602
|
+
<!-- MazSidebarTrigger uses useSidebar() internally -->
|
|
603
|
+
<MazSidebarTrigger />
|
|
604
|
+
</MazSidebar>
|
|
605
|
+
</template>
|
|
606
|
+
```
|
|
607
|
+
|
|
608
|
+
## Persistent open state
|
|
609
|
+
|
|
610
|
+
The sidebar persists its open/collapsed state in a cookie (`maz-sidebar-open`) so it survives page reloads. This is **enabled by default**.
|
|
611
|
+
|
|
612
|
+
```html
|
|
613
|
+
<!-- Default: persistence enabled, cookie name "maz-sidebar-open" -->
|
|
614
|
+
<MazSidebar v-model:open="isOpen" />
|
|
615
|
+
|
|
616
|
+
<!-- Disable persistence -->
|
|
617
|
+
<MazSidebar v-model:open="isOpen" :persist="false" />
|
|
618
|
+
|
|
619
|
+
<!-- Custom cookie key (useful when multiple sidebars coexist) -->
|
|
620
|
+
<MazSidebar v-model:open="isOpen" persist-key="admin-sidebar-open" />
|
|
621
|
+
```
|
|
622
|
+
|
|
623
|
+
### How it works
|
|
624
|
+
|
|
625
|
+
- **In setup (server + client)**: the cookie is read and used to initialize the open state. On the server, the value is taken from the request `Cookie` header via Vue's `useSSRContext()`; on the client it comes from `document.cookie`.
|
|
626
|
+
- **On client mount**: `update:open` is emitted if the persisted value differs from the `:open` prop, so your parent `v-model` stays in sync.
|
|
627
|
+
- **On state change**: every transition between expanded/collapsed writes the new value to the cookie (1-year expiry, `SameSite=Lax`).
|
|
628
|
+
|
|
629
|
+
### SSR considerations
|
|
630
|
+
|
|
631
|
+
Persistence is **SSR-native** — the server reads the request cookie and renders the sidebar in its persisted state immediately, so there is no expand → collapse flash on hydration. This works out of the box in Nuxt and any Vue 3 SSR runtime that exposes the request headers through `useSSRContext()`.
|
|
632
|
+
|
|
633
|
+
If you prefer to manage the state yourself (e.g. to share it with other parts of your app), disable persistence and feed the cookie via your own ref:
|
|
634
|
+
|
|
635
|
+
```html
|
|
636
|
+
<script setup>
|
|
637
|
+
const sidebarOpen = useCookie<boolean>('maz-sidebar-open', { default: () => true })
|
|
638
|
+
</script>
|
|
639
|
+
|
|
640
|
+
<template>
|
|
641
|
+
<MazSidebar v-model:open="sidebarOpen" :persist="false">
|
|
642
|
+
<!-- ... -->
|
|
643
|
+
</MazSidebar>
|
|
644
|
+
</template>
|
|
645
|
+
```
|
|
646
|
+
|
|
647
|
+
`:persist="false"` prevents the sidebar from also writing the cookie, leaving full control to your `useCookie` ref.
|
|
648
|
+
|
|
649
|
+
## With router (vue-router / NuxtLink)
|
|
650
|
+
|
|
651
|
+
`MazSidebarMenuButton` uses `resolveLinkComponent()` internally — it detects `RouterLink` (vue-router) or a provided `NuxtLink`. Pass the `to` prop for router navigation, `href` for plain anchor links.
|
|
652
|
+
|
|
653
|
+
```html
|
|
654
|
+
<!-- With vue-router -->
|
|
655
|
+
<MazSidebarMenuButton :to="{ name: 'home' }" label="Home" />
|
|
656
|
+
<MazSidebarMenuButton to="/about" label="About" />
|
|
657
|
+
|
|
658
|
+
<!-- With plain href -->
|
|
659
|
+
<MazSidebarMenuButton href="https://maz-ui.com" label="Docs" />
|
|
660
|
+
|
|
661
|
+
<!-- Mark as active manually (useful when router is not available) -->
|
|
662
|
+
<MazSidebarMenuButton label="Dashboard" :active="$route.name === 'dashboard'" />
|
|
663
|
+
```
|
|
664
|
+
|
|
665
|
+
## CSS Variables
|
|
666
|
+
|
|
667
|
+
Customize the sidebar width using these CSS custom properties (also settable via `width` / `iconWidth` props):
|
|
668
|
+
|
|
669
|
+
```css
|
|
670
|
+
:root {
|
|
671
|
+
--maz-sidebar-width: 16rem; /* expanded width */
|
|
672
|
+
--maz-sidebar-icon-width: 3rem; /* icon-mode collapsed width */
|
|
673
|
+
}
|
|
674
|
+
```
|
|
675
|
+
|
|
676
|
+
## Accessibility
|
|
677
|
+
|
|
678
|
+
- The sidebar root element renders as `<aside aria-label="Sidebar">`
|
|
679
|
+
- `MazSidebarMenu` renders as `<ul role="menu">`
|
|
680
|
+
- `MazSidebarMenuItem` renders as `<li role="none">`
|
|
681
|
+
- `MazSidebarTrigger` has `aria-expanded` and `aria-controls` referencing the sidebar `id`
|
|
682
|
+
- `MazSidebarMenuButton` applies `aria-current="page"` on active items and exposes the label via `aria-label`
|
|
683
|
+
- `MazSidebarMenuSub` trigger has `aria-expanded` and `aria-controls`
|
|
684
|
+
- In `mode="overlay"`, pressing `Escape` closes the sidebar and focus is restored to the trigger element
|
|
685
|
+
- In `mode="overlay"`, `Tab`/`Shift+Tab` are trapped within the sidebar
|
|
686
|
+
- All transitions respect `prefers-reduced-motion`
|
|
687
|
+
|
|
688
|
+
## MazSidebar
|
|
689
|
+
|
|
690
|
+
<!--@include: ./../../.vitepress/generated-docs/maz-sidebar.doc.md-->
|
|
691
|
+
|
|
692
|
+
## MazSidebarMenuButton
|
|
693
|
+
|
|
694
|
+
<!--@include: ./../../.vitepress/generated-docs/maz-sidebar-menu-button.doc.md-->
|
|
695
|
+
|
|
696
|
+
## MazSidebarMenuSub
|
|
697
|
+
|
|
698
|
+
<!--@include: ./../../.vitepress/generated-docs/maz-sidebar-menu-sub.doc.md-->
|
|
699
|
+
|
|
700
|
+
## MazSidebarGroup
|
|
701
|
+
|
|
702
|
+
<!--@include: ./../../.vitepress/generated-docs/maz-sidebar-group.doc.md-->
|
|
703
|
+
|
|
704
|
+
<script setup>
|
|
705
|
+
import { ref } from 'vue'
|
|
706
|
+
|
|
707
|
+
import { MazHome } from '@maz-ui/icons/lazy/MazHome'
|
|
708
|
+
import { MazCog6Tooth } from '@maz-ui/icons/lazy/MazCog6Tooth'
|
|
709
|
+
|
|
710
|
+
const overlayOpen = ref(false)
|
|
711
|
+
const offcanvasOpen = ref(true)
|
|
712
|
+
const userMenuOpen = ref(true)
|
|
713
|
+
const badgesOpen = ref(true)
|
|
714
|
+
const sideEndOpen = ref(true)
|
|
715
|
+
const iconModeOpen = ref(true)
|
|
716
|
+
const submenusOpen = ref(true)
|
|
717
|
+
const groupsOpen = ref(true)
|
|
718
|
+
const basicOpen = ref(true)
|
|
719
|
+
</script>
|