2023-12-08 08:50:33 +00:00
|
|
|
import { Preview } from '@storybook/react';
|
|
|
|
import { themes } from '@storybook/theming';
|
|
|
|
import i18n from 'i18next';
|
|
|
|
import { initReactI18next } from 'react-i18next';
|
|
|
|
import { Provider } from 'react-redux';
|
|
|
|
import ThemeLocaleProvider from '../src/app/components/ThemeLocaleProvider';
|
2023-12-28 13:03:21 +00:00
|
|
|
import { $baseUrl } from '../src/app/store/nanostores/baseUrl';
|
2023-12-08 08:50:33 +00:00
|
|
|
import { createStore } from '../src/app/store/store';
|
|
|
|
// TODO: Disabled for IDE performance issues with our translation JSON
|
|
|
|
// eslint-disable-next-line @typescript-eslint/ban-ts-comment
|
|
|
|
// @ts-ignore
|
|
|
|
import translationEN from '../public/locales/en.json';
|
2023-12-28 13:03:21 +00:00
|
|
|
import { ReduxInit } from './ReduxInit';
|
2024-04-09 09:25:45 +00:00
|
|
|
import { $store } from 'app/store/nanostores/store';
|
2023-12-08 08:50:33 +00:00
|
|
|
|
|
|
|
i18n.use(initReactI18next).init({
|
|
|
|
lng: 'en',
|
|
|
|
resources: {
|
|
|
|
en: { translation: translationEN },
|
|
|
|
},
|
|
|
|
debug: true,
|
|
|
|
interpolation: {
|
|
|
|
escapeValue: false,
|
|
|
|
},
|
|
|
|
returnNull: false,
|
|
|
|
});
|
|
|
|
|
|
|
|
const store = createStore(undefined, false);
|
2024-04-09 09:25:45 +00:00
|
|
|
$store.set(store)
|
2023-12-28 13:03:21 +00:00
|
|
|
$baseUrl.set('http://localhost:9090');
|
2023-12-08 08:50:33 +00:00
|
|
|
|
|
|
|
const preview: Preview = {
|
|
|
|
decorators: [
|
2023-12-28 13:03:21 +00:00
|
|
|
(Story) => {
|
|
|
|
return (
|
|
|
|
<Provider store={store}>
|
|
|
|
<ThemeLocaleProvider>
|
|
|
|
<ReduxInit>
|
|
|
|
<Story />
|
|
|
|
</ReduxInit>
|
|
|
|
</ThemeLocaleProvider>
|
|
|
|
</Provider>
|
|
|
|
);
|
|
|
|
},
|
2023-12-08 08:50:33 +00:00
|
|
|
],
|
|
|
|
parameters: {
|
|
|
|
docs: {
|
|
|
|
theme: themes.dark,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
export default preview;
|