From ff148de47539eef2c49eb641f7f4de480c70d690 Mon Sep 17 00:00:00 2001 From: NotAShelf Date: Thu, 26 Oct 2023 15:03:58 +0300 Subject: [PATCH] modules/lsp: add nvim-docs-view A neovim plugin to display lsp hover documentation in a side panel. --- configuration.nix | 1 + flake.lock | 17 ++++++++ flake.nix | 29 +++++++------ lib/types/plugins.nix | 1 + modules/lsp/default.nix | 1 + modules/lsp/nvim-docs-view/config.nix | 26 ++++++++++++ modules/lsp/nvim-docs-view/default.nix | 6 +++ modules/lsp/nvim-docs-view/nvim-docs-view.nix | 41 +++++++++++++++++++ 8 files changed, 110 insertions(+), 12 deletions(-) create mode 100644 modules/lsp/nvim-docs-view/config.nix create mode 100644 modules/lsp/nvim-docs-view/default.nix create mode 100644 modules/lsp/nvim-docs-view/nvim-docs-view.nix diff --git a/configuration.nix b/configuration.nix index 2fdf65546..0864fed82 100644 --- a/configuration.nix +++ b/configuration.nix @@ -38,6 +38,7 @@ inputs: let trouble.enable = true; lspSignature.enable = true; lsplines.enable = isMaximal; + nvim-docs-view.enable = isMaximal; }; vim.debugger = { diff --git a/flake.lock b/flake.lock index 37b6d5684..48592e7dd 100644 --- a/flake.lock +++ b/flake.lock @@ -1108,6 +1108,22 @@ "type": "github" } }, + "nvim-docs-view": { + "flake": false, + "locked": { + "lastModified": 1697737319, + "narHash": "sha256-EmQbnleqxE+VHO5bMI9U/gMpwbJbPdNhrEWE7357MCE=", + "owner": "amrbashir", + "repo": "nvim-docs-view", + "rev": "74a5e989e3fdcfd9418bb9dfec0ace308e00a5a0", + "type": "github" + }, + "original": { + "owner": "amrbashir", + "repo": "nvim-docs-view", + "type": "github" + } + }, "nvim-lightbulb": { "flake": false, "locked": { @@ -1511,6 +1527,7 @@ "nvim-cursorline": "nvim-cursorline", "nvim-dap": "nvim-dap", "nvim-dap-ui": "nvim-dap-ui", + "nvim-docs-view": "nvim-docs-view", "nvim-lightbulb": "nvim-lightbulb", "nvim-lspconfig": "nvim-lspconfig", "nvim-navbuddy": "nvim-navbuddy", diff --git a/flake.nix b/flake.nix index ca96dda64..9196ec8b2 100644 --- a/flake.nix +++ b/flake.nix @@ -116,6 +116,12 @@ flake = false; }; + nvim-docs-view = { + url = "github:amrbashir/nvim-docs-view"; + flake = false; + }; + + # language support sqls-nvim = { url = "github:nanotee/sqls.nvim"; flake = false; @@ -146,6 +152,17 @@ flake = false; }; + glow-nvim = { + url = "github:ellisonleao/glow.nvim"; + flake = false; + }; + + # Tidal cycles + tidalcycles = { + url = "github:mitchmindtree/tidalcycles.nix"; + inputs.vim-tidal-src.url = "github:tidalcycles/vim-tidal"; + }; + # Copying/Registers registers = { url = "github:tversteeg/registers.nvim"; @@ -373,18 +390,6 @@ flake = false; }; - # Markdown - glow-nvim = { - url = "github:ellisonleao/glow.nvim"; - flake = false; - }; - - # Tidal cycles - tidalcycles = { - url = "github:mitchmindtree/tidalcycles.nix"; - inputs.vim-tidal-src.url = "github:tidalcycles/vim-tidal"; - }; - # Minimap minimap-vim = { url = "github:wfxr/minimap.vim"; diff --git a/lib/types/plugins.nix b/lib/types/plugins.nix index dcc5f79ba..344c40577 100644 --- a/lib/types/plugins.nix +++ b/lib/types/plugins.nix @@ -95,6 +95,7 @@ with lib; let "lsp-lines" "vim-dirtytalk" "highlight-undo" + "nvim-docs-view" ]; # You can either use the name of the plugin or a package. pluginType = with types; diff --git a/modules/lsp/default.nix b/modules/lsp/default.nix index e39e33afc..9a70efc6f 100644 --- a/modules/lsp/default.nix +++ b/modules/lsp/default.nix @@ -16,5 +16,6 @@ _: { ./lightbulb ./lspkind ./lsplines + ./nvim-docs-view ]; } diff --git a/modules/lsp/nvim-docs-view/config.nix b/modules/lsp/nvim-docs-view/config.nix new file mode 100644 index 000000000..1cbb37a0a --- /dev/null +++ b/modules/lsp/nvim-docs-view/config.nix @@ -0,0 +1,26 @@ +{ + config, + lib, + ... +}: let + inherit (lib) mkIf nvim; + inherit (builtins) toString; + + cfg = config.vim.lsp.nvim-docs-view; +in { + config = mkIf cfg.enable { + vim = { + lsp.enable = true; + startPlugins = ["nvim-docs-view"]; + + luaConfigRC.nvim-docs-view = nvim.dag.entryAnywhere '' + require("docs-view").setup { + position = "${cfg.position}", + width = ${toString cfg.width}, + height = ${toString cfg.height}, + update_mode = "${cfg.updateMode}", + } + ''; + }; + }; +} diff --git a/modules/lsp/nvim-docs-view/default.nix b/modules/lsp/nvim-docs-view/default.nix new file mode 100644 index 000000000..499ec39b3 --- /dev/null +++ b/modules/lsp/nvim-docs-view/default.nix @@ -0,0 +1,6 @@ +_: { + imports = [ + ./config.nix + ./nvim-docs-view.nix + ]; +} diff --git a/modules/lsp/nvim-docs-view/nvim-docs-view.nix b/modules/lsp/nvim-docs-view/nvim-docs-view.nix new file mode 100644 index 000000000..acbc1c409 --- /dev/null +++ b/modules/lsp/nvim-docs-view/nvim-docs-view.nix @@ -0,0 +1,41 @@ +{lib, ...}: let + inherit (lib) mkEnableOption mkOption types; +in { + options.vim.lsp.nvim-docs-view = { + enable = mkEnableOption "nvim-docs-view, for displaying lsp hover documentation in a side panel."; + + position = mkOption { + type = types.enum ["left" "right" "top" "bottom"]; + default = "right"; + description = '' + Where to open the docs view panel + ''; + }; + + height = mkOption { + type = types.int; + default = 10; + description = '' + Height of the docs view panel if the position is set to either top or bottom + ''; + }; + + width = mkOption { + type = types.int; + default = 60; + description = '' + Width of the docs view panel if the position is set to either left or right + ''; + }; + + updateMode = mkOption { + type = types.enum ["auto" "manual"]; + default = "auto"; + description = '' + Determines the mechanism used to update the docs view panel content. + - If auto, the content will update upon cursor move. + - If manual, the content will only update once :DocsViewUpdate is called + ''; + }; + }; +}