blob: cef3fc505e8c06102b11ed7c844509e96a020a4c (
plain) (
blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
|
/** @jsx jsx */
import React from "react";
import { jsx } from "theme-ui";
import LinkButton from "./LinkButton";
import Snackbar from "@material-ui/core/Snackbar";
function CopyButton({
children,
title,
value,
duration = 3000,
forwardedRef,
...props
}) {
const [open, setOpen] = React.useState(false);
const copyChild = event => {
event.currentTarget.children[0].children[0].select();
event.currentTarget.children[0].children[0].setSelectionRange(0, 99999);
document.execCommand("copy");
};
const handleClick = event => {
copyChild(event);
setOpen(true);
};
const handleClose = (event, reason) => {
if (reason === "clickaway") {
return;
}
setOpen(false);
};
return (
<div ref={forwardedRef}>
<LinkButton
onClick={handleClick}
title={title}
href="javascript:;"
{...props}
>
<textarea
type="text"
sx={{ position: "absolute", left: "-1000px" }}
readOnly
value={value}
/>
{children}
</LinkButton>
<Snackbar
open={open}
autoHideDuration={duration}
onClose={handleClose}
message="Copied!"
anchorOrigin={{
vertical: "bottom",
horizontal: "left"
}}
/>
</div>
);
}
export default React.forwardRef((props, ref) => (
<CopyButton {...props} forwardedRef={ref} />
));
|