2023-02-08 23:54:09 +03:30
|
|
|
import { DecoratorFunction, useGlobals } from '@storybook/addons'
|
|
|
|
import React, { useEffect } from 'react'
|
2023-02-13 13:13:50 +03:30
|
|
|
import { defaultThemes, Theme, ThemeProvider } from '../src'
|
2023-02-08 23:54:09 +03:30
|
|
|
|
|
|
|
export const withTheme: DecoratorFunction = (Story, context) => {
|
|
|
|
const StoryComponent = Story as any as React.ComponentType
|
|
|
|
|
|
|
|
const themeName = context.globals?.theme ?? 'light'
|
2023-02-13 13:13:50 +03:30
|
|
|
const theme = defaultThemes[themeName] as Theme
|
2023-02-08 23:54:09 +03:30
|
|
|
|
|
|
|
const [globals, setGlobals] = useGlobals()
|
|
|
|
|
|
|
|
useEffect(() => {
|
2023-02-13 13:13:50 +03:30
|
|
|
const background = (context.parameters.backgrounds?.values ?? []).find(
|
|
|
|
(value) => value.name === themeName,
|
|
|
|
)?.value
|
|
|
|
|
|
|
|
globals.backgrounds?.value !== background &&
|
|
|
|
setGlobals({
|
|
|
|
...globals,
|
|
|
|
backgrounds: {
|
|
|
|
...(globals.background ?? {}),
|
|
|
|
value: background,
|
|
|
|
},
|
|
|
|
})
|
2023-02-08 23:54:09 +03:30
|
|
|
}, [theme])
|
|
|
|
|
|
|
|
return (
|
|
|
|
<div>
|
|
|
|
<ThemeProvider theme={theme}>
|
|
|
|
<StoryComponent />
|
|
|
|
</ThemeProvider>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}
|