2024-01-17 12:16:46 +03:00
|
|
|
import '../src/theme/global.css';
|
2023-12-04 11:32:19 +03:00
|
|
|
import './preview.css';
|
|
|
|
import { ThemeProvider, useTheme } from 'next-themes';
|
|
|
|
import type { ComponentType } from 'react';
|
|
|
|
import { useEffect } from 'react';
|
|
|
|
import { useDarkMode } from 'storybook-dark-mode';
|
|
|
|
|
|
|
|
import type { Preview } from '@storybook/react';
|
|
|
|
import React from 'react';
|
|
|
|
|
|
|
|
export const parameters: Preview = {
|
|
|
|
argTypes: {
|
|
|
|
param: {
|
|
|
|
table: { category: 'Group' },
|
|
|
|
},
|
|
|
|
},
|
|
|
|
globalTypes: {
|
|
|
|
theme: {
|
|
|
|
description: 'Global theme for components',
|
|
|
|
defaultValue: 'light',
|
|
|
|
toolbar: {
|
|
|
|
title: 'Theme',
|
|
|
|
icon: 'circlehollow',
|
|
|
|
items: ['light', 'dark'],
|
|
|
|
dynamicTitle: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
},
|
|
|
|
};
|
|
|
|
|
|
|
|
const ThemeChange = () => {
|
|
|
|
const isDark = useDarkMode();
|
|
|
|
const theme = useTheme();
|
|
|
|
if (theme.resolvedTheme === 'dark' && !isDark) {
|
|
|
|
theme.setTheme('light');
|
|
|
|
} else if (theme.resolvedTheme === 'light' && isDark) {
|
|
|
|
theme.setTheme('dark');
|
|
|
|
}
|
|
|
|
return null;
|
|
|
|
};
|
|
|
|
|
|
|
|
const Component = () => {
|
|
|
|
const isDark = useDarkMode();
|
|
|
|
const theme = useTheme();
|
|
|
|
useEffect(() => {
|
|
|
|
theme.setTheme(isDark ? 'dark' : 'light');
|
|
|
|
}, [isDark]);
|
|
|
|
return null;
|
|
|
|
};
|
|
|
|
|
|
|
|
export const decorators = [
|
|
|
|
(Story: ComponentType, context) => {
|
|
|
|
return (
|
|
|
|
<ThemeProvider themes={['dark', 'light']} enableSystem={true}>
|
|
|
|
<ThemeChange />
|
|
|
|
<Component />
|
|
|
|
<Story {...context} />
|
|
|
|
</ThemeProvider>
|
|
|
|
);
|
|
|
|
},
|
|
|
|
];
|