diff options
Diffstat (limited to 'lua')
-rw-r--r-- | lua/default-config.lua | 3 | ||||
-rw-r--r-- | lua/lsp/efm-general-ls.lua | 58 | ||||
-rw-r--r-- | lua/lsp/ts-fmt-lint.lua | 66 | ||||
-rw-r--r-- | lua/lv-dashboard/init.lua | 2 | ||||
-rw-r--r-- | lua/lv-which-key/init.lua | 3 |
5 files changed, 71 insertions, 61 deletions
diff --git a/lua/default-config.lua b/lua/default-config.lua index 83ff1cc2..7a26f242 100644 --- a/lua/default-config.lua +++ b/lua/default-config.lua @@ -150,7 +150,8 @@ O = { underline = true, }, cross_file_rename = true, - header_insertion = 'never' + header_insertion = 'never', + autoformat = false -- update this to true for enabling autoformat }, ruby = { diagnostics = { diff --git a/lua/lsp/efm-general-ls.lua b/lua/lsp/efm-general-ls.lua deleted file mode 100644 index 8b4b8449..00000000 --- a/lua/lsp/efm-general-ls.lua +++ /dev/null @@ -1,58 +0,0 @@ --- Example configuations here: https://github.com/mattn/efm-langserver - --- tsserver/web javascript react, vue, json, html, css, yaml -local prettier = {formatCommand = "prettier --stdin-filepath ${INPUT}", formatStdin = true} --- You can look for project scope Prettier and Eslint with e.g. vim.fn.glob("node_modules/.bin/prettier") etc. If it is not found revert to global Prettier where needed. --- local prettier = {formatCommand = "./node_modules/.bin/prettier --stdin-filepath ${INPUT}", formatStdin = true} - -local eslint = { - lintCommand = "./node_modules/.bin/eslint -f unix --stdin --stdin-filename ${INPUT}", - lintIgnoreExitCode = true, - lintStdin = true, - lintFormats = {"%f:%l:%c: %m"}, - formatCommand = "./node_modules/.bin/eslint --fix-to-stdout --stdin --stdin-filename=${INPUT}", - formatStdin = true -} - -local tsserver_args = {} - -if O.lang.tsserver.formatter == 'prettier' then table.insert(tsserver_args, prettier) end - -if O.lang.tsserver.linter == 'eslint' then table.insert(tsserver_args, eslint) end - --- local markdownlint = { --- -- TODO default to global lintrc --- -- lintcommand = 'markdownlint -s -c ./markdownlintrc', --- lintCommand = 'markdownlint -s', --- lintStdin = true, --- lintFormats = {'%f:%l %m', '%f:%l:%c %m', '%f: %l: %m'} --- } - -local markdownPandocFormat = {formatCommand = 'pandoc -f markdown -t gfm -sp --tab-stop=2', formatStdin = true} - -require"lspconfig".efm.setup { - -- init_options = {initializationOptions}, - cmd = {DATA_PATH .. "/lspinstall/efm/efm-langserver"}, - init_options = {documentFormatting = true, codeAction = false}, - filetypes = {"lua", "python", "javascriptreact", "javascript", "typescript","typescriptreact","sh", "html", "css", "yaml", "markdown", "vue"}, - settings = { - rootMarkers = {".git/"}, - languages = { - javascript = tsserver_args, - javascriptreact = tsserver_args, - typescript = tsserver_args, - typescriptreact = tsserver_args, - html = {prettier}, - css = {prettier}, - json = {prettier}, - yaml = {prettier}, - markdown = {markdownPandocFormat} - -- javascriptreact = {prettier, eslint}, - -- javascript = {prettier, eslint}, - -- markdown = {markdownPandocFormat, markdownlint}, - } - } -} - --- Also find way to toggle format on save --- maybe this will help: https://superuser.com/questions/439078/how-to-disable-autocmd-or-augroup-in-vim diff --git a/lua/lsp/ts-fmt-lint.lua b/lua/lsp/ts-fmt-lint.lua new file mode 100644 index 00000000..3ca97d71 --- /dev/null +++ b/lua/lsp/ts-fmt-lint.lua @@ -0,0 +1,66 @@ +-- Example configuations here: https://github.com/mattn/efm-langserver +-- You can look for project scope Prettier and Eslint with e.g. vim.fn.glob("node_modules/.bin/prettier") etc. If it is not found revert to global Prettier where needed. +local M = {} + +M.setup = function() + local tsserver_args = {} + + local prettier = { + formatCommand = "prettier --stdin-filepath ${INPUT}", + formatStdin = true + } + + if vim.fn.glob("node_modules/.bin/prettier") then + prettier = { + formatCommand = "./node_modules/.bin/prettier --stdin-filepath ${INPUT}", + formatStdin = true + } + end + + -- TODO global eslint? + + local eslint = { + lintCommand = "./node_modules/.bin/eslint -f unix --stdin --stdin-filename ${INPUT}", + lintIgnoreExitCode = true, + lintStdin = true, + lintFormats = {"%f:%l:%c: %m"}, + -- formatCommand = "./node_modules/.bin/eslint -f unix --fix --stdin-filename ${INPUT}", -- TODO check if eslint is the formatter then add this + formatStdin = true + } + + if O.lang.tsserver.formatter == 'prettier' then + table.insert(tsserver_args, prettier) + end + + if O.lang.tsserver.linter == 'eslint' then + table.insert(tsserver_args, eslint) + end + + require"lspconfig".efm.setup { + -- init_options = {initializationOptions}, + cmd = {DATA_PATH .. "/lspinstall/efm/efm-langserver"}, + init_options = {documentFormatting = true, codeAction = false}, + filetypes = { + "javascriptreact", "javascript", "typescript", "typescriptreact", + "html", "css", "yaml", "vue" + }, + settings = { + rootMarkers = {".git/", "package.json"}, + languages = { + javascript = tsserver_args, + javascriptreact = tsserver_args, + typescript = tsserver_args, + typescriptreact = tsserver_args, + html = {prettier}, + css = {prettier}, + json = {prettier}, + yaml = {prettier} + -- javascriptreact = {prettier, eslint}, + -- javascript = {prettier, eslint}, + -- markdown = {markdownPandocFormat, markdownlint}, + } + } + } +end + +return M diff --git a/lua/lv-dashboard/init.lua b/lua/lv-dashboard/init.lua index e577fdc3..99fcb10f 100644 --- a/lua/lv-dashboard/init.lua +++ b/lua/lv-dashboard/init.lua @@ -30,7 +30,7 @@ M.config = function() }, f = { description = {' Neovim Config Files'}, - command = 'lua require(\'telescope.builtin\').find_files({search_dirs = {"~/.config/nvim"}})' + command = 'Telescope find_files cwd=' .. CONFIG_PATH } -- e = {description = {' Marks '}, command = 'Telescope marks'} } diff --git a/lua/lv-which-key/init.lua b/lua/lv-which-key/init.lua index 3af04edf..88dd2ef0 100644 --- a/lua/lv-which-key/init.lua +++ b/lua/lv-which-key/init.lua @@ -213,7 +213,8 @@ local mappings = { r = {"<cmd>Lspsaga rename<cr>", "Rename"}, t = {"<cmd>LspTypeDefinition<cr>", "Type Definition"}, x = {"<cmd>cclose<cr>", "Close Quickfix"}, - s = {"<cmd>Telescope lsp_document_symbols<cr>", "Document Symbols"}, + s = {O.plugin.symbol_outline.active and "<cmd>SymbolsOutline<cr>" or + "<cmd> Telescope lsp_document_symbols<cr>", "Document Symbols"}, S = { "<cmd>Telescope lsp_dynamic_workspace_symbols<cr>", "Workspace Symbols" |