İçeriğe geç

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ı truecolor veya 24bit olmalıdır
  • Truecolor etkinleştirin: kabuk profilinizde COLORTERM=truecolor ortam 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.

AdAçıklama
systemTerminalinizin arka plan rengine uyum sağlar
tokyonighttokyonight temasını temel alır
everforestEverforest temasını temel alır
ayuAyu koyu temasını temel alır
catppuccinCatppuccin temasını temel alır
catppuccin-macchiatoCatppuccin temasını temel alır
gruvboxGruvbox temasını temel alır
kanagawaKanagawa temasını temel alır
nordNord temasını temel alır
matrixHacker tarzı yeşil üzerine siyah tema
one-darkAtom 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 none kullanarak 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.

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

  1. Yerleşik temalar - Binary içine gömülüdür
  2. Kullanıcı yapılandırma dizini - ~/.config/opencode/themes/*.json veya $XDG_CONFIG_HOME/opencode/themes/*.json
  3. Proje kök dizini - <project-root>/.opencode/themes/*.json
  4. 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:

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

Proje özel temalar için:

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

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

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"
}
}
}