Skip to content
Draft
Show file tree
Hide file tree
Changes from all commits
Commits
Show all changes
59 commits
Select commit Hold shift + click to select a range
3439e3c
feat: Add placeholderText theme color for input placeholders
ariane-emory Dec 5, 2025
6fcea5f
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 6, 2025
a02ebc7
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 6, 2025
ec57d82
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 7, 2025
bb103b2
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 7, 2025
86cc178
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 7, 2025
e1876bc
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 7, 2025
319f6fd
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 8, 2025
e62a847
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 8, 2025
09a4a09
Fix TypeScript error: remove cacheKey from FileContents interface usage
ariane-emory Dec 8, 2025
1ac2ac7
Merge upstream/dev into fix/placeholder-color-5088
ariane-emory Dec 9, 2025
36dd035
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 9, 2025
2d3f1c5
tweak: use placeholderColor here as per bOo's request.
ariane-emory Dec 9, 2025
a2e9fe8
Merge branch 'fix/placeholder-color-5088' of github.com:ariane-emory/…
ariane-emory Dec 9, 2025
d3d50fb
chore: resync this file
ariane-emory Dec 9, 2025
5e9e093
Add placeholderColor prop to OpenTUI Textarea component
ariane-emory Dec 9, 2025
9c16374
Update OpenCode to use placeholderColor prop from opentui
ariane-emory Dec 9, 2025
70fe2aa
Merge branch 'fix/placeholder-color-5088' of github.com:ariane-emory/…
ariane-emory Dec 9, 2025
9c0a31c
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 9, 2025
19bb3e0
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 10, 2025
9d2587f
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 10, 2025
24b760d
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 10, 2025
f1780a9
Merge remote-tracking branch 'upstream/dev' into fix/placeholder-colo…
ariane-emory Dec 10, 2025
7183ae3
Fix TypeScript error: remove placeholderColor property
ariane-emory Dec 10, 2025
b5a9e66
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 10, 2025
99304a4
fix: uncorrupt
ariane-emory Dec 11, 2025
9d4cc1c
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 11, 2025
ea54b82
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 11, 2025
d74137b
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 11, 2025
6f18eb3
tidy: whitespace
ariane-emory Dec 13, 2025
4021386
Merge branch 'dev' into repair/fix/placeholder-color-5088
ariane-emory Dec 13, 2025
4892a23
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 17, 2025
81f027b
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 17, 2025
832ec71
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 18, 2025
1cca733
Merge remote-tracking branch 'origin/dev' into fix/placeholder-color-…
ariane-emory Dec 19, 2025
51eb9e2
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 19, 2025
e7539d8
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 20, 2025
42eec82
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 20, 2025
525547d
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 21, 2025
7d0a657
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 21, 2025
ae99d9c
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 23, 2025
5ee529a
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 23, 2025
4865b09
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 23, 2025
8629ef5
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 23, 2025
fc790ab
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 23, 2025
7025790
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 24, 2025
a890140
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 24, 2025
eaa9cc6
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 24, 2025
33574d2
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 24, 2025
42c4cab
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 25, 2025
1b368e7
Merge branch 'fix/placeholder-color-5088' of github.com:ariane-emory/…
ariane-emory Dec 25, 2025
3c8e07d
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 25, 2025
48d690d
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 25, 2025
a1858e2
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 26, 2025
f6e6e3b
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 27, 2025
d6cbb8b
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 27, 2025
3549221
Merge remote-tracking branch 'origin/dev' into fix/placeholder-color-…
ariane-emory Dec 27, 2025
3ff0630
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 28, 2025
63b854f
Merge branch 'dev' into fix/placeholder-color-5088
ariane-emory Dec 28, 2025
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
1 change: 1 addition & 0 deletions packages/console/app/public/theme.json
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@
"info": { "$ref": "#/definitions/colorValue" },
"text": { "$ref": "#/definitions/colorValue" },
"textMuted": { "$ref": "#/definitions/colorValue" },
"placeholderText": { "$ref": "#/definitions/colorValue" },
"background": { "$ref": "#/definitions/colorValue" },
"backgroundPanel": { "$ref": "#/definitions/colorValue" },
"backgroundElement": { "$ref": "#/definitions/colorValue" },
Expand Down
14 changes: 12 additions & 2 deletions packages/opencode/src/cli/cmd/tui/context/theme.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -50,6 +50,7 @@ type ThemeColors = {
info: RGBA
text: RGBA
textMuted: RGBA
placeholderText: RGBA
selectedListItemText: RGBA
background: RGBA
backgroundPanel: RGBA
Expand Down Expand Up @@ -127,9 +128,10 @@ type ColorValue = HexColor | RefName | Variant | RGBA
type ThemeJson = {
$schema?: string
defs?: Record<string, HexColor | RefName>
theme: Omit<Record<keyof ThemeColors, ColorValue>, "selectedListItemText" | "backgroundMenu"> & {
theme: Omit<Record<keyof ThemeColors, ColorValue>, "selectedListItemText" | "backgroundMenu" | "placeholderText"> & {
selectedListItemText?: ColorValue
backgroundMenu?: ColorValue
placeholderText?: ColorValue
thinkingOpacity?: number
}
}
Expand Down Expand Up @@ -193,7 +195,7 @@ function resolveTheme(theme: ThemeJson, mode: "dark" | "light") {

const resolved = Object.fromEntries(
Object.entries(theme.theme)
.filter(([key]) => key !== "selectedListItemText" && key !== "backgroundMenu" && key !== "thinkingOpacity")
.filter(([key]) => key !== "selectedListItemText" && key !== "backgroundMenu" && key !== "placeholderText" && key !== "thinkingOpacity")
.map(([key, value]) => {
return [key, resolveColor(value as ColorValue)]
}),
Expand All @@ -216,6 +218,13 @@ function resolveTheme(theme: ThemeJson, mode: "dark" | "light") {
resolved.backgroundMenu = resolved.backgroundElement
}

// Handle placeholderText - optional with fallback to textMuted
if (theme.theme.placeholderText !== undefined) {
resolved.placeholderText = resolveColor(theme.theme.placeholderText)
} else {
resolved.placeholderText = resolved.textMuted
}

// Handle thinkingOpacity - optional with default of 0.6
const thinkingOpacity = theme.theme.thinkingOpacity ?? 0.6

Expand Down Expand Up @@ -434,6 +443,7 @@ function generateSystem(colors: TerminalColors, mode: "dark" | "light"): ThemeJs
// Text colors
text: fg,
textMuted,
placeholderText: textMuted,
selectedListItemText: bg,

// Background colors
Expand Down
1 change: 1 addition & 0 deletions packages/opencode/src/cli/cmd/tui/ui/dialog-select.tsx
Original file line number Diff line number Diff line change
Expand Up @@ -205,6 +205,7 @@ export function DialogSelect<T>(props: DialogSelectProps<T>) {
focusedBackgroundColor={theme.backgroundPanel}
cursorColor={theme.primary}
focusedTextColor={theme.textMuted}
placeholderColor={theme.placeholderText}
ref={(r) => {
input = r
setTimeout(() => input.focus(), 1)
Expand Down
1 change: 1 addition & 0 deletions packages/web/public/theme.json
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@
"info": { "$ref": "#/definitions/colorValue" },
"text": { "$ref": "#/definitions/colorValue" },
"textMuted": { "$ref": "#/definitions/colorValue" },
"placeholderText": { "$ref": "#/definitions/colorValue" },
"selectedListItemText": { "$ref": "#/definitions/colorValue" },
"background": { "$ref": "#/definitions/colorValue" },
"backgroundPanel": { "$ref": "#/definitions/colorValue" },
Expand Down