Jotai

一個 Storybook 擴充功能,可讓您使用和模擬依賴 Jotai 的 React 元件。

在 Github 上檢視

Storybook Jotai 擴充功能

適用於 Storybook v8 的擴充功能和裝飾器,用於 Jotai 的模擬,並在 Storybook 面板中顯示目前的值。

如果您想將 parameters 設定為強型別,請參閱 @alexgorbatchev/storybook-parameters

安裝

npm i --save-dev @alexgorbatchev/storybook-addon-jotai

.storybook/main.js 中註冊擴充功能

export default {
  stories: ['../stories/**/*.stories.tsx'],
  addons: ['@alexgorbatchev/storybook-addon-jotai'],
};

重要

請記住,擴充功能會使用來自 jotai 套件的 Provider 包裹所有內容。重要的是,您的 story 元件不包含 Provider,否則擴充功能將無法查看和設定 atom 值。

用法

假設有一個簡單的元件

import { useAtom, atom } from 'jotai';

const userAtom = atom(null);

export const Header = () => {
  const [user] = useAtom(userAtom);

  return (
    <div>
      {user ? (
        <div>
          <div>{`Logged in as ${user.name}`}</div>
          <Button size="small" label="Log out" onClick={() => setUser(null)} />
        </div>
      ) : (
        <div>
          <div>No one is signed in</div>
          <Button size="small" label="Log in" onClick={() => setUser({ name: 'John' })} />
        </div>
      )}
    </div>
  );
};

您可以這樣編寫 story

import { atomsForStorybook } from '@alexgorbatchev/storybook-addon-jotai';
import { Meta, StoryObj } from '@storybook/react';

import { User, userAtom } from './User';

type Story = StoryObj<typeof Header>;

const meta: : Meta<typeof Header> = {
  title: 'User',
  component: User,
};

export default meta;

export const JohnLoggedIn: Story = {
  parameters: {
    jotai: atomsForStorybook({
      atoms: {
        user: userAtom,
      },
      values: {
        user: {
          name: 'John Doe',
        },
      },
    }),
  },
};

// `jotai`, `atoms`, and `values` each can be a function for deferred evaluation.
export const JaneLoggedIn: Story = {
  parameters: {
    jotai: () => atomsForStorybook({
      atoms: () => ({
        user: userAtom,
      }),
      values: () => ({
        user: {
          name: 'Jane Doe',
        },
      }),
    }),
  };
};

export const LoggedOut: Story = {};

強型別範例

import { Meta, StoryObj } from '@alexgorbatchev/storybook-parameters';
import { JotaiParameters } from '@alexgorbatchev/storybook-addon-jotai';

import { User, userAtom } from './User';

interface StoryParameters extends JotaiParameters {}

const meta: Meta<typeof Header, StoryParameters> = {
  title: 'Header',
  component: Header,
};

export default meta;

type Story = StoryObj<typeof Header, StoryParameters>;

export const JohnLoggedIn: Story = {
  parameters: {
    // `jotai` is strongly typed
    jotai: atomsForStorybook({
      atoms: {
        user: userAtom,
      },
      values: {
        user: {
          name: 'Jane Doe',
        },
      },
    }),
  },
};

開發指令稿

  • npm run storybook 啟動 Storybook
  • tsup 建置 ./dist
由以下人員製作
  • alexgorbatchev
    alexgorbatchev
適用於
    React
標籤