otterscan/src/components/Copy.tsx

50 lines
1.4 KiB
TypeScript
Raw Normal View History

2021-07-01 18:21:40 +00:00
import React, { useState } from "react";
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
import { faCopy } from "@fortawesome/free-regular-svg-icons/faCopy";
import { faCheckCircle } from "@fortawesome/free-regular-svg-icons/faCheckCircle";
import { faCheck } from "@fortawesome/free-solid-svg-icons/faCheck";
2021-07-01 18:21:40 +00:00
type CopyProps = {
value: string;
rounded?: boolean;
};
const Copy: React.FC<CopyProps> = ({ value, rounded }) => {
const [copying, setCopying] = useState<boolean>(false);
const doCopy = () => {
navigator.clipboard.writeText(value);
setCopying(true);
setTimeout(() => {
setCopying(false);
}, 1000);
};
return (
<button
2022-02-19 19:55:27 +00:00
className={`self-center flex flex-no-wrap justify-center items-center space-x-1 text-gray-500 focus:outline-none ${
2021-07-01 18:21:40 +00:00
rounded
? "transition-colors transition-shadows bg-gray-200 hover:bg-gray-500 hover:text-gray-200 hover:shadow w-7 h-7 rounded-full text-xs"
: "text-sm"
}`}
title="Click to copy to clipboard"
onClick={doCopy}
>
{copying ? (
rounded ? (
<FontAwesomeIcon icon={faCheck} size="1x" />
) : (
2022-02-19 19:55:27 +00:00
<>
2021-07-01 18:21:40 +00:00
<FontAwesomeIcon icon={faCheckCircle} size="1x" />
2022-02-19 19:55:27 +00:00
<span className="self-baseline">Copied</span>
</>
2021-07-01 18:21:40 +00:00
)
) : (
<FontAwesomeIcon icon={faCopy} size="1x" />
)}
</button>
);
};
export default React.memo(Copy);