mirror of https://github.com/portainer/portainer
50 lines
1.1 KiB
TypeScript
50 lines
1.1 KiB
TypeScript
import { PropsWithChildren } from 'react';
|
|
import clsx from 'clsx';
|
|
|
|
import { Button } from '../Button';
|
|
|
|
import styles from './CopyButton.module.css';
|
|
import { useCopy } from './useCopy';
|
|
|
|
export interface Props {
|
|
copyText: string;
|
|
fadeDelay?: number;
|
|
displayText?: string;
|
|
className?: string;
|
|
}
|
|
|
|
export function CopyButton({
|
|
copyText,
|
|
fadeDelay = 1000,
|
|
displayText = 'copied',
|
|
className,
|
|
children,
|
|
}: PropsWithChildren<Props>) {
|
|
const { handleCopy, copiedSuccessfully } = useCopy(copyText, fadeDelay);
|
|
|
|
return (
|
|
<div className={styles.container}>
|
|
<Button
|
|
className={className}
|
|
size="small"
|
|
onClick={handleCopy}
|
|
title="Copy Value"
|
|
type="button"
|
|
>
|
|
<i className="fa fa-copy space-right" aria-hidden="true" /> {children}
|
|
</Button>
|
|
|
|
<span
|
|
className={clsx(
|
|
copiedSuccessfully && styles.fadeout,
|
|
styles.displayText,
|
|
'space-left'
|
|
)}
|
|
>
|
|
<i className="fa fa-check" aria-hidden="true" />
|
|
{displayText && <span className="space-left">{displayText}</span>}
|
|
</span>
|
|
</div>
|
|
);
|
|
}
|