1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-12-23 09:52:26 +01:00
metamask-extension/ui/components/component-library/icon/icon.stories.tsx

381 lines
11 KiB
TypeScript
Raw Normal View History

import React, { useState } from 'react';
import { StoryFn, Meta } from '@storybook/react';
import {
AlignItems,
Display,
IconColor,
FlexDirection,
JustifyContent,
TextVariant,
FlexWrap,
TextAlign,
BackgroundColor,
BorderColor,
Color,
TextColor,
BorderRadius,
} from '../../../helpers/constants/design-system';
2022-11-23 18:58:43 +01:00
import {
ButtonIcon,
ButtonLink,
ButtonLinkSize,
2022-11-23 18:58:43 +01:00
Label,
Text,
TextField,
TextFieldSearch,
TEXT_FIELD_SIZES,
ButtonIconSize,
Box,
2022-11-23 18:58:43 +01:00
} from '..';
import { Icon } from './icon';
import { IconName, IconSize } from './icon.types';
import README from './README.mdx';
export default {
title: 'Components/ComponentLibrary/Icon',
component: Icon,
parameters: {
docs: {
page: README,
},
},
args: {
name: IconName.AddSquare,
color: IconColor.inherit,
size: IconSize.Md,
},
} as Meta<typeof Icon>;
export const DefaultStory: StoryFn<typeof Icon> = (args) => {
const [search, setSearch] = useState('');
const iconList = Object.keys(IconName)
.filter(
(item) =>
search === '' ||
item.toLowerCase().includes(search.toLowerCase().replace(' ', '_')),
)
.sort();
const handleSearch = (e) => {
setSearch(e.target.value);
};
2022-11-23 18:58:43 +01:00
const handleOnClear = () => {
setSearch('');
};
return (
<>
<Text as="h2" marginBottom={2} variant={TextVariant.headingMd}>
Icon search
</Text>
<Box
display={Display.Grid}
gap={2}
2022-11-23 18:58:43 +01:00
style={{
gridTemplateColumns: 'repeat(auto-fill, minmax(180px, 1fr))',
}}
>
2022-11-23 18:58:43 +01:00
<Box
style={{ gridColumnStart: 1, gridColumnEnd: 3 }}
display={Display.Flex}
flexDirection={FlexDirection.Column}
2022-11-23 18:58:43 +01:00
>
{/* TODO replace with FormTextField */}
<Label htmlFor="icon-search">IconName</Label>
2022-11-23 18:58:43 +01:00
<TextFieldSearch
id="icon-search"
marginBottom={4}
onChange={handleSearch}
clearButtonOnClick={handleOnClear}
value={search}
placeholder="Search icon name"
/>
</Box>
</Box>
2022-11-23 18:58:43 +01:00
{iconList.length > 0 ? (
<Box
display={Display.Grid}
2022-11-23 18:58:43 +01:00
gap={2}
style={{
gridTemplateColumns: 'repeat(auto-fill, minmax(180px, 1fr))',
}}
>
{iconList.map((item) => {
return (
<Box
borderColor={BorderColor.borderMuted}
borderRadius={BorderRadius.MD}
display={Display.Flex}
flexDirection={FlexDirection.Column}
alignItems={AlignItems.center}
justifyContent={JustifyContent.center}
2022-11-23 18:58:43 +01:00
padding={4}
key={item}
>
<Icon marginBottom={2} {...args} name={IconName[item]} />
2022-11-23 18:58:43 +01:00
<TextField
placeholder={item}
value={item}
readOnly
size={TEXT_FIELD_SIZES.SM}
2022-11-23 18:58:43 +01:00
inputProps={{
variant: TextVariant.bodyXs,
textAlign: TextAlign.Center,
2022-11-23 18:58:43 +01:00
}}
backgroundColor={BackgroundColor.backgroundAlternative}
endAccessory={
2022-11-23 18:58:43 +01:00
<ButtonIcon
iconName={IconName.Copy}
size={ButtonIconSize.Sm}
color={IconColor.iconAlternative}
2022-11-23 18:58:43 +01:00
ariaLabel="Copy to clipboard"
title="Copy to clipboard"
onClick={() => {
const tempEl = document.createElement('textarea');
tempEl.value = item;
document.body.appendChild(tempEl);
tempEl.select();
document.execCommand('copy');
document.body.removeChild(tempEl);
}}
/>
}
/>
</Box>
);
})}
</Box>
) : (
<Text>
No matches. Please try again or ask in the{' '}
<ButtonLink
size={ButtonLinkSize.Inherit}
color={TextColor.primaryDefault}
2022-11-23 18:58:43 +01:00
href="https://consensys.slack.com/archives/C0354T27M5M"
target="_blank"
>
#metamask-design-system
</ButtonLink>{' '}
channel on slack.
</Text>
)}
</>
);
};
2022-11-23 18:58:43 +01:00
DefaultStory.storyName = 'Default';
export const Name: StoryFn<typeof Icon> = (args) => (
2022-11-23 18:58:43 +01:00
<>
<Box display={Display.Flex} flexWrap={FlexWrap.Wrap} gap={2}>
{Object.keys(IconName).map((item) => {
2022-11-23 18:58:43 +01:00
return (
<Box
borderColor={BorderColor.borderMuted}
borderRadius={BorderRadius.MD}
display={Display.Flex}
flexDirection={FlexDirection.Column}
alignItems={AlignItems.center}
justifyContent={JustifyContent.center}
2022-11-23 18:58:43 +01:00
padding={4}
key={item}
>
<Icon {...args} name={IconName[item]} />
2022-11-23 18:58:43 +01:00
</Box>
);
})}
</Box>
</>
);
export const SizeStory: StoryFn<typeof Icon> = (args) => (
<>
<Box
display={Display.Flex}
alignItems={AlignItems.baseline}
gap={1}
marginBottom={4}
>
<Icon {...args} size={IconSize.Xs} />
<Icon {...args} size={IconSize.Sm} />
<Icon {...args} size={IconSize.Md} />
<Icon {...args} size={IconSize.Lg} />
<Icon {...args} size={IconSize.Xl} />
</Box>
<Text variant={TextVariant.displayMd}>
inherits the font-size of the parent element.{' '}
<Icon {...args} size={IconSize.Inherit} />
</Text>
<Text variant={TextVariant.headingLg}>
inherits the font-size of the parent element.{' '}
<Icon {...args} size={IconSize.Inherit} />
</Text>
<Text variant={TextVariant.headingMd}>
inherits the font-size of the parent element.{' '}
<Icon {...args} size={IconSize.Inherit} />
</Text>
<Text variant={TextVariant.headingSm}>
inherits the font-size of the parent element.{' '}
<Icon {...args} size={IconSize.Inherit} />
</Text>
<Text variant={TextVariant.bodyLgMedium}>
inherits the font-size of the parent element.{' '}
<Icon {...args} size={IconSize.Inherit} />
</Text>
<Text variant={TextVariant.bodyMd}>
inherits the font-size of the parent element.{' '}
<Icon {...args} size={IconSize.Inherit} />
</Text>
<Text variant={TextVariant.bodySm}>
inherits the font-size of the parent element.{' '}
<Icon {...args} size={IconSize.Inherit} />
</Text>
<Text variant={TextVariant.bodyXs}>
inherits the font-size of the parent element.{' '}
<Icon {...args} size={IconSize.Inherit} />
</Text>
</>
);
SizeStory.storyName = 'Size';
2022-11-23 18:58:43 +01:00
export const ColorStory: StoryFn<typeof Icon> = (args) => (
<Box display={Display.Flex} alignItems={AlignItems.baseline}>
<Box padding={1} display={Display.Flex} alignItems={AlignItems.center}>
<Icon {...args} color={IconColor.inherit} />
</Box>
<Box padding={1} display={Display.Flex} alignItems={AlignItems.center}>
<Icon {...args} color={IconColor.iconDefault} />
</Box>
<Box padding={1} display={Display.Flex} alignItems={AlignItems.center}>
<Icon {...args} color={IconColor.iconAlternative} />
</Box>
<Box padding={1} display={Display.Flex} alignItems={AlignItems.center}>
<Icon {...args} color={IconColor.iconMuted} />
</Box>
<Box
padding={1}
display={Display.Flex}
alignItems={AlignItems.center}
backgroundColor={BackgroundColor.overlayDefault}
>
<Icon {...args} color={IconColor.overlayInverse} />
</Box>
<Box padding={1} display={Display.Flex} alignItems={AlignItems.center}>
<Icon {...args} color={IconColor.primaryDefault} />
</Box>
<Box
padding={1}
display={Display.Flex}
alignItems={AlignItems.center}
backgroundColor={BackgroundColor.primaryDefault}
>
<Icon {...args} color={IconColor.primaryInverse} />
</Box>
<Box padding={1} display={Display.Flex} alignItems={AlignItems.center}>
<Icon {...args} color={IconColor.errorDefault} />
</Box>
<Box
padding={1}
display={Display.Flex}
alignItems={AlignItems.center}
backgroundColor={BackgroundColor.errorDefault}
>
<Icon {...args} color={IconColor.errorInverse} />
</Box>
<Box padding={1} display={Display.Flex} alignItems={AlignItems.center}>
<Icon {...args} color={IconColor.successDefault} />
</Box>
<Box
padding={1}
display={Display.Flex}
alignItems={AlignItems.center}
backgroundColor={BackgroundColor.successDefault}
>
<Icon {...args} color={IconColor.successInverse} />
</Box>
<Box padding={1} display={Display.Flex} alignItems={AlignItems.center}>
<Icon {...args} color={IconColor.warningDefault} />
</Box>
<Box
padding={1}
display={Display.Flex}
alignItems={AlignItems.center}
backgroundColor={BackgroundColor.warningDefault}
>
<Icon {...args} color={IconColor.warningInverse} />
</Box>
<Box padding={1} display={Display.Flex} alignItems={AlignItems.center}>
<Icon {...args} color={IconColor.infoDefault} />
</Box>
<Box
padding={1}
display={Display.Flex}
alignItems={AlignItems.center}
backgroundColor={BackgroundColor.infoDefault}
>
<Icon {...args} color={IconColor.infoInverse} />
</Box>
</Box>
);
ColorStory.storyName = 'Color';
export const LayoutAndSpacing = () => (
<Box display={Display.Flex} flexDirection={FlexDirection.Column} gap={4}>
<Box display={Display.Flex} alignItems={AlignItems.center}>
<Icon
name={IconName.Check}
color={IconColor.successDefault}
marginRight={1}
/>
<Text>Always allow you to opt-out via Settings</Text>
</Box>
<Box
as="button"
display={Display.Flex}
alignItems={AlignItems.center}
borderRadius={BorderRadius.pill}
backgroundColor={BackgroundColor.primaryMuted}
marginRight="auto"
>
<Text color={Color.primaryDefault}>
0x79fAaFe7B6D5DB5D8c63FE88DFF0AF1Fe53358db
</Text>
<Icon
name={IconName.Copy}
color={IconColor.primaryDefault}
marginLeft={1}
/>
</Box>
<Box
as="button"
display={Display.Flex}
alignItems={AlignItems.center}
padding={4}
borderColor={BorderColor.borderMuted}
backgroundColor={BackgroundColor.backgroundDefault}
>
<Icon name={IconName.Add} color={IconColor.iconDefault} marginRight={2} />
<Text>Create account</Text>
</Box>
<Label>
Custom spending cap{' '}
<Icon name={IconName.Info} size={IconSize.Inherit} marginLeft={1} />
</Label>
<div>
<Text>
<Icon
name={IconName.Warning}
size={IconSize.Inherit}
marginLeft={1}
color={IconColor.warningDefault}
/>{' '}
Warning
</Text>
</div>
</Box>
);