Skip to content

Clarify environment and workspace picker labels#1854

Merged
juliusmarminge merged 5 commits intomainfrom
t3code/clarify-picker-labels
Apr 9, 2026
Merged

Clarify environment and workspace picker labels#1854
juliusmarminge merged 5 commits intomainfrom
t3code/clarify-picker-labels

Conversation

@juliusmarminge
Copy link
Copy Markdown
Member

@juliusmarminge juliusmarminge commented Apr 9, 2026

Summary

  • Clarify environment picker labels so the primary device reads as This device unless a more specific machine label is available.
  • Add grouped labels and clearer icons to the environment and workspace selectors.
  • Centralize label resolution logic in BranchToolbar.logic and cover the new behavior with tests.
  • Update the chat view to use the shared environment label resolution helper.

Testing

  • Added unit coverage in apps/web/src/components/BranchToolbar.logic.test.ts for environment and workspace label resolution.
  • Not run: bun fmt
  • Not run: bun lint
  • Not run: bun typecheck
  • Not run: bun run test

Note

Medium Risk
Changes the logic that derives effective environment/worktree mode and mutates draft thread context (clearing worktreePath when switching to worktree), which could affect thread/worktree selection flows. UI label/icon updates are low risk but touch widely used toolbar components.

Overview
Clarifies the branch toolbar’s environment and workspace pickers by centralizing label resolution in BranchToolbar.logic (primary environment now shows a device-specific label or This device; workspace labels become Current checkout/Current worktree/New worktree) and updating selectors with grouped menus, new icons, and improved aria-labels.

Refines resolveEffectiveEnvMode so draft threads already attached to a worktree are treated as local (current checkout), while preserving explicit new-worktree intent when no worktree exists; BranchToolbar also now locks the env-mode selector when a server thread has an attached worktree. ChatView adopts the shared helpers and now clears a draft’s worktreePath when switching to worktree mode; adds unit coverage for the new label and env-mode behavior.

Reviewed by Cursor Bugbot for commit 72cb14f. Bugbot is set up for automated code reviews on this repo. Configure here.

Note

Clarify environment and workspace picker labels in the branch toolbar

  • Replaces generic environment labels with context-aware ones: primary environments show a machine name or fall back to 'This device'; non-primary environments use configured or runtime labels before falling back to the environment ID.
  • Adds resolveEnvModeLabel and resolveCurrentWorkspaceLabel helpers so the env mode selector shows 'Current checkout', 'Current worktree', or 'New worktree' depending on context.
  • Updates icons: MonitorIcon for primary environments, CloudIcon for remote, and folder-based icons in the env mode selector.
  • Draft threads with an attached worktree path are now treated as local mode instead of worktree; switching to worktree mode clears any existing worktreePath.
  • The env mode selector becomes read-only when on a server thread attached to a worktree, even if envLocked is false.

Macroscope summarized 72cb14f.

- Label the primary environment as "This device" when appropriate
- Group workspace and run-on options in the selectors
- Reuse shared label resolution logic in chat and toolbar
@coderabbitai
Copy link
Copy Markdown

coderabbitai bot commented Apr 9, 2026

Important

Review skipped

Auto reviews are disabled on this repository. Please check the settings in the CodeRabbit UI or the .coderabbit.yaml file in this repository. To trigger a single review, invoke the @coderabbitai review command.

⚙️ Run configuration

Configuration used: Repository UI

Review profile: CHILL

Plan: Pro

Run ID: 2376f974-b9fd-40fc-960d-19d3e1b7c069

You can disable this status message by setting the reviews.review_status to false in the CodeRabbit configuration file.

Use the checkbox below for a quick retry:

  • 🔍 Trigger review
✨ Finishing Touches
🧪 Generate unit tests (beta)
  • Create PR with unit tests
  • Commit unit tests in branch t3code/clarify-picker-labels

Comment @coderabbitai help to get the list of available commands and usage tips.

@github-actions github-actions bot added size:L 100-499 changed lines (additions + deletions). vouch:trusted PR author is trusted by repo permissions or the VOUCHED list. labels Apr 9, 2026
macroscopeapp[bot]
macroscopeapp bot previously approved these changes Apr 9, 2026
@macroscopeapp
Copy link
Copy Markdown
Contributor

macroscopeapp bot commented Apr 9, 2026

Approvability

