Skip to main content
Glama
empty.tsx3.41 kB
import { cva, type VariantProps } from "class-variance-authority"; import { cn } from "@/lib/utils"; function Empty({ className, ...props }: React.ComponentProps<"div">) { return ( <div className={cn( "flex min-w-0 flex-1 flex-col items-center justify-center gap-6 text-balance rounded-xl border-dashed p-6 text-center md:p-12", className, )} data-slot="empty" {...props} /> ); } function EmptyHeader({ className, ...props }: React.ComponentProps<"div">) { return ( <div className={cn( "flex max-w-sm flex-col items-center text-center", className, )} data-slot="empty-header" {...props} /> ); } const emptyMediaVariants = cva( "flex shrink-0 items-center justify-center [&_svg]:pointer-events-none [&_svg]:shrink-0", { defaultVariants: { variant: "default", }, variants: { variant: { default: "bg-transparent", icon: "relative flex size-9 shrink-0 items-center justify-center rounded-md border bg-card text-foreground shadow-black/5 shadow-sm before:pointer-events-none before:absolute before:inset-0 before:rounded-[calc(var(--radius-md)-1px)] before:shadow-[0_1px_--theme(--color-black/4%)] dark:before:shadow-[0_-1px_--theme(--color-white/8%)] [&_svg:not([class*='size-'])]:size-4.5", }, }, }, ); function EmptyMedia({ className, variant = "default", ...props }: React.ComponentProps<"div"> & VariantProps<typeof emptyMediaVariants>) { return ( <div className={cn("relative mb-6", className)} data-slot="empty-media" data-variant={variant} {...props} > {variant === "icon" && ( <> <div aria-hidden="true" className={cn( emptyMediaVariants({ className, variant }), "-translate-x-0.5 -rotate-10 pointer-events-none absolute bottom-px origin-bottom-left scale-84 shadow-none", )} /> <div aria-hidden="true" className={cn( emptyMediaVariants({ className, variant }), "pointer-events-none absolute bottom-px origin-bottom-right translate-x-0.5 rotate-10 scale-84 shadow-none", )} /> </> )} <div className={cn(emptyMediaVariants({ className, variant }))} {...props} /> </div> ); } function EmptyTitle({ className, ...props }: React.ComponentProps<"div">) { return ( <div className={cn("font-heading text-xl leading-none", className)} data-slot="empty-title" {...props} /> ); } function EmptyDescription({ className, ...props }: React.ComponentProps<"p">) { return ( <div className={cn( "text-muted-foreground text-sm/relaxed [&>a:hover]:text-primary [&>a]:underline [&>a]:underline-offset-4 [[data-slot=empty-title]+&]:mt-1", className, )} data-slot="empty-description" {...props} /> ); } function EmptyContent({ className, ...props }: React.ComponentProps<"div">) { return ( <div className={cn( "flex w-full min-w-0 max-w-sm flex-col items-center gap-4 text-balance text-sm", className, )} data-slot="empty-content" {...props} /> ); } export { Empty, EmptyHeader, EmptyTitle, EmptyDescription, EmptyContent, EmptyMedia, };

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