summaryrefslogtreecommitdiffhomepage
path: root/packages/app/src/components
diff options
context:
space:
mode:
authoradamelmore <[email protected]>2026-01-26 15:34:59 -0600
committeradamelmore <[email protected]>2026-01-26 15:36:59 -0600
commitccc7aa49c33dc2247ceee0a51e7816ea5803c404 (patch)
treecda50d5e5ef48ef1e49a2bff5f5f5aacb903570b /packages/app/src/components
parent53ac394c685780985d776c4f861c283714615999 (diff)
downloadopencode-ccc7aa49c33dc2247ceee0a51e7816ea5803c404.tar.gz
opencode-ccc7aa49c33dc2247ceee0a51e7816ea5803c404.zip
wip: highlights
Diffstat (limited to 'packages/app/src/components')
-rw-r--r--packages/app/src/components/dialog-release-notes.tsx30
-rw-r--r--packages/app/src/components/settings-general.tsx17
2 files changed, 35 insertions, 12 deletions
diff --git a/packages/app/src/components/dialog-release-notes.tsx b/packages/app/src/components/dialog-release-notes.tsx
index c62cbc188..d3ee7e201 100644
--- a/packages/app/src/components/dialog-release-notes.tsx
+++ b/packages/app/src/components/dialog-release-notes.tsx
@@ -2,11 +2,11 @@ import { createSignal, createEffect, onMount, onCleanup } from "solid-js"
import { Dialog } from "@opencode-ai/ui/dialog"
import { Button } from "@opencode-ai/ui/button"
import { useDialog } from "@opencode-ai/ui/context/dialog"
+import { useSettings } from "@/context/settings"
export type Highlight = {
title: string
description: string
- tag?: string
media?: {
type: "image" | "video"
src: string
@@ -16,6 +16,7 @@ export type Highlight = {
export function DialogReleaseNotes(props: { highlights: Highlight[] }) {
const dialog = useDialog()
+ const settings = useSettings()
const [index, setIndex] = createSignal(0)
const total = () => props.highlights.length
@@ -34,9 +35,20 @@ export function DialogReleaseNotes(props: { highlights: Highlight[] }) {
dialog.close()
}
+ function handleDisable() {
+ settings.general.setReleaseNotes(false)
+ handleClose()
+ }
+
let focusTrap: HTMLDivElement | undefined
function handleKeyDown(e: KeyboardEvent) {
+ if (e.key === "Escape") {
+ e.preventDefault()
+ handleClose()
+ return
+ }
+
if (!paged()) return
if (e.key === "ArrowLeft" && !isFirst()) {
e.preventDefault()
@@ -50,8 +62,6 @@ export function DialogReleaseNotes(props: { highlights: Highlight[] }) {
onMount(() => {
focusTrap?.focus()
-
- if (!paged()) return
document.addEventListener("keydown", handleKeyDown)
onCleanup(() => document.removeEventListener("keydown", handleKeyDown))
})
@@ -72,14 +82,6 @@ export function DialogReleaseNotes(props: { highlights: Highlight[] }) {
<div class="flex flex-col gap-2 pt-22">
<div class="flex items-center gap-2">
<h1 class="text-16-medium text-text-strong">{feature()?.title ?? ""}</h1>
- {feature()?.tag && (
- <span
- class="text-12-medium text-text-weak px-1.5 py-0.5 bg-surface-base rounded-sm border border-border-weak-base"
- style={{ "border-width": "0.5px" }}
- >
- {feature()!.tag}
- </span>
- )}
</div>
<p class="text-14-regular text-text-base">{feature()?.description ?? ""}</p>
</div>
@@ -89,7 +91,7 @@ export function DialogReleaseNotes(props: { highlights: Highlight[] }) {
{/* Bottom section - buttons and indicators (fixed position) */}
<div class="flex flex-col gap-12">
- <div class="flex items-center gap-3">
+ <div class="flex flex-col items-start gap-3">
{isLast() ? (
<Button variant="primary" size="large" onClick={handleClose}>
Get started
@@ -99,6 +101,10 @@ export function DialogReleaseNotes(props: { highlights: Highlight[] }) {
Next
</Button>
)}
+
+ <Button variant="ghost" size="small" onClick={handleDisable}>
+ Don't show these in the future
+ </Button>
</div>
{paged() && (
diff --git a/packages/app/src/components/settings-general.tsx b/packages/app/src/components/settings-general.tsx
index cfb8a998d..e7e5b67f3 100644
--- a/packages/app/src/components/settings-general.tsx
+++ b/packages/app/src/components/settings-general.tsx
@@ -214,6 +214,23 @@ export const SettingsGeneral: Component = () => {
</div>
</div>
+ {/* Updates Section */}
+ <div class="flex flex-col gap-1">
+ <h3 class="text-14-medium text-text-strong pb-2">{language.t("settings.general.section.updates")}</h3>
+
+ <div class="bg-surface-raised-base px-4 rounded-lg">
+ <SettingsRow
+ title={language.t("settings.general.row.releaseNotes.title")}
+ description={language.t("settings.general.row.releaseNotes.description")}
+ >
+ <Switch
+ checked={settings.general.releaseNotes()}
+ onChange={(checked) => settings.general.setReleaseNotes(checked)}
+ />
+ </SettingsRow>
+ </div>
+ </div>
+
{/* Sound effects Section */}
<div class="flex flex-col gap-1">
<h3 class="text-14-medium text-text-strong pb-2">{language.t("settings.general.section.sounds")}</h3>