-
Notifications
You must be signed in to change notification settings - Fork 339
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
[Feature]: Sidebar #819
Comments
Came here to request this and was excitee to see @zernonia already being on top of this like half a day ago 😅 But, yes, the new sidebar components from shadcn are 🔥 The only thing that I didn't see them implement is to be able to drag and drop for reordering. That'd be a great extra bonus. |
Currently attempting a port of this 👍 Edit: probably won't have time to finish this |
Hi @zernonia It's nice to see this discussion lively :) Currently I am focusing on ease of navigation for the user, where he can move to pages he has previously opened or in the same context quickly. Let me convey my problem, currently I am making a system with a lot of menus, and this is not enough with one menu, but requires me to create a double sidebar / nested sidebar. Vben.Recording.2024-03-23.204852.mp4In this video functionally it meets my needs, the component based is using shadcn-vue (with new version of vben, but on this video is old version), but it's nice if shadcn-vue have new sidebar component like this functionality, and added to block. My Feature Request :
Block / Example
I think if shadcn-vue had a menu model like this it on block template would be amazing 👍 |
Would be a lovely addition to the lib!! |
Yo guys! The same functionalities for Sidebar will be added. |
I just came from the world of vuetify and I am so excited to use shadcn-vue in my current project .. |
@zernonia, any idea how long it takes to add sidebar? I’d like to buy you a coffee for your effort, man. Great job! |
Yoo guys.. a quick update on this. (sorry I couldn't get much done this week as I had function oversea) This ticket will have dependency on #805 to add sidebar blocks to your app.
|
@zernonia That sounds great and looks very promising! I also used the sponsor feature here on GitHub for the first time to support your great work. |
Hi @zernonia thanks for your great work! I really wanted to use the new Sidebar, installed with npx... it adds over 20 components to ui/sidebar Do have any estimate when instruction of how-to-use will be added to docs? Thank you!! 🙏 |
In the blocks are two examples. Based on them I was able to set it up. But you are right - docs would be great 😊 |
While it's not a bulletproof solution, you can always refer to the original version. They have detailed documentation of the sidebar, and while the source codes are implemented in React, the core ideas should work the same. I used those docs and the blocks implemented on the original site to set up my sidebar. |
this x sidebar thread can also help: https://x.com/shadcn/status/1842329158879420864 |
After long search, I think it can save some time the next guy looking for this. @Nils3311 Feel free to add it also to your comment :) |
Opening and closing the sidebar does not work in the mobile version. I get the mobile version by reducing the browser width. |
Have a look here, maybe this will solve your problem #840 |
Seems the sidebar causes hydration issues when used with nuxt/ssr. I've documented said hydration errors below for easy access. Desktop view - sidebar can be displayed fully and not become a sheet/overlay1 [Vue warn]: Hydration children mismatch on
<button id="radix-vue-dropdown-menu-trigger-v-0-0" class="peer/menu-button flex w-…debar-accent-foreground" data-sidebar="menu-button" data-size="lg" data-active="false" type="button" aria-haspopup="menu" aria-expanded="false" data-state="closed">
Server rendered element contains fewer child nodes than client vdom.
at <Primitive data-sidebar="menu-button" data-size="lg" data-active=false ... >
at <SidebarMenuButtonChild key=0 class="outline-none data-[state=open]:bg-sidebar-accent data-[state=open]:text-sidebar-accent-foreground" variant="default" ... >
at <SidebarMenuButton size="lg" id="radix-vue-dropdown-menu-trigger-v-0-0" type="button" ... >
at <PrimitiveSlot id="radix-vue-dropdown-menu-trigger-v-0-0" type="button" aria-haspopup="menu" ... >
at <Primitive id="radix-vue-dropdown-menu-trigger-v-0-0" type="button" as-child=true ... >
at <PrimitiveSlot class="outline-none" >
at <Primitive ref=fn<s> as=undefined as-child=true ... >
at <PopperAnchor asChild=true element=undefined as=undefined ... >
at <MenuAnchor as-child="" class="outline-none" >
at <DropdownMenuTrigger class="outline-none" asChild=true >
at <DropdownMenuTrigger as-child="" >
at <PopperRoot>
at <MenuRoot open=false onUpdate:open=fn dir="ltr" ... >
at <DropdownMenuRoot onUpdate:open=fn >
at <DropdownMenu>
at <SidebarMenuItem>
at <SidebarMenu>
at <SidebarHeader>
at <Sidebar key=0 collapsible="icon" >
at <TooltipProvider delay-duration=0 >
at <SidebarProvider> 2 [Vue warn]: Hydration node mismatch:
- rendered on server:
<button class="inline-flex items-center…round h-10 w-10 ml-auto">
<empty string>
- expected on client: Symbol("v-cmt")
at <Teleport to=undefined disabled=false forceMount=false >
at <MenuPortal disabled=false forceMount=false to=undefined >
at <DropdownMenuPortal>
at <DropdownMenuContent class="w-[--radix-dropdown-menu-trigger-width] min-w-56 rounded-lg" align="start" side="bottom" ... >
at <PopperRoot>
at <MenuRoot open=false onUpdate:open=fn dir="ltr" ... >
at <DropdownMenuRoot onUpdate:open=fn >
at <DropdownMenu>
at <SidebarMenuItem>
at <SidebarMenu>
at <SidebarHeader>
at <Sidebar key=0 collapsible="icon" >
at <TooltipProvider delay-duration=0 >
at <SidebarProvider> 3 [Vue warn]: Hydration children mismatch on
<li class="group/menu-item relative" data-sidebar="menu-item">
Server rendered element contains more child nodes than client vdom.
at <SidebarMenuItem>
at <SidebarMenu>
at <SidebarHeader>
at <Sidebar key=0 collapsible="icon" >
at <TooltipProvider delay-duration=0 >
at <SidebarProvider> Mobile View - Sidebar is a sheet and overlays on top of page contents1 [Vue warn]: Hydration node mismatch:
- rendered on server:
<div class="group peer hidden md:block" data-state="expanded" data-collapsible="" data-variant="sidebar" data-side="left"> <empty string>
- expected on client: Symbol("v-fgt")
at <DialogRoot open=false onUpdate:open=fn >
at <Sheet key=1 open=false onUpdate:open=fn<setOpenMobile> >
at <Sidebar key=0 collapsible="icon" >
at <TooltipProvider delay-duration=0 >
at <SidebarProvider> |
Hey guys i found this Bug and created an MR
|
It seems the 'side' prop of the Sidebar is ignored by the SidebarProvider. The content is always pushed to the right, even when the Sidebar is on the right side. |
I'm seeing similar errors just using a dropdown, I'm not rendering the sidebar: 10:44:29.873 runtime-core.esm-bundler.js:51 [Vue warn]: Hydration attribute mismatch on <button class="inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground h-9 px-4 py-2 outline-none float-right icon-button" id="radix-vue-dropdown-menu-trigger-v-0-1-7" type="button" aria-haspopup="menu" aria-expanded="false" data-state="closed">…</button>flex
- rendered on server: id="radix-vue-dropdown-menu-trigger-v-0-1-7"
- expected on client: id="radix-vue-dropdown-menu-trigger-v-0-7"
Note: this mismatch is check-only. The DOM will not be rectified in production due to performance overhead.
You should fix the source of the mismatch.
at <Primitive as="button" as-child=false class="inline-flex items-center justify-center gap-2 whitespace-nowrap rounded-md text-sm font-medium ring-offset-background transition-colors focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-ring focus-visible:ring-offset-2 disabled:pointer-events-none disabled:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0 border border-input bg-background shadow-sm hover:bg-accent hover:text-accent-foreground h-9 px-4 py-2 outline-none float-right icon-button" ... >
at <UiButton variant="outline" id="radix-vue-dropdown-menu-trigger-v-0-7" type="button" ... >
at <PrimitiveSlot id="radix-vue-dropdown-menu-trigger-v-0-7" type="button" aria-haspopup="menu" ... >
at <Primitive id="radix-vue-dropdown-menu-trigger-v-0-7" type="button" as-child=true ... >
at <PrimitiveSlot class="outline-none" >
at <Primitive ref=fn<s> as=undefined as-child=true ... >
at <PopperAnchor asChild=true element=undefined as=undefined ... >
at <MenuAnchor as-child="" class="outline-none" >
at <DropdownMenuTrigger class="outline-none" asChild=true >
at <UiDropdownMenuTrigger as-child="" >
at <PopperRoot>
at <MenuRoot open=false onUpdate:open=fn dir="ltr" ... >
at <DropdownMenuRoot onUpdate:open=fn >
at <UiDropdownMenu>
at <ContextMenu context-menu= (2) [{…}, {…}] > I'm on these versions:
|
Describe the feature
https://x.com/i/bookmarks?post_id=1847359896557408461
Additional information
The text was updated successfully, but these errors were encountered: