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
啟動 Storybooktsup
建置./dist