summaryrefslogtreecommitdiffhomepage
path: root/packages
diff options
context:
space:
mode:
authorAdam <[email protected]>2026-04-16 01:03:41 -0500
committerGitHub <[email protected]>2026-04-16 06:03:41 +0000
commitf418fd56323c42f7bf1a0009db966632ca9bbab2 (patch)
tree1631f95acd86ed76190d506d75ae3e9f59b7fef1 /packages
parent675a46e23e679c294355435584ae662a7c0903c7 (diff)
downloadopencode-f418fd56323c42f7bf1a0009db966632ca9bbab2.tar.gz
opencode-f418fd56323c42f7bf1a0009db966632ca9bbab2.zip
beta badge for desktop app (#14471)
Co-authored-by: Brendan Allan <[email protected]>
Diffstat (limited to 'packages')
-rw-r--r--packages/app/src/components/titlebar.tsx73
-rw-r--r--packages/app/src/env.d.ts1
-rw-r--r--packages/desktop-electron/electron.vite.config.ts3
3 files changed, 44 insertions, 33 deletions
diff --git a/packages/app/src/components/titlebar.tsx b/packages/app/src/components/titlebar.tsx
index a90178abd..b7edb85ed 100644
--- a/packages/app/src/components/titlebar.tsx
+++ b/packages/app/src/components/titlebar.tsx
@@ -252,41 +252,48 @@ export function Titlebar() {
</div>
</div>
</Show>
- <Show when={hasProjects()}>
- <div
- class="flex items-center gap-0 transition-transform"
- classList={{
- "translate-x-0": !layout.sidebar.opened(),
- "-translate-x-[36px]": layout.sidebar.opened(),
- "duration-180 ease-out": !layout.sidebar.opened(),
- "duration-180 ease-in": layout.sidebar.opened(),
- }}
- >
- <Tooltip placement="bottom" value={language.t("common.goBack")} openDelay={2000}>
- <Button
- variant="ghost"
- icon="chevron-left"
- class="titlebar-icon w-6 h-6 p-0 box-border"
- disabled={!canBack()}
- onClick={back}
- aria-label={language.t("common.goBack")}
- />
- </Tooltip>
- <Tooltip placement="bottom" value={language.t("common.goForward")} openDelay={2000}>
- <Button
- variant="ghost"
- icon="chevron-right"
- class="titlebar-icon w-6 h-6 p-0 box-border"
- disabled={!canForward()}
- onClick={forward}
- aria-label={language.t("common.goForward")}
- />
- </Tooltip>
- </div>
- </Show>
+ <div
+ class="flex items-center shrink-0"
+ classList={{
+ "translate-x-0": !layout.sidebar.opened(),
+ "-translate-x-[36px]": layout.sidebar.opened(),
+ "duration-180 ease-out": !layout.sidebar.opened(),
+ "duration-180 ease-in": layout.sidebar.opened(),
+ }}
+ >
+ <Show when={hasProjects()}>
+ <div class="flex items-center gap-0 transition-transform">
+ <Tooltip placement="bottom" value={language.t("common.goBack")} openDelay={2000}>
+ <Button
+ variant="ghost"
+ icon="chevron-left"
+ class="titlebar-icon w-6 h-6 p-0 box-border"
+ disabled={!canBack()}
+ onClick={back}
+ aria-label={language.t("common.goBack")}
+ />
+ </Tooltip>
+ <Tooltip placement="bottom" value={language.t("common.goForward")} openDelay={2000}>
+ <Button
+ variant="ghost"
+ icon="chevron-right"
+ class="titlebar-icon w-6 h-6 p-0 box-border"
+ disabled={!canForward()}
+ onClick={forward}
+ aria-label={language.t("common.goForward")}
+ />
+ </Tooltip>
+ </div>
+ </Show>
+ <div id="opencode-titlebar-left" class="flex items-center gap-3 min-w-0 px-2" />
+ {["beta", "dev"].includes(import.meta.env.VITE_OPENCODE_CHANNEL) && (
+ <div class="bg-icon-interactive-base text-[#FFF] font-medium px-2 rounded-sm uppercase font-mono">
+ {import.meta.env.VITE_OPENCODE_CHANNEL.toUpperCase()}
+ </div>
+ )}
+ </div>
</div>
</div>
- <div id="opencode-titlebar-left" class="flex items-center gap-3 min-w-0 px-2" />
</div>
<div class="min-w-0 flex items-center justify-center pointer-events-none">
diff --git a/packages/app/src/env.d.ts b/packages/app/src/env.d.ts
index 89721f34f..22e52f991 100644
--- a/packages/app/src/env.d.ts
+++ b/packages/app/src/env.d.ts
@@ -3,6 +3,7 @@ import "solid-js"
interface ImportMetaEnv {
readonly VITE_OPENCODE_SERVER_HOST: string
readonly VITE_OPENCODE_SERVER_PORT: string
+ readonly OPENCODE_CHANNEL?: "dev" | "beta" | "prod"
}
interface ImportMeta {
diff --git a/packages/desktop-electron/electron.vite.config.ts b/packages/desktop-electron/electron.vite.config.ts
index e2b296a3e..d0e6c42b6 100644
--- a/packages/desktop-electron/electron.vite.config.ts
+++ b/packages/desktop-electron/electron.vite.config.ts
@@ -60,6 +60,9 @@ export default defineConfig({
plugins: [appPlugin],
publicDir: "../../../app/public",
root: "src/renderer",
+ define: {
+ "import.meta.env.VITE_OPENCODE_CHANNEL": JSON.stringify(channel),
+ },
build: {
rollupOptions: {
input: {