mirror of
https://github.com/kremalicious/metamask-extension.git
synced 2024-12-23 09:52:26 +01:00
70 lines
1.7 KiB
JavaScript
70 lines
1.7 KiB
JavaScript
import React from 'react';
|
|
import PropTypes from 'prop-types';
|
|
import Box from '../../../ui/box';
|
|
import Typography from '../../../ui/typography';
|
|
import {
|
|
AlignItems,
|
|
BorderRadius,
|
|
JustifyContent,
|
|
OVERFLOW_WRAP,
|
|
FLEX_DIRECTION,
|
|
TypographyVariant,
|
|
BackgroundColor,
|
|
TextColor,
|
|
Color,
|
|
} from '../../../../helpers/constants/design-system';
|
|
import { useCopyToClipboard } from '../../../../hooks/useCopyToClipboard';
|
|
import { Icon, IconName, IconSize } from '../../../component-library';
|
|
|
|
export const Copyable = ({ text }) => {
|
|
const [copied, handleCopy] = useCopyToClipboard();
|
|
return (
|
|
<Box
|
|
className="copyable"
|
|
backgroundColor={BackgroundColor.backgroundAlternative}
|
|
alignItems={AlignItems.stretch}
|
|
justifyContent={JustifyContent.spaceBetween}
|
|
borderRadius={BorderRadius.SM}
|
|
paddingLeft={4}
|
|
paddingRight={4}
|
|
paddingTop={2}
|
|
paddingBottom={2}
|
|
>
|
|
<Typography
|
|
variant={TypographyVariant.H6}
|
|
color={TextColor.textAlternative}
|
|
marginRight={2}
|
|
overflowWrap={OVERFLOW_WRAP.ANYWHERE}
|
|
>
|
|
{text}
|
|
</Typography>
|
|
<Box
|
|
flexDirection={FLEX_DIRECTION.COLUMN}
|
|
alignItems={AlignItems.center}
|
|
justifyContent={JustifyContent.flexStart}
|
|
marginTop={2}
|
|
marginBottom={1}
|
|
>
|
|
{copied ? (
|
|
<Icon
|
|
name={IconName.CopySuccess}
|
|
size={IconSize.Lg}
|
|
color={Color.iconAlternative}
|
|
/>
|
|
) : (
|
|
<Icon
|
|
name={IconName.Copy}
|
|
size={IconSize.Lg}
|
|
color={Color.iconAlternative}
|
|
onClick={() => handleCopy(text)}
|
|
/>
|
|
)}
|
|
</Box>
|
|
</Box>
|
|
);
|
|
};
|
|
|
|
Copyable.propTypes = {
|
|
text: PropTypes.string,
|
|
};
|