İçeriğe geç

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 $COLORTERM calistirin - cikti truecolor veya 24bit olmalidir
  • Truecolor etkinlestirin: kabuk profilinizde COLORTERM=truecolor ortam 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.

AdAciklama
systemTerminalinizin arka plan rengine uyum saglar
tokyonighttokyonight temasini temel alir
everforestEverforest temasini temel alir
ayuAyu koyu temasini temel alir
catppuccinCatppuccin temasini temel alir
catppuccin-macchiatoCatppuccin temasini temel alir
gruvboxGruvbox temasini temel alir
kanagawaKanagawa temasini temel alir
nordNord temasini temel alir
matrixHacker tarzi yesil uzerine siyah tema
one-darkAtom 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 none kullanarak 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.

opencode.json
{
"$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:

  1. Yerlesik temalar - Binary icine gomuludur
  2. Kullanici config dizini - ~/.config/opencode/themes/*.json veya $XDG_CONFIG_HOME/opencode/themes/*.json
  3. Proje kok dizini - <project-root>/.opencode/themes/*.json
  4. 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:

Terminal window
mkdir -p ~/.config/opencode/themes
vim ~/.config/opencode/themes/my-theme.json

Proje ozel temalar icin:

Terminal window
mkdir -p .opencode/themes
vim .opencode/themes/my-theme.json

JSON 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:

my-theme.json
{
"$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"
}
}
}