mirror of
https://github.com/wavetermdev/waveterm.git
synced 2025-01-04 18:59:08 +01:00
62 lines
1.6 KiB
TypeScript
62 lines
1.6 KiB
TypeScript
// organize-imports-ignore
|
|
import type { Preview } from "@storybook/react";
|
|
import React from "react";
|
|
import { DndProvider } from "react-dnd";
|
|
import { HTML5Backend } from "react-dnd-html5-backend";
|
|
import "../frontend/app/theme.less";
|
|
import "../frontend/app/app.less";
|
|
import "../frontend/app/reset.less";
|
|
import "./global.css";
|
|
import { light, dark } from "./theme";
|
|
import { DocsContainer } from "@storybook/addon-docs";
|
|
|
|
import { addons } from "@storybook/preview-api";
|
|
import { DARK_MODE_EVENT_NAME } from "storybook-dark-mode";
|
|
|
|
const channel = addons.getChannel();
|
|
|
|
const preview: Preview = {
|
|
parameters: {
|
|
controls: {
|
|
matchers: {
|
|
color: /(background|color)$/i,
|
|
date: /Date$/i,
|
|
},
|
|
},
|
|
darkMode: {
|
|
dark,
|
|
light,
|
|
stylePreview: true,
|
|
classTarget: "html",
|
|
},
|
|
docs: {
|
|
container: (props) => {
|
|
const [isDark, setDark] = React.useState();
|
|
|
|
React.useEffect(() => {
|
|
channel.on(DARK_MODE_EVENT_NAME, setDark);
|
|
return () => channel.removeListener(DARK_MODE_EVENT_NAME, setDark);
|
|
}, [channel, setDark]);
|
|
|
|
return (
|
|
<div>
|
|
<DocsContainer {...props} theme={isDark ? dark : light} />
|
|
</div>
|
|
);
|
|
},
|
|
},
|
|
},
|
|
|
|
decorators: [
|
|
(Story) => (
|
|
<DndProvider backend={HTML5Backend}>
|
|
<Story />
|
|
</DndProvider>
|
|
),
|
|
],
|
|
|
|
tags: ["autodocs"],
|
|
};
|
|
|
|
export default preview;
|