From 0a7d4e49ae20039cc8ec5087ebf39d22d17f4d2f Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Wed, 1 Mar 2023 15:22:41 +0300 Subject: [PATCH] feat: separate lualine confiig and apply globalstatus --- modules/statusline/lualine/config.nix | 135 ++++++++------------ modules/statusline/lualine/lualine.nix | 164 +++++++++++++++++-------- 2 files changed, 162 insertions(+), 137 deletions(-) diff --git a/modules/statusline/lualine/config.nix b/modules/statusline/lualine/config.nix index 10b8bf0..5e64886 100644 --- a/modules/statusline/lualine/config.nix +++ b/modules/statusline/lualine/config.nix @@ -4,91 +4,56 @@ lib, ... }: -with lib; { - config = { - vim.statusline.lualine = { - enable = mkDefault false; +with lib; let + cfg = config.vim.statusline.lualine; +in { + config = (mkIf cfg.enable) { + vim.startPlugins = [ + "lualine" + ]; - icons = mkDefault true; - theme = mkDefault "auto"; - sectionSeparator = { - left = mkDefault ""; - right = mkDefault ""; - }; - - componentSeparator = { - left = mkDefault ""; - right = mkDefault ""; - }; - - activeSection = { - # left side of the statusline 4 - a = mkDefault "{'mode'}"; - b = mkDefault '' - { - { - "filename", - color = {bg='none'}, - symbols = {modified = '', readonly = ''}, - }, - } - ''; - c = mkDefault '' - { - { - "branch", - icon = ' •', - separator = { left = '(', right = ')'}, - }, - } - ''; - # right side of the statusline (x, y, z) - x = mkDefault '' - { - { - "diagnostics", - sources = {'nvim_lsp', 'nvim_diagnostic'}, - symbols = {error = '', warn = '', info = '', hint = ''} - }, - } - ''; - y = mkDefault '' - { - { - "fileformat", - color = {bg='none'} - }, - } - ''; - z = mkDefault '' - { - { - "progress", - color = { - bg='none', - fg='lavender' - } - }, - { - "location", - color = {bg='none', fg='lavender'}, - }, - { - "filetype", - color = {bg='none', fg='lavender'}, - }, - } - ''; - }; - - inactiveSection = { - a = mkDefault "{}"; - b = mkDefault "{}"; - c = mkDefault "{'filename'}"; - x = mkDefault "{'location'}"; - y = mkDefault "{}"; - z = mkDefault "{}"; - }; - }; + vim.luaConfigRC.lualine = nvim.dag.entryAnywhere '' + require('lualine').setup { + options = { + icons_enabled = ${boolToString cfg.icons.enable}, + theme = "${cfg.theme}", + component_separators = {"${cfg.componentSeparator.left}","${cfg.componentSeparator.right}"}, + section_separators = {"${cfg.sectionSeparator.left}","${cfg.sectionSeparator.right}"}, + disabled_filetypes = { 'alpha' }, -- 'NvimTree' + always_divide_middle = true, + globalstatus = ${boolToString cfg.globalStatus}, + ignore_focus = {'NvimTree'}, + refresh = { + statusline = ${toString cfg.refresh.statusline}, + tabline = ${toString cfg.refresh.tabline}, + winbar = ${toString cfg.refresh.winbar}, + }, + }, + -- active sections + sections = { + lualine_a = ${cfg.activeSection.a}, + lualine_b = ${cfg.activeSection.b}, + lualine_c = ${cfg.activeSection.c}, + lualine_x = ${cfg.activeSection.x}, + lualine_y = ${cfg.activeSection.y}, + lualine_z = ${cfg.activeSection.z}, + }, + -- + inactive_sections = { + lualine_a = ${cfg.inactiveSection.a}, + lualine_b = ${cfg.inactiveSection.b}, + lualine_c = ${cfg.inactiveSection.c}, + lualine_x = ${cfg.inactiveSection.x}, + lualine_y = ${cfg.inactiveSection.y}, + lualine_z = ${cfg.inactiveSection.z}, + }, + tabline = {}, + extensions = {${ + if (config.vim.filetree.nvimTreeLua.enable) + then "\"nvim-tree\"" + else "" + }}, + } + ''; }; } diff --git a/modules/statusline/lualine/lualine.nix b/modules/statusline/lualine/lualine.nix index 3b8f8d2..a6599bb 100644 --- a/modules/statusline/lualine/lualine.nix +++ b/modules/statusline/lualine/lualine.nix @@ -13,14 +13,43 @@ in { enable = mkOption { type = types.bool; description = "Enable lualine"; + default = true; }; - icons = mkOption { + icons = { + enable = mkOption { + type = types.bool; + description = "Enable icons for lualine"; + default = true; + }; + }; + + refresh = { + statusline = mkOption { + type = types.int; + description = "Refresh rate for lualine"; + default = 1000; + }; + tabline = mkOption { + type = types.int; + description = "Refresh rate for tabline"; + default = 1000; + }; + winbar = mkOption { + type = types.int; + description = "Refresh rate for winbar"; + default = 1000; + }; + }; + + globalStatus = mkOption { type = types.bool; - description = "Enable icons for lualine"; + description = "Enable global status for lualine"; + default = true; }; theme = mkOption { + default = "auto"; type = types.enum ( [ "auto" @@ -68,11 +97,13 @@ in { left = mkOption { type = types.str; description = "Section separator for left side"; + default = ""; }; right = mkOption { type = types.str; description = "Section separator for right side"; + default = ""; }; }; @@ -80,11 +111,13 @@ in { left = mkOption { type = types.str; description = "Component separator for left side"; + default = ""; }; right = mkOption { type = types.str; description = "Component separator for right side"; + default = ""; }; }; @@ -92,31 +125,102 @@ in { a = mkOption { type = types.str; description = "active config for: | (A) | B | C X | Y | Z |"; + default = '' + { + { + "mode", + separator = { + left = '▎', + }, + }, + } + ''; }; b = mkOption { type = types.str; description = "active config for: | A | (B) | C X | Y | Z |"; + default = '' + { + { + "filename", + color = {bg='none'}, + symbols = {modified = '', readonly = ''}, + }, + } + ''; }; c = mkOption { type = types.str; description = "active config for: | A | B | (C) X | Y | Z |"; + default = '' + { + { + "branch", + icon = ' •', + separator = { + left = '(', + right = ')' + } + }, + } + ''; }; x = mkOption { type = types.str; description = "active config for: | A | B | C (X) | Y | Z |"; + default = '' + { + { + "diagnostics", + sources = {'nvim_lsp', 'nvim_diagnostic', 'coc'}, + symbols = {error = '', warn = '', info = '', hint = ''} + }, + } + ''; }; y = mkOption { type = types.str; description = "active config for: | A | B | C X | (Y) | Z |"; + default = '' + { + { + "fileformat", + color = {bg='none', fg='lavender'}, + symbols = { + unix = '', -- e712 + dos = '', -- e70f + mac = '', -- e711 + }, + }, + } + ''; }; z = mkOption { type = types.str; description = "active config for: | A | B | C X | Y | (Z) |"; + default = '' + { + { + "progress", + color = {bg='none', fg='lavender'}, + }, + { + "location", + color = {bg='none', fg='lavender'}, + }, + { + "filetype", + colored = true, + icon = { align = 'right' }, + color = {bg='none', fg='lavender'}, + }, + } + ''; }; }; @@ -124,82 +228,38 @@ in { a = mkOption { type = types.str; description = "inactive config for: | (A) | B | C X | Y | Z |"; + default = "{}"; }; b = mkOption { type = types.str; description = "inactive config for: | A | (B) | C X | Y | Z |"; + default = "{}"; }; c = mkOption { type = types.str; description = "inactive config for: | A | B | (C) X | Y | Z |"; + default = "{'filename'}"; }; x = mkOption { type = types.str; description = "inactive config for: | A | B | C (X) | Y | Z |"; + default = "{'location'}"; }; y = mkOption { type = types.str; description = "inactive config for: | A | B | C X | (Y) | Z |"; + default = "{}"; }; z = mkOption { type = types.str; description = "inactive config for: | A | B | C X | Y | (Z) |"; + default = "{}"; }; }; }; - - config = - mkIf cfg.enable - { - #assertions = [ - # ({ - # assertion = if cfg.icons then (config.vim.visuals.enable && config.vim.visuals.nvimWebDevicons.enable) else true; - # message = "Must enable config.vim.visual.nvimWebDevicons if using config.vim.visuals.lualine.icons"; - # }) - #]; - - vim.startPlugins = ["lualine"]; - vim.luaConfigRC.lualine = nvim.dag.entryAnywhere '' - require'lualine'.setup { - options = { - icons_enabled = ${ - if cfg.icons - then "true" - else "false" - }, - theme = "${cfg.theme}", - component_separators = {"${cfg.componentSeparator.left}","${cfg.componentSeparator.right}"}, - section_separators = {"${cfg.sectionSeparator.left}","${cfg.sectionSeparator.right}"}, - disabled_filetypes = { 'packer', 'NvimTree', 'alpha' } - }, - sections = { - lualine_a = ${cfg.activeSection.a}, - lualine_b = ${cfg.activeSection.b}, - lualine_c = ${cfg.activeSection.c}, - lualine_x = ${cfg.activeSection.x}, - lualine_y = ${cfg.activeSection.y}, - lualine_z = ${cfg.activeSection.z}, - }, - inactive_sections = { - lualine_a = ${cfg.inactiveSection.a}, - lualine_b = ${cfg.inactiveSection.b}, - lualine_c = ${cfg.inactiveSection.c}, - lualine_x = ${cfg.inactiveSection.x}, - lualine_y = ${cfg.inactiveSection.y}, - lualine_z = ${cfg.inactiveSection.z}, - }, - tabline = {}, - extensions = {${ - if config.vim.filetree.nvimTreeLua.enable - then "\"nvim-tree\"" - else "" - }}, - } - ''; - }; }