Files
supabase/apps/studio/components/interfaces/Functions/CommandRender.tsx
Joshen Lim 085bddafc5 Chore/consolidate copy icons (#39386)
* Replace all clipboard icons with copy icons

* Fix Menu.Item active styling for light mode

* Update

* Use bg side bar accent
2025-10-10 11:06:42 +08:00

57 lines
1.7 KiB
TypeScript

import { Check, Copy } from 'lucide-react'
import { forwardRef, useState } from 'react'
import { cn, copyToClipboard } from 'ui'
const CommandRender = forwardRef<HTMLDivElement, { commands: any[]; className?: string }>(
({ commands, className }, ref) => {
return (
<div ref={ref} className={cn('space-y-4', className)}>
{commands.map((item: any, idx: number) => (
<Command key={`command-${idx}`} item={item} />
))}
</div>
)
}
)
CommandRender.displayName = 'CommandRender'
export default CommandRender
const Command = ({ item }: any) => {
const [isCopied, setIsCopied] = useState(false)
return (
<div className="space-y-1">
<span className="font-mono text-sm text-foreground-lighter">{`> ${item.comment}`}</span>
<div className="flex items-center gap-2">
<div className="flex gap-2 font-mono text-sm font-normal text-foreground">
<span className="text-foreground-lighter">$</span>
<span>
<span>{item.jsx ? item.jsx() : null} </span>
<button
type="button"
className="text-foreground-lighter hover:text-foreground"
onClick={() => {
function onCopy(value: any) {
setIsCopied(true)
copyToClipboard(value)
setTimeout(() => setIsCopied(false), 3000)
}
onCopy(item.command)
}}
>
{isCopied ? (
<Check size={14} strokeWidth={3} className="text-brand" />
) : (
<Copy size={14} />
)}
</button>
</span>
</div>
</div>
</div>
)
}