home-manager/modules/programs/termite.nix

388 lines
12 KiB
Nix
Raw Normal View History

2017-08-23 16:10:41 +02:00
{ config, lib, pkgs, ... }:
with lib;
let
cfg = config.programs.termite;
2020-02-02 00:39:17 +01:00
in {
2017-08-23 16:10:41 +02:00
options = {
programs.termite = {
enable = mkEnableOption (lib.mdDoc "Termite VTE-based terminal");
2017-08-23 16:10:41 +02:00
allowBold = mkOption {
default = null;
type = types.nullOr types.bool;
description = lib.mdDoc ''
2017-08-23 16:10:41 +02:00
Allow the output of bold characters when the bold escape sequence appears.
'';
};
audibleBell = mkOption {
default = null;
type = types.nullOr types.bool;
description = lib.mdDoc "Have the terminal beep on the terminal bell.";
2017-08-23 16:10:41 +02:00
};
clickableUrl = mkOption {
default = null;
type = types.nullOr types.bool;
description = lib.mdDoc ''
2017-08-23 16:10:41 +02:00
Auto-detected URLs can be clicked on to open them in your browser.
Only enabled if a browser is configured or detected.
'';
};
dynamicTitle = mkOption {
default = null;
type = types.nullOr types.bool;
description = lib.mdDoc ''
2017-08-23 16:10:41 +02:00
Settings dynamic title allows the terminal and the shell to
update the terminal's title.
'';
};
enableVteIntegration = mkEnableOption (lib.mdDoc "Shell VTE integration")
// {
default = true;
};
2017-08-23 16:10:41 +02:00
fullscreen = mkOption {
default = null;
type = types.nullOr types.bool;
description =
lib.mdDoc "Enables entering fullscreen mode by pressing F11.";
2017-08-23 16:10:41 +02:00
};
mouseAutohide = mkOption {
default = null;
type = types.nullOr types.bool;
description = lib.mdDoc ''
2020-02-02 00:39:17 +01:00
Automatically hide the mouse pointer when you start typing.
'';
2017-08-23 16:10:41 +02:00
};
scrollOnOutput = mkOption {
default = null;
type = types.nullOr types.bool;
description =
lib.mdDoc "Scroll to the bottom when the shell generates output.";
2017-08-23 16:10:41 +02:00
};
scrollOnKeystroke = mkOption {
default = null;
type = types.nullOr types.bool;
description = lib.mdDoc ''
2020-02-02 00:39:17 +01:00
Scroll to the bottom automatically when a key is pressed.
'';
2017-08-23 16:10:41 +02:00
};
searchWrap = mkOption {
default = null;
type = types.nullOr types.bool;
description =
lib.mdDoc "Search from top again when you hit the bottom.";
2017-08-23 16:10:41 +02:00
};
urgentOnBell = mkOption {
default = null;
type = types.nullOr types.bool;
description =
lib.mdDoc "Sets the window as urgent on the terminal bell.";
2017-08-23 16:10:41 +02:00
};
font = mkOption {
default = null;
example = "Monospace 12";
type = types.nullOr types.str;
description = lib.mdDoc "The font description for the terminal's font.";
2017-08-23 16:10:41 +02:00
};
geometry = mkOption {
default = null;
example = "640x480";
type = types.nullOr types.str;
description =
lib.mdDoc "The default window geometry for new terminal windows.";
2017-08-23 16:10:41 +02:00
};
iconName = mkOption {
default = null;
example = "terminal";
type = types.nullOr types.str;
2020-02-02 00:39:17 +01:00
description =
lib.mdDoc "The name of the icon to be used for the terminal process.";
2017-08-23 16:10:41 +02:00
};
scrollbackLines = mkOption {
default = null;
example = 10000;
type = types.nullOr types.int;
description = lib.mdDoc
2020-02-02 00:39:17 +01:00
"Set the number of lines to limit the terminal's scrollback.";
2017-08-23 16:10:41 +02:00
};
browser = mkOption {
default = null;
type = types.nullOr types.str;
example = "${pkgs.xdg-utils}/xdg-open";
description = lib.mdDoc ''
2017-08-23 16:10:41 +02:00
Set the default browser for opening links. If its not set, $BROWSER is read.
If that's not set, url hints will be disabled.
'';
};
cursorBlink = mkOption {
default = null;
example = "system";
type = types.nullOr (types.enum [ "system" "on" "off" ]);
description = lib.mdDoc ''
2017-08-23 16:10:41 +02:00
Specify the how the terminal's cursor should behave.
Accepts system to respect the gtk global configuration,
on and off to explicitly enable or disable them.
'';
};
cursorShape = mkOption {
default = null;
example = "block";
type = types.nullOr (types.enum [ "block" "underline" "ibeam" ]);
description = lib.mdDoc ''
2017-08-23 16:10:41 +02:00
Specify how the cursor should look. Accepts block, ibeam and underline.
'';
};
filterUnmatchedUrls = mkOption {
default = null;
type = types.nullOr types.bool;
description = lib.mdDoc
2020-02-02 00:39:17 +01:00
"Whether to hide url hints not matching input in url hints mode.";
2017-08-23 16:10:41 +02:00
};
modifyOtherKeys = mkOption {
default = null;
type = types.nullOr types.bool;
description = lib.mdDoc ''
2017-08-23 16:10:41 +02:00
Emit escape sequences for extra keys,
like the modifyOtherKeys resource for
{manpage}`xterm(1)`.
2017-08-23 16:10:41 +02:00
'';
};
sizeHints = mkOption {
default = null;
type = types.nullOr types.bool;
description = lib.mdDoc ''
2017-08-23 16:10:41 +02:00
Enable size hints. Locks the terminal resizing
to increments of the terminal's cell size.
Requires a window manager that respects scroll hints.
'';
};
scrollbar = mkOption {
default = null;
type = types.nullOr (types.enum [ "off" "left" "right" ]);
description = lib.mdDoc "Scrollbar position.";
2017-08-23 16:10:41 +02:00
};
backgroundColor = mkOption {
default = null;
example = "rgba(63, 63, 63, 0.8)";
type = types.nullOr types.str;
description = lib.mdDoc "Background color value.";
2017-08-23 16:10:41 +02:00
};
cursorColor = mkOption {
default = null;
example = "#dcdccc";
type = types.nullOr types.str;
description = lib.mdDoc "Cursor color value.";
2017-08-23 16:10:41 +02:00
};
cursorForegroundColor = mkOption {
default = null;
example = "#dcdccc";
type = types.nullOr types.str;
description = lib.mdDoc "Cursor foreground color value.";
2017-08-23 16:10:41 +02:00
};
foregroundColor = mkOption {
default = null;
example = "#dcdccc";
type = types.nullOr types.str;
description = lib.mdDoc "Foreground color value.";
2017-08-23 16:10:41 +02:00
};
foregroundBoldColor = mkOption {
default = null;
example = "#ffffff";
type = types.nullOr types.str;
description = lib.mdDoc "Foreground bold color value.";
2017-08-23 16:10:41 +02:00
};
highlightColor = mkOption {
default = null;
example = "#2f2f2f";
type = types.nullOr types.str;
description = lib.mdDoc "highlight color value.";
2017-08-23 16:10:41 +02:00
};
hintsActiveBackgroundColor = mkOption {
default = null;
example = "#3f3f3f";
type = types.nullOr types.str;
description = lib.mdDoc "Hints active background color value.";
2017-08-23 16:10:41 +02:00
};
hintsActiveForegroundColor = mkOption {
default = null;
example = "#e68080";
type = types.nullOr types.str;
description = lib.mdDoc "Hints active foreground color value.";
2017-08-23 16:10:41 +02:00
};
hintsBackgroundColor = mkOption {
default = null;
example = "#3f3f3f";
type = types.nullOr types.str;
description = lib.mdDoc "Hints background color value.";
2017-08-23 16:10:41 +02:00
};
hintsForegroundColor = mkOption {
default = null;
example = "#dcdccc";
type = types.nullOr types.str;
description = lib.mdDoc "Hints foreground color value.";
2017-08-23 16:10:41 +02:00
};
hintsBorderColor = mkOption {
default = null;
example = "#3f3f3f";
type = types.nullOr types.str;
description = lib.mdDoc "Hints border color value.";
2017-08-23 16:10:41 +02:00
};
hintsBorderWidth = mkOption {
default = null;
example = "0.5";
type = types.nullOr types.str;
description = lib.mdDoc "Hints border width.";
2017-08-23 16:10:41 +02:00
};
hintsFont = mkOption {
default = null;
example = "Monospace 12";
type = types.nullOr types.str;
description = lib.mdDoc "The font description for the hints font.";
2017-08-23 16:10:41 +02:00
};
hintsPadding = mkOption {
default = null;
example = 2;
type = types.nullOr types.int;
description = lib.mdDoc "Hints padding.";
2017-08-23 16:10:41 +02:00
};
hintsRoundness = mkOption {
default = null;
example = "0.2";
type = types.nullOr types.str;
description = lib.mdDoc "Hints roundness.";
2017-08-23 16:10:41 +02:00
};
optionsExtra = mkOption {
default = "";
example = "fullscreen = true";
type = types.lines;
2020-02-02 00:39:17 +01:00
description =
lib.mdDoc "Extra options that should be added to [options] section.";
2017-08-23 16:10:41 +02:00
};
colorsExtra = mkOption {
default = "";
example = ''
color0 = #3f3f3f
color1 = #705050
color2 = #60b48a
'';
type = types.lines;
description = lib.mdDoc
2020-02-02 00:39:17 +01:00
"Extra colors options that should be added to [colors] section.";
2017-08-23 16:10:41 +02:00
};
hintsExtra = mkOption {
default = "";
example = "border = #3f3f3f";
type = types.lines;
description = lib.mdDoc
2020-02-02 00:39:17 +01:00
"Extra hints options that should be added to [hints] section.";
2017-08-23 16:10:41 +02:00
};
};
};
2020-02-02 00:39:17 +01:00
config = (let
boolToString = v: if v then "true" else "false";
optionalBoolean = name: val:
lib.optionalString (val != null) "${name} = ${boolToString val}";
optionalInteger = name: val:
lib.optionalString (val != null) "${name} = ${toString val}";
optionalString = name: val:
lib.optionalString (val != null) "${name} = ${val}";
in mkIf cfg.enable {
home.packages = [ pkgs.termite ];
xdg.configFile."termite/config".text = ''
[options]
${optionalBoolean "allow_bold" cfg.allowBold}
${optionalBoolean "audible_bell" cfg.audibleBell}
${optionalString "browser" cfg.browser}
${optionalBoolean "clickable_url" cfg.clickableUrl}
${optionalString "cursor_blink" cfg.cursorBlink}
${optionalString "cursor_shape" cfg.cursorShape}
${optionalBoolean "dynamic_title" cfg.dynamicTitle}
${optionalBoolean "filter_unmatched_urls" cfg.filterUnmatchedUrls}
${optionalString "font" cfg.font}
${optionalBoolean "fullscreen" cfg.fullscreen}
${optionalString "geometry" cfg.geometry}
${optionalString "icon_name" cfg.iconName}
${optionalBoolean "modify_other_keys" cfg.modifyOtherKeys}
${optionalBoolean "mouse_autohide" cfg.mouseAutohide}
${optionalBoolean "scroll_on_keystroke" cfg.scrollOnKeystroke}
${optionalBoolean "scroll_on_output" cfg.scrollOnOutput}
${optionalInteger "scrollback_lines" cfg.scrollbackLines}
${optionalString "scrollbar" cfg.scrollbar}
${optionalBoolean "search_wrap" cfg.searchWrap}
${optionalBoolean "size_hints" cfg.sizeHints}
${optionalBoolean "urgent_on_bell" cfg.urgentOnBell}
${cfg.optionsExtra}
[colors]
${optionalString "background" cfg.backgroundColor}
${optionalString "cursor" cfg.cursorColor}
${optionalString "cursor_foreground" cfg.cursorForegroundColor}
${optionalString "foreground" cfg.foregroundColor}
${optionalString "foreground_bold" cfg.foregroundBoldColor}
2020-02-02 00:39:17 +01:00
${optionalString "highlight" cfg.highlightColor}
${cfg.colorsExtra}
[hints]
${optionalString "active_background" cfg.hintsActiveBackgroundColor}
${optionalString "active_foreground" cfg.hintsActiveForegroundColor}
${optionalString "background" cfg.hintsBackgroundColor}
${optionalString "border" cfg.hintsBorderColor}
${optionalInteger "border_width" cfg.hintsBorderWidth}
${optionalString "font" cfg.hintsFont}
${optionalString "foreground" cfg.hintsForegroundColor}
${optionalInteger "padding" cfg.hintsPadding}
${optionalInteger "roundness" cfg.hintsRoundness}
${cfg.hintsExtra}
'';
programs.bash.enableVteIntegration = lib.mkDefault cfg.enableVteIntegration;
programs.zsh.enableVteIntegration = lib.mkDefault cfg.enableVteIntegration;
2020-02-02 00:39:17 +01:00
});
2017-08-23 16:10:41 +02:00
}