You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 

82 lines
2.0 KiB

import { addDecorator, configure, setAddon } from '@storybook/react'
import { withThemesProvider } from 'storybook-addon-styled-component-theme'
import { themes } from '@storybook/components'
import { withOptions } from '@storybook/addon-options'
import { setDefaults, withInfo } from '@storybook/addon-info'
import { withConsole } from '@storybook/addon-console'
import { linkTo } from '@storybook/addon-links'
import { setIntlConfig, withIntl } from 'storybook-addon-intl'
import chaptersAddon from 'react-storybook-addon-chapters'
import StoryRouter from 'storybook-react-router'
import { dark, light } from 'themes'
import { getDefaultLocale, locales } from 'lib/i18n'
import React from 'react'
import GlobalStyle from 'components/UI/GlobalStyle'
// Register supported locales.
import '../app/lib/i18n/locale'
// Get translations.
import translations from '../app/lib/i18n/translation'
// Set intl configuration
setIntlConfig({
locales: locales,
defaultLocale: getDefaultLocale(),
getMessages: locale => translations[locale]
})
// Info
addDecorator(
withInfo({
styles: {
button: {
base: {
background: dark.colors.lightningOrange
}
}
}
})
)
// Intl
addDecorator(withIntl)
// Router
addDecorator(StoryRouter({}))
// Chapters
setAddon(chaptersAddon)
// Console.
addDecorator((storyFn, context) => withConsole()(storyFn)(context))
// Options
addDecorator(
withOptions({
name: 'Zap Desktop',
url: 'https://ln-zap.github.io/zap-desktop',
theme: themes.dark,
hierarchySeparator: /\./
})
)
// Zap Global style.
addDecorator(story => (
<React.Fragment>
<GlobalStyle />
{story()}
</React.Fragment>
))
// Zap Themes.
const zapThemes = [dark, light]
addDecorator(withThemesProvider(zapThemes))
// automatically import all files ending in *.stories.js
const req = require.context('../stories', true, /.stories.js$/)
function loadStories() {
req.keys().forEach(filename => req(filename))
}
configure(loadStories, module)