2021-10-01 19:36:59 +02:00
|
|
|
import React, { useState } from "react";
|
|
|
|
import Typography from "@mui/material/Typography";
|
|
|
|
import Tooltip from "@mui/material/Tooltip";
|
2021-05-04 01:46:04 +02:00
|
|
|
|
2021-03-31 06:45:21 +02:00
|
|
|
type IProps = {
|
2021-09-05 01:09:30 +02:00
|
|
|
value: string;
|
2021-10-01 21:39:56 +02:00
|
|
|
color?: string;
|
2021-10-01 19:36:59 +02:00
|
|
|
variant?:
|
|
|
|
| "button"
|
|
|
|
| "caption"
|
|
|
|
| "h1"
|
|
|
|
| "h2"
|
|
|
|
| "h3"
|
|
|
|
| "h4"
|
|
|
|
| "h5"
|
|
|
|
| "h6"
|
|
|
|
| "subtitle1"
|
|
|
|
| "subtitle2"
|
|
|
|
| "body1"
|
|
|
|
| "body2"
|
|
|
|
| "overline"
|
|
|
|
| "inherit"
|
|
|
|
| undefined;
|
2021-09-05 01:09:30 +02:00
|
|
|
};
|
2021-03-31 06:45:21 +02:00
|
|
|
|
2021-10-01 19:36:59 +02:00
|
|
|
export function CopyableText(props: IProps): React.ReactElement {
|
|
|
|
const [open, setOpen] = useState(false);
|
2021-03-31 06:45:21 +02:00
|
|
|
|
2021-10-01 19:36:59 +02:00
|
|
|
function copy(): void {
|
2021-09-05 01:09:30 +02:00
|
|
|
const copyText = document.createElement("textarea");
|
2021-10-01 19:36:59 +02:00
|
|
|
copyText.value = props.value;
|
2021-09-05 01:09:30 +02:00
|
|
|
document.body.appendChild(copyText);
|
|
|
|
copyText.select();
|
|
|
|
copyText.setSelectionRange(0, 1e10);
|
|
|
|
document.execCommand("copy");
|
|
|
|
document.body.removeChild(copyText);
|
2021-10-01 19:36:59 +02:00
|
|
|
setOpen(true);
|
|
|
|
setTimeout(() => setOpen(false), 1000);
|
2021-09-05 01:09:30 +02:00
|
|
|
}
|
2021-03-31 06:45:21 +02:00
|
|
|
|
2021-10-01 19:36:59 +02:00
|
|
|
return (
|
|
|
|
<Tooltip open={open} title={<Typography>Copied!</Typography>}>
|
2021-10-01 21:39:56 +02:00
|
|
|
<Typography variant={props.variant} color={props.color} onClick={copy}>
|
2021-10-01 19:36:59 +02:00
|
|
|
{props.value}
|
|
|
|
</Typography>
|
|
|
|
</Tooltip>
|
|
|
|
);
|
2021-09-05 01:09:30 +02:00
|
|
|
}
|