Skip to content

Commit

Permalink
lualine: increase theme compatibility; fix component definitions
Browse files Browse the repository at this point in the history
  • Loading branch information
NotAShelf committed May 15, 2024
1 parent 355d483 commit b5f38b8
Show file tree
Hide file tree
Showing 2 changed files with 96 additions and 105 deletions.
71 changes: 37 additions & 34 deletions modules/plugins/statusline/lualine/config.nix
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
lib,
...
}: let
inherit (builtins) map;
inherit (lib.modules) mkIf mkMerge;
inherit (lib.trivial) boolToString;
inherit (lib.nvim.dag) entryAnywhere;
Expand Down Expand Up @@ -31,44 +32,46 @@ in {
};
})
(mkIf cfg.enable {
vim.startPlugins = [
"lualine"
];
vim = {
startPlugins = ["lualine"];

vim.luaConfigRC.lualine = entryAnywhere ''
local lualine = require('lualine')
lualine.setup ${toLuaObject cfg.setupOpts}
'';
luaConfigRC.lualine = entryAnywhere ''
local lualine = require('lualine')
lualine.setup ${toLuaObject cfg.setupOpts}
'';

# this is for backwards-compatibility
vim.statusline.lualine.setupOpts = {
options = {
icons_enabled = cfg.icons.enable;
theme = cfg.theme;
component_separators = [cfg.componentSeparator.left cfg.componentSeparator.right];
section_separators = [cfg.sectionSeparator.left cfg.sectionSeparator.right];
globalstatus = cfg.globalStatus;
refresh = cfg.refresh;
};
# this is for backwards-compatibility
statusline.lualine.setupOpts = {
options = {
icons_enabled = cfg.icons.enable;
theme = cfg.theme;
component_separators = [cfg.componentSeparator.left cfg.componentSeparator.right];
section_separators = [cfg.sectionSeparator.left cfg.sectionSeparator.right];
globalstatus = cfg.globalStatus;
refresh = cfg.refresh;
};

sections = {
lualine_a = builtins.map mkLuaInline (cfg.activeSection.a ++ cfg.extraActiveSection.a);
lualine_b = builtins.map mkLuaInline (cfg.activeSection.b ++ cfg.extraActiveSection.b);
lualine_c = builtins.map mkLuaInline (cfg.activeSection.c ++ cfg.extraActiveSection.c);
lualine_x = builtins.map mkLuaInline (cfg.activeSection.x ++ cfg.extraActiveSection.x);
lualine_y = builtins.map mkLuaInline (cfg.activeSection.y ++ cfg.extraActiveSection.y);
lualine_z = builtins.map mkLuaInline (cfg.activeSection.z ++ cfg.extraActiveSection.z);
};
inactive_sections = {
lualine_a = builtins.map mkLuaInline (cfg.inactiveSection.a ++ cfg.extraInactiveSection.a);
lualine_b = builtins.map mkLuaInline (cfg.inactiveSection.b ++ cfg.extraInactiveSection.b);
lualine_c = builtins.map mkLuaInline (cfg.inactiveSection.c ++ cfg.extraInactiveSection.c);
lualine_x = builtins.map mkLuaInline (cfg.inactiveSection.x ++ cfg.extraInactiveSection.x);
lualine_y = builtins.map mkLuaInline (cfg.inactiveSection.y ++ cfg.extraInactiveSection.y);
lualine_z = builtins.map mkLuaInline (cfg.inactiveSection.z ++ cfg.extraInactiveSection.z);
sections = {
lualine_a = map mkLuaInline (cfg.activeSection.a ++ cfg.extraActiveSection.a);
lualine_b = map mkLuaInline (cfg.activeSection.b ++ cfg.extraActiveSection.b);
lualine_c = map mkLuaInline (cfg.activeSection.c ++ cfg.extraActiveSection.c);
lualine_x = map mkLuaInline (cfg.activeSection.x ++ cfg.extraActiveSection.x);
lualine_y = map mkLuaInline (cfg.activeSection.y ++ cfg.extraActiveSection.y);
lualine_z = map mkLuaInline (cfg.activeSection.z ++ cfg.extraActiveSection.z);
};

inactive_sections = {
lualine_a = map mkLuaInline (cfg.inactiveSection.a ++ cfg.extraInactiveSection.a);
lualine_b = map mkLuaInline (cfg.inactiveSection.b ++ cfg.extraInactiveSection.b);
lualine_c = map mkLuaInline (cfg.inactiveSection.c ++ cfg.extraInactiveSection.c);
lualine_x = map mkLuaInline (cfg.inactiveSection.x ++ cfg.extraInactiveSection.x);
lualine_y = map mkLuaInline (cfg.inactiveSection.y ++ cfg.extraInactiveSection.y);
lualine_z = map mkLuaInline (cfg.inactiveSection.z ++ cfg.extraInactiveSection.z);
};

# probably don't need this?
tabline = [];
};
# probably don't need this?
tabline = [];
};
})
];
Expand Down
130 changes: 59 additions & 71 deletions modules/plugins/statusline/lualine/lualine.nix
Original file line number Diff line number Diff line change
Expand Up @@ -10,19 +10,45 @@
inherit (lib.nvim.types) mkPluginSetupOption;

supported_themes = import ./supported_themes.nix;
colorPuccin =
if config.vim.statusline.lualine.theme == "catppuccin"
then "#181825"
else "none";
builtin_themes = [
"auto"
"16color"
"gruvbox"
"ayu_dark"
"ayu_light"
"ayu_mirage"
"codedark"
"dracula"
"everforest"
"gruvbox"
"gruvbox_light"
"gruvbox_material"
"horizon"
"iceberg_dark"
"iceberg_light"
"jellybeans"
"material"
"modus_vivendi"
"molokai"
"nightfly"
"nord"
"oceanicnext"
"onelight"
"palenight"
"papercolor_dark"
"papercolor_light"
"powerline"
"seoul256"
"solarized_dark"
"tomorrow"
"wombat"
];
in {
options.vim.statusline.lualine = {
enable = mkEnableOption "lualine statusline plugin";
setupOpts = mkPluginSetupOption "Lualine" {};

enable = mkEnableOption "lualine statusline plugin";

icons = {
enable = mkEnableOption "icons for lualine" // {default = true;};
};
icons.enable = mkEnableOption "icons for lualine" // {default = true;};

refresh = {
statusline = mkOption {
Expand Down Expand Up @@ -73,47 +99,15 @@ in {

theme = let
themeSupported = elem config.vim.theme.name supported_themes;
themesConcatted = builtin_themes ++ optional themeSupported config.vim.theme.name;
in
mkOption {
description = "Theme for lualine";
type = enum ([
"auto"
"16color"
"gruvbox"
"ayu_dark"
"ayu_light"
"ayu_mirage"
"codedark"
"dracula"
"everforest"
"gruvbox"
"gruvbox_light"
"gruvbox_material"
"horizon"
"iceberg_dark"
"iceberg_light"
"jellybeans"
"material"
"modus_vivendi"
"molokai"
"nightfly"
"nord"
"oceanicnext"
"onelight"
"palenight"
"papercolor_dark"
"papercolor_light"
"powerline"
"seoul256"
"solarized_dark"
"tomorrow"
"wombat"
]
++ optional themeSupported config.vim.theme.name);
type = enum themesConcatted;
default = "auto";
# TODO: xml generation error if the closing '' is on a new line.
# issue: https://gitlab.com/rycee/nmd/-/issues/10
defaultText = ''`config.vim.theme.name` if theme supports lualine else "auto"'';
description = "Theme for lualine";
};

sectionSeparator = {
Expand Down Expand Up @@ -171,15 +165,14 @@ in {
"filetype",
colored = true,
icon_only = true,
icon = { align = 'left' },
color = {bg='${colorPuccin}', fg='lavender'},
icon = { align = 'left' }
}
''
''
{
"filename",
color = {bg='${colorPuccin}'},
symbols = {modified = '', readonly = ''},
symbols = {modified = ' ', readonly = ' '},
separator = {right = ''}
}
''
];
Expand All @@ -200,13 +193,7 @@ in {
removed = 'DiffDelete', -- Changes the diff's removed color you
},
symbols = {added = '+', modified = '~', removed = '-'}, -- Changes the diff symbols
color = {
bg='${colorPuccin}',
fg='lavender'
},
separator = {
right = ''
},
separator = {right = ''}
}
''
];
Expand Down Expand Up @@ -251,18 +238,13 @@ in {
return msg
end,
icon = ' ',
color = {bg='${colorPuccin}', fg='lavender'},
separator = {
left = '',
},
}
''
''
{
"diagnostics",
sources = {'nvim_lsp', 'nvim_diagnostic', 'coc'},
symbols = {error = '󰅙 ', warn = ' ', info = ' ', hint = '󰌵 '},
color = {bg='${colorPuccin}', fg='lavender'},
diagnostics_color = {
color_error = { fg = 'red' },
color_warn = { fg = 'yellow' },
Expand All @@ -282,14 +264,16 @@ in {
'searchcount',
maxcount = 999,
timeout = 120,
color = {bg='${colorPuccin}', fg='lavender'}
}
''
''
{
"branch",
icon = ' •',
color = {bg='${colorPuccin}', fg='lavender'},
separator = {
left = '',
},
}
''
];
Expand All @@ -300,17 +284,10 @@ in {
description = "active config for: | A | B | C X | Y | (Z) |";
default = [
''
{
"progress",
separator = {
left = '',
},
}
{"progress"}
''
''
{
"location",
}
{"location"}
''
''
{
Expand All @@ -326,32 +303,38 @@ in {
];
};
};

extraActiveSection = {
a = mkOption {
type = listOf str;
description = "Extra entries for activeSection.a";
default = [];
};

b = mkOption {
type = listOf str;
description = "Extra entries for activeSection.b";
default = [];
};

c = mkOption {
type = listOf str;
description = "Extra entries for activeSection.c";
default = [];
};

x = mkOption {
type = listOf str;
description = "Extra entries for activeSection.x";
default = [];
};

y = mkOption {
type = listOf str;
description = "Extra entries for activeSection.y";
default = [];
};

z = mkOption {
type = listOf str;
description = "Extra entries for activeSection.z";
Expand Down Expand Up @@ -402,26 +385,31 @@ in {
description = "Extra entries for inactiveSection.a";
default = [];
};

b = mkOption {
type = listOf str;
description = "Extra entries for inactiveSection.b";
default = [];
};

c = mkOption {
type = listOf str;
description = "Extra entries for inactiveSection.c";
default = [];
};

x = mkOption {
type = listOf str;
description = "Extra entries for inactiveSection.x";
default = [];
};

y = mkOption {
type = listOf str;
description = "Extra entries for inactiveSection.y";
default = [];
};

z = mkOption {
type = listOf str;
description = "Extra entries for inactiveSection.z";
Expand Down

0 comments on commit b5f38b8

Please sign in to comment.