From 9f8626d2e16837c62305644d3a591d500ee5f531 Mon Sep 17 00:00:00 2001 From: Ching Pei Yang Date: Wed, 3 Jan 2024 00:55:32 +0100 Subject: [PATCH] feat(telescope): add custom setup options --- modules/utility/telescope/config.nix | 49 +------------------- modules/utility/telescope/telescope.nix | 60 ++++++++++++++++++++++++- 2 files changed, 60 insertions(+), 49 deletions(-) diff --git a/modules/utility/telescope/config.nix b/modules/utility/telescope/config.nix index 53cde9676..0536aa31c 100644 --- a/modules/utility/telescope/config.nix +++ b/modules/utility/telescope/config.nix @@ -7,7 +7,7 @@ inherit (lib) addDescriptionsToMappings mkIf mkMerge mkSetBinding nvim; cfg = config.vim.telescope; - self = import ./telescope.nix {inherit lib;}; + self = import ./telescope.nix {inherit pkgs lib;}; mappingDefinitions = self.options.vim.telescope.mappings; mappings = addDescriptionsToMappings cfg.mappings mappingDefinitions; @@ -54,52 +54,7 @@ in { vim.luaConfigRC.telescope = nvim.dag.entryAnywhere '' local telescope = require('telescope') - telescope.setup { - defaults = { - vimgrep_arguments = { - "${pkgs.ripgrep}/bin/rg", - "--color=never", - "--no-heading", - "--with-filename", - "--line-number", - "--column", - "--smart-case", - "--hidden", - "--no-ignore", - }, - pickers = { - find_command = { - "${pkgs.fd}/bin/fd", - }, - }, - }, - prompt_prefix = "  ", - selection_caret = " ", - entry_prefix = " ", - initial_mode = "insert", - selection_strategy = "reset", - sorting_strategy = "ascending", - layout_strategy = "horizontal", - layout_config = { - horizontal = { - prompt_position = "top", - preview_width = 0.55, - results_width = 0.8, - }, - vertical = { - mirror = false, - }, - width = 0.8, - height = 0.8, - preview_cutoff = 120, - }, - file_ignore_patterns = { "node_modules", ".git/", "dist/", "build/", "target/", "result/" }, -- TODO: make this configurable - color_devicons = true, - path_display = { "absolute" }, - set_env = { ["COLORTERM"] = "truecolor" }, - winblend = 0, - border = {}, - } + telescope.setup(${nvim.lua.toLuaObject cfg.setupOpts}) ${ if config.vim.ui.noice.enable diff --git a/modules/utility/telescope/telescope.nix b/modules/utility/telescope/telescope.nix index 12ea88785..7c3c73f0d 100644 --- a/modules/utility/telescope/telescope.nix +++ b/modules/utility/telescope/telescope.nix @@ -1,5 +1,59 @@ -{lib, ...}: let - inherit (lib) mkMappingOption mkEnableOption; +{ + pkgs, + lib, + ... +}: let + inherit (lib) mkMappingOption mkEnableOption types mkOption nvim; + mkOptOfType = type: default: + mkOption { + # TODO: description + description = "See plugin docs for more info"; + inherit type default; + }; + + setupOptions = { + defaults = { + vimgrep_arguments = mkOptOfType (with types; listOf str) [ + "${pkgs.ripgrep}/bin/rg" + "--color=never" + "--no-heading" + "--with-filename" + "--line-number" + "--column" + "--smart-case" + "--hidden" + "--no-ignore" + ]; + pickers.find_command = mkOptOfType (with types; listOf str) ["${pkgs.fd}/bin/fd"]; + prompt_prefix = mkOptOfType types.str "  "; + selection_caret = mkOptOfType types.str " "; + entry_prefix = mkOptOfType types.str " "; + initial_mode = mkOptOfType types.str "insert"; + selection_strategy = mkOptOfType types.str "reset"; + sorting_strategy = mkOptOfType types.str "ascending"; + layout_strategy = mkOptOfType types.str "horizontal"; + layout_config = { + horizontal = { + prompt_position = mkOptOfType types.str "top"; + preview_width = mkOptOfType types.float 0.55; + results_width = mkOptOfType types.float 0.8; + }; + vertical = { + mirror = mkOptOfType types.bool false; + }; + width = mkOptOfType types.float 0.8; + height = mkOptOfType types.float 0.8; + preview_cutoff = mkOptOfType types.int 120; + }; + file_ignore_patterns = mkOptOfType (types.listOf types.str) ["node_modules" ".git/" "dist/" "build/" "target/" "result/"]; + color_devicons = mkOptOfType types.bool true; + path_display = mkOptOfType (types.listOf types.str) ["absolute"]; + set_env = { + COLORTERM = mkOptOfType types.str "truecolor"; + }; + winblend = mkOptOfType types.int 0; + }; + }; in { options.vim.telescope = { mappings = { @@ -29,5 +83,7 @@ in { }; enable = mkEnableOption "telescope.nvim: multi-purpose search and picker utility"; + + setupOpts = nvim.types.mkPluginSetupOption "Telescope" setupOptions; }; }