aboutsummaryrefslogtreecommitdiffstats
path: root/hm/soispha/conf/nvim/plgs/telescope
diff options
context:
space:
mode:
authorSoispha <soispha@vhack.eu>2023-08-29 21:33:43 +0200
committerSoispha <soispha@vhack.eu>2023-08-29 21:33:43 +0200
commit3925f6ee04f09d7d09b7aff018812670a0e89492 (patch)
tree12642e7332ebb53153bef1bf5d5f811e3f19884b /hm/soispha/conf/nvim/plgs/telescope
parentFeat(hm/conf/nvim/plgs/debugprint): Init (diff)
downloadnixos-config-3925f6ee04f09d7d09b7aff018812670a0e89492.zip
Refactor(hm/conf/nvim/plugins): Rename to `plgs` to safe commit msg space
Diffstat (limited to 'hm/soispha/conf/nvim/plgs/telescope')
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/default.nix10
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/defaults/default.nix30
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/extensions/bibtex/default.nix13
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/extensions/default.nix9
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/extensions/frecency/default.nix22
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/extensions/fzy-native/default.nix5
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/default.nix7
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua/rooter.lua84
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/extensions/symbols/default.nix51
-rw-r--r--hm/soispha/conf/nvim/plgs/telescope/keymaps/default.nix8
10 files changed, 239 insertions, 0 deletions
diff --git a/hm/soispha/conf/nvim/plgs/telescope/default.nix b/hm/soispha/conf/nvim/plgs/telescope/default.nix
new file mode 100644
index 00000000..b5054ed0
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/default.nix
@@ -0,0 +1,10 @@
+{...}: {
+ imports = [
+ ./defaults
+ ./keymaps
+ ./extensions
+ ];
+ programs.nixvim.plugins.telescope = {
+ enable = true;
+ };
+}
diff --git a/hm/soispha/conf/nvim/plgs/telescope/defaults/default.nix b/hm/soispha/conf/nvim/plgs/telescope/defaults/default.nix
new file mode 100644
index 00000000..1d88aad8
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/defaults/default.nix
@@ -0,0 +1,30 @@
+{...}: {
+ programs.nixvim.plugins.telescope.defaults = {
+ mappings = let
+ insert_and_normal_mappings = {
+ # map actions.which_key to <c-h> (default: <c-/>)
+ # actions.which_key shows the mappings for your picker,
+ # e.g. git_{create, delete, ...}_branch for the git_branches picker
+ "<C-h>" = "which_key";
+ };
+ in {
+ i =
+ insert_and_normal_mappings;
+ n =
+ {
+ "t" = "move_selection_next";
+ "n" = "move_selection_previous";
+ "<Space>" = "toggle_all";
+
+ "<C-d>" = "preview_scrolling_up";
+ "<C-u>" = "preview_scrolling_down";
+ "<Left>" = "preview_scrolling_left";
+ "<Right>" = "preview_scrolling_right";
+
+ "<Esc>" = "close";
+ "q" = "close";
+ }
+ // insert_and_normal_mappings;
+ };
+ };
+}
diff --git a/hm/soispha/conf/nvim/plgs/telescope/extensions/bibtex/default.nix b/hm/soispha/conf/nvim/plgs/telescope/extensions/bibtex/default.nix
new file mode 100644
index 00000000..12c9736c
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/extensions/bibtex/default.nix
@@ -0,0 +1,13 @@
+{pkgs, ...}: {
+ # WARNING: This is only activated in tex files via the ftplugin.
+ programs.nixvim = {
+ extraPlugins = [
+ pkgs.vimExtraPlugins.telescope-bibtex-nvim
+ ];
+ maps.normal = {
+ "<space>ib" = {
+ desc = "[i]nsert a [b]atex citation";
+ };
+ };
+ };
+}
diff --git a/hm/soispha/conf/nvim/plgs/telescope/extensions/default.nix b/hm/soispha/conf/nvim/plgs/telescope/extensions/default.nix
new file mode 100644
index 00000000..0b1e033a
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/extensions/default.nix
@@ -0,0 +1,9 @@
+{...}: {
+ imports = [
+ ./bibtex
+ ./frecency
+ ./fzy-native
+ ./rooter
+ ./symbols
+ ];
+}
diff --git a/hm/soispha/conf/nvim/plgs/telescope/extensions/frecency/default.nix b/hm/soispha/conf/nvim/plgs/telescope/extensions/frecency/default.nix
new file mode 100644
index 00000000..4a4c22be
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/extensions/frecency/default.nix
@@ -0,0 +1,22 @@
+{...}: {
+ programs.nixvim = {
+ maps = {
+ normal = {
+ "gff" = {
+ action = "function() require('telescope').extensions.frecency.frecency() end";
+ lua = true;
+ desc = "activate the frecency file selection";
+ };
+ };
+ };
+ plugins.telescope = {
+ extensions.frecency = {
+ enable = true;
+ showUnindexed = true;
+ showScores = true;
+ # TODO: add this:
+ #db_safe_mode = true;
+ };
+ };
+ };
+}
diff --git a/hm/soispha/conf/nvim/plgs/telescope/extensions/fzy-native/default.nix b/hm/soispha/conf/nvim/plgs/telescope/extensions/fzy-native/default.nix
new file mode 100644
index 00000000..ce0bdccc
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/extensions/fzy-native/default.nix
@@ -0,0 +1,5 @@
+{...}: {
+ programs.nixvim.plugins.telescope.extensions.fzy-native = {
+ enable = true;
+ };
+}
diff --git a/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/default.nix b/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/default.nix
new file mode 100644
index 00000000..779448cc
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/default.nix
@@ -0,0 +1,7 @@
+{lib, ...}: {
+ programs.nixvim = {
+ extraConfigLuaPost = ''
+ ${lib.strings.fileContents ./lua/rooter.lua}
+ '';
+ };
+}
diff --git a/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua/rooter.lua b/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua/rooter.lua
new file mode 100644
index 00000000..eaf68ecf
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/extensions/rooter/lua/rooter.lua
@@ -0,0 +1,84 @@
+-- Taken from: https://github.com/desdic/telescope-rooter.nvim/blob/69423216c75a5f1f1477bbf8faf6b0dc8af04099/lua/telescope/_extensions/rooter.lua
+local has_telescope, telescope = pcall(require, "telescope")
+if not has_telescope then
+ error("This extension requires telescope.nvim")
+ return
+end
+
+local has_plenary, plenary = pcall(require, "plenary")
+if not has_plenary then
+ error("This extension requires plenary")
+ return
+end
+
+local log = plenary.log.new({ plugin = "telescope_rooter"; level = "info"; })
+
+-- TODO: expose this function
+local toggle = function(_)
+ vim.g["Telescope#rooter#enabled"] = not vim.g["Telescope#rooter#enabled"]
+ print("Telescope#rooter#enabled=" .. vim.inspect(vim.g["Telescope#rooter#enabled"]))
+end
+
+local config = { patterns = { ".git"; }; enable = true; debug = false; }
+
+-- default enabled
+vim.g["Telescope#rooter#enabled"] = vim.F.if_nil(config.enable, true)
+
+-- redefine log if debug enabled
+if vim.F.if_nil(config.debug, false) then
+ log = plenary.log.new({ plugin = "telescope_rooter"; level = "debug"; })
+end
+
+local group = vim.api.nvim_create_augroup("TelescopeRooter", { clear = true; })
+
+vim.api.nvim_create_autocmd({ "DirChangedPre"; }, {
+ callback = function()
+ if vim.g["Telescope#rooter#enabled"] ~= true then
+ return
+ end
+
+ if vim.g["Telescope#rooter#oldpwd"] == nil then
+ vim.g["Telescope#rooter#oldpwd"] = vim.loop.cwd()
+ log.debug("before " .. vim.inspect(vim.loop.cwd()))
+ end
+ end;
+ group = group;
+})
+
+vim.api.nvim_create_autocmd({ "BufEnter"; "BufWinEnter"; }, {
+ callback = function()
+ if vim.g["Telescope#rooter#enabled"] ~= true then
+ return
+ end
+
+ vim.schedule(function()
+ if vim.bo.filetype == "TelescopePrompt" then
+ local rootdir = vim.fs.dirname(vim.fs.find(config.patterns, { upward = true; })[1])
+ if rootdir ~= nil then
+ vim.api.nvim_set_current_dir(rootdir)
+ log.debug("changing dir to " .. rootdir)
+ end
+ end
+ end)
+ end;
+ group = group;
+})
+
+vim.api.nvim_create_autocmd({ "BufWinLeave"; }, {
+ callback = function()
+ if vim.g["Telescope#rooter#enabled"] ~= true then
+ return
+ end
+
+ vim.schedule(function()
+ if vim.bo.filetype ~= "TelescopePrompt" then
+ if vim.g["Telescope#rooter#oldpwd"] ~= nil then
+ log.debug("restoring " .. vim.g["Telescope#rooter#oldpwd"])
+ vim.api.nvim_set_current_dir(vim.g["Telescope#rooter#oldpwd"])
+ vim.g["Telescope#rooter#oldpwd"] = nil
+ end
+ end
+ end)
+ end;
+ group = group;
+})
diff --git a/hm/soispha/conf/nvim/plgs/telescope/extensions/symbols/default.nix b/hm/soispha/conf/nvim/plgs/telescope/extensions/symbols/default.nix
new file mode 100644
index 00000000..fe38f8c1
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/extensions/symbols/default.nix
@@ -0,0 +1,51 @@
+{pkgs, ...}: {
+ programs.nixvim = {
+ extraPlugins = [
+ # Source of symbols for telescope symbols
+ pkgs.vimPlugins.telescope-symbols-nvim
+ ];
+ maps = {
+ normal = {
+ "<space>il" = {
+ action = ''
+ function()
+ require('telescope.builtin').symbols{ sources = {
+ 'latex'
+ }}
+ end
+ '';
+ lua = true;
+ desc = "[i]nsert a [l]atex symbol";
+ };
+ "<space>ie" = {
+ action = ''
+ function()
+ require('telescope.builtin').symbols{ sources = {
+ 'emoji',
+ }}
+ end
+ '';
+ lua = true;
+ desc = "[i]nsert a [e]moji";
+ };
+ "<space>is" = {
+ action = ''
+ function()
+ require('telescope.builtin').symbols{ sources = {
+ 'emoji',
+ 'gitmoji',
+ 'julia',
+ 'kaomoji',
+ 'latex',
+ 'math',
+ 'nerd',
+ }}
+ end
+ '';
+ lua = true;
+ desc = "[i]nsert a [s]ymbol (like emojis)";
+ };
+ };
+ };
+ };
+}
diff --git a/hm/soispha/conf/nvim/plgs/telescope/keymaps/default.nix b/hm/soispha/conf/nvim/plgs/telescope/keymaps/default.nix
new file mode 100644
index 00000000..f0745f73
--- /dev/null
+++ b/hm/soispha/conf/nvim/plgs/telescope/keymaps/default.nix
@@ -0,0 +1,8 @@
+{...}: {
+ programs.nixvim.plugins.telescope.keymaps = {
+ "<space>rg" = {
+ action = "live_grep";
+ desc = "[rg] in a live session";
+ };
+ };
+}