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.

45 lines
1.1 KiB

import React from 'react'
import { configure, addDecorator } from '@storybook/react'
import { withKnobs } from '@storybook/addon-knobs'
import { setOptions } from '@storybook/addon-options'
import { ThemeProvider } from 'styled-components'
import { I18nextProvider } from 'react-i18next'
import { Provider } from 'react-redux'
import 'babel-polyfill'
import 'globals'
import 'styles/global'
import theme from 'styles/theme'
import i18n from 'renderer/i18n/storybook'
import createStore from 'renderer/createStore'
import state from '__mocks__/storybook-state'
7 years ago
const req = require.context('../src', true, /.stories.js$/)
function loadStories() {
req.keys().forEach(filename => req(filename))
}
const store = createStore({ state })
addDecorator(story => (
<I18nextProvider i18n={i18n} initialLanguage="en">
<ThemeProvider theme={theme}>
<Provider store={store}>
<div style={{ padding: 20 }}>{story()}</div>
</Provider>
</ThemeProvider>
</I18nextProvider>
))
addDecorator(withKnobs)
const { name, repository: url } = require('../package.json')
setOptions({
name,
url,
})
7 years ago
configure(loadStories, module)