mirror of
https://gitea.toothfairyai.com/ToothFairyAI/tf_code.git
synced 2026-04-11 11:18:34 +00:00
71 lines
1.9 KiB
TypeScript
71 lines
1.9 KiB
TypeScript
// @ts-nocheck
|
|
import { createSignal } from "solid-js"
|
|
import * as mod from "./hover-card"
|
|
|
|
const docs = `### Overview
|
|
Hover-triggered card for lightweight previews and metadata.
|
|
|
|
Use for short summaries; avoid dense interactive controls.
|
|
|
|
### API
|
|
- Required: \`trigger\` element.
|
|
- Children render inside the hover card body.
|
|
|
|
### Variants and states
|
|
- None; content and trigger are fully composable.
|
|
|
|
### Behavior
|
|
- Opens on hover/focus over the trigger.
|
|
|
|
### Accessibility
|
|
- TODO: confirm focus and hover intent behavior from Kobalte.
|
|
|
|
### Theming/tokens
|
|
- Uses \`data-component="hover-card-content"\` and slots for styling.
|
|
|
|
`
|
|
|
|
export default {
|
|
title: "UI/HoverCard",
|
|
id: "components-hover-card",
|
|
component: mod.HoverCard,
|
|
tags: ["autodocs"],
|
|
parameters: {
|
|
docs: {
|
|
description: {
|
|
component: docs,
|
|
},
|
|
},
|
|
},
|
|
}
|
|
|
|
export const Basic = {
|
|
render: () => (
|
|
<mod.HoverCard trigger={<span style={{ "text-decoration": "underline", cursor: "default" }}>Hover me</span>}>
|
|
<div style={{ display: "grid", gap: "6px" }}>
|
|
<div style={{ "font-weight": 600 }}>Preview</div>
|
|
<div style={{ color: "var(--text-weak)", "font-size": "12px" }}>Short supporting text.</div>
|
|
</div>
|
|
</mod.HoverCard>
|
|
),
|
|
}
|
|
|
|
export const InlineMount = {
|
|
render: () => {
|
|
const [mount, setMount] = createSignal<HTMLDivElement | undefined>(undefined)
|
|
return (
|
|
<div ref={setMount} style={{ padding: "16px", border: "1px dashed var(--border-weak)" }}>
|
|
<mod.HoverCard
|
|
mount={mount()}
|
|
trigger={<span style={{ "text-decoration": "underline", cursor: "default" }}>Hover me</span>}
|
|
>
|
|
<div style={{ display: "grid", gap: "6px" }}>
|
|
<div style={{ "font-weight": 600 }}>Mounted inside</div>
|
|
<div style={{ color: "var(--text-weak)", "font-size": "12px" }}>Uses custom mount node.</div>
|
|
</div>
|
|
</mod.HoverCard>
|
|
</div>
|
|
)
|
|
},
|
|
}
|