Files
Frontend/src/app/components/copy-button.tsx
Liam 3ebc3c0612
All checks were successful
Deploy App / docker (ubuntu-latest) (push) Successful in 2m2s
add context menu to server and player
2024-04-18 02:07:02 +01:00

36 lines
747 B
TypeScript

"use client";
import { useToast } from "@/common/use-toast";
import copy from "clipboard-copy";
import { ReactElement } from "react";
type CopyButtonProps = {
content: string;
children: React.ReactNode;
};
/**
* A button that copies the content to the clipboard
*
* @param props the properties for the button
* @returns the copy button
*/
export function CopyButton({ content, children }: CopyButtonProps): ReactElement {
const { toast } = useToast();
return (
<button
onClick={async () => {
await copy(content);
toast({
title: "Copied!",
description: `Copied "${content}" to the clipboard.`,
duration: 5000,
});
}}
>
{children}
</button>
);
}