mirror of
https://github.com/ruvnet/RuVector.git
synced 2026-05-24 22:15:18 +00:00
Major additions: - Complete Next.js studio application with 1600+ components - Docker support (Dockerfile.combined, docker-compose.yml) - GCP deployment documentation and benchmarks - SQL benchmark scripts for performance testing - Sentry integration for monitoring - Comprehensive test suite and mocks Studio features: - Dashboard and admin interfaces - Data visualization components - Authentication and user management - API integration with RuVector backend - Static data and public assets 🤖 Generated with [Claude Code](https://claude.com/claude-code) Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
45 lines
1.2 KiB
TypeScript
45 lines
1.2 KiB
TypeScript
import { Command } from 'lucide-react'
|
|
import { ReactNode } from 'react'
|
|
|
|
import { detectOS } from 'lib/helpers'
|
|
import { cn } from 'ui'
|
|
|
|
interface CommandOptionProps {
|
|
icon: ReactNode
|
|
label: string
|
|
shortcut: string
|
|
onClick: () => void
|
|
}
|
|
|
|
export const CommandOption = ({ icon, label, shortcut, onClick }: CommandOptionProps) => {
|
|
const os = detectOS()
|
|
|
|
return (
|
|
<div
|
|
className="px-2 py-1 transition hover:bg-surface-100 flex items-center justify-between rounded cursor-pointer"
|
|
onClick={onClick}
|
|
>
|
|
<div className="flex items-center gap-x-2">
|
|
{icon}
|
|
<p className="text-sm">{label}</p>
|
|
</div>
|
|
<div
|
|
className={cn(
|
|
'flex items-center gap-1',
|
|
'h-6 py-1.5 px-2 leading-none',
|
|
'bg-surface-100 text-foreground-lighter',
|
|
'border border-default rounded-md',
|
|
'shadow-xs shadow-background-surface-100'
|
|
)}
|
|
>
|
|
{/* Issue with `os` and hydration fail */}
|
|
{os === 'macos' || true ? (
|
|
<Command size={11.5} strokeWidth={1.5} />
|
|
) : (
|
|
<p className="text-xs">CTRL</p>
|
|
)}
|
|
<p className="text-xs font-mono">{shortcut}</p>
|
|
</div>
|
|
</div>
|
|
)
|
|
}
|