mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
01057f9824
* convert text component to TS * invisible character fix * storybook fix * fix types export * update ButtonBase * add typeof to objects in TextProps * fix linting issues * fix implicit conversion * lint fix * add deprecated Text back * change box ref to any * fix classnames issue * account details to use deprecated text reference * ref update * make RefObject * remove RefObject and go back to Ref * react.ref change to box
85 lines
2.2 KiB
TypeScript
85 lines
2.2 KiB
TypeScript
import React, { forwardRef, Ref } from 'react';
|
|
import classnames from 'classnames';
|
|
import Box from '../../ui/box';
|
|
import {
|
|
FONT_WEIGHT,
|
|
TextVariant,
|
|
TextColor,
|
|
} from '../../../helpers/constants/design-system';
|
|
import { TextProps, ValidTag } from './text.types';
|
|
|
|
const getTextElementDefault = (variant: TextVariant) => {
|
|
switch (variant) {
|
|
case TextVariant.displayMd:
|
|
return ValidTag.H1;
|
|
case TextVariant.headingLg:
|
|
return ValidTag.H2;
|
|
case TextVariant.headingMd:
|
|
return ValidTag.H3;
|
|
case TextVariant.headingSm:
|
|
return ValidTag.H4;
|
|
case TextVariant.inherit:
|
|
return ValidTag.Span;
|
|
// TextVariant.bodyLgMedium, TextVariant.bodyMd, TextVariant.bodyMdBold, TextVariant.bodySm, TextVariant.bodySmBold, TextVariant.bodyXs use default 'p' tag
|
|
default:
|
|
return ValidTag.P;
|
|
}
|
|
};
|
|
|
|
export const Text = forwardRef(function Text(
|
|
{
|
|
variant = TextVariant.bodyMd,
|
|
color = TextColor.textDefault,
|
|
fontWeight,
|
|
fontStyle,
|
|
textTransform,
|
|
textAlign,
|
|
textDirection,
|
|
overflowWrap,
|
|
ellipsis,
|
|
as,
|
|
className = '',
|
|
children,
|
|
...props
|
|
}: TextProps,
|
|
ref: Ref<HTMLElement>,
|
|
) {
|
|
// Check if as is set otherwise set a default tag based on variant
|
|
const Tag = as ?? getTextElementDefault(variant);
|
|
let strongTagFontWeight;
|
|
|
|
if (Tag === 'strong') {
|
|
strongTagFontWeight = FONT_WEIGHT.BOLD;
|
|
}
|
|
|
|
const computedClassName = classnames(
|
|
'mm-text',
|
|
className,
|
|
`mm-text--${variant}`,
|
|
{
|
|
[`mm-text--font-weight-${strongTagFontWeight || fontWeight}`]: Boolean(
|
|
strongTagFontWeight || fontWeight,
|
|
),
|
|
[`mm-text--font-style-${String(fontStyle)}`]: Boolean(fontStyle),
|
|
[`mm-text--ellipsis`]: Boolean(ellipsis),
|
|
[`mm-text--text-transform-${String(textTransform)}`]:
|
|
Boolean(textTransform),
|
|
[`mm-text--text-align-${String(textAlign)}`]: Boolean(textAlign),
|
|
[`mm-text--overflow-wrap-${String(overflowWrap)}`]: Boolean(overflowWrap),
|
|
},
|
|
);
|
|
|
|
return (
|
|
<Box
|
|
className={classnames(computedClassName)}
|
|
as={Tag}
|
|
dir={textDirection}
|
|
color={color}
|
|
ref={ref}
|
|
{...props}
|
|
>
|
|
{children}
|
|
</Box>
|
|
);
|
|
});
|