Verdict: Needs human review

This PR modifies runtime behavior beyond just label clarifications - it changes how environment modes are determined and locked, and there's an unresolved bug comment about label mismatches between the trigger and dropdown options that should be addressed before merging.

You can customize Macroscope's approvability policy. Learn more.

- Show current checkout vs current worktree labels consistently
- Lock env mode when a server thread is attached to a worktree
- Update chat env mode derivation and selection behavior
- Adjust picker icon labels and browser test viewport
@macroscopeapp macroscopeapp bot dismissed their stale review April 9, 2026 18:45

Dismissing prior approval to re-evaluate 638670c

Copy link
Copy Markdown
Contributor

@cursor cursor bot left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Cursor Bugbot has reviewed your changes and found 1 potential issue.

Fix All in Cursor

Bugbot Autofix prepared a fix for the issue found in the latest run.

  • ✅ Fixed: Static items label mismatches dynamic dropdown item label
    • Moved envModeItems from a static module-level constant into the component as a useMemo dependent on activeWorktreePath, using resolveCurrentWorkspaceLabel() for the local item label so the trigger and dropdown labels always match.

Create PR

Or push these changes by commenting:

@cursor push a77a4b5975
Preview (a77a4b5975)
diff --git a/apps/web/src/components/BranchToolbarEnvModeSelector.tsx b/apps/web/src/components/BranchToolbarEnvModeSelector.tsx
--- a/apps/web/src/components/BranchToolbarEnvModeSelector.tsx
+++ b/apps/web/src/components/BranchToolbarEnvModeSelector.tsx
@@ -1,5 +1,5 @@
 import { FolderIcon, GitForkIcon } from "lucide-react";
-import { memo } from "react";
+import { memo, useMemo } from "react";
 
 import {
   resolveCurrentWorkspaceLabel,
@@ -16,11 +16,6 @@
   SelectValue,
 } from "./ui/select";
 
