|  | import * as React from 'react' | 
					
						
						|  | import { type DialogProps } from '@radix-ui/react-dialog' | 
					
						
						|  | import { Command as CommandPrimitive } from 'cmdk' | 
					
						
						|  | import { Search } from 'lucide-react' | 
					
						
						|  |  | 
					
						
						|  | import { cn } from '@/lib/utils' | 
					
						
						|  | import { Dialog, DialogContent } from './Dialog' | 
					
						
						|  |  | 
					
						
						|  | const Command = React.forwardRef< | 
					
						
						|  | React.ComponentRef<typeof CommandPrimitive>, | 
					
						
						|  | React.ComponentPropsWithoutRef<typeof CommandPrimitive> | 
					
						
						|  | >(({ className, ...props }, ref) => ( | 
					
						
						|  | <CommandPrimitive | 
					
						
						|  | ref={ref} | 
					
						
						|  | className={cn( | 
					
						
						|  | 'bg-popover text-popover-foreground flex h-full w-full flex-col overflow-hidden rounded-md', | 
					
						
						|  | className | 
					
						
						|  | )} | 
					
						
						|  | {...props} | 
					
						
						|  | /> | 
					
						
						|  | )) | 
					
						
						|  | Command.displayName = CommandPrimitive.displayName | 
					
						
						|  |  | 
					
						
						|  | const CommandDialog = ({ children, ...props }: DialogProps) => { | 
					
						
						|  | return ( | 
					
						
						|  | <Dialog {...props}> | 
					
						
						|  | <DialogContent className="overflow-hidden p-0 shadow-lg"> | 
					
						
						|  | <Command className="[&_[cmdk-group-heading]]:text-muted-foreground [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:font-medium [&_[cmdk-group]]:px-2 [&_[cmdk-group]:not([hidden])_~[cmdk-group]]:pt-0 [&_[cmdk-input-wrapper]_svg]:h-5 [&_[cmdk-input-wrapper]_svg]:w-5 [&_[cmdk-input]]:h-12 [&_[cmdk-item]]:px-2 [&_[cmdk-item]]:py-3 [&_[cmdk-item]_svg]:h-5 [&_[cmdk-item]_svg]:w-5"> | 
					
						
						|  | {children} | 
					
						
						|  | </Command> | 
					
						
						|  | </DialogContent> | 
					
						
						|  | </Dialog> | 
					
						
						|  | ) | 
					
						
						|  | } | 
					
						
						|  |  | 
					
						
						|  | const CommandInput = React.forwardRef< | 
					
						
						|  | React.ComponentRef<typeof CommandPrimitive.Input>, | 
					
						
						|  | React.ComponentPropsWithoutRef<typeof CommandPrimitive.Input> | 
					
						
						|  | >(({ className, ...props }, ref) => ( | 
					
						
						|  |  | 
					
						
						|  | <div className="flex items-center border-b px-3" cmdk-input-wrapper=""> | 
					
						
						|  | <Search className="mr-2 h-4 w-4 shrink-0 opacity-50" /> | 
					
						
						|  | <CommandPrimitive.Input | 
					
						
						|  | ref={ref} | 
					
						
						|  | className={cn( | 
					
						
						|  | 'placeholder:text-muted-foreground flex h-11 w-full rounded-md bg-transparent py-3 text-sm outline-none disabled:cursor-not-allowed disabled:opacity-50', | 
					
						
						|  | className | 
					
						
						|  | )} | 
					
						
						|  | {...props} | 
					
						
						|  | /> | 
					
						
						|  | </div> | 
					
						
						|  | )) | 
					
						
						|  |  | 
					
						
						|  | CommandInput.displayName = CommandPrimitive.Input.displayName | 
					
						
						|  |  | 
					
						
						|  | const CommandList = React.forwardRef< | 
					
						
						|  | React.ComponentRef<typeof CommandPrimitive.List>, | 
					
						
						|  | React.ComponentPropsWithoutRef<typeof CommandPrimitive.List> | 
					
						
						|  | >(({ className, ...props }, ref) => ( | 
					
						
						|  | <CommandPrimitive.List | 
					
						
						|  | ref={ref} | 
					
						
						|  | className={cn('max-h-[300px] overflow-x-hidden overflow-y-auto', className)} | 
					
						
						|  | {...props} | 
					
						
						|  | /> | 
					
						
						|  | )) | 
					
						
						|  |  | 
					
						
						|  | CommandList.displayName = CommandPrimitive.List.displayName | 
					
						
						|  |  | 
					
						
						|  | const CommandEmpty = React.forwardRef< | 
					
						
						|  | React.ComponentRef<typeof CommandPrimitive.Empty>, | 
					
						
						|  | React.ComponentPropsWithoutRef<typeof CommandPrimitive.Empty> | 
					
						
						|  | >((props, ref) => ( | 
					
						
						|  | <CommandPrimitive.Empty ref={ref} className="py-6 text-center text-sm" {...props} /> | 
					
						
						|  | )) | 
					
						
						|  |  | 
					
						
						|  | CommandEmpty.displayName = CommandPrimitive.Empty.displayName | 
					
						
						|  |  | 
					
						
						|  | const CommandGroup = React.forwardRef< | 
					
						
						|  | React.ComponentRef<typeof CommandPrimitive.Group>, | 
					
						
						|  | React.ComponentPropsWithoutRef<typeof CommandPrimitive.Group> | 
					
						
						|  | >(({ className, ...props }, ref) => ( | 
					
						
						|  | <CommandPrimitive.Group | 
					
						
						|  | ref={ref} | 
					
						
						|  | className={cn( | 
					
						
						|  | 'text-foreground [&_[cmdk-group-heading]]:text-muted-foreground overflow-hidden p-1 [&_[cmdk-group-heading]]:px-2 [&_[cmdk-group-heading]]:py-1.5 [&_[cmdk-group-heading]]:text-xs [&_[cmdk-group-heading]]:font-medium', | 
					
						
						|  | className | 
					
						
						|  | )} | 
					
						
						|  | {...props} | 
					
						
						|  | /> | 
					
						
						|  | )) | 
					
						
						|  |  | 
					
						
						|  | CommandGroup.displayName = CommandPrimitive.Group.displayName | 
					
						
						|  |  | 
					
						
						|  | const CommandSeparator = React.forwardRef< | 
					
						
						|  | React.ComponentRef<typeof CommandPrimitive.Separator>, | 
					
						
						|  | React.ComponentPropsWithoutRef<typeof CommandPrimitive.Separator> | 
					
						
						|  | >(({ className, ...props }, ref) => ( | 
					
						
						|  | <CommandPrimitive.Separator | 
					
						
						|  | ref={ref} | 
					
						
						|  | className={cn('bg-border -mx-1 h-px', className)} | 
					
						
						|  | {...props} | 
					
						
						|  | /> | 
					
						
						|  | )) | 
					
						
						|  | CommandSeparator.displayName = CommandPrimitive.Separator.displayName | 
					
						
						|  |  | 
					
						
						|  | const CommandItem = React.forwardRef< | 
					
						
						|  | React.ComponentRef<typeof CommandPrimitive.Item>, | 
					
						
						|  | React.ComponentPropsWithoutRef<typeof CommandPrimitive.Item> | 
					
						
						|  | >(({ className, ...props }, ref) => ( | 
					
						
						|  | <CommandPrimitive.Item | 
					
						
						|  | ref={ref} | 
					
						
						|  | className={cn( | 
					
						
						|  | // eslint-disable-next-line @stylistic/js/quotes | 
					
						
						|  | "data-[selected='true']:bg-accent data-[selected=true]:text-accent-foreground relative flex cursor-default items-center gap-2 rounded-sm px-2 py-1.5 text-sm outline-none select-none data-[disabled=true]:pointer-events-none data-[disabled=true]:opacity-50 [&_svg]:pointer-events-none [&_svg]:size-4 [&_svg]:shrink-0", | 
					
						
						|  | className | 
					
						
						|  | )} | 
					
						
						|  | {...props} | 
					
						
						|  | /> | 
					
						
						|  | )) | 
					
						
						|  |  | 
					
						
						|  | CommandItem.displayName = CommandPrimitive.Item.displayName | 
					
						
						|  |  | 
					
						
						|  | const CommandShortcut = ({ className, ...props }: React.HTMLAttributes<HTMLSpanElement>) => { | 
					
						
						|  | return ( | 
					
						
						|  | <span | 
					
						
						|  | className={cn('text-muted-foreground ml-auto text-xs tracking-widest', className)} | 
					
						
						|  | {...props} | 
					
						
						|  | /> | 
					
						
						|  | ) | 
					
						
						|  | } | 
					
						
						|  | CommandShortcut.displayName = 'CommandShortcut' | 
					
						
						|  |  | 
					
						
						|  | export { | 
					
						
						|  | Command, | 
					
						
						|  | CommandDialog, | 
					
						
						|  | CommandInput, | 
					
						
						|  | CommandList, | 
					
						
						|  | CommandEmpty, | 
					
						
						|  | CommandGroup, | 
					
						
						|  | CommandItem, | 
					
						
						|  | CommandShortcut, | 
					
						
						|  | CommandSeparator | 
					
						
						|  | } | 
					
						
						|  |  |