nvim: Update lualine diagnostics

master
Ian Mancini 3 years ago
parent f714f732d9
commit 0f66741bde

@ -5,155 +5,182 @@ local lualine = require 'lualine'
-- Color table for highlights -- Color table for highlights
local colors = { local colors = {
bg = '{{colors.light_bg}}', bg = '{{colors.light_bg}}',
fg = '{{colors.fg}}', fg = '{{colors.fg}}',
yellow = '{{colors.yellow}}', yellow = '{{colors.yellow}}',
cyan = '{{colors.cyan}}', cyan = '{{colors.cyan}}',
darkblue = '{{colors.alt_blue}}', darkblue = '{{colors.alt_blue}}',
green = '{{colors.green}}', green = '{{colors.green}}',
orange = '{{colors.orange}}', orange = '{{colors.orange}}',
violet = '{{colors.alt_magenta}}', violet = '{{colors.alt_magenta}}',
magenta = '{{colors.magenta}}', magenta = '{{colors.magenta}}',
blue = '{{colors.blue}}', blue = '{{colors.blue}}',
red = '{{colors.red}}' red = '{{colors.red}}'
} }
local conditions = { local conditions = {
buffer_not_empty = function() return vim.fn.empty(vim.fn.expand('%:t')) ~= 1 end, buffer_not_empty = function()
hide_in_width = function() return vim.fn.winwidth(0) > 80 end, return vim.fn.empty(vim.fn.expand('%:t')) ~= 1
check_git_workspace = function() end,
local filepath = vim.fn.expand('%:p:h') hide_in_width = function() return vim.fn.winwidth(0) > 80 end,
local gitdir = vim.fn.finddir('.git', filepath .. ';') check_git_workspace = function()
return gitdir and #gitdir > 0 and #gitdir < #filepath local filepath = vim.fn.expand('%:p:h')
end local gitdir = vim.fn.finddir('.git', filepath .. ';')
return gitdir and #gitdir > 0 and #gitdir < #filepath
end
} }
-- Config -- Config
local config = { local config = {
options = { options = {
-- Disable sections and component separators -- Disable sections and component separators
component_separators = "", component_separators = "",
section_separators = "", section_separators = "",
disabled_filetypes = {'NvimTree'}, disabled_filetypes = {'NvimTree'},
theme = { theme = {
-- We are going to use lualine_c an lualine_x as left and -- We are going to use lualine_c an lualine_x as left and
-- right section. Both are highlighted by c theme . So we -- right section. Both are highlighted by c theme . So we
-- are just setting default looks o statusline -- are just setting default looks o statusline
normal = {c = {fg = colors.fg, bg = colors.bg}}, normal = {
inactive = {c = {fg = colors.fg, bg = colors.bg}} c = {
fg = colors.fg,
bg = colors.bg
}
},
inactive = {
c = {
fg = colors.fg,
bg = colors.bg
}
}
}
},
sections = {
-- these are to remove the defaults
lualine_a = {},
lualine_b = {},
lualine_y = {},
lualine_z = {},
-- These will be filled later
lualine_c = {},
lualine_x = {}
},
inactive_sections = {
-- these are to remove the defaults
lualine_a = {},
lualine_v = {},
lualine_y = {},
lualine_z = {},
lualine_c = {},
lualine_x = {}
} }
},
sections = {
-- these are to remove the defaults
lualine_a = {},
lualine_b = {},
lualine_y = {},
lualine_z = {},
-- These will be filled later
lualine_c = {},
lualine_x = {}
},
inactive_sections = {
-- these are to remove the defaults
lualine_a = {},
lualine_v = {},
lualine_y = {},
lualine_z = {},
lualine_c = {},
lualine_x = {}
}
} }
-- Inserts a component in lualine_c at left section -- Inserts a component in lualine_c at left section
local function ins_left(component) local function ins_left(component)
table.insert(config.sections.lualine_c, component) table.insert(config.sections.lualine_c, component)
end end
-- Inserts a component in lualine_x ot right section -- Inserts a component in lualine_x ot right section
local function ins_right(component) local function ins_right(component)
table.insert(config.sections.lualine_x, component) table.insert(config.sections.lualine_x, component)
end end
ins_left { ins_left {
function() return '' end, function() return '' end,
color = {fg = colors.blue}, -- Sets highlighting of component color = {
left_padding = 0 -- We don't need space before this fg = colors.blue
}, -- Sets highlighting of component
left_padding = 0 -- We don't need space before this
} }
ins_left { ins_left {
-- mode component -- mode component
function() function()
-- auto change color according to neovims mode -- auto change color according to neovims mode
local mode_color = { local mode_color = {
n = colors.red, n = colors.red,
i = colors.green, i = colors.green,
v = colors.blue, v = colors.blue,
[''] = colors.blue, [''] = colors.blue,
V = colors.blue, V = colors.blue,
c = colors.magenta, c = colors.magenta,
no = colors.red, no = colors.red,
s = colors.orange, s = colors.orange,
S = colors.orange, S = colors.orange,
[''] = colors.orange, [''] = colors.orange,
ic = colors.yellow, ic = colors.yellow,
R = colors.violet, R = colors.violet,
Rv = colors.violet, Rv = colors.violet,
cv = colors.red, cv = colors.red,
ce = colors.red, ce = colors.red,
r = colors.cyan, r = colors.cyan,
rm = colors.cyan, rm = colors.cyan,
['r?'] = colors.cyan, ['r?'] = colors.cyan,
['!'] = colors.red, ['!'] = colors.red,
t = colors.red t = colors.red
} }
vim.api.nvim_command( vim.api.nvim_command('hi! LualineMode guifg=' ..
'hi! LualineMode guifg=' .. mode_color[vim.fn.mode()] .. " guibg=" .. mode_color[vim.fn.mode()] .. " guibg=" ..
colors.bg) colors.bg)
return '' return ''
end, end,
color = "LualineMode", color = "LualineMode",
left_padding = 0 left_padding = 0
} }
ins_left { ins_left {
-- filesize component -- filesize component
function() function()
local function format_file_size(file) local function format_file_size(file)
local size = vim.fn.getfsize(file) local size = vim.fn.getfsize(file)
if size <= 0 then return '' end if size <= 0 then return '' end
local sufixes = {'b', 'k', 'm', 'g'} local sufixes = {'b', 'k', 'm', 'g'}
local i = 1 local i = 1
while size > 1024 do while size > 1024 do
size = size / 1024 size = size / 1024
i = i + 1 i = i + 1
end end
return string.format('%.1f%s', size, sufixes[i]) return string.format('%.1f%s', size, sufixes[i])
end end
local file = vim.fn.expand('%:p') local file = vim.fn.expand('%:p')
if string.len(file) == 0 then return '' end if string.len(file) == 0 then return '' end
return format_file_size(file) return format_file_size(file)
end, end,
condition = conditions.buffer_not_empty condition = conditions.buffer_not_empty
} }
ins_left { ins_left {
'filename', 'filename',
condition = conditions.buffer_not_empty, condition = conditions.buffer_not_empty,
color = {fg = colors.magenta, gui = 'bold'} color = {
fg = colors.magenta,
gui = 'bold'
}
} }
ins_left {'location'} ins_left {'location'}
ins_left {'progress', color = {fg = colors.fg, gui = 'bold'}} ins_left {
'progress',
color = {
fg = colors.fg,
gui = 'bold'
}
}
ins_left { ins_left {
'diagnostics', 'diagnostics',
sources = {'nvim_lsp'}, sources = {'nvim_diagnostic'},
symbols = {error = '', warn = '', info = ''}, symbols = {
color_error = colors.red, error = '',
color_warn = colors.yellow, warn = '',
color_info = colors.cyan info = ''
},
color_error = colors.red,
color_warn = colors.yellow,
color_info = colors.cyan
} }
-- Insert mid section. You can make any number of sections in neovim :) -- Insert mid section. You can make any number of sections in neovim :)
@ -161,60 +188,78 @@ ins_left {
-- ins_left {function() return '%=' end} -- ins_left {function() return '%=' end}
ins_right { ins_right {
-- Lsp server name . -- Lsp server name .
function() function()
local msg = 'No Active Lsp' local msg = 'No Active Lsp'
local buf_ft = vim.api.nvim_buf_get_option(0, 'filetype') local buf_ft = vim.api.nvim_buf_get_option(0, 'filetype')
local clients = vim.lsp.get_active_clients() local clients = vim.lsp.get_active_clients()
if next(clients) == nil then return msg end if next(clients) == nil then return msg end
for _, client in ipairs(clients) do for _, client in ipairs(clients) do
local filetypes = client.config.filetypes local filetypes = client.config.filetypes
if filetypes and vim.fn.index(filetypes, buf_ft) ~= -1 then if filetypes and vim.fn.index(filetypes, buf_ft) ~= -1 then
return client.name return client.name
end end
end end
return msg return msg
end, end,
icon = '', icon = '',
color = {fg = '#ffffff', gui = 'bold'} color = {
fg = '#ffffff',
gui = 'bold'
}
} }
-- Add components to right sections -- Add components to right sections
ins_right { ins_right {
'o:encoding', -- option component same as &encoding in viml 'o:encoding', -- option component same as &encoding in viml
upper = true, -- I'm not sure why it's upper case either ;) upper = true, -- I'm not sure why it's upper case either ;)
condition = conditions.hide_in_width, condition = conditions.hide_in_width,
color = {fg = colors.green, gui = 'bold'} color = {
fg = colors.green,
gui = 'bold'
}
} }
ins_right { ins_right {
'fileformat', 'fileformat',
upper = true, upper = true,
icons_enabled = false, -- I think icons are cool but Eviline doesn't have them. sigh icons_enabled = false, -- I think icons are cool but Eviline doesn't have them. sigh
color = {fg = colors.green, gui = 'bold'} color = {
fg = colors.green,
gui = 'bold'
}
} }
ins_right { ins_right {
'branch', 'branch',
icon = '', icon = '',
condition = conditions.check_git_workspace, condition = conditions.check_git_workspace,
color = {fg = colors.violet, gui = 'bold'} color = {
fg = colors.violet,
gui = 'bold'
}
} }
ins_right { ins_right {
'diff', 'diff',
-- Is it me or the symbol for modified us really weird -- Is it me or the symbol for modified us really weird
symbols = {added = '', modified = '', removed = ''}, symbols = {
color_added = colors.green, added = '',
color_modified = colors.orange, modified = '',
color_removed = colors.red, removed = ''
condition = conditions.hide_in_width },
color_added = colors.green,
color_modified = colors.orange,
color_removed = colors.red,
condition = conditions.hide_in_width
} }
ins_right { ins_right {
function() return '' end, function() return '' end,
color = {fg = colors.blue}, color = {
right_padding = 0 fg = colors.blue
},
right_padding = 0
} }
-- Now don't forget to initialize lualine -- Now don't forget to initialize lualine

Loading…
Cancel
Save