Skip to main content
Glama
preview-card.tsx1.87 kB
"use client"; import { PreviewCard as PreviewCardPrimitive } from "@base-ui/react/preview-card"; import { cn } from "@/lib/utils"; const PreviewCard = PreviewCardPrimitive.Root; function PreviewCardTrigger({ ...props }: PreviewCardPrimitive.Trigger.Props) { return ( <PreviewCardPrimitive.Trigger data-slot="preview-card-trigger" {...props} /> ); } function PreviewCardPopup({ className, children, align = "center", sideOffset = 4, ...props }: PreviewCardPrimitive.Popup.Props & { align?: PreviewCardPrimitive.Positioner.Props["align"]; sideOffset?: PreviewCardPrimitive.Positioner.Props["sideOffset"]; }) { return ( <PreviewCardPrimitive.Portal> <PreviewCardPrimitive.Positioner align={align} className="z-50" data-slot="preview-card-positioner" sideOffset={sideOffset} > <PreviewCardPrimitive.Popup className={cn( "relative flex w-64 origin-(--transform-origin) text-balance rounded-lg border bg-popover bg-clip-padding p-4 text-popover-foreground text-sm shadow-lg transition-[scale,opacity] before:pointer-events-none before:absolute before:inset-0 before:rounded-[calc(var(--radius-lg)-1px)] before:shadow-[0_1px_--theme(--color-black/4%)] data-ending-style:scale-98 data-starting-style:scale-98 data-ending-style:opacity-0 data-starting-style:opacity-0 dark:bg-clip-border dark:before:shadow-[0_-1px_--theme(--color-white/8%)]", className, )} data-slot="preview-card-content" {...props} > {children} </PreviewCardPrimitive.Popup> </PreviewCardPrimitive.Positioner> </PreviewCardPrimitive.Portal> ); } export { PreviewCard, PreviewCard as HoverCard, PreviewCardTrigger, PreviewCardTrigger as HoverCardTrigger, PreviewCardPopup, PreviewCardPopup as HoverCardContent, };

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