Temalar
Yerleşik bir tema seçin veya kendiniz oluşturun.
opencode ile birden fazla yerleşik tema arasından seçim yapabilir, terminal temanıza uyum sağlayan bir tema kullanabilir veya kendi özel temanızı tanımlayabilirsiniz.
Varsayılan olarak opencode kendi opencode temasını kullanır.
Terminal gereksinimleri
Temaların tüm renk paletiyle doğru görünmesi için terminalinizin truecolor (24-bit renk) desteklemesi gerekir. Çoğu modern terminal bunu varsayılan olarak destekler, ancak gerekirse etkinleştirmeniz gerekebilir:
- Desteği kontrol edin:
echo $COLORTERMçalıştırın - çıktıtruecolorveya24bitolmalıdır - Truecolor etkinleştirin: kabuk profilinizde
COLORTERM=truecolorortam değişkenini ayarlayın - Terminal uyumluluğu: terminal emülatörünüzün 24-bit rengi desteklediğinden emin olun (iTerm2, Alacritty, Kitty, Windows Terminal ve GNOME Terminal’in yeni sürümleri gibi modern terminaller genelde destekler)
Truecolor desteği yoksa temalar daha düşük renk doğruluğu ile görünebilir veya en yakın 256 renk yaklaşımına düşebilir.
Yerleşik temalar
opencode birden fazla yerleşik temayla gelir.
| Ad | Açıklama |
|---|---|
system | Terminalinizin arka plan rengine uyum sağlar |
tokyonight | tokyonight temasını temel alır |
everforest | Everforest temasını temel alır |
ayu | Ayu koyu temasını temel alır |
catppuccin | Catppuccin temasını temel alır |
catppuccin-macchiato | Catppuccin temasını temel alır |
gruvbox | Gruvbox temasını temel alır |
kanagawa | Kanagawa temasını temel alır |
nord | Nord temasını temel alır |
matrix | Hacker tarzı yeşil üzerine siyah tema |
one-dark | Atom One Dark temasını temel alır |
Ve daha fazlası; sürekli yeni temalar ekliyoruz.
Sistem teması
system teması, terminalinizin renk düzenine otomatik uyum sağlamak için tasarlanmıştır. Sabit renk kullanan klasik temalardan farklı olarak system teması:
- Gri ölçeği üretir: En iyi kontrast için terminal arka planına göre özel gri tonları oluşturur
- ANSI renkleri kullanır: 0-15 arası standart ANSI renklerini syntax highlighting ve UI öğelerinde kullanır, böylece terminal paletinize uyar
- Terminal varsayılanlarını korur: Metin ve arka plan renklerinde
nonekullanarak terminalin yerel görünümünü korur
Sistem teması şu kullanıcılar için idealdir:
- opencode’un terminal görünümüyle birebir uyumlu olmasını isteyenler
- Özel terminal renk şemaları kullananlar
- Tüm terminal uygulamalarında tutarlı bir görünüm tercih edenler
Tema kullanımı
/theme komutuyla tema seçicisini açıp tema seçebilirsiniz. İsterseniz config dosyanızda da belirtebilirsiniz.
{ "$schema": "https://opencode.ai/config.json", "theme": "tokyonight"}Özel temalar
opencode, kullanıcıların kolayca tema oluşturup özelleştirebilmesi için esnek bir JSON tabanlı tema sistemi sunar.
Hiyerarşi
Temalar birden fazla dizinden şu sırayla yüklenir; daha sonra gelen dizin öncekini ezer:
- Yerleşik temalar - Binary içine gömülüdür
- Kullanıcı yapılandırma dizini -
~/.config/opencode/themes/*.jsonveya$XDG_CONFIG_HOME/opencode/themes/*.json - Proje kök dizini -
<project-root>/.opencode/themes/*.json - Geçerli çalışma dizini -
./.opencode/themes/*.json
Birden fazla dizinde aynı adlı tema varsa, önceliği daha yüksek dizindeki tema kullanılır.
Tema oluşturma
Özel tema oluşturmak için tema dizinlerinden birinde bir JSON dosyası oluşturun.
Kullanıcı geneli temalar için:
mkdir -p ~/.config/opencode/themesvim ~/.config/opencode/themes/my-theme.jsonProje özel temalar için:
mkdir -p .opencode/themesvim .opencode/themes/my-theme.jsonJSON formatı
Temalar aşağıdaki özellikleri destekleyen esnek bir JSON formatı kullanır:
- Hex renkler:
"#ffffff" - ANSI renkler:
3(0-255) - Renk referansları:
"primary"veya özel tanımlar - Koyu/açık varyantlar:
{"dark": "#000", "light": "#fff"} - Renk yok:
"none"- Terminal varsayılan rengi veya şeffaflık kullanılır
Renk tanımları
defs bölümü isteğe bağlıdır ve tema içinde tekrar kullanılabilir renkler tanımlamanızı sağlar.
Terminal varsayılanları
Özel "none" değeri, terminalin varsayılan rengini miras almak için herhangi bir renkte kullanılabilir. Bu, terminalinizin renk şemasıyla doğal şekilde bütünleşen temalar oluştururken özellikle faydalıdır:
"text": "none"- Terminalin varsayılan ön plan rengini kullanır"background": "none"- Terminalin varsayılan arka plan rengini kullanır
Örnek
Aşağıda özel bir tema örneği var:
{ "$schema": "https://opencode.ai/theme.json", "defs": { "nord0": "#2E3440", "nord1": "#3B4252", "nord2": "#434C5E", "nord3": "#4C566A", "nord4": "#D8DEE9", "nord5": "#E5E9F0", "nord6": "#ECEFF4", "nord7": "#8FBCBB", "nord8": "#88C0D0", "nord9": "#81A1C1", "nord10": "#5E81AC", "nord11": "#BF616A", "nord12": "#D08770", "nord13": "#EBCB8B", "nord14": "#A3BE8C", "nord15": "#B48EAD" }, "theme": { "primary": { "dark": "nord8", "light": "nord10" }, "secondary": { "dark": "nord9", "light": "nord9" }, "accent": { "dark": "nord7", "light": "nord7" }, "error": { "dark": "nord11", "light": "nord11" }, "warning": { "dark": "nord12", "light": "nord12" }, "success": { "dark": "nord14", "light": "nord14" }, "info": { "dark": "nord8", "light": "nord10" }, "text": { "dark": "nord4", "light": "nord0" }, "textMuted": { "dark": "nord3", "light": "nord1" }, "background": { "dark": "nord0", "light": "nord6" }, "backgroundPanel": { "dark": "nord1", "light": "nord5" }, "backgroundElement": { "dark": "nord1", "light": "nord4" }, "border": { "dark": "nord2", "light": "nord3" }, "borderActive": { "dark": "nord3", "light": "nord2" }, "borderSubtle": { "dark": "nord2", "light": "nord3" }, "diffAdded": { "dark": "nord14", "light": "nord14" }, "diffRemoved": { "dark": "nord11", "light": "nord11" }, "diffContext": { "dark": "nord3", "light": "nord3" }, "diffHunkHeader": { "dark": "nord3", "light": "nord3" }, "diffHighlightAdded": { "dark": "nord14", "light": "nord14" }, "diffHighlightRemoved": { "dark": "nord11", "light": "nord11" }, "diffAddedBg": { "dark": "#3B4252", "light": "#E5E9F0" }, "diffRemovedBg": { "dark": "#3B4252", "light": "#E5E9F0" }, "diffContextBg": { "dark": "nord1", "light": "nord5" }, "diffLineNumber": { "dark": "nord2", "light": "nord4" }, "diffAddedLineNumberBg": { "dark": "#3B4252", "light": "#E5E9F0" }, "diffRemovedLineNumberBg": { "dark": "#3B4252", "light": "#E5E9F0" }, "markdownText": { "dark": "nord4", "light": "nord0" }, "markdownHeading": { "dark": "nord8", "light": "nord10" }, "markdownLink": { "dark": "nord9", "light": "nord9" }, "markdownLinkText": { "dark": "nord7", "light": "nord7" }, "markdownCode": { "dark": "nord14", "light": "nord14" }, "markdownBlockQuote": { "dark": "nord3", "light": "nord3" }, "markdownEmph": { "dark": "nord12", "light": "nord12" }, "markdownStrong": { "dark": "nord13", "light": "nord13" }, "markdownHorizontalRule": { "dark": "nord3", "light": "nord3" }, "markdownListItem": { "dark": "nord8", "light": "nord10" }, "markdownListEnumeration": { "dark": "nord7", "light": "nord7" }, "markdownImage": { "dark": "nord9", "light": "nord9" }, "markdownImageText": { "dark": "nord7", "light": "nord7" }, "markdownCodeBlock": { "dark": "nord4", "light": "nord0" }, "syntaxComment": { "dark": "nord3", "light": "nord3" }, "syntaxKeyword": { "dark": "nord9", "light": "nord9" }, "syntaxFunction": { "dark": "nord8", "light": "nord8" }, "syntaxVariable": { "dark": "nord7", "light": "nord7" }, "syntaxString": { "dark": "nord14", "light": "nord14" }, "syntaxNumber": { "dark": "nord15", "light": "nord15" }, "syntaxType": { "dark": "nord7", "light": "nord7" }, "syntaxOperator": { "dark": "nord9", "light": "nord9" }, "syntaxPunctuation": { "dark": "nord4", "light": "nord0" } }}