Skip to content
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

Docs is always in light mode #180

Open
thany opened this issue Feb 25, 2022 · 21 comments
Open

Docs is always in light mode #180

thany opened this issue Feb 25, 2022 · 21 comments

Comments

@thany
Copy link

thany commented Feb 25, 2022

All docs as rendered by addon-docs, an official essentials-addon mind you, are always in light mode. No specific configuration has been added to colour anything - it just renders in light mode no matter what.

@seedy
Copy link

seedy commented Apr 7, 2022

Trying to upgrade storybook on our repo (https://github.com/traefik/faency), which is publicly accessible here: https://traefik.github.io/faency/

I notice the following:

  • There's a specific css class (probably coming from emotion) applying styles to the docs element

image

@frassinier
Copy link
Contributor

frassinier commented Apr 29, 2022

Here is a workaround by editing your preview.js

import React from 'react';
import addons from '@storybook/addons';
import { DocsContainer } from '@storybook/addon-docs';
import { themes } from '@storybook/theming';

import { DARK_MODE_EVENT_NAME } from 'storybook-dark-mode';

const channel = addons.getChannel();

export const parameters = {
	darkMode: {
		dark: { ...themes.dark },
		light: { ...themes.light },
	},
	docs: {
		container: props => {
			const [isDark, setDark] = React.useState();

			React.useEffect(() => {
				channel.on(DARK_MODE_EVENT_NAME, setDark);
				return () => channel.off(DARK_MODE_EVENT_NAME, setDark);
			}, [channel, setDark]);

+			const { id: storyId, storyById } = props.context;
+			const {
+				parameters: { docs = {} },
+			} = storyById(storyId);
+			docs.theme = isDark ? themes.dark : themes.light;

			return (
				<DocsContainer {...props} />
			);
		},
	},
};

@TUTAMKHAMON
Copy link

For anyone struggling with this, this is what worked best for me (building upon the answer by @frassinier):

import React from 'react';
import { DocsContainer } from '@storybook/addon-docs';
import { themes } from '@storybook/theming';

import { useDarkMode } from 'storybook-dark-mode'

export const parameters = {
    docs: {
        container: (props) => {
            const isDark = useDarkMode();
      
            const { id: storyId, storyById } = props.context;
            const {
                parameters: { docs = {} },
            } = storyById(storyId);
            docs.theme = isDark ? themes.dark : themes.light;
      
            return React.createElement(DocsContainer, props);
        },
    },
};

This should result in a better performing dark mode and removes the need for jsx support on a .js file.

@kovjogin
Copy link

Thank you very much @TUTAMKHAMON
I use:
"storybook": "^7.0.0-rc.5",
"storybook-dark-mode": "^2.1.1",

It seems to me that in version 7 api has changed a bit.
It's work for me:

import type { Preview } from '@storybook/vue3';
import { DocsContainer } from '@storybook/addon-docs';
import { useDarkMode } from 'storybook-dark-mode';
import { themes } from '@storybook/theming';

const preview: Preview = {
	parameters: {
		docs: {
			container: (context: any) => {
				const isDark = useDarkMode();

				const props = {
					...context,
					theme: isDark ? themes.dark : themes.light,
				};

				return React.createElement(DocsContainer, props);
			},
		},
	},
};
export default preview;

@kovjogin
Copy link

kovjogin commented Mar 22, 2023

Also addon addon-docs adds styles for "preview-loading". Because of what in the dark theme - there are white loading screens.

I didn't find a better solution than to override styles like this:

.sb-preparing-story, .sb-preparing-docs {
  background: transparent !important;
}

.sb-preparing-docs {
  display: none !important;
}

@hipstersmoothie @TUTAMKHAMON FYI

@quantizor
Copy link

At least for storybook 7, I think I've managed to partially track down the issue to the useParameter() hook from @storybook/api returning nothing when rendering a docs page

@RomanPanaget
Copy link

Thank you very much @TUTAMKHAMON I use: "storybook": "^7.0.0-rc.5", "storybook-dark-mode": "^2.1.1",

It seems to me that in version 7 api has changed a bit. It's work for me:

import type { Preview } from '@storybook/vue3';
import { DocsContainer } from '@storybook/addon-docs';
import { useDarkMode } from 'storybook-dark-mode';
import { themes } from '@storybook/theming';

const preview: Preview = {
	parameters: {
		docs: {
			container: (context: any) => {
				const isDark = useDarkMode();

				const props = {
					...context,
					theme: isDark ? themes.dark : themes.light,
				};

				return React.createElement(DocsContainer, props);
			},
		},
	},
};
export default preview;

This worked for me thank you !

@pgrones
Copy link

pgrones commented Apr 21, 2023

The workaround above doesn't completely work for me. I'm on "storybook": "7.0.6" and "storybook-dark-mode": "^3.0.0".
The first render of the docs is always in light mode. When switching to a different docs page and coming back to the previous one, the theme gets updated (most of the time). I'l fiddle around with it a bit more to see if I can find a solution.

Kinda hard to believe that an official addon doesn't support a basic feature like this.

@quantizor
Copy link

quantizor commented Apr 21, 2023

It’s not an official addon, and we’re working hard with the storybook team to find a solution.

storybookjs/storybook#21798
storybookjs/storybook#22119 (comment)

The number of breaking changes in v7 are extremely high and it’s been very difficult for addon authors to properly migrate because some functionality disappeared without a replacement.

@pgrones
Copy link

pgrones commented Apr 21, 2023

I phrased that wrong. I'm not trying to blame you. On the contrary, it's a great addon!

What I meant is that addon-docs is officially maintained by the storybook team, but doesn't support a proper API to toggle the theme. Let's hope the missing APIs are getting replaced in the future.

If you need any information from me to test solutions for this problem just let me know!

@tmeasday
Copy link

@pgr3931 can you try in 7.0.7 or later? If you are still seeing a problem can you let me know?

@joshuaellis
Copy link

@pgr3931 can you try in 7.0.7 or later? If you are still seeing a problem can you let me know?

I've upgraded today, sorry to tell you still issues :(

@tmeasday
Copy link

tmeasday commented May 5, 2023

Can you give a bit more detail @joshuaellis? Ideally with a reproduction I can look at that demonstrates a regression in the addon from 6.5 -> 7.0?

@quantizor
Copy link

quantizor commented May 5, 2023

I was able to get everything working as expected with 7.0.8. Make sure you run yarn dedupe as well to ensure things are on the proper versions.

If you had any custom styling in preview-head.html, note that storybook changed the name of some of the IDs for bits in the UI so CSS selectors might need to be adjusted.

I also added some code in manager-head.html to unset the background color on the preview iframe which helps avoid FOUC.

@hipstersmoothie
Copy link
Owner

So is there anything to fix here? Will happily merge PRs if there is!

@lucasbatiiista
Copy link

lucasbatiiista commented Jun 2, 2023

The workaround above doesn't completely work for me. I'm on "storybook": "7.0.6" and "storybook-dark-mode": "^3.0.0". The first render of the docs is always in light mode. When switching to a different docs page and coming back to the previous one, the theme gets updated (most of the time). I'l fiddle around with it a bit more to see if I can find a solution.

Kinda hard to believe that an official addon doesn't support a basic feature like this.

For everyone having issues with the first render not applying the theme, this approach worked great for me while using the useDarkMode hook brought in by @TUTAMKHAMON:

docs: {
    container: (props) => {
         const isDark = useDarkMode();
         const currentProps = { ...props };
         currentProps.theme = isDark ? themes.dark : themes.light;
         return React.createElement(DocsContainer, currentProps);
    },
},

@TristanBrotherton
Copy link

The workarounds here seem to be for react - can anyone point me in the right direction for getting them to work with Svelte?

@d9k
Copy link

d9k commented Nov 18, 2023

docs: {
    container: (props) => {
         const isDark = useDarkMode();
         const currentProps = { ...props };
         currentProps.theme = isDark ? themes.dark : themes.light;
         return React.createElement(DocsContainer, currentProps);
    },
},

#180 (comment) Works. README should be updated!

@hipstersmoothie
Copy link
Owner

@d9k wanna make a PR?

@silverwind
Copy link

silverwind commented Jul 9, 2024

Since storybook 8.1.11, it seems the method with useDarkMode inside the docs.container component seems to fail with "Storybook preview hooks can only be called inside decorators and story functions." for me.

@unional
Copy link

unional commented Jul 30, 2024

Created ticket in storybook: storybookjs/storybook#28758

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

No branches or pull requests