import React from 'react'; import { ComponentStory, ComponentMeta } from '@storybook/react'; import { DISPLAY, BackgroundColor, BorderColor, FONT_WEIGHT, FONT_STYLE, TextColor, TEXT_ALIGN, OVERFLOW_WRAP, TEXT_TRANSFORM, FRACTIONS, FLEX_DIRECTION, TextVariant, Color, } from '../../../helpers/constants/design-system'; import Box from '../../ui/box'; import README from './README.mdx'; import { Text } from './text'; import { ValidTag, TextDirection } from './text.types'; export default { title: 'Components/ComponentLibrary/Text', component: Text, parameters: { docs: { page: README, }, }, } as ComponentMeta; function renderBackgroundColor(color) { let bgColor; switch (color) { case Color.overlayInverse: bgColor = BackgroundColor.overlayDefault; break; case Color.primaryInverse: bgColor = BackgroundColor.primaryDefault; break; case Color.errorInverse: bgColor = BackgroundColor.errorDefault; break; case Color.warningInverse: bgColor = BackgroundColor.warningDefault; break; case Color.successInverse: bgColor = BackgroundColor.successDefault; break; case Color.infoInverse: bgColor = BackgroundColor.infoDefault; break; case Color.goerliInverse: bgColor = BackgroundColor.goerli; break; case Color.sepoliaInverse: bgColor = BackgroundColor.sepolia; break; case Color.lineaTestnetInverse: bgColor = BackgroundColor.lineaTestnet; break; default: bgColor = null; break; } return bgColor; } const Template: ComponentStory = (args) => ( {args.children} ); export const DefaultStory = Template.bind({}); DefaultStory.args = { children: 'The quick orange fox jumped over the lazy dog.', }; DefaultStory.storyName = 'Default'; export const Variant = (args) => ( <> {Object.values(TextVariant).map((variant) => ( {args.children || variant} ))} ); export const ColorStory: ComponentStory = (args) => { // Index of last valid color in TextColor array return ( <> {Object.values(TextColor).map((color) => { return ( {color} ); })} ); }; ColorStory.storyName = 'Color'; export const FontWeight: ComponentStory = (args) => ( <> {Object.values(FONT_WEIGHT).map((weight) => ( {weight} ))} ); export const FontStyle: ComponentStory = (args) => ( <> {Object.values(FONT_STYLE).map((style) => ( {style} ))} ); export const TextTransform: ComponentStory = (args) => ( <> {Object.values(TEXT_TRANSFORM).map((transform) => ( {transform} ))} ); export const TextAlign: ComponentStory = (args) => ( <> {Object.values(TEXT_ALIGN).map((align) => ( {align} ))} ); export const OverflowWrap: ComponentStory = (args) => ( {OVERFLOW_WRAP.NORMAL}: 0x39013f961c378f02c2b82a6e1d31e9812786fd9d {OVERFLOW_WRAP.BREAK_WORD}: 0x39013f961c378f02c2b82a6e1d31e9812786fd9d ); export const Ellipsis: ComponentStory = (args) => ( Ellipsis: 0x39013f961c378f02c2b82a6e1d31e9812786fd9d No Ellipsis: 0x39013f961c378f02c2b82a6e1d31e9812786fd9d ); export const As: ComponentStory = (args) => ( <> {Object.keys(ValidTag).map((tag) => { if (ValidTag[tag] === ValidTag.Input) { return ( ); } return (
{ValidTag[tag]}
); })} ); export const TextDirectionStory: ComponentStory = (args) => ( This is left to right (ltr) for English and most languages This is right to left (rtl) for use with other laguanges such as Arabic. This Enlgish example is incorrect usage. Let the user agent decide with the auto option );