-
-
Notifications
You must be signed in to change notification settings - Fork 9.4k
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 Request] Add option to hide toolbars for doc pages #22081
Comments
@noranda Great point!! This is the line of code that says show the toolbar no matter what the viewMode is: https://github.com/storybookjs/storybook/blob/next/code/addons/toolbars/src/manager.tsx#L11 Here's another addon that only shows the toolbar for stories and never for docs: https://github.com/storybookjs/storybook/blob/next/code/addons/measure/src/manager.tsx#L12 I'd be open to hide toolbars on unattached docs pages that don't render any stories. I'm too big a fan of making that behavior user configurable, since it will just lead to more documentation/maintenance. I'm not sure whether we have enough info inside that function to be smart about it for unattached docs. @tmeasday any thoughts? |
I guess if the file has no stories imports @shilman? Won't work for legacy id based rendering but that's probably ok. We do want to move the toolbar onto the canvas block though. Not sure how soon that'll happen however as it's a bit tricky. |
@tmeasday I guess to get more specific: This is the calling code for that match function. If the callee (in this case the toolbars addon) has access to |
I created a PR for this issue, I want to know if we should, completely hide the toolbar like what happens when you disable the toolbar or just hide the tools? Also, what would be a good place to add the setting for toggling this functionality? If anyone could guide me, that would be helpful! |
I can't imagine that would be enough to determine if there are stories in the docs or not. We can't remove the toolbar completely, as it contains the fullscreen tool, and I would expect it to get more native tools later. Are we certain that all addon tools can safely be removed if there are no stories? because we know they can only affect stories, and not the docs content? |
@JReinhold I don't know whether it's 100% safe to remove the addon-toolbars (or any addon that adds itself to the toolbar) if there are no stories on the docs page. I guess, given that, the safest thing to do is give users the option of hiding them by configuration. Or to hide the entire toolbar. |
I share your concern about the API though, I think it would make more sense to give addon authors the ability to more fine-grainily hide the tools, they should know if it makes sense or not to have them without stories. |
@shilman @JReinhold If it helps, for my specific use case I'd like to be able to hide the Canvas and any addon tabs from the toolbar. That would just leave the full screen button, which I could live with or without. So either an option to hide the toolbar for a given doc page, or options to hide the Canvas and all addon tabs would work for me. I'm on Storybook 7. |
Do you want to do it for all your docs pages, or just some of them? If the latter, what makes them special from the rest? |
I'd like the option for some doc pages, but not all. For example, I have:
|
Thanks for stepping in for my lack of response @JReinhold -- I think you are spot on.
My understanding is the plan is to move the fullscreen button and any future native tools to more of a "button/menu" UI on the top RHS (of the docs page) and drop the toolbar entirely, then to put addon toolbars on top of the story in a toolbar on the Canvas block. (credit @MichaelArestad): My opinion is we'd want to be pretty cautious making changes to the "defunct" docs-level toolbar that requires addon authors to do anything, given that we will likely require changes to support the above later (maybe 8.0?). Adding a tag or something that a user can set to do something like @noranda suggested might make sense, as long as we were sure to tell them that likely it's a bandaid for a bigger change coming later. |
@tmeasday Adding a config option to turn off toolbar options would be great for me with the understanding that the toolbar may undergo significant changes in an upcoming update. Is this something that can be added in the short term? |
@JReinhold @shilman do y'all think it would make sense for users to be able to write a function that looks something like: shouldShowToolbar(toolbarName: string, entry: IndexEntry): boolean Then they could look at |
@shilman @tmeasday Am I correct in thinking this new option should go in From within the addon's If that's the way forward, I'll factorise this code into a shared util. I don't know, though, if there's a preferred way to get the CLI |
I think given the toolbar is rendered by the manager, the option would probably want to live in addons.setConfig({
toolbar: {
shouldShow(..) // not sure about naming
},
}); TBH I'm not 100% confident about how the manager configuration works but I'm looking at some storybook/code/lib/manager-api/src/lib/stories.ts Lines 159 to 160 in bdbd335
We could probably do something similar with reading toolbar options here-ish: storybook/code/ui/manager/src/components/preview/toolbar.tsx Lines 136 to 138 in bdbd335
|
Thanks Tom, I'll give it a try with that. |
The good news is I managed to make it work. The bad news is that hiding the toolbar itself isn't enough, I should hide the space reserved within it by preview. I think it would make more sense for the function to impact WDYT? |
I guess changing the state on every route change might be a bit difficult/brittle. Did you have an idea of how you might do that @Sidnioulz? |
Hm, you're right. Updating the UI when I change the value would be easy, but knowing when to call my function again wouldn't. I'll stick to the original plan then, but I'll host the logic in |
An update following a brainstorming session with Norbert. We found a way to get rid of the Here's what we came up with:
And some noteworthy optimisations and extensions:
Ultimately, this update (and possibly others to follow) should let users repurpose Storybook a little bit to include more use cases of documentation, including MDX pages with custom navigation, by only showing the built-in Storybook UI when relevant to their needs. We also briefly discussed the possibility of introducing a reducer logic in the manager state, where modules could reduce their own part of the manager state. If this had been available, it would have given us more options. The user-defined functions discussed here would obviously be reducer logic that provides more literal types to store in the I'm going on holiday so there's plenty of time to comment and point out flaws before I start updating the PR. Your feedback is very much welcome :) |
Hello! |
Hi @deraw! I need to update my code against the v8 architecture and reopen the PR. It's taking a lot of time because I'm super busy with conferences at the moment :( I'll be able to resume work on this some time in the summer. |
Hey @Sidnioulz any news on that? I just noticed that the SB8 UI has a keyboard shortcut to hide this toolbar, we should be close 🤞 |
I may or may not be busy with a Figma CLI so I may or may not be neglecting this PR 😬 The kb shortcut was here since SB 5 or 6, but the problem is storing that you want it disabled by default. We had that logic baked in, but it went through the addon singleton (which needs to go). We had the whole logic down with Norbert to implement this without using the singleton, but I failed at my initial refactor attempt and I have since shamefully forgotten how to handle my sandboxes. I need to sit down and finish this, I will get back to it as soon as my current project is released. |
#29516 is the latest iteration, and it implements most of what we discussed with @ndelangen. There are a few areas that I'd like to talk to the maintainers about before I finish the doc, especially regarding testing. The features are now testable but the story files where tests had been possible in the past are gone, so I'm not sure what the expectation from the team is. |
Is your feature request related to a problem? Please describe
It's not currently possible to show toolbars for stories, but hide them for doc pages (see thread). I have unattached doc pages with no stories as well as doc pages with stories.
Describe the solution you'd like
I'd like to be able to hide the toolbar for unattached doc pages with no stories, where the toolbar options don't apply.
Describe alternatives you've considered
I could look into hiding the individual toolbar options (I believe SB 6.5 did this), but I'd like to just be able to hide the toolbar.
Are you able to assist to bring the feature to reality?
yes, I can
Additional context
No response
The text was updated successfully, but these errors were encountered: