2021-02-08 16:45:06 +01:00
|
|
|
import React, { useEffect } from 'react';
|
|
|
|
import { addDecorator, addParameters } from '@storybook/react';
|
|
|
|
import { useGlobals } from '@storybook/api';
|
|
|
|
import { withKnobs } from '@storybook/addon-knobs';
|
|
|
|
import { Provider } from 'react-redux';
|
|
|
|
import configureStore from '../ui/app/store/store';
|
|
|
|
import '../ui/app/css/index.scss';
|
|
|
|
import localeList from '../app/_locales/index.json';
|
|
|
|
import * as allLocales from './locales';
|
|
|
|
import { I18nProvider, LegacyI18nProvider } from './i18n';
|
2021-02-08 17:49:49 +01:00
|
|
|
import testData from './test-data.js'
|
2018-05-03 19:51:15 +02:00
|
|
|
|
2020-02-26 18:40:53 +01:00
|
|
|
addParameters({
|
2020-11-30 21:10:46 +01:00
|
|
|
backgrounds: {
|
|
|
|
default: 'light',
|
|
|
|
values: [
|
2021-02-08 16:45:06 +01:00
|
|
|
{ name: 'light', value: '#FFFFFF' },
|
2020-11-30 21:10:46 +01:00
|
|
|
{ name: 'dark', value: '#333333' },
|
|
|
|
],
|
2021-02-08 16:45:06 +01:00
|
|
|
},
|
|
|
|
});
|
2020-02-26 18:40:53 +01:00
|
|
|
|
2021-02-06 03:28:54 +01:00
|
|
|
export const globalTypes = {
|
|
|
|
locale: {
|
|
|
|
name: 'Locale',
|
|
|
|
description: 'internationalization locale',
|
|
|
|
defaultValue: 'en',
|
|
|
|
toolbar: {
|
|
|
|
icon: 'globe',
|
|
|
|
items: localeList.map(({ code, name }) => {
|
2021-02-08 16:45:06 +01:00
|
|
|
return { value: code, right: code, title: name };
|
|
|
|
}),
|
2021-02-06 03:28:54 +01:00
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
2018-05-03 19:51:15 +02:00
|
|
|
const styles = {
|
|
|
|
height: '100vh',
|
|
|
|
display: 'flex',
|
|
|
|
justifyContent: 'center',
|
|
|
|
alignItems: 'center',
|
2021-02-08 16:45:06 +01:00
|
|
|
};
|
2018-05-03 19:51:15 +02:00
|
|
|
|
2021-02-08 17:49:49 +01:00
|
|
|
const store = configureStore(testData)
|
2020-03-17 20:15:53 +01:00
|
|
|
|
2021-02-06 03:28:54 +01:00
|
|
|
const metamaskDecorator = (story, context) => {
|
2021-02-08 16:45:06 +01:00
|
|
|
const currentLocale = context.globals.locale;
|
|
|
|
const current = allLocales[currentLocale];
|
2021-02-06 03:28:54 +01:00
|
|
|
return (
|
|
|
|
<Provider store={store}>
|
|
|
|
<I18nProvider
|
|
|
|
currentLocale={currentLocale}
|
|
|
|
current={current}
|
|
|
|
en={allLocales.en}
|
|
|
|
>
|
|
|
|
<LegacyI18nProvider>
|
2021-02-08 16:45:06 +01:00
|
|
|
<div style={styles}>{story()}</div>
|
2021-02-06 03:28:54 +01:00
|
|
|
</LegacyI18nProvider>
|
|
|
|
</I18nProvider>
|
|
|
|
</Provider>
|
2021-02-08 16:45:06 +01:00
|
|
|
);
|
|
|
|
};
|
2018-05-03 19:51:15 +02:00
|
|
|
|
2021-02-08 16:45:06 +01:00
|
|
|
addDecorator(withKnobs);
|
|
|
|
addDecorator(metamaskDecorator);
|