-const envModeItems = [
-  { value: "local", label: resolveEnvModeLabel("local") },
-  { value: "worktree", label: resolveEnvModeLabel("worktree") },
-] as const;
-
 interface BranchToolbarEnvModeSelectorProps {
   envLocked: boolean;
   effectiveEnvMode: EnvMode;
@@ -34,6 +29,14 @@
   activeWorktreePath,
   onEnvModeChange,
 }: BranchToolbarEnvModeSelectorProps) {
+  const envModeItems = useMemo(
+    () => [
+      { value: "local" as const, label: resolveCurrentWorkspaceLabel(activeWorktreePath) },
+      { value: "worktree" as const, label: resolveEnvModeLabel("worktree") },
+    ],
+    [activeWorktreePath],
+  );
+
   if (envLocked) {
     return (
       <span className="inline-flex items-center gap-1 border border-transparent px-[calc(--spacing(3)-1px)] text-sm font-medium text-muted-foreground/70 sm:text-xs">

You can send follow-ups to the cloud agent here.

Reviewed by Cursor Bugbot for commit 638670c. Configure here.

- Show the current workspace label for local mode
- Keep worktree label unchanged
- Use distinct folder/git icons for local and worktree modes
- Improve toolbar and menu affordance when a worktree is active
@juliusmarminge juliusmarminge merged commit 7b3cdc6 into main Apr 9, 2026
12 checks passed
@juliusmarminge juliusmarminge deleted the t3code/clarify-picker-labels branch April 9, 2026 19:51
rororowyourboat added a commit to rororowyourboat/t3code that referenced this pull request Apr 9, 2026
…threadId (#2)

* Raise slow RPC ack warning threshold to 15s (pingdotgg#1760)

* Use active worktree path for workspace saves (pingdotgg#1762)

* Stream git status updates over WebSocket (pingdotgg#1763)

Co-authored-by: codex <codex@users.noreply.github.com>

* fix(web): unwrap windows shell command wrappers (pingdotgg#1719)

* Rename "Chat" to "Build" in interaction mode toggle (pingdotgg#1769)

Co-authored-by: Julius Marminge <julius0216@outlook.com>

* Assign default capabilities to Codex custom models (pingdotgg#1793)

* Add project rename support in the sidebar (pingdotgg#1798)

* Support multi-select pending user inputs (pingdotgg#1797)

* Add Zed support to Open actions via editor command aliases (pingdotgg#1303)

Co-authored-by: codex <codex@users.noreply.github.com>
Co-authored-by: Julius Marminge <julius0216@outlook.com>

* Closes pingdotgg#1795 - Support building and developing in a devcontainer (pingdotgg#1791)

* Add explicit timeouts to CI and release workflows (pingdotgg#1825)

* fix(web): distinguish singular/plural in pending action submit label (pingdotgg#1826)

* Refactor web stores into atomic slices ready to split ChatView (pingdotgg#1708)

* Add VSCode Insiders and VSCodium icons (pingdotgg#1847)

* Prepare datamodel for multi-environment (pingdotgg#1765)

Co-authored-by: justsomelegs <145564979+justsomelegs@users.noreply.github.com>
Co-authored-by: codex <codex@users.noreply.github.com>
Co-authored-by: Cursor Agent <cursoragent@cursor.com>
Co-authored-by: cursor[bot] <206951365+cursor[bot]@users.noreply.github.com>

* Implement server auth bootstrap and pairing flow (pingdotgg#1768)

Co-authored-by: codex <codex@users.noreply.github.com>
Co-authored-by: Julius Marminge <julius@macmini.local>
Co-authored-by: Cursor Agent <cursoragent@cursor.com>
Co-authored-by: cursor[bot] <206951365+cursor[bot]@users.noreply.github.com>

* Use dev proxy for loopback auth and environment requests (pingdotgg#1853)

* Refresh local git status on turn completion (pingdotgg#1821)

Co-authored-by: codex <codex@users.noreply.github.com>

* fix(desktop): add Copy Link action for chat links (pingdotgg#1835)

* fix: map runtime modes to correct permission levels (pingdotgg#1587)

Co-authored-by: Julius Marminge <julius0216@outlook.com>
Co-authored-by: codex <codex@users.noreply.github.com>

* Fix persisted composer image hydration typo (pingdotgg#1831)

* Clarify environment and workspace picker labels (pingdotgg#1854)

* Scope git toast state by thread ref (pingdotgg#1855)

* fix build (pingdotgg#1859)

* Stabilize keybindings toast stream setup (pingdotgg#1860)

Co-authored-by: Julius Marminge <julius@macmini.local>

* feat(web): add embeddable thread route for canvas tile hosts

Adds /embed/thread/:environmentId/:threadId — a standalone route that
renders the existing ChatView without the app sidebar chrome. This is the
iframe target for t3-canvas agent shapes (see rororowyourboat/t3-canvas#3).

- New file-based route embed.thread.\$environmentId.\$threadId.tsx
- __root.tsx bypasses AppSidebarLayout for any /embed/* pathname so the
  environment connection + websocket surface + toasts still initialize
  but the sidebar/diff/plan chrome does not render
- minimal=1 search param is parsed and wired to a data attribute on the
  container for future targeted CSS; chrome hiding (BranchToolbar,
  PlanSidebar, ThreadTerminalDrawer) stays as a follow-up pass
- routeTree.gen.ts regenerated by the @tanstack/router-plugin

---------

Co-authored-by: Julius Marminge <julius0216@outlook.com>
Co-authored-by: codex <codex@users.noreply.github.com>
Co-authored-by: legs <145564979+justsomelegs@users.noreply.github.com>
Co-authored-by: sonder <168988030+heysonder@users.noreply.github.com>
Co-authored-by: Adem Ben Abdallah <96244394+AdemBenAbdallah@users.noreply.github.com>
Co-authored-by: Kyle Gottfried <6462596+Spitfire1900@users.noreply.github.com>
Co-authored-by: Jacob <589761+jvzijp@users.noreply.github.com>
Co-authored-by: Cursor Agent <cursoragent@cursor.com>
Co-authored-by: cursor[bot] <206951365+cursor[bot]@users.noreply.github.com>
Co-authored-by: Julius Marminge <julius@macmini.local>
Co-authored-by: Klemencina <56873773+Klemencina@users.noreply.github.com>
Co-authored-by: Oskar Sekutowicz <me.oski646@gmail.com>
Co-authored-by: Noxire <59626436+noxire-dev@users.noreply.github.com>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment

Labels

size:L 100-499 changed lines (additions + deletions). vouch:trusted PR author is trusted by repo permissions or the VOUCHED list.

Projects

None yet

Development

Successfully merging this pull request may close these issues.

1 participant