1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/components/ui/icon/icon.stories.js
Mark Stacey c154145e85 Add IconEye and IconEyeSlash icon components (#13978)
Add two new FontAwesome icon components. The first is an eye, and the
second is an eye with a slash through it. These will be used in a
subsequent PR for a "Show/Hide" toggle.
2022-03-21 18:51:18 -02:30

246 lines
6.5 KiB
JavaScript

import PropTypes from 'prop-types';
import React from 'react';
import { SEVERITIES } from '../../../helpers/constants/design-system';
import Card from '../card';
import Typography from '../typography';
import Box from '../box';
import README from './README.mdx';
import Approve from './approve-icon.component';
import BuyIcon from './overview-buy-icon.component';
import CopyIcon from './copy-icon.component';
import InfoIcon from './info-icon.component';
import InfoIconInverted from './info-icon-inverted.component';
import Interaction from './interaction-icon.component';
import PaperAirplane from './paper-airplane-icon';
import Preloader from './preloader';
import ReceiveIcon from './receive-icon.component';
import SendIcon from './send-icon.component';
import Sign from './sign-icon.component';
import SunCheck from './sun-check-icon.component';
import Swap from './swap-icon-for-list.component';
import SwapIcon from './overview-send-icon.component';
import SwapIconComponent from './swap-icon.component';
import IconEye from './icon-eye';
import IconEyeSlash from './icon-eye-slash';
export default {
title: 'Components/UI/Icon',
id: __filename,
parameters: {
docs: {
page: README,
},
},
};
const IconItem = ({ Component }) => {
return (
<Card display="flex" flexDirection="column" textAlign="center">
<Box marginBottom={2}>{Component}</Box>
<code>{`${Component.type.__docgenInfo.displayName}`}</code>
</Card>
);
};
IconItem.propTypes = {
Component: PropTypes.node,
};
export const DefaultStory = (args) => (
<div>
<Typography variant="h2" boxProps={{ marginBottom: 4 }}>
Icons
</Typography>
<Box marginBottom={4}>
<Typography variant="h4" boxProps={{ marginBottom: 2 }}>
Circle Icons
</Typography>
<div
style={{
display: 'grid',
gridGap: '16px',
gridTemplateColumns: 'repeat(auto-fill, 176px)',
}}
>
<IconItem Component={<Approve {...args} />} />
<IconItem Component={<Sign {...args} />} />
<IconItem Component={<Swap {...args} />} />
<IconItem Component={<SendIcon {...args} />} />
<IconItem Component={<ReceiveIcon {...args} />} />
<IconItem Component={<Interaction {...args} />} />
</div>
</Box>
<Box marginBottom={4}>
<Typography variant="h4" boxProps={{ marginBottom: 2 }}>
Invertible Icons
</Typography>
<div
style={{
display: 'grid',
gridGap: '16px',
gridTemplateColumns: 'repeat(auto-fill, 176px)',
}}
>
<IconItem Component={<InfoIcon {...args} />} />
<IconItem Component={<InfoIconInverted {...args} />} />
<IconItem Component={<SunCheck {...args} />} />
<IconItem Component={<SunCheck {...args} reverseColors />} />
</div>
</Box>
<Box marginBottom={4}>
<Typography variant="h4" boxProps={{ marginBottom: 2 }}>
Other Icons
</Typography>
<div
style={{
display: 'grid',
gridGap: '16px',
gridTemplateColumns: 'repeat(auto-fill, 176px)',
}}
>
<IconItem Component={<BuyIcon {...args} />} />
<IconItem Component={<SwapIcon {...args} />} />
<IconItem Component={<SwapIconComponent {...args} />} />
<IconItem Component={<PaperAirplane {...args} />} />
<IconItem Component={<CopyIcon {...args} />} />
<IconItem Component={<Preloader {...args} />} />
<IconItem Component={<IconEye {...args} />} />
<IconItem Component={<IconEyeSlash {...args} />} />
</div>
</Box>
</div>
);
DefaultStory.args = {
width: '17',
height: '21',
fill: '#2F80ED',
size: 40,
color: '#2F80ED',
severity: 'info',
reverseColors: false,
};
export const ApproveStory = (args) => <Approve {...args} />;
ApproveStory.args = {
size: 40,
color: '#2F80ED',
};
ApproveStory.storyName = 'Approve';
export const SignStory = (args) => <Sign {...args} />;
SignStory.args = {
size: 40,
color: '#2F80ED',
};
SignStory.storyName = 'Sign';
export const SwapStory = (args) => <Swap {...args} />;
SwapStory.args = {
size: 40,
color: '#2F80ED',
};
SwapStory.storyName = 'Swap';
export const SendIconStory = (args) => <SendIcon {...args} />;
SendIconStory.args = {
size: 40,
color: '#2F80ED',
};
SendIconStory.storyName = 'SendIcon';
export const ReceiveIconStory = (args) => <ReceiveIcon {...args} />;
ReceiveIconStory.args = {
size: 40,
color: '#2F80ED',
};
ReceiveIconStory.storyName = 'ReceiveIcon';
export const InteractionStory = (args) => <Interaction {...args} />;
InteractionStory.args = {
size: 40,
color: '#2F80ED',
};
InteractionStory.storyName = 'Interaction';
export const InfoIconStory = (args) => <InfoIcon {...args} />;
InfoIconStory.args = {
severity: SEVERITIES.INFO,
};
InfoIconStory.argTypes = {
severity: {
control: 'select',
options: ['warning', 'info', 'danger', 'success'],
},
};
InfoIconStory.storyName = 'InfoIcon';
export const InfoIconInvertedStory = (args) => <InfoIconInverted {...args} />;
InfoIconInvertedStory.args = {
severity: SEVERITIES.INFO,
};
InfoIconInvertedStory.argTypes = {
severity: {
control: 'select',
options: ['warning', 'info', 'danger', 'success'],
},
};
InfoIconInvertedStory.storyName = 'InfoIconInverted';
export const SunCheckStory = (args) => <SunCheck {...args} />;
SunCheckStory.args = {
reverseColors: false,
};
SunCheckStory.argTypes = {
reverseColors: {
control: 'boolean',
},
};
SunCheckStory.storyName = 'SunCheck';
export const BuyIconStory = (args) => <BuyIcon {...args} />;
BuyIconStory.args = {
width: '17',
height: '21',
fill: '#2F80ED',
};
BuyIconStory.storyName = 'BuyIcon';
export const SwapIconStory = (args) => <SwapIcon {...args} />;
SwapIconStory.args = {
width: '17',
height: '21',
fill: '#2F80ED',
};
SwapIconStory.storyName = 'SwapIcon';
export const SendSwapIconStory = (args) => <SwapIconComponent {...args} />;
SendSwapIconStory.args = {
width: '17',
height: '17',
color: '#2F80ED',
};
SendSwapIconStory.storyName = 'Send/SwapIcon';
export const PaperAirplaneStory = (args) => <PaperAirplane {...args} />;
PaperAirplaneStory.args = {
size: 40,
color: '#2F80ED',
};
PaperAirplaneStory.storyName = 'PaperAirplane';
export const CopyIconStory = (args) => <CopyIcon {...args} />;
CopyIconStory.args = {
size: 40,
color: '#2F80ED',
};
CopyIconStory.storyName = 'CopyIcon';
export const PreloaderStory = (args) => <Preloader {...args} />;
PreloaderStory.args = {
size: 40,
};
PreloaderStory.storyName = 'Preloader';