ruvector/studio/components/layouts/ProjectLayout/NavigationBar/CommandOption.tsx
rUv 814f595995 feat(studio): Add complete RuVector Studio application
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>
2025-12-06 23:04:48 +00:00

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>
)
}