Skip to content

Commit

Permalink
chore(lib): add theme mode control to storybook (#24)
Browse files Browse the repository at this point in the history
  • Loading branch information
mwiercinska authored Sep 4, 2024
1 parent e919384 commit a5732dd
Show file tree
Hide file tree
Showing 4 changed files with 48 additions and 16 deletions.
2 changes: 1 addition & 1 deletion lib/.storybook/main.ts
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@ import type { StorybookConfig } from '@storybook/react-webpack5';

const config: StorybookConfig = {
stories: ['../__stories__/**/*.stories.@(js|jsx|mjs|ts|tsx)'],
addons: ['@storybook/addon-webpack5-compiler-swc'],
addons: ['@storybook/addon-webpack5-compiler-swc', '@storybook/addon-controls'],
framework: {
name: '@storybook/react-webpack5',
options: {},
Expand Down
46 changes: 31 additions & 15 deletions lib/__stories__/CryptoIcon.stories.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -6,15 +6,31 @@ import CryptoIcon from '../src/components/CryptoIcon';
const meta = {
title: 'CryptoIcon',
component: CryptoIcon,
argTypes: {
theme: {
control: {
type: 'radio',
},
options: ['dark', 'light'],
table: {
type: {
summary: 'radio',
},
defaultValue: {
summary: 'light',
},
},
},
},
} satisfies Meta<typeof CryptoIcon>;

export default meta;

const Template: StoryFn = () => (
<div>
const Template: StoryFn = ({ theme = 'light' }) => (
<div style={{ padding: '0.5rem', backgroundColor: theme === 'light' ? '#FFFFFF' : '#1C1D1F' }}>
{Object.entries(iconsObj).map(([key, value]) => (
<div key={key}>
<p>{key}</p>
<p style={{ color: theme === 'light' ? '#1C1D1F' : '#FFFFFF' }}>{key}</p>
<div
style={{
marginBottom: '20px',
Expand All @@ -28,12 +44,12 @@ const Template: StoryFn = () => (
marginBottom: '10px',
}}
>
<CryptoIcon ledgerId={key} ticker={value.icon} size="56px" />
<CryptoIcon ledgerId={key} ticker={value.icon} size="48px" />
<CryptoIcon ledgerId={key} ticker={value.icon} size="40px" />
<CryptoIcon ledgerId={key} ticker={value.icon} size="32px" />
<CryptoIcon ledgerId={key} ticker={value.icon} size="24px" />
<CryptoIcon ledgerId={key} ticker={value.icon} />
<CryptoIcon ledgerId={key} ticker={value.icon} size="56px" theme={theme} />
<CryptoIcon ledgerId={key} ticker={value.icon} size="48px" theme={theme} />
<CryptoIcon ledgerId={key} ticker={value.icon} size="40px" theme={theme} />
<CryptoIcon ledgerId={key} ticker={value.icon} size="32px" theme={theme} />
<CryptoIcon ledgerId={key} ticker={value.icon} size="24px" theme={theme} />
<CryptoIcon ledgerId={key} ticker={value.icon} theme={theme} />
</div>
<div
style={{
Expand All @@ -43,12 +59,12 @@ const Template: StoryFn = () => (
marginBottom: '10px',
}}
>
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="56px" />
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="48px" />
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="40px" />
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="32px" />
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="24px" />
<CryptoIcon ledgerId={'none'} ticker={value.icon} />
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="56px" theme={theme} />
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="48px" theme={theme} />
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="40px" theme={theme} />
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="32px" theme={theme} />
<CryptoIcon ledgerId={'none'} ticker={value.icon} size="24px" theme={theme} />
<CryptoIcon ledgerId={'none'} ticker={value.icon} theme={theme} />
</div>
</div>
</div>
Expand Down
1 change: 1 addition & 0 deletions lib/package.json
Original file line number Diff line number Diff line change
Expand Up @@ -28,6 +28,7 @@
"@rollup/plugin-node-resolve": "^15.2.3",
"@rollup/plugin-terser": "^0.4.4",
"@rollup/plugin-url": "^8.0.2",
"@storybook/addon-controls": "8.2.6",
"@storybook/addon-webpack5-compiler-swc": "^1.0.4",
"@storybook/react": "^8.2.6",
"@storybook/react-webpack5": "^8.2.6",
Expand Down
15 changes: 15 additions & 0 deletions lib/pnpm-lock.yaml

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

0 comments on commit a5732dd

Please sign in to comment.