Storybook 和 AntDesign 组件 - 如何使用 CRA 和 Typescript 进行设置?

Pet*_* K. 2 typescript create-react-app antd storybook

我想使用 Typescript 在我的 CRA 项目中使用基于 AntDesign 组件构建的组件来设置 Storybook。

CRA - v3 故事书 - v5.25 AntDesign - v3.23.2

我成功设置了 CRA + AntDesign,设置了 Storybook,我的 AntDesign 组件使用 AntD css 类在 Storybook 中渲染,但缺少样式

我试过

这些方法都不允许我用样式渲染 AntD 组件

// .stories/webpack.config.js

const path = require("path");

module.exports = {
  module: {
    rules: [
      {
        loader: "babel-loader",
        exclude: /node_modules/,
        test: /\.js$/,
        options: {
          presets: ["@babel/react"],
          plugins: [["import", { libraryName: "antd", style: true }]]
        }
      },
      {
        test: /\.less$/,
        loaders: [
          "style-loader",
          "css-loader",
          {
            loader: "less-loader",

            options: {
              modifyVars: { "@primary-color": "#d8df19" },
              javascriptEnabled: true
            }
          }
        ],
        include: path.resolve(__dirname, "../")
      }
    ]
  }
};
Run Code Online (Sandbox Code Playgroud)

// .stories/.babelrc

{
  "plugins": [
    [
      "import",
      {
        "libraryName": "antd",
        "style": "css"
      }
    ]
  ]
}

Run Code Online (Sandbox Code Playgroud)

// 我的组件基于 AntDesign

import { Menu } from "antd";
import React, { FC } from "react";
import { RouteComponentProps, withRouter } from "react-router";
import { styled } from "styletron-react";

export const Sidebar: FC<RouteComponentProps> = ({ history }) => {
  const SidebarLayout = styled(Menu, {
    height: "100vh",
    width: "100%"
  });

  return (
    <SidebarLayout
      onSelect={item => {
        history.push(item.key);
      }}
      defaultSelectedKeys={["/"]}
      selectedKeys={[history.location.pathname]}
      mode="inline"
      theme="dark"
    >
      <Menu.Item key="/">Table View</Menu.Item>
      <Menu.Item key="/dashboard">Dashboard</Menu.Item>
    </SidebarLayout>
  );
};

export default withRouter(Sidebar);
Run Code Online (Sandbox Code Playgroud)

// 我的故事

import { storiesOf } from "@storybook/react";
import { Button } from "antd";
import React from "react";
import { MemoryRouter } from "react-router";
import Sidebar from ".";

storiesOf("Sidebar", module).add("Renders a regular menu", () => {
  return (
    <MemoryRouter initialEntries={["/"]}>
      <Sidebar />
      <Button type="primary">Button</Button>
    </MemoryRouter>
  );
});

Run Code Online (Sandbox Code Playgroud)

// 运行故事书显示: 运行故事书的结果

我希望在我的故事书中呈现基于 AntD 的组件,就像在我的 CRA 项目中一样: 运行基于 CRA 的项目的结果

Suj*_*rni 5

这是我如何让它与Storybook v6一起使用

步骤 1:安装 Ant design 的预设。来源

npm i -D @storybook/preset-ant-design

第 2 步:在 .storybook/main.js 中添加上述预设的引用。另请注意 @storybook/preset-create-react-app 的选项是如何被覆盖的。

module.exports = {
  "stories": [
    "../src/**/*.stories.mdx",
    "../src/**/*.stories.@(js|jsx|ts|tsx)"
  ],
  "addons": [
    "@storybook/addon-links",
    "@storybook/addon-essentials",
    "@storybook/preset-ant-design",
    {
      "name": "@storybook/preset-create-react-app",
      "options": {
        "craOverrides": {
          "fileLoaderExcludes": ["less"]
        }
      }
    }
  ],
}
Run Code Online (Sandbox Code Playgroud)

看起来 Storybook 6.0 会处理其余的事情,就我而言,除了这两件事之外不需要任何更改。