Skip to content

Instantly share code, notes, and snippets.

@dzungtran89
Last active October 18, 2021 11:18
Show Gist options
  • Save dzungtran89/678e16316ebef4c187671a6d163ae511 to your computer and use it in GitHub Desktop.
Save dzungtran89/678e16316ebef4c187671a6d163ae511 to your computer and use it in GitHub Desktop.
-- INFO : Heavily inspired by: Eviline config for lualine
-- Source : https://gist.github.com/hoob3rt/b200435a765ca18f09f83580a606b878
-- Credit : shadmansaleh, glepnir
-- Changes:
-- - Disable `expand` to respect the workspace's root dir
-- - Add disabled_filetypes
local lualine = require('lualine')
-- Color table for highlights
local colors = {
-- bg = '#202328',
bg = '#32302f',
fg = '#bbc2cf',
yellow = '#ECBE7B',
cyan = '#008080',
darkblue = '#081633',
green = '#98be65',
orange = '#FF8800',
violet = '#a9a1e1',
magenta = '#c678dd',
blue = '#51afef',
red = '#ec5f67'
}
local conditions = {
-- buffer_not_empty = function() return vim.fn.empty(vim.fn.expand('%:t')) ~= 1 end,
hide_in_width = function() return vim.fn.winwidth(0) > 80 end,
-- check_git_workspace = function()
-- local filepath = vim.fn.expand('%:p:h')
-- local gitdir = vim.fn.finddir('.git', filepath .. ';')
-- return gitdir and #gitdir > 0 and #gitdir < #filepath
-- end
}
-- Config
local config = {
options = {
-- Disable sections and component separators
component_separators = "",
section_separators = "",
theme = {
-- We are going to use lualine_c an lualine_x as left and
-- right section. Both are highlighted by c theme . So we
-- are just setting default looks o statusline
normal = {c = {fg = colors.fg, bg = colors.bg}},
inactive = {c = {fg = colors.fg, bg = colors.bg}}
},
disabled_filetypes = {'fzf', 'coc-explorer', 'ctrlsf', 'tagbar'},
},
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 = {'filename'},
lualine_v = {},
lualine_y = {},
lualine_z = {},
lualine_c = {},
lualine_x = {}
}
}
-- Inserts a component in lualine_c at left section
local function ins_left(component)
table.insert(config.sections.lualine_c, component)
end
-- Inserts a component in lualine_x ot right section
local function ins_right(component)
table.insert(config.sections.lualine_x, component)
end
-- ins_left {
-- function() return '▊' end,
-- color = {fg = colors.blue}, -- Sets highlighting of component
-- left_padding = 0 -- We don't need space before this
-- }
ins_left {
-- mode component
function()
-- auto change color according to neovims mode
local mode_color = {
n = colors.red,
i = colors.green,
v = colors.blue,
[''] = colors.blue,
V = colors.blue,
c = colors.magenta,
no = colors.red,
s = colors.orange,
S = colors.orange,
[''] = colors.orange,
ic = colors.yellow,
R = colors.violet,
Rv = colors.violet,
cv = colors.red,
ce = colors.red,
r = colors.cyan,
rm = colors.cyan,
['r?'] = colors.cyan,
['!'] = colors.red,
t = colors.red
}
vim.api.nvim_command(
'hi! LualineMode guifg=' .. mode_color[vim.fn.mode()] .. " guibg=" ..
colors.bg)
return '▓▒░' -- , 
end,
color = "LualineMode",
left_padding = 0
}
ins_left {
'filename',
color = {fg = colors.magenta, gui = 'bold'}
-- condition = conditions.buffer_not_empty,
}
ins_left {'location'}
ins_left {'progress', color = {fg = colors.fg, gui = 'bold'}}
-- Tagbar
ins_left {
function()
local _tag = "%{tagbar#currenttag('%s', '', 'f', 'scoped-stl')}"
if _tag == nil or _tag == '' then return 'n/a' end
return _tag
end,
icon = '»',
color = {fg = colors.green}
}
-- ins_left {
-- 'diagnostics',
-- sources = {'nvim_lsp'},
-- symbols = {error = ' ', warn = ' ', 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 :)
-- for lualine it's any number greater then 2
ins_left {function() return '%=' end}
ins_right {
-- Lsp server name .
'coc#status',
icon = ' LSP:',
color = {fg = colors.white, gui = 'bold'}
}
-- Add components to right sections
ins_right {
'o:encoding', -- option component same as &encoding in viml
upper = true,
condition = conditions.hide_in_width,
color = {fg = colors.green, gui = 'bold'}
}
ins_right {
'filetype',
upper = true,
icons_enabled = false,
color = {fg = colors.green, gui = 'bold'}
}
ins_right {
'branch',
icon = '',
condition = conditions.hide_in_width,
color = {fg = colors.violet, gui = 'bold'}
}
ins_right {
'diff',
symbols = {added = '+ ', modified = '~ ', removed = '- '},
color_added = colors.green,
color_modified = colors.orange,
color_removed = colors.red,
condition = conditions.hide_in_width
}
ins_right {
function() return '░▒▓' end, -- ▊
color = {fg = colors.blue},
right_padding = 0
}
lualine.setup(config)
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment