Command
A command component with a searchable input for selecting items from a list.
A simple 8-bit command component
No results found.
Calendar
Search Emoji
Calculator
Profile⌘P
Billing⌘B
Settings⌘S
Installation
pnpm dlx shadcn@canary add https://8bitcn.com/r/8bit-command.json
Usage
"use client"
import * as React from "react"
import {
Calculator,
Calendar,
CreditCard,
Settings,
Smile,
User,
} from "lucide-react"
import {
Command,
CommandEmpty,
CommandGroup,
CommandInput,
CommandItem,
CommandList,
CommandSeparator,
CommandShortcut,
} from "@/components/ui/command"
const suggestionCommands = [
{
value: "Calendar",
symbol: (
<>
<Calendar />
<span>Calendar</span>
</>
),
},
{
value: "Search Emoji",
symbol: (
<>
<Smile />
<span>Search Emoji</span>
</>
),
},
{
value: "Calculator",
symbol: (
<>
<Calculator />
<span>Calculator</span>
</>
),
},
]
const settingCommands = [
{
value: "Profile",
symbol: (
<>
<User />
<span>Profile</span>
</>
),
shortcut: "⌘P",
},
{
value: "Billing",
symbol: (
<>
<CreditCard />
<span>Billing</span>
</>
),
shortcut: "⌘B",
},
{
value: "Settings",
symbol: (
<>
<Settings />
<span>Settings</span>
</>
),
shortcut: "⌘S",
},
]
export function CommandExample() {
return (
<Command>
<CommandInput placeholder="Type a command..." />
<CommandList>
<CommandEmpty>No results found.</CommandEmpty>
<CommandGroup heading="Suggestions">
{suggestionCommands.map((command) => (
<CommandItem key={command.value} value={command.value}>
{command.symbol}
</CommandItem>
))}
</CommandGroup>
<CommandSeparator />
<CommandGroup heading="Settings">
{settingCommands.map((command) => (
<CommandItem key={command.value} value={command.value}>
{command.symbol}
<CommandShortcut>{command.shortcut}</CommandShortcut>
</CommandItem>
))}
</CommandGroup>
</CommandList>
</Command>
)
}