-
-
Notifications
You must be signed in to change notification settings - Fork 311
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
Add props to control sidebar's collapsed state in DashboardLayout component #4406
Comments
Agree with providing a way to access the state of the sidebar, and also imperatively setting it. An alternative way of doing this is through a const { collapsed, setCollapsed } = useSidebar();
const onClick = () => { if(!collapsed) { setCollapsed(); } This will enable components across the app to be able to access (and imperatively set) the sidebar's state instead of having to share props. |
@Mohammad-210 are you planning to work on this and create a PR? If not, I can help with the PR |
a controlled prop makes sense to me. a hook will be constraint to descendants only, which is probably too limiting. |
@vikasgurjar I'm swamped with other tasks, I won't get to it.But I'm planning to fix it, but I haven't started yet. Feel free to create the PR!. if help needed let me know ..! |
@Janpot from what I understand, controlled prop will have to be passed down to every child that needs it. Also even in that case these props will be constraint to descendants only |
@bharatkashyap I'm thinking of using
|
I discussed this with @mnajdova and we came to the conclusion that a controlled prop makes sense to begin with, while a hook/context can be implemented by users themselves if they need it as long as the prop is present. We could make an issue to collect upvotes on the hook feature request, to see if there is enough interest in providing that out of the box. Let's focus on adding a controlled prop as part of this issue 👍🏻 |
A controlled prop as suggested sounds good! |
@apedroferreira I think eventually |
I think they would both stay with different purposes: |
@apedroferreira @bharatkashyap I got some time to work on this. I was wondering what's the use of |
Yes, it should run when the menu button on the top-right is clicked and by default toggle the sidebarCollapsed state. |
Summary
This feature request is to enhance the DashboardLayout component by adding two new props:
collapsed: A boolean prop that controls the initial state of the sidebar (collapsed or expanded).
onToggleSidebar: A function prop that allows toggling the sidebar’s collapsed state from outside the DashboardLayout component.
This setup will make the sidebar’s state externally controllable, enabling more dynamic and flexible UI behaviors in various responsive scenarios.
Examples
import React, { useState } from 'react';
import DashboardLayout from './DashboardLayout';
const AppProvider = () => {
const [isSidebarCollapsed, setIsSidebarCollapsed] = useState(false);
const handleToggleSidebar = (collapsed) => {
setIsSidebarCollapsed(collapsed);
};
return (
{/* Application Content */}
);
};
export default AppProvider;
Motivation
This feature will improve DashboardLayout’s flexibility and control by allowing parent components to manage and toggle the sidebar’s collapsed state. With responsive design requirements, many apps need to control the sidebar's visibility dynamically based on user interactions or screen size. This enhancement will make DashboardLayout more adaptable for complex UI requirements and enhance user experience across devices. The issue i face is i need a state to ensure the sidebar is collapsed or not to manage the responsiveness of design of rendered children comp
Search keywords: sidebar toggle, sidebar collapsed state, DashboardLayout, Material-UI, Toolpad sidebar, responsive sidebar, toggle sidebar from parent, sidebar props
The text was updated successfully, but these errors were encountered: