mirror of
https://github.com/supabase/supabase.git
synced 2026-05-08 07:50:20 +08:00
* Replace all clipboard icons with copy icons * Fix Menu.Item active styling for light mode * Update * Use bg side bar accent
57 lines
1.7 KiB
TypeScript
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>
|
|
)
|
|
}
|