Temalar
Yerlesik bir tema secin veya kendiniz olusturun.
opencode ile birden fazla yerlesik tema arasindan secim yapabilir, terminal temaniza uyum saglayan bir tema kullanabilir veya kendi ozel temanizi tanimlayabilirsiniz.
Varsayilan olarak opencode kendi opencode temasini kullanir.
Terminal gereksinimleri
Temalarin tum renk paletiyle dogru gorunmesi icin terminalinizin truecolor (24-bit renk) desteklemesi gerekir. Cogu modern terminal bunu varsayilan olarak destekler, ancak gerekirse etkinlestirmeniz gerekebilir:
- Destegi kontrol edin:
echo $COLORTERMcalistirin - ciktitruecolorveya24bitolmalidir - Truecolor etkinlestirin: kabuk profilinizde
COLORTERM=truecolorortam degiskenini ayarlayin - Terminal uyumlulugu: terminal emulatorunuzun 24-bit rengi desteklediginden emin olun (iTerm2, Alacritty, Kitty, Windows Terminal ve GNOME Terminal’in yeni surumleri gibi modern terminaller genelde destekler)
Truecolor destegi yoksa temalar daha dusuk renk dogrulugu ile gorunebilir veya en yakin 256 renk yaklasimina dusebilir.
Yerlesik temalar
opencode birden fazla yerlesik temayla gelir.
| Ad | Aciklama |
|---|---|
system | Terminalinizin arka plan rengine uyum saglar |
tokyonight | tokyonight temasini temel alir |
everforest | Everforest temasini temel alir |
ayu | Ayu koyu temasini temel alir |
catppuccin | Catppuccin temasini temel alir |
catppuccin-macchiato | Catppuccin temasini temel alir |
gruvbox | Gruvbox temasini temel alir |
kanagawa | Kanagawa temasini temel alir |
nord | Nord temasini temel alir |
matrix | Hacker tarzi yesil uzerine siyah tema |
one-dark | Atom One Dark temasini temel alir |
Ve daha fazlasi; surekli yeni temalar ekliyoruz.
Sistem temasi
system temasi, terminalinizin renk duzenine otomatik uyum saglamak icin tasarlanmistir. Sabit renk kullanan klasik temalardan farkli olarak system temasi:
- Gri olcegi uretir: En iyi kontrast icin terminal arka planina gore ozel gri tonlari olusturur
- ANSI renkleri kullanir: 0-15 arasi standart ANSI renklerini syntax highlighting ve UI ogelerinde kullanir, boylece terminal paletinize uyar
- Terminal varsayilanlarini korur: Metin ve arka plan renklerinde
nonekullanarak terminalin yerel gorunumunu korur
Sistem temasi su kullanicilar icin idealdir:
- opencode’un terminal gorunumuyle birebir uyumlu olmasini isteyenler
- Ozel terminal renk semalari kullananlar
- Tum terminal uygulamalarinda tutarli bir gorunum tercih edenler
Tema kullanin
/theme komutuyla tema secicisini acip tema secebilirsiniz. Isterseniz config dosyanizda da belirtebilirsiniz.
{ "$schema": "https://opencode.ai/config.json", "theme": "tokyonight"}Ozel temalar
opencode, kullanicilarin kolayca tema olusturup ozellestirebilmesi icin esnek bir JSON tabanli tema sistemi sunar.
Hiyerarsi
Temalar birden fazla dizinden su sirayla yuklenir; daha sonra gelen dizin oncekini ezer:
- Yerlesik temalar - Binary icine gomuludur
- Kullanici config dizini -
~/.config/opencode/themes/*.jsonveya$XDG_CONFIG_HOME/opencode/themes/*.json - Proje kok dizini -
<project-root>/.opencode/themes/*.json - Gecerli calisma dizini -
./.opencode/themes/*.json
Birden fazla dizinde ayni adli tema varsa, onceligi daha yuksek dizindeki tema kullanilir.
Tema olusturun
Ozel tema olusturmak icin tema dizinlerinden birinde bir JSON dosyasi olusturun.
Kullanici geneli temalar icin:
mkdir -p ~/.config/opencode/themesvim ~/.config/opencode/themes/my-theme.jsonProje ozel temalar icin:
mkdir -p .opencode/themesvim .opencode/themes/my-theme.jsonJSON formati
Temalar asagidaki ozellikleri destekleyen esnek bir JSON formati kullanir:
- Hex renkler:
"#ffffff" - ANSI renkler:
3(0-255) - Renk referanslari:
"primary"veya ozel tanimlar - Koyu/acik varyantlar:
{"dark": "#000", "light": "#fff"} - Renk yok:
"none"- Terminal varsayilan rengi veya seffaflik kullanilir
Renk tanimlari
defs bolumu istege baglidir ve tema icinde tekrar kullanilabilir renkler tanimlamanizi saglar.
Terminal varsayilanlari
Ozel "none" degeri, terminalin varsayilan rengini miras almak icin herhangi bir renkte kullanilabilir. Bu, terminalinizin renk semasiyla dogal sekilde butunlesen temalar olustururken ozellikle faydalidir:
"text": "none"- Terminalin varsayilan on plan rengini kullanir"background": "none"- Terminalin varsayilan arka plan rengini kullanir
Ornek
Asagida ozel bir tema ornegi 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" } }}