Skip to content

Latest commit

 

History

History
90 lines (64 loc) · 3.39 KB

THEMES.md

File metadata and controls

90 lines (64 loc) · 3.39 KB

Themes

default on light terminal:

Configuration

To change the colors of the default theme you need to add a theme.ron file that contains the colors you want to override. Note that you don’t have to specify the full theme anymore (as of 0.23). Instead, it is sufficient to override just the values that you want to differ from their default values.

The file uses the Ron format and is located at one of the following paths, depending on your operating system:

  • $HOME/.config/gitui/theme.ron (mac)
  • $XDG_CONFIG_HOME/gitui/theme.ron (linux using XDG)
  • $HOME/.config/gitui/theme.ron (linux)
  • %APPDATA%/gitui/theme.ron (Windows)

Alternatively, you can create a theme in the same directory mentioned above and use it with the -t flag followed by the name of the file in the directory. E.g. If you are on linux calling gitui -t arc.ron, this will load the theme in $XDG_CONFIG_HOME/gitui/arc.ron or $HOME/.config/gitui/arc.ron.

Example theme override:

(
    selection_bg: Some("Blue"),
    selection_fg: Some("#ffffff"),
)

Note that you need to wrap values in Some due to the way the overrides work (as of 0.23).

Notes:

  • rgb colors might not be supported in every terminal.
  • using a color like yellow might appear in whatever your terminal/theme defines for yellow
  • valid colors can be found in ratatui's Color struct.
  • all customizable theme elements can be found in style.rs in the impl Default for Theme block

Preset Themes

You can find preset themes by Catppuccin here.

Syntax Highlighting

The syntax highlighting theme can be defined using the element syntax. Both default themes of the syntect library and custom themes are supported.

Example syntax theme:

(
    syntax: Some("InspiredGitHub"),
)

Custom themes are located in the configuration directory, are using TextMate's theme format and must have a .tmTheme file extension. To load a custom theme, syntax must be set to the file name without the file extension. For example, to load Blackboard.tmTheme, place the file next to theme.ron and set:

(
    syntax: Some("Blackboard"),
)

filmgirl/TextMate-Themes offers many beautiful TextMate themes to choose from.

Customizing line breaks

If you want to change how the line break is displayed in the diff, you can also specify line_break in your theme.ron:

(
    line_break: Some("¶"),
)

Note that if you want to turn it off, you should use a blank string:

(
    line_break: Some(""),
)

Customizing selection

By default the selection_fg color is used to color the text of the selected line. Diff line, filename, commit hashes, time and author are re-colored with selection_fg color. This can be changed by specifying the use_selection_fg boolean in your theme.ron:

(
    use_selection_fg: Some(false),
)

By default, use_selection_fg is set to true.