Skip to main content
Glama
select.tsx7.18 kB
"use client"; import { Select as SelectPrimitive } from "@base-ui/react/select"; import { ChevronDownIcon, ChevronsUpDownIcon, ChevronUpIcon, } from "lucide-react"; import { cn } from "@/lib/utils"; const Select = SelectPrimitive.Root; function SelectTrigger({ className, size = "default", children, ...props }: SelectPrimitive.Trigger.Props & { size?: "sm" | "default" | "lg"; }) { return ( <SelectPrimitive.Trigger className={cn( "relative inline-flex min-h-9 w-full min-w-36 select-none items-center justify-between gap-2 rounded-lg border border-input bg-background bg-clip-padding px-[calc(--spacing(3)-1px)] text-left text-base shadow-xs outline-none ring-ring/24 transition-shadow before:pointer-events-none before:absolute before:inset-0 before:rounded-[calc(var(--radius-lg)-1px)] not-data-disabled:not-focus-visible:not-aria-invalid:not-data-pressed:before:shadow-[0_1px_--theme(--color-black/4%)] pointer-coarse:after:absolute pointer-coarse:after:size-full pointer-coarse:after:min-h-11 focus-visible:border-ring focus-visible:ring-[3px] aria-invalid:border-destructive/36 focus-visible:aria-invalid:border-destructive/64 focus-visible:aria-invalid:ring-destructive/16 data-disabled:pointer-events-none data-disabled:opacity-64 sm:min-h-8 sm:text-sm dark:bg-input/32 dark:not-in-data-[slot=group]:bg-clip-border dark:aria-invalid:ring-destructive/24 dark:not-data-disabled:not-focus-visible:not-aria-invalid:not-data-pressed:before:shadow-[0_-1px_--theme(--color-white/8%)] [&_svg:not([class*='opacity-'])]:opacity-80 [&_svg:not([class*='size-'])]:size-4.5 sm:[&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none [&_svg]:shrink-0 [[data-disabled],:focus-visible,[aria-invalid],[data-pressed]]:shadow-none", size === "sm" && "min-h-8 gap-1.5 px-[calc(--spacing(2.5)-1px)] sm:min-h-7", size === "lg" && "min-h-10 sm:min-h-9", className, )} data-slot="select-trigger" {...props} > {children} <SelectPrimitive.Icon data-slot="select-icon"> <ChevronsUpDownIcon className="-me-1 size-4.5 opacity-80 sm:size-4" /> </SelectPrimitive.Icon> </SelectPrimitive.Trigger> ); } function SelectValue({ className, ...props }: SelectPrimitive.Value.Props) { return ( <SelectPrimitive.Value className={cn( "flex-1 truncate data-placeholder:text-muted-foreground", className, )} data-slot="select-value" {...props} /> ); } function SelectPopup({ className, children, sideOffset = 4, alignItemWithTrigger = true, ...props }: SelectPrimitive.Popup.Props & { sideOffset?: SelectPrimitive.Positioner.Props["sideOffset"]; alignItemWithTrigger?: SelectPrimitive.Positioner.Props["alignItemWithTrigger"]; }) { return ( <SelectPrimitive.Portal> <SelectPrimitive.Positioner alignItemWithTrigger={alignItemWithTrigger} className="z-50 select-none" data-slot="select-positioner" sideOffset={sideOffset} > <SelectPrimitive.Popup className="origin-(--transform-origin) transition-[scale,opacity] has-data-[side=none]:scale-100 has-data-starting-style:scale-98 has-data-starting-style:opacity-0 has-data-[side=none]:transition-none" data-slot="select-popup" {...props} > <SelectPrimitive.ScrollUpArrow className="top-0 z-50 flex h-6 w-full cursor-default items-center justify-center before:pointer-events-none before:absolute before:inset-x-px before:top-px before:h-[200%] before:rounded-t-[calc(var(--radius-lg)-1px)] before:bg-linear-to-b before:from-50% before:from-popover" data-slot="select-scroll-up-arrow" > <ChevronUpIcon className="relative size-4.5 sm:size-4" /> </SelectPrimitive.ScrollUpArrow> <span className="relative block h-full rounded-lg border bg-popover bg-clip-padding before:pointer-events-none before:absolute before:inset-0 before:rounded-[calc(var(--radius-lg)-1px)] before:shadow-lg dark:not-in-data-[slot=group]:bg-clip-border"> <SelectPrimitive.List className={cn( "max-h-(--available-height) min-w-(--anchor-width) overflow-y-auto p-1", className, )} data-slot="select-list" > {children} </SelectPrimitive.List> </span> <SelectPrimitive.ScrollDownArrow className="bottom-0 z-50 flex h-6 w-full cursor-default items-center justify-center before:pointer-events-none before:absolute before:inset-x-px before:bottom-px before:h-[200%] before:rounded-b-[calc(var(--radius-lg)-1px)] before:bg-linear-to-t before:from-50% before:from-popover" data-slot="select-scroll-down-arrow" > <ChevronDownIcon className="relative size-4.5 sm:size-4" /> </SelectPrimitive.ScrollDownArrow> </SelectPrimitive.Popup> </SelectPrimitive.Positioner> </SelectPrimitive.Portal> ); } function SelectItem({ className, children, ...props }: SelectPrimitive.Item.Props) { return ( <SelectPrimitive.Item className={cn( "grid min-h-8 in-data-[side=none]:min-w-[calc(var(--anchor-width)+1.25rem)] cursor-default grid-cols-[1rem_1fr] items-center gap-2 rounded-sm py-1 ps-2 pe-4 text-base outline-none data-disabled:pointer-events-none data-highlighted:bg-accent data-highlighted:text-accent-foreground data-disabled:opacity-64 sm:min-h-7 sm:text-sm [&_svg:not([class*='size-'])]:size-4.5 sm:[&_svg:not([class*='size-'])]:size-4 [&_svg]:pointer-events-none [&_svg]:shrink-0", className, )} data-slot="select-item" {...props} > <SelectPrimitive.ItemIndicator className="col-start-1"> <svg fill="none" height="24" stroke="currentColor" strokeLinecap="round" strokeLinejoin="round" strokeWidth="2" viewBox="0 0 24 24" width="24" xmlns="http://www.w3.org/1500/svg" > <path d="M5.252 12.7 10.2 18.63 18.748 5.37" /> </svg> </SelectPrimitive.ItemIndicator> <SelectPrimitive.ItemText className="col-start-2 min-w-0"> {children} </SelectPrimitive.ItemText> </SelectPrimitive.Item> ); } function SelectSeparator({ className, ...props }: SelectPrimitive.Separator.Props) { return ( <SelectPrimitive.Separator className={cn("mx-2 my-1 h-px bg-border", className)} data-slot="select-separator" {...props} /> ); } function SelectGroup(props: SelectPrimitive.Group.Props) { return <SelectPrimitive.Group data-slot="select-group" {...props} />; } function SelectGroupLabel(props: SelectPrimitive.GroupLabel.Props) { return ( <SelectPrimitive.GroupLabel className="px-2 py-1.5 font-medium text-muted-foreground text-xs" data-slot="select-group-label" {...props} /> ); } export { Select, SelectTrigger, SelectValue, SelectPopup, SelectPopup as SelectContent, SelectItem, SelectSeparator, SelectGroup, SelectGroupLabel, };

Latest Blog Posts

MCP directory API

We provide all the information about MCP servers via our MCP API.

curl -X GET 'https://glama.ai/api/mcp/v1/servers/bytebase/dbhub'

If you have feedback or need assistance with the MCP directory API, please join our Discord server