diff options
| author | adamelmore <[email protected]> | 2026-01-25 19:07:19 -0600 |
|---|---|---|
| committer | adamelmore <[email protected]> | 2026-01-25 19:07:24 -0600 |
| commit | 5369e96ab70b88abf1492c50f191dcf9e3bb7108 (patch) | |
| tree | 466c39d6d5ff44a445a432d18033511eadab7058 /packages/ui/src/components/code.tsx | |
| parent | fbcf13852658750bc3e5ba4d7114f7411f61a772 (diff) | |
| download | opencode-5369e96ab70b88abf1492c50f191dcf9e3bb7108.tar.gz opencode-5369e96ab70b88abf1492c50f191dcf9e3bb7108.zip | |
fix(app): line selection colors
Diffstat (limited to 'packages/ui/src/components/code.tsx')
| -rw-r--r-- | packages/ui/src/components/code.tsx | 27 |
1 files changed, 27 insertions, 0 deletions
diff --git a/packages/ui/src/components/code.tsx b/packages/ui/src/components/code.tsx index eb0ba7826..a7687444f 100644 --- a/packages/ui/src/components/code.tsx +++ b/packages/ui/src/components/code.tsx @@ -91,6 +91,19 @@ export function Code<T>(props: CodeProps<T>) { return root } + const applyScheme = () => { + const host = container.querySelector("diffs-container") + if (!(host instanceof HTMLElement)) return + + const scheme = document.documentElement.dataset.colorScheme + if (scheme === "dark" || scheme === "light") { + host.dataset.colorScheme = scheme + return + } + + host.removeAttribute("data-color-scheme") + } + const applyCommentedLines = (ranges: SelectedLineRange[]) => { const root = getRoot() if (!root) return @@ -369,11 +382,25 @@ export function Code<T>(props: CodeProps<T>) { containerWrapper: container, }) + applyScheme() + setRendered((value) => value + 1) notifyRendered() }) createEffect(() => { + if (typeof document === "undefined") return + if (typeof MutationObserver === "undefined") return + + const root = document.documentElement + const monitor = new MutationObserver(() => applyScheme()) + monitor.observe(root, { attributes: true, attributeFilter: ["data-color-scheme"] }) + applyScheme() + + onCleanup(() => monitor.disconnect()) + }) + + createEffect(() => { rendered() const ranges = local.commentedLines ?? [] requestAnimationFrame(() => applyCommentedLines(ranges)) |
