diff options
| author | Adam <[email protected]> | 2025-10-16 14:53:44 -0500 |
|---|---|---|
| committer | Adam <[email protected]> | 2025-10-16 14:53:44 -0500 |
| commit | 47d9e017657c4d265dea53bd86d727097a7ba282 (patch) | |
| tree | e278fb3983f13f6fa474228cf5031c3b4680f566 /packages/ui/src/components | |
| parent | fc18fc8a08e703a54553e714344e638673b2d313 (diff) | |
| download | opencode-47d9e017657c4d265dea53bd86d727097a7ba282.tar.gz opencode-47d9e017657c4d265dea53bd86d727097a7ba282.zip | |
wip: css/ui and desktop work
Diffstat (limited to 'packages/ui/src/components')
| -rw-r--r-- | packages/ui/src/components/fonts.tsx | 44 | ||||
| -rw-r--r-- | packages/ui/src/components/index.ts | 2 | ||||
| -rw-r--r-- | packages/ui/src/components/tooltip.tsx | 44 |
3 files changed, 90 insertions, 0 deletions
diff --git a/packages/ui/src/components/fonts.tsx b/packages/ui/src/components/fonts.tsx new file mode 100644 index 000000000..447c486e4 --- /dev/null +++ b/packages/ui/src/components/fonts.tsx @@ -0,0 +1,44 @@ +import { Style, Link } from "@solidjs/meta" +import geist from "@opencode-ai/css/fonts/geist.woff2" +import geistMono from "@opencode-ai/css/fonts/geist-mono.woff2" + +export const Fonts = () => { + return ( + <> + <Style>{` + @font-face { + font-family: "geist"; + src: url("${geist}") format("woff2-variations"); + font-display: swap; + font-style: normal; + font-weight: 100 900; + } + @font-face { + font-family: "geist-fallback"; + src: local("Arial"); + size-adjust: 100%; + ascent-override: 97%; + descent-override: 25%; + line-gap-override: 1%; + } + @font-face { + font-family: "geist-mono"; + src: url("${geistMono}") format("woff2-variations"); + font-display: swap; + font-style: normal; + font-weight: 100 900; + } + @font-face { + font-family: "geist-mono-fallback"; + src: local("Courier New"); + size-adjust: 100%; + ascent-override: 97%; + descent-override: 25%; + line-gap-override: 1%; + } + `}</Style> + <Link rel="preload" href={geist} as="font" type="font/woff2" crossorigin="anonymous" /> + <Link rel="preload" href={geistMono} as="font" type="font/woff2" crossorigin="anonymous" /> + </> + ) +} diff --git a/packages/ui/src/components/index.ts b/packages/ui/src/components/index.ts index be12d6a67..2048ec639 100644 --- a/packages/ui/src/components/index.ts +++ b/packages/ui/src/components/index.ts @@ -1,4 +1,6 @@ export * from "./button" export * from "./icon" +export * from "./fonts" export * from "./select" export * from "./tabs" +export * from "./tooltip" diff --git a/packages/ui/src/components/tooltip.tsx b/packages/ui/src/components/tooltip.tsx new file mode 100644 index 000000000..7cb22b290 --- /dev/null +++ b/packages/ui/src/components/tooltip.tsx @@ -0,0 +1,44 @@ +import { Tooltip as KobalteTooltip } from "@kobalte/core/tooltip" +import { children, createEffect, createSignal, splitProps } from "solid-js" +import type { ComponentProps } from "solid-js" + +export interface TooltipProps extends ComponentProps<typeof KobalteTooltip> { + value: string | (() => string) + class?: string +} + +export function Tooltip(props: TooltipProps) { + const [open, setOpen] = createSignal(false) + const [local, others] = splitProps(props, ["children", "class"]) + + const c = children(() => local.children) + + createEffect(() => { + const childElements = c() + if (childElements instanceof HTMLElement) { + childElements.addEventListener("focus", () => setOpen(true)) + childElements.addEventListener("blur", () => setOpen(false)) + } else if (Array.isArray(childElements)) { + for (const child of childElements) { + if (child instanceof HTMLElement) { + child.addEventListener("focus", () => setOpen(true)) + child.addEventListener("blur", () => setOpen(false)) + } + } + } + }) + + return ( + <KobalteTooltip forceMount {...others} open={open()} onOpenChange={setOpen}> + <KobalteTooltip.Trigger as={"div"} data-component="tooltip-trigger"> + {c()} + </KobalteTooltip.Trigger> + <KobalteTooltip.Portal> + <KobalteTooltip.Content data-component="tooltip" data-placement={props.placement} class={local.class}> + {typeof others.value === "function" ? others.value() : others.value} + <KobalteTooltip.Arrow data-slot="arrow" size={18} /> + </KobalteTooltip.Content> + </KobalteTooltip.Portal> + </KobalteTooltip> + ) +} |
