Release (#254)
- fix: an autocommand issue when creating an MR - feat: adds a keybinding for copying the URL of the current discussion to the system clipboard This is a #MINOR release
This commit is contained in:
committed by
GitHub
parent
7c3ee0530b
commit
49f2451e59
@@ -149,6 +149,7 @@ require("gitlab").setup({
|
||||
toggle_resolved = "p" -- Toggles the resolved status of the whole discussion
|
||||
position = "left", -- "top", "right", "bottom" or "left"
|
||||
open_in_browser = "b" -- Jump to the URL of the current note/discussion
|
||||
copy_node_url = "u", -- Copy the URL of the current node to clipboard
|
||||
size = "20%", -- Size of split
|
||||
relative = "editor", -- Position of tree split relative to "editor" or "window"
|
||||
resolved = '✓', -- Symbol to show next to resolved discussions
|
||||
|
||||
@@ -173,6 +173,7 @@ you call this function with no values the defaults will be used:
|
||||
toggle_resolved = "p" -- Toggles the resolved status of the whole discussion
|
||||
position = "left", -- "top", "right", "bottom" or "left"
|
||||
open_in_browser = "b" -- Jump to the URL of the current note/discussion
|
||||
copy_node_url = "u", -- Copy the URL of the current node to clipboard
|
||||
size = "20%", -- Size of split
|
||||
relative = "editor", -- Position of tree split relative to "editor" or "window"
|
||||
resolved = '✓', -- Symbol to show next to resolved discussions
|
||||
@@ -551,7 +552,7 @@ you can also interact with the Go server like any other process:
|
||||
LUA API *gitlab.nvim.api*
|
||||
|
||||
*gitlab.nvim.setup*
|
||||
setup() ~
|
||||
gitlab.setup() ~
|
||||
|
||||
Call this first to initialize the plugin. With no arguments, it will use the
|
||||
default arguments outlined under "Configuring the Plugin".
|
||||
@@ -563,7 +564,7 @@ default arguments outlined under "Configuring the Plugin".
|
||||
require("gitlab").setup({ discussion_tree = { blacklist = { "some_bot"} } })
|
||||
<
|
||||
*gitlab.nvim.review*
|
||||
review() ~
|
||||
gitlab.review() ~
|
||||
|
||||
Opens the reviewer pane. Can be used from anywhere within Neovim after the
|
||||
plugin is loaded. If run twice, will open a second reviewer pane.
|
||||
@@ -571,7 +572,7 @@ plugin is loaded. If run twice, will open a second reviewer pane.
|
||||
require("gitlab").review()
|
||||
<
|
||||
*gitlab.nvim.summary*
|
||||
summary() ~
|
||||
gitlab.summary() ~
|
||||
|
||||
Opens the summary window with information about the current MR, such as the
|
||||
description, the author, and the title. Can be configured via the `info` field
|
||||
@@ -583,7 +584,7 @@ The summary can be edited. Once you have made changes, send them to Gitlab via
|
||||
the `settings.popup.perform_action` keybinding.
|
||||
|
||||
*gitlab.nvim.approve*
|
||||
approve() ~
|
||||
gitlab.approve() ~
|
||||
|
||||
Approves the current MR. Will error if the current user does not have
|
||||
permission.
|
||||
@@ -604,13 +605,13 @@ gitlab.create_comment() ~
|
||||
Opens a popup to create a comment on the current line. Must be called when focused on the
|
||||
reviewer pane (see the gitlab.nvim.review command), otherwise it will error.
|
||||
>lua
|
||||
require("gitlab").comment()
|
||||
require("gitlab").create_comment()
|
||||
|
||||
After the comment is typed, submit it to Gitlab via the `settings.popup.perform_action`
|
||||
keybinding, by default `<leader>l`.
|
||||
|
||||
*gitlab.nvim.create_multiline_comment*
|
||||
create_multiline_comment() ~
|
||||
gitlab.create_multiline_comment() ~
|
||||
|
||||
Opens a popup to create a multi-line comment. May only be called in visual
|
||||
mode, and will use the currently selected lines.
|
||||
@@ -621,7 +622,7 @@ After the comment is typed, submit it to Gitlab via the |settings.popup.perform_
|
||||
keybinding, by default `<leader>l`.
|
||||
|
||||
*gitlab.nvim.create_comment_suggestion*
|
||||
create_comment_suggestion() ~
|
||||
gitlab.create_comment_suggestion() ~
|
||||
|
||||
Opens a popup to create a comment suggestion (aka a comment that makes a committable
|
||||
change suggestion to the currently selected lines).
|
||||
|
||||
@@ -837,6 +837,9 @@ M.set_tree_keymaps = function(tree, bufnr, unlinked)
|
||||
vim.keymap.set("n", state.settings.discussion_tree.open_in_browser, function()
|
||||
M.open_in_browser(tree)
|
||||
end, { buffer = bufnr, desc = "Open the note in your browser" })
|
||||
vim.keymap.set("n", state.settings.discussion_tree.copy_node_url, function()
|
||||
M.copy_node_url(tree)
|
||||
end, { buffer = bufnr, desc = "Copy the URL of the current node to clipboard" })
|
||||
vim.keymap.set("n", "<leader>p", function()
|
||||
M.print_node(tree)
|
||||
end, { buffer = bufnr, desc = "Print current node (for debugging)" })
|
||||
@@ -953,7 +956,7 @@ M.add_reply_to_tree = function(tree, note, discussion_id)
|
||||
end
|
||||
|
||||
---@param tree NuiTree
|
||||
M.open_in_browser = function(tree)
|
||||
M.get_url = function(tree)
|
||||
local current_node = tree:get_node()
|
||||
local note_node = M.get_note_node(tree, current_node)
|
||||
if note_node == nil then
|
||||
@@ -964,10 +967,28 @@ M.open_in_browser = function(tree)
|
||||
u.notify("Could not get URL of note", vim.log.levels.ERROR)
|
||||
return
|
||||
end
|
||||
return url
|
||||
end
|
||||
|
||||
---@param tree NuiTree
|
||||
M.open_in_browser = function(tree)
|
||||
local url = M.get_url(tree)
|
||||
if url == nil then
|
||||
return
|
||||
end
|
||||
u.open_in_browser(url)
|
||||
end
|
||||
|
||||
---@param tree NuiTree
|
||||
M.copy_node_url = function(tree)
|
||||
local url = M.get_url(tree)
|
||||
if url == nil then
|
||||
return
|
||||
end
|
||||
u.notify("Copied '" .. url .. "' to clipboard", vim.log.levels.INFO)
|
||||
vim.fn.setreg("+", url)
|
||||
end
|
||||
|
||||
M.add_emoji_to_note = function(tree, unlinked)
|
||||
local node = tree:get_node()
|
||||
local note_node = M.get_note_node(tree, node)
|
||||
|
||||
@@ -51,6 +51,7 @@ M.settings = {
|
||||
edit_comment = "e",
|
||||
delete_comment = "dd",
|
||||
open_in_browser = "b",
|
||||
copy_node_url = "u",
|
||||
reply = "r",
|
||||
toggle_node = "t",
|
||||
add_emoji = "Ea",
|
||||
@@ -280,9 +281,9 @@ M.set_popup_keymaps = function(popup, action, linewise_action, opts)
|
||||
local text = u.get_buffer_text(popup.bufnr)
|
||||
if opts.action_before_close then
|
||||
action(text, popup.bufnr)
|
||||
exit(popup, opts)
|
||||
vim.api.nvim_buf_delete(popup.bufnr, {})
|
||||
else
|
||||
exit(popup, opts)
|
||||
vim.api.nvim_buf_delete(popup.bufnr, {})
|
||||
action(text, popup.bufnr)
|
||||
end
|
||||
end, { buffer = popup.bufnr, desc = "Perform action" })
|
||||
|
||||
Reference in New Issue
Block a user