mirror of
https://github.com/NotAShelf/neovim-flake.git
synced 2025-01-25 18:49:48 +01:00
144 lines
4.3 KiB
Nix
144 lines
4.3 KiB
Nix
{
|
||
config,
|
||
lib,
|
||
...
|
||
}: let
|
||
inherit (builtins) elem;
|
||
inherit (lib.options) mkOption mkEnableOption literalExpression;
|
||
inherit (lib.types) str listOf attrs attrsOf anything either submodule;
|
||
inherit (lib.lists) optional;
|
||
inherit (lib.generators) mkLuaInline;
|
||
inherit (lib.nvim.types) mkPluginSetupOption;
|
||
|
||
conditionalRenderers = {
|
||
options = {
|
||
filetypes = mkOption {
|
||
type = listOf str;
|
||
default = [
|
||
"^NvimTree$"
|
||
"^neo-tree$"
|
||
"^startify$"
|
||
"^fugitive$"
|
||
"^fugitiveblame$"
|
||
"^qf$"
|
||
"^help$"
|
||
];
|
||
|
||
description = "Filetypes in which to force render inactive statusline";
|
||
};
|
||
|
||
buftypes = mkOption {
|
||
type = listOf str;
|
||
default = ["^terminal$"];
|
||
description = "Buffer types in which to force render inactive statusline";
|
||
};
|
||
|
||
bufnames = mkOption {
|
||
type = listOf str;
|
||
default = [];
|
||
description = "Buffer names in which to force render inactive statusline";
|
||
};
|
||
};
|
||
};
|
||
in {
|
||
options.vim.statusline.feline-nvim = {
|
||
enable = mkEnableOption "minimal, stylish and customizable statusline, statuscolumn, and winbar [feline.nvim]";
|
||
setupOpts = mkPluginSetupOption "feline-nvim" {
|
||
custom_providers = mkOption {
|
||
type = attrsOf anything;
|
||
default = {};
|
||
example = literalExpression ''
|
||
{
|
||
window_number = mkLuaInline ''''
|
||
function()
|
||
return tostring(vim.api.nvim_win_get_number(0))
|
||
end
|
||
'''';
|
||
}
|
||
'';
|
||
|
||
description = "User-defined feline provider functions";
|
||
};
|
||
|
||
theme = mkOption {
|
||
type = either str (attrsOf str);
|
||
default = {};
|
||
example = {
|
||
fg = "#fff";
|
||
bg = "#111";
|
||
};
|
||
description = ''
|
||
Either a string containing the color theme name or an attribute set of
|
||
strings, containing the colors.
|
||
|
||
The theme’s `fg` and `bg` values also represent the default foreground
|
||
and background colors, respectively.
|
||
'';
|
||
};
|
||
|
||
separators = mkOption {
|
||
type = listOf str;
|
||
default = [];
|
||
example = ["slant_right_2"];
|
||
description = ''
|
||
A table containing custom Feline separator prests.
|
||
|
||
:::{.warning}
|
||
This option is not type-checked! Before setting this option, please take
|
||
a look at {command}`:help feline-separator-preset` for a list of
|
||
available separator presets.
|
||
:::
|
||
'';
|
||
};
|
||
|
||
force_inactive = mkOption {
|
||
default = {};
|
||
type = attrsOf (submodule conditionalRenderers);
|
||
description = ''
|
||
A table that determines which buffers should always have the inactive
|
||
statusline, even when they are active.
|
||
'';
|
||
};
|
||
|
||
disable = mkOption {
|
||
default = {};
|
||
type = attrsOf (submodule conditionalRenderers);
|
||
description = ''
|
||
A table that determines which buffers should always have the statusline
|
||
disabled, even when they are active.
|
||
'';
|
||
};
|
||
|
||
vi_mode_colors = mkOption {
|
||
type = attrsOf str;
|
||
default = {};
|
||
description = ''
|
||
Attribute set containing colors associated with specific Vi modes.
|
||
|
||
It can later be used to get the color associated with the current Vim
|
||
mode using `require('feline.providers.vi_mode').get_mode_color()`.
|
||
|
||
See `:help feline-vi-mode` for more details on vi mode.
|
||
'';
|
||
};
|
||
|
||
# TODO:
|
||
# - Check for the number of elements in the list maybe? Can Feline have infinite components per section?
|
||
# - type-check contents of `attrsOf anything`? Is there a downside for not doing that?
|
||
# - add examples for each one of those components. The option types are necessary, but confusing.
|
||
components = {
|
||
active = mkOption {
|
||
type = listOf (listOf (attrsOf anything));
|
||
default = [];
|
||
description = "List of components to display for buffers feline will render as 'active'";
|
||
};
|
||
|
||
inactive = mkOption {
|
||
type = listOf (listOf (attrsOf anything));
|
||
default = [];
|
||
description = "List of components to display for buffers feline will render as 'inactive'";
|
||
};
|
||
};
|
||
};
|
||
};
|
||
}
|