mirror of
https://github.com/shadcn-ui/ui.git
synced 2026-06-30 08:04:18 +00:00
* feat: init * fix * fix * fix * feat * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: implement icons * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: update init command * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: dialog * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add registry:base item type * feat: rename frame to canva * fix * feat * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fi * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add all colors * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * fix * feat: add outfit font * fix * fix * fix * fix * fix * chore: changeset * fix * fix * fix * fix * fix * fix * fix * fix
96 lines
2.7 KiB
TypeScript
96 lines
2.7 KiB
TypeScript
import {
|
|
Example,
|
|
ExampleWrapper,
|
|
} from "@/registry/bases/base/components/example"
|
|
import { Button } from "@/registry/bases/base/ui/button"
|
|
import {
|
|
Dialog,
|
|
DialogContent,
|
|
DialogDescription,
|
|
DialogHeader,
|
|
DialogTitle,
|
|
DialogTrigger,
|
|
} from "@/registry/bases/base/ui/dialog"
|
|
import {
|
|
HoverCard,
|
|
HoverCardContent,
|
|
HoverCardTrigger,
|
|
} from "@/registry/bases/base/ui/hover-card"
|
|
|
|
export default function HoverCardExample() {
|
|
return (
|
|
<ExampleWrapper>
|
|
<HoverCardSides />
|
|
<HoverCardInDialog />
|
|
</ExampleWrapper>
|
|
)
|
|
}
|
|
|
|
const HOVER_CARD_SIDES = ["top", "right", "bottom", "left"] as const
|
|
|
|
function HoverCardSides() {
|
|
return (
|
|
<Example title="Sides">
|
|
<div className="flex flex-wrap items-center justify-center gap-4">
|
|
{HOVER_CARD_SIDES.map((side) => (
|
|
<HoverCard key={side}>
|
|
<HoverCardTrigger
|
|
delay={100}
|
|
closeDelay={100}
|
|
render={<Button variant="outline" className="capitalize" />}
|
|
>
|
|
{side}
|
|
</HoverCardTrigger>
|
|
<HoverCardContent side={side}>
|
|
<div className="style-lyra:gap-1 style-nova:gap-1.5 style-vega:gap-2 style-maia:gap-2 style-mira:gap-1 flex flex-col">
|
|
<h4 className="font-medium">Hover Card</h4>
|
|
<p>
|
|
This hover card appears on the {side} side of the trigger.
|
|
</p>
|
|
</div>
|
|
</HoverCardContent>
|
|
</HoverCard>
|
|
))}
|
|
</div>
|
|
</Example>
|
|
)
|
|
}
|
|
|
|
function HoverCardInDialog() {
|
|
return (
|
|
<Example title="In Dialog">
|
|
<Dialog>
|
|
<DialogTrigger render={<Button variant="outline" />}>
|
|
Open Dialog
|
|
</DialogTrigger>
|
|
<DialogContent>
|
|
<DialogHeader>
|
|
<DialogTitle>Hover Card Example</DialogTitle>
|
|
<DialogDescription>
|
|
Hover over the button below to see the hover card.
|
|
</DialogDescription>
|
|
</DialogHeader>
|
|
<HoverCard>
|
|
<HoverCardTrigger
|
|
delay={100}
|
|
closeDelay={100}
|
|
render={<Button variant="outline" className="w-fit" />}
|
|
>
|
|
Hover me
|
|
</HoverCardTrigger>
|
|
<HoverCardContent>
|
|
<div className="style-lyra:gap-1 style-nova:gap-1.5 style-vega:gap-2 style-maia:gap-2 style-mira:gap-1 flex flex-col">
|
|
<h4 className="font-medium">Hover Card</h4>
|
|
<p>
|
|
This hover card appears inside a dialog. Hover over the button
|
|
to see it.
|
|
</p>
|
|
</div>
|
|
</HoverCardContent>
|
|
</HoverCard>
|
|
</DialogContent>
|
|
</Dialog>
|
|
</Example>
|
|
)
|
|
}
|