1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-11-22 09:57:02 +01:00
metamask-extension/ui/components/component-library/text/text.tsx
2023-07-20 15:06:28 -07:00

81 lines
2.1 KiB
TypeScript

import React from 'react';
import classnames from 'classnames';
import {
TextVariant,
TextColor,
} from '../../../helpers/constants/design-system';
import { Box } from '..';
import type { PolymorphicRef, BoxProps } from '../box';
import { TextProps, TextComponent } from './text.types';
const getTextElementDefault = (variant: TextVariant) => {
switch (variant) {
case TextVariant.displayMd:
return 'h1';
case TextVariant.headingLg:
return 'h2';
case TextVariant.headingMd:
return 'h3';
case TextVariant.headingSm:
return 'h4';
case TextVariant.inherit:
return 'span';
// TextVariant.bodyLgMedium, TextVariant.bodyMd, TextVariant.bodyMdBold, TextVariant.bodySm, TextVariant.bodySmBold, TextVariant.bodyXs use default 'p' tag
default:
return 'p';
}
};
export const Text: TextComponent = React.forwardRef(
<C extends React.ElementType = 'p'>(
{
variant = TextVariant.bodyMd,
fontWeight,
fontStyle,
textTransform,
textAlign,
textDirection,
overflowWrap,
ellipsis,
className = '',
children,
...props
}: TextProps<C>,
ref?: PolymorphicRef<C>,
) => {
// Set tag based on variant
// If as prop is passed tag will be overridden
const tag = getTextElementDefault(variant);
const computedClassName = classnames(
'mm-text',
className,
`mm-text--${variant}`,
{
[`mm-text--font-weight-${fontWeight}`]: Boolean(fontWeight),
[`mm-text--font-style-${fontStyle}`]: Boolean(fontStyle),
[`mm-text--ellipsis`]: Boolean(ellipsis),
[`mm-text--text-transform-${textTransform}`]: Boolean(textTransform),
[`mm-text--text-align-${textAlign}`]: Boolean(textAlign),
[`mm-text--overflow-wrap-${overflowWrap}`]: Boolean(overflowWrap),
},
);
return (
<Box
className={classnames(computedClassName)}
as={tag}
dir={textDirection}
ref={ref}
color={TextColor.textDefault}
{...(props as BoxProps<C>)}
>
{children}
</Box>
);
},
);