|
@@ -1,7 +1,7 @@
|
|
|
import * as React from "react"
|
|
import * as React from "react"
|
|
|
import { PortalProps } from "@radix-ui/react-portal"
|
|
import { PortalProps } from "@radix-ui/react-portal"
|
|
|
import * as SelectPrimitive from "@radix-ui/react-select"
|
|
import * as SelectPrimitive from "@radix-ui/react-select"
|
|
|
-import { CheckIcon, ChevronDownIcon, ChevronUpIcon } from "lucide-react"
|
|
|
|
|
|
|
+import { Check, ChevronDown, ChevronUp } from "lucide-react"
|
|
|
|
|
|
|
|
import { cn } from "@/lib/utils"
|
|
import { cn } from "@/lib/utils"
|
|
|
|
|
|
|
@@ -22,13 +22,16 @@ function SelectTrigger({ className, children, ...props }: React.ComponentProps<t
|
|
|
<SelectPrimitive.Trigger
|
|
<SelectPrimitive.Trigger
|
|
|
data-slot="select-trigger"
|
|
data-slot="select-trigger"
|
|
|
className={cn(
|
|
className={cn(
|
|
|
- "border-vscode-input-border data-[placeholder]:text-muted-foreground [&_svg:not([class*='text-'])]:text-muted-foreground focus-visible:border-vscode-focusBorder aria-invalid:border-destructive flex h-7 w-fit items-center justify-between gap-2 rounded-xs border bg-vscode-input-background hover:bg-transparent px-3 py-2 text-sm whitespace-nowrap shadow-xs transition-[color,box-shadow] outline-none disabled:cursor-not-allowed disabled:opacity-50 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 cursor-pointer",
|
|
|
|
|
|
|
+ "data-[placeholder]:text-muted-foreground [&_svg:not([class*='text-'])]:text-muted-foreground aria-invalid:border-destructive flex h-7 w-fit items-center justify-between gap-2 rounded-xs px-3 py-2 whitespace-nowrap transition-[color,box-shadow] outline-none disabled:cursor-not-allowed disabled:opacity-50 *:data-[slot=select-value]:line-clamp-1 *:data-[slot=select-value]:flex *:data-[slot=select-value]:items-center *:data-[slot=select-value]:gap-2 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 cursor-pointer",
|
|
|
|
|
+ "border border-vscode-dropdown-border aria-expanded:border-vscode-focusBorder focus-visible:border-vscode-focusBorder",
|
|
|
|
|
+ "bg-vscode-dropdown-background hover:bg-transparent",
|
|
|
|
|
+ "text-vscode-dropdown-foreground",
|
|
|
className,
|
|
className,
|
|
|
)}
|
|
)}
|
|
|
{...props}>
|
|
{...props}>
|
|
|
{children}
|
|
{children}
|
|
|
<SelectPrimitive.Icon asChild>
|
|
<SelectPrimitive.Icon asChild>
|
|
|
- <ChevronDownIcon className="size-4 opacity-50" />
|
|
|
|
|
|
|
+ <ChevronDown className="size-4 opacity-50" />
|
|
|
</SelectPrimitive.Icon>
|
|
</SelectPrimitive.Icon>
|
|
|
</SelectPrimitive.Trigger>
|
|
</SelectPrimitive.Trigger>
|
|
|
)
|
|
)
|
|
@@ -46,7 +49,10 @@ function SelectContent({
|
|
|
<SelectPrimitive.Content
|
|
<SelectPrimitive.Content
|
|
|
data-slot="select-content"
|
|
data-slot="select-content"
|
|
|
className={cn(
|
|
className={cn(
|
|
|
- "bg-popover text-popover-foreground data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 relative z-50 max-h-72 min-w-[8rem] overflow-hidden rounded-xs border border-vscode-focusBorder shadow-md",
|
|
|
|
|
|
|
+ "data-[state=open]:animate-in data-[state=closed]:animate-out data-[state=closed]:fade-out-0 data-[state=open]:fade-in-0 data-[state=closed]:zoom-out-95 data-[state=open]:zoom-in-95 data-[side=bottom]:slide-in-from-top-2 data-[side=left]:slide-in-from-right-2 data-[side=right]:slide-in-from-left-2 data-[side=top]:slide-in-from-bottom-2 relative z-50 max-h-72 min-w-[8rem] overflow-hidden rounded-xs shadow-xs",
|
|
|
|
|
+ "bg-popover",
|
|
|
|
|
+ "border border-vscode-focusBorder",
|
|
|
|
|
+ "text-popover-foreground",
|
|
|
position === "popper" &&
|
|
position === "popper" &&
|
|
|
"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1",
|
|
"data-[side=bottom]:translate-y-1 data-[side=left]:-translate-x-1 data-[side=right]:translate-x-1 data-[side=top]:-translate-y-1",
|
|
|
className,
|
|
className,
|
|
@@ -83,13 +89,15 @@ function SelectItem({ className, children, ...props }: React.ComponentProps<type
|
|
|
<SelectPrimitive.Item
|
|
<SelectPrimitive.Item
|
|
|
data-slot="select-item"
|
|
data-slot="select-item"
|
|
|
className={cn(
|
|
className={cn(
|
|
|
- "focus:bg-vscode-list-activeSelectionBackground focus:text-accent-foreground [&_svg:not([class*='text-'])]:text-muted-foreground relative flex w-full items-center gap-2 rounded-xs py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2 cursor-pointer",
|
|
|
|
|
|
|
+ "[&_svg:not([class*='text-'])]:text-muted-foreground relative flex w-full items-center gap-2 rounded-xs py-1.5 pr-8 pl-2 text-sm outline-hidden select-none data-[disabled]:pointer-events-none data-[disabled]:opacity-50 [&_svg]:pointer-events-none [&_svg]:shrink-0 [&_svg:not([class*='size-'])]:size-4 *:[span]:last:flex *:[span]:last:items-center *:[span]:last:gap-2 cursor-pointer",
|
|
|
|
|
+ "focus:bg-vscode-list-activeSelectionBackground focus:text-vscode-list-activeSelectionForeground",
|
|
|
|
|
+ "text-vscode-dropdown-foreground",
|
|
|
className,
|
|
className,
|
|
|
)}
|
|
)}
|
|
|
{...props}>
|
|
{...props}>
|
|
|
<span className="absolute right-2 flex size-3.5 items-center justify-center">
|
|
<span className="absolute right-2 flex size-3.5 items-center justify-center">
|
|
|
<SelectPrimitive.ItemIndicator>
|
|
<SelectPrimitive.ItemIndicator>
|
|
|
- <CheckIcon className="size-4" />
|
|
|
|
|
|
|
+ <Check className="size-4 p-0.5" />
|
|
|
</SelectPrimitive.ItemIndicator>
|
|
</SelectPrimitive.ItemIndicator>
|
|
|
</span>
|
|
</span>
|
|
|
<SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>
|
|
<SelectPrimitive.ItemText>{children}</SelectPrimitive.ItemText>
|
|
@@ -101,7 +109,7 @@ function SelectSeparator({ className, ...props }: React.ComponentProps<typeof Se
|
|
|
return (
|
|
return (
|
|
|
<SelectPrimitive.Separator
|
|
<SelectPrimitive.Separator
|
|
|
data-slot="select-separator"
|
|
data-slot="select-separator"
|
|
|
- className={cn("bg-border pointer-events-none -mx-1 my-1 h-px", className)}
|
|
|
|
|
|
|
+ className={cn("bg-vscode-dropdown-foreground/10 pointer-events-none -mx-1 my-1 h-px", className)}
|
|
|
{...props}
|
|
{...props}
|
|
|
/>
|
|
/>
|
|
|
)
|
|
)
|
|
@@ -113,7 +121,7 @@ function SelectScrollUpButton({ className, ...props }: React.ComponentProps<type
|
|
|
data-slot="select-scroll-up-button"
|
|
data-slot="select-scroll-up-button"
|
|
|
className={cn("flex cursor-default items-center justify-center py-1", className)}
|
|
className={cn("flex cursor-default items-center justify-center py-1", className)}
|
|
|
{...props}>
|
|
{...props}>
|
|
|
- <ChevronUpIcon className="size-4" />
|
|
|
|
|
|
|
+ <ChevronUp className="size-4" />
|
|
|
</SelectPrimitive.ScrollUpButton>
|
|
</SelectPrimitive.ScrollUpButton>
|
|
|
)
|
|
)
|
|
|
}
|
|
}
|
|
@@ -127,7 +135,7 @@ function SelectScrollDownButton({
|
|
|
data-slot="select-scroll-down-button"
|
|
data-slot="select-scroll-down-button"
|
|
|
className={cn("flex cursor-default items-center justify-center py-1", className)}
|
|
className={cn("flex cursor-default items-center justify-center py-1", className)}
|
|
|
{...props}>
|
|
{...props}>
|
|
|
- <ChevronDownIcon className="size-4" />
|
|
|
|
|
|
|
+ <ChevronDown className="size-4" />
|
|
|
</SelectPrimitive.ScrollDownButton>
|
|
</SelectPrimitive.ScrollDownButton>
|
|
|
)
|
|
)
|
|
|
}
|
|
}
|