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 'globals'

import 'styles/global'
import theme from 'styles/theme'
import i18n from 'renderer/i18n/storybook'

const req = require.context('../src', true, /.stories.js$/)
function loadStories() {
  req.keys().forEach(filename => req(filename))
}

addDecorator(story => (
  <I18nextProvider i18n={i18n} initialLanguage="en">
    <ThemeProvider theme={theme}>
      <div style={{ padding: 20 }}>{story()}</div>
    </ThemeProvider>
  </I18nextProvider>
))

addDecorator(withKnobs)

const { name, repository: url } = require('../package.json')

setOptions({
  name,
  url,
})

configure(loadStories, module)