summaryrefslogtreecommitdiffhomepage
path: root/packages/ui/src/components
diff options
context:
space:
mode:
authorAdam <[email protected]>2025-10-16 14:53:44 -0500
committerAdam <[email protected]>2025-10-16 14:53:44 -0500
commit47d9e017657c4d265dea53bd86d727097a7ba282 (patch)
treee278fb3983f13f6fa474228cf5031c3b4680f566 /packages/ui/src/components
parentfc18fc8a08e703a54553e714344e638673b2d313 (diff)
downloadopencode-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.tsx44
-rw-r--r--packages/ui/src/components/index.ts2
-rw-r--r--packages/ui/src/components/tooltip.tsx44
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>
+ )
+}