otterscan/src/components/Copy.tsx
Willian Mitsuda 48ab694001 Fix wrap
2022-02-19 16:55:27 -03:00

50 lines
1.4 KiB
TypeScript

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";
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
className={`self-center flex flex-no-wrap justify-center items-center space-x-1 text-gray-500 focus:outline-none ${
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" />
) : (
<>
<FontAwesomeIcon icon={faCheckCircle} size="1x" />
<span className="self-baseline">Copied</span>
</>
)
) : (
<FontAwesomeIcon icon={faCopy} size="1x" />
)}
</button>
);
};
export default React.memo(Copy);