From 868f8087099400e92451085b33dff0ccf771469b Mon Sep 17 00:00:00 2001 From: Frothy <76622149+FrothyMarrow@users.noreply.github.com> Date: Sat, 10 Feb 2024 20:52:02 -0500 Subject: [PATCH 1/6] visuals/fidget: switch input branch to main --- flake.lock | 7 +++---- flake.nix | 2 +- 2 files changed, 4 insertions(+), 5 deletions(-) diff --git a/flake.lock b/flake.lock index 44d96fad..d7af1a25 100644 --- a/flake.lock +++ b/flake.lock @@ -388,16 +388,15 @@ "fidget-nvim": { "flake": false, "locked": { - "lastModified": 1699509702, - "narHash": "sha256-8Gl2Ck4YJGReSEq1Xeh1dpdRq4eImmrxvIHrfxdem3Q=", + "lastModified": 1707329128, + "narHash": "sha256-mMLAhAbIs33RoU9c8COchbWRr2NM231zJn6TtwJmI+4=", "owner": "j-hui", "repo": "fidget.nvim", - "rev": "2f7c08f45639a64a5c0abcf67321d52c3f499ae6", + "rev": "ad8873c16faa123fe3f9fd6539c41dfb0f97a9e9", "type": "github" }, "original": { "owner": "j-hui", - "ref": "legacy", "repo": "fidget.nvim", "type": "github" } diff --git a/flake.nix b/flake.nix index 67b65777..609f8fc0 100644 --- a/flake.nix +++ b/flake.nix @@ -398,7 +398,7 @@ }; fidget-nvim = { - url = "github:j-hui/fidget.nvim?ref=legacy"; + url = "github:j-hui/fidget.nvim"; flake = false; }; From 042af029552d3ec48046e50099cd79b9e4477dd4 Mon Sep 17 00:00:00 2001 From: Frothy <76622149+FrothyMarrow@users.noreply.github.com> Date: Sat, 10 Feb 2024 20:49:27 -0500 Subject: [PATCH 2/6] visuals/fidget: migrate to newer configuration with custom setup options --- modules/visuals/config.nix | 17 +- modules/visuals/default.nix | 1 + modules/visuals/fidget/config.nix | 16 ++ modules/visuals/fidget/default.nix | 6 + modules/visuals/fidget/fidget.nix | 387 +++++++++++++++++++++++++++++ modules/visuals/visuals.nix | 18 -- 6 files changed, 411 insertions(+), 34 deletions(-) create mode 100644 modules/visuals/fidget/config.nix create mode 100644 modules/visuals/fidget/default.nix create mode 100644 modules/visuals/fidget/fidget.nix diff --git a/modules/visuals/config.nix b/modules/visuals/config.nix index 7e4a83ba..8cd4ecfc 100644 --- a/modules/visuals/config.nix +++ b/modules/visuals/config.nix @@ -113,24 +113,9 @@ in { ''; }) - (mkIf cfg.fidget-nvim.enable { - vim.startPlugins = ["fidget-nvim"]; - vim.luaConfigRC.fidget-nvim = nvim.dag.entryAnywhere '' - require"fidget".setup{ - align = { - bottom = ${boolToString cfg.fidget-nvim.align.bottom}, - right = ${boolToString cfg.fidget-nvim.align.right}, - }, - window = { - blend = 0, - }, - } - ''; - }) - (mkIf cfg.highlight-undo.enable { vim.startPlugins = ["highlight-undo"]; - vim.luaConfigRC.fidget-nvim = nvim.dag.entryAnywhere '' + vim.luaConfigRC.highlight-undo = nvim.dag.entryAnywhere '' require('highlight-undo').setup({ duration = ${toString cfg.highlight-undo.duration}, highlight_for_count = ${boolToString cfg.highlight-undo.highlightForCount}, diff --git a/modules/visuals/default.nix b/modules/visuals/default.nix index 9efdde73..3c977cba 100644 --- a/modules/visuals/default.nix +++ b/modules/visuals/default.nix @@ -2,5 +2,6 @@ imports = [ ./config.nix ./visuals.nix + ./fidget ]; } diff --git a/modules/visuals/fidget/config.nix b/modules/visuals/fidget/config.nix new file mode 100644 index 00000000..cb212db2 --- /dev/null +++ b/modules/visuals/fidget/config.nix @@ -0,0 +1,16 @@ +{ + config, + lib, + ... +}: let + inherit (lib) mkIf nvim; + cfg = config.vim.visuals.fidget-nvim; +in { + config = mkIf cfg.enable { + vim.startPlugins = ["fidget-nvim"]; + + vim.luaConfigRC.fidget-nvim = nvim.dag.entryAnywhere '' + require'fidget'.setup(${nvim.lua.toLuaObject cfg.setupOpts}) + ''; + }; +} diff --git a/modules/visuals/fidget/default.nix b/modules/visuals/fidget/default.nix new file mode 100644 index 00000000..70dbc7c1 --- /dev/null +++ b/modules/visuals/fidget/default.nix @@ -0,0 +1,6 @@ +{ + imports = [ + ./config.nix + ./fidget.nix + ]; +} diff --git a/modules/visuals/fidget/fidget.nix b/modules/visuals/fidget/fidget.nix new file mode 100644 index 00000000..efa89326 --- /dev/null +++ b/modules/visuals/fidget/fidget.nix @@ -0,0 +1,387 @@ +{ + config, + lib, + ... +}: let + inherit (lib) mkEnableOption mkOption mapAttrs toUpper nvim types; + rawLua = lua: {__raw = lua;}; +in { + options.vim.visuals.fidget-nvim = { + enable = mkEnableOption "nvim LSP UI element [fidget-nvim]"; + + setupOpts = nvim.types.mkPluginSetupOption "Nvim Tree" { + progress = { + poll_rate = mkOption { + description = "How frequently to poll for LSP progress messages"; + type = types.int; + default = 0; + }; + suppress_on_insert = mkOption { + description = "Suppress new messages when in insert mode"; + type = types.bool; + default = false; + }; + ignore_done_already = mkOption { + description = "Ignore new tasks that are already done"; + type = types.bool; + default = false; + }; + ignore_empty_message = mkOption { + description = "Ignore new tasks with empty messages"; + type = types.bool; + default = false; + }; + clear_on_detach = mkOption { + description = "Clear notification group when LSP server detaches"; + type = types.bool; + default = true; + apply = clear: + if clear + then + rawLua '' + function(client_id) + local client = vim.lsp.get_client_by_id(client_id) + return client and client.name or nil + end + '' + else null; + }; + notification_group = mkOption { + description = "How to get a progress message's notification group key"; + type = types.str; + default = '' + function(msg) + return msg.lsp_client.name + end + ''; + apply = rawLua; + }; + ignore = mkOption { + description = "Ignore LSP servers by name"; + type = types.listOf types.str; + default = []; + }; + + display = { + render_limit = mkOption { + description = "Maximum number of messages to render"; + type = types.int; + default = 16; + }; + done_ttl = mkOption { + description = "How long a message should persist when complete"; + type = types.int; + default = 3; + }; + done_icon = mkOption { + description = "Icon shown when LSP progress tasks are completed"; + type = types.str; + default = "✓"; + }; + done_style = mkOption { + description = "Highlight group for completed LSP tasks"; + type = types.str; + default = "Constant"; + }; + progress_ttl = mkOption { + description = "How long a message should persist when in progress"; + type = types.int; + default = 99999; + }; + progress_icon = { + pattern = mkOption { + description = "Pattern shown when LSP progress tasks are in progress"; + type = types.enum [ + "dots" + "dots_negative" + "dots_snake" + "dots_footsteps" + "dots_hop" + "line" + "pipe" + "dots_ellipsis" + "dots_scrolling" + "star" + "flip" + "hamburger" + "grow_vertical" + "grow_horizontal" + "noise" + "dots_bounce" + "triangle" + "arc" + "circle" + "square_corners" + "circle_quarters" + "circle_halves" + "dots_toggle" + "box_toggle" + "arrow" + "zip" + "bouncing_bar" + "bouncing_ball" + "clock" + "earth" + "moon" + "dots_pulse" + "meter" + ]; + default = "dots"; + }; + period = mkOption { + description = "Period of the pattern"; + type = types.int; + default = 1; + }; + }; + progress_style = mkOption { + description = "Highlight group for in-progress LSP tasks"; + type = types.str; + default = "WarningMsg"; + }; + group_style = mkOption { + description = "Highlight group for group name (LSP server name)"; + type = types.str; + default = "Title"; + }; + icon_style = mkOption { + description = "Highlight group for group icons"; + type = types.str; + default = "Question"; + }; + priority = mkOption { + description = "Priority of the progress notification"; + type = types.int; + default = 30; + }; + skip_history = mkOption { + description = "Skip adding messages to history"; + type = types.bool; + default = true; + }; + format_message = mkOption { + description = "How to format a progress message"; + type = types.str; + default = '' + require("fidget.progress.display").default_format_message + ''; + apply = rawLua; + }; + format_annote = mkOption { + description = "How to format a progress annotation"; + type = types.str; + default = '' + function(msg) return msg.title end + ''; + apply = rawLua; + }; + format_group_name = mkOption { + description = "How to format a progress notification group's name"; + type = types.str; + default = '' + function(group) return tostring(group) end + ''; + apply = rawLua; + }; + overrides = mkOption { + description = "Override options from the default notification config"; + type = types.attrsOf types.str; + default = {rust_analyzer = "{ name = 'rust-analyzer' }";}; + apply = mapAttrs (key: lua: rawLua lua); + }; + }; + + lsp = { + progress_ringbuf_size = mkOption { + description = "Nvim's LSP client ring buffer size"; + type = types.int; + default = 100; + }; + log_handler = mkOption { + description = "Log `$/progress` handler invocations"; + type = types.bool; + default = false; + }; + }; + }; + + notification = { + poll_rate = mkOption { + description = "How frequently to update and render notifications"; + type = types.int; + default = 10; + }; + filter = mkOption { + description = "Minimum notifications level"; + type = types.enum ["debug" "info" "warn" "error"]; + default = "info"; + apply = filter: rawLua "vim.log.levels.${toUpper filter}"; + }; + history_size = mkOption { + description = "Number of removed messages to retain in history"; + type = types.int; + default = 128; + }; + override_vim_notify = mkOption { + description = "Automatically override vim.notify() with Fidget"; + type = types.bool; + default = false; + }; + configs = mkOption { + description = "How to configure notification groups when instantiated"; + type = types.attrsOf types.str; + default = {default = "require('fidget.notification').default_config";}; + apply = mapAttrs (key: lua: rawLua lua); + }; + redirect = mkOption { + description = "Conditionally redirect notifications to another backend"; + type = types.str; + default = '' + function(msg, level, opts) + if opts and opts.on_open then + return require("fidget.integration.nvim-notify").delegate(msg, level, opts) + end + end + ''; + apply = rawLua; + }; + + view = { + stack_upwards = mkOption { + description = "Display notification items from bottom to top"; + type = types.bool; + default = true; + }; + icon_separator = mkOption { + description = "Separator between group name and icon"; + type = types.str; + default = " "; + }; + group_separator = mkOption { + description = "Separator between notification groups"; + type = types.str; + default = "---"; + }; + group_separator_hl = mkOption { + description = "Highlight group used for group separator"; + type = types.str; + default = "Comment"; + }; + render_message = mkOption { + description = "How to render notification messages"; + type = types.str; + default = '' + function(msg, cnt) + return cnt == 1 and msg or string.format("(%dx) %s", cnt, msg) + end + ''; + apply = rawLua; + }; + }; + + window = { + normal_hl = mkOption { + description = "Base highlight group in the notification window"; + type = types.str; + default = "Comment"; + }; + winblend = mkOption { + description = "Background color opacity in the notification window"; + type = types.int; + default = 100; + }; + border = mkOption { + description = "Border style of the notification window"; + type = types.enum ["none" "single" "double" "rounded" "solid" "shadow"]; + default = + if config.vim.ui.borders.enable + then config.vim.ui.borders.globalStyle + else "none"; + }; + zindex = mkOption { + description = "Stacking priority of the notification window"; + type = types.int; + default = 45; + }; + max_width = mkOption { + description = "Maximum width of the notification window"; + type = types.int; + default = 0; + }; + max_height = mkOption { + description = "Maximum height of the notification window"; + type = types.int; + default = 0; + }; + x_padding = mkOption { + description = "Padding from right edge of window boundary"; + type = types.int; + default = 1; + }; + y_padding = mkOption { + description = "Padding from bottom edge of window boundary"; + type = types.int; + default = 0; + }; + align = mkOption { + description = "How to align the notification window"; + type = types.enum ["top" "bottom"]; + default = "bottom"; + }; + relative = mkOption { + description = "What the notification window position is relative to"; + type = types.enum ["editor" "win"]; + default = "editor"; + }; + }; + }; + + integration = { + nvim-tree = { + enable = mkOption { + description = "Integrate with nvim-tree/nvim-tree.lua (if enabled)"; + type = types.bool; + default = + if config.vim.filetree.nvimTree.enable + then true + else false; + }; + }; + xcodebuild-nvim = { + enable = mkOption { + description = "Integrate with wojciech-kulik/xcodebuild.nvim (if enabled)"; + type = types.bool; + default = true; + }; + }; + }; + + logger = { + level = mkOption { + description = "Minimum logging level"; + type = types.enum ["debug" "error" "info" "trace" "warn" "off"]; + default = "warn"; + apply = logLevel: rawLua "vim.log.levels.${toUpper logLevel}"; + }; + max_size = mkOption { + description = "Maximum log file size, in KB"; + type = types.int; + default = 10000; + }; + float_precision = mkOption { + description = "Limit the number of decimals displayed for floats"; + type = types.float; + default = 0.01; + }; + path = mkOption { + description = "Where Fidget writes its logs to"; + type = types.str; + default = '' + string.format("%s/fidget.nvim.log", vim.fn.stdpath("cache")) + ''; + apply = rawLua; + }; + }; + }; + }; +} diff --git a/modules/visuals/visuals.nix b/modules/visuals/visuals.nix index 08dc1c31..4fde5885 100644 --- a/modules/visuals/visuals.nix +++ b/modules/visuals/visuals.nix @@ -30,24 +30,6 @@ in { }; }; - fidget-nvim = { - enable = mkEnableOption "nvim LSP UI element [fidget-nvim]"; - - align = { - bottom = mkOption { - type = types.bool; - description = "Align to bottom"; - default = true; - }; - - right = mkOption { - type = types.bool; - description = "Align to right"; - default = true; - }; - }; - }; - cursorline = { enable = mkEnableOption "line hightlighting on the cursor [nvim-cursorline]"; From adde1f08e66688de996ddb8fa3403544dfe33f21 Mon Sep 17 00:00:00 2001 From: Frothy <76622149+FrothyMarrow@users.noreply.github.com> Date: Mon, 19 Feb 2024 01:58:41 -0500 Subject: [PATCH 3/6] docs: add entry for rewritten `fidget.nvim` module --- docs/release-notes/rl-0.6.md | 6 +++++- 1 file changed, 5 insertions(+), 1 deletion(-) diff --git a/docs/release-notes/rl-0.6.md b/docs/release-notes/rl-0.6.md index 01fbe62f..c162ac02 100644 --- a/docs/release-notes/rl-0.6.md +++ b/docs/release-notes/rl-0.6.md @@ -49,6 +49,10 @@ Release notes for release 0.6 - Added rose-pine theme -[frothymarrow](https://github.com/frothymarrow) +[frothymarrow](https://github.com/frothymarrow): - Added option `vim.luaPackages` to wrap neovim with extra Lua packages. + +- Rewrote the entire `fidget.nvim` module to include extensive configuration options. Option `vim.fidget-nvim.align.bottom` has + been removed in favor of [vim.fidget-nvim.notification.window.align](vim.fidget-nvim.notification.window.align), which now supports + `top` and `bottom` values. `vim.fidget-nvim.align.right` has no longer any equivalent and also has been removed. From fc511966f0b97596c315a173c1fa6070493be5a2 Mon Sep 17 00:00:00 2001 From: Frothy <76622149+FrothyMarrow@users.noreply.github.com> Date: Mon, 19 Feb 2024 03:17:01 -0500 Subject: [PATCH 4/6] visuals/fidget: add `mkRemovedOptionModule` for the old configuration options --- modules/visuals/fidget/fidget.nix | 9 ++++++++- 1 file changed, 8 insertions(+), 1 deletion(-) diff --git a/modules/visuals/fidget/fidget.nix b/modules/visuals/fidget/fidget.nix index efa89326..5968d10e 100644 --- a/modules/visuals/fidget/fidget.nix +++ b/modules/visuals/fidget/fidget.nix @@ -3,9 +3,16 @@ lib, ... }: let - inherit (lib) mkEnableOption mkOption mapAttrs toUpper nvim types; + inherit (lib) mkRemovedOptionModule mkEnableOption mkOption mapAttrs toUpper nvim types; rawLua = lua: {__raw = lua;}; in { + imports = [ + (mkRemovedOptionModule ["vim" "visuals" "fidget-nvim" "align" "bottom"] + "Option `vim.fidget-nvim.align.bottom` has been removed in favor of `vim.fidget-nvim.notification.window.align`, which supports the `bottom` value for the same purpose.") + (mkRemovedOptionModule ["vim" "visuals" "fidget-nvim" "align" "right"] + "Option `vim.fidget-nvim.align.right` has been removed and does not have an equivalent replacement in rewritten fidget.nvim configuration.") + ]; + options.vim.visuals.fidget-nvim = { enable = mkEnableOption "nvim LSP UI element [fidget-nvim]"; From 0b9e5e8f37ce5cb046818457587b36d4325d142c Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Mon, 19 Feb 2024 11:10:44 +0100 Subject: [PATCH 5/6] docs: use mkRenamedOptionModule instead of RemovedOption --- modules/visuals/fidget/fidget.nix | 5 ++--- 1 file changed, 2 insertions(+), 3 deletions(-) diff --git a/modules/visuals/fidget/fidget.nix b/modules/visuals/fidget/fidget.nix index 5968d10e..6b88a4b5 100644 --- a/modules/visuals/fidget/fidget.nix +++ b/modules/visuals/fidget/fidget.nix @@ -3,12 +3,11 @@ lib, ... }: let - inherit (lib) mkRemovedOptionModule mkEnableOption mkOption mapAttrs toUpper nvim types; + inherit (lib) mkRemovedOptionModule mkEnableOption mkOption mapAttrs toUpper nvim types mkRenamedOptionModule; rawLua = lua: {__raw = lua;}; in { imports = [ - (mkRemovedOptionModule ["vim" "visuals" "fidget-nvim" "align" "bottom"] - "Option `vim.fidget-nvim.align.bottom` has been removed in favor of `vim.fidget-nvim.notification.window.align`, which supports the `bottom` value for the same purpose.") + (mkRenamedOptionModule ["vim" "visuals" "fidget-nvim" "align" "bottom"] ["vim" "visuals" "fidget-nvim" "setupOpts" "notification" "window" "align"]) (mkRemovedOptionModule ["vim" "visuals" "fidget-nvim" "align" "right"] "Option `vim.fidget-nvim.align.right` has been removed and does not have an equivalent replacement in rewritten fidget.nvim configuration.") ]; From 055fcb4f571bfbe2efc726bf1eaaa996ee550338 Mon Sep 17 00:00:00 2001 From: Frothy <76622149+FrothyMarrow@users.noreply.github.com> Date: Mon, 19 Feb 2024 16:15:18 -0500 Subject: [PATCH 6/6] visuals/fidget: fix plugin setupOpts name --- modules/visuals/fidget/fidget.nix | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/modules/visuals/fidget/fidget.nix b/modules/visuals/fidget/fidget.nix index 6b88a4b5..173cfd8d 100644 --- a/modules/visuals/fidget/fidget.nix +++ b/modules/visuals/fidget/fidget.nix @@ -15,7 +15,7 @@ in { options.vim.visuals.fidget-nvim = { enable = mkEnableOption "nvim LSP UI element [fidget-nvim]"; - setupOpts = nvim.types.mkPluginSetupOption "Nvim Tree" { + setupOpts = nvim.types.mkPluginSetupOption "Fidget" { progress = { poll_rate = mkOption { description = "How frequently to poll for LSP progress messages";