[bitbucket] improvements

- click on pr's title opens the pr
 - click on avatar opens user's prs
  - put source and destination branches on one line
This commit is contained in:
streetturtle 2020-09-03 21:25:08 -04:00
parent 2af3a4b037
commit 93fe707fd1
1 changed files with 120 additions and 55 deletions

View File

@ -20,49 +20,13 @@ local gfs = require("gears.filesystem")
local HOME_DIR = os.getenv("HOME") local HOME_DIR = os.getenv("HOME")
local GET_PRS_CMD= [[bash -c "curl -s --show-error -n '%s/2.0/repositories/%s/%s/pullrequests?fields=values.title,values.links.html,values.author.display_name,values.author.uuid,values.author.links.avatar&q=%%28author.uuid+%%3D+%%22%s%%22+OR+reviewers.uuid+%%3D+%%22%s%%22+%%29+AND+state+%%3D+%%22OPEN%%22' | jq '.[] | unique'"]] local GET_PRS_CMD= [[bash -c "curl -s --show-error -n '%s/2.0/repositories/%s/%s/pullrequests?fields=values.title,values.links.html,values.author.display_name,values.author.uuid,values.author.links.avatar,values.source.branch,values.destination.branch&q=%%28author.uuid+%%3D+%%22%s%%22+OR+reviewers.uuid+%%3D+%%22%s%%22+%%29+AND+state+%%3D+%%22OPEN%%22' | jq '.[] | unique'"]]
local DOWNLOAD_AVATAR_CMD = [[bash -c "curl -n --create-dirs -o %s/.cache/awmw/bitbucket-widget/avatars/%s %s"]] local DOWNLOAD_AVATAR_CMD = [[bash -c "curl -L -n --create-dirs -o %s/.cache/awmw/bitbucket-widget/avatars/%s %s"]]
local bitbucket_widget = {} local bitbucket_widget = wibox.widget {
local function show_warning(message)
naughty.notify{
preset = naughty.config.presets.critical,
title = 'Bitbucket Widget',
text = message}
end
local function worker(args)
local args = args or {}
local icon = args.icon or HOME_DIR .. '/.config/awesome/awesome-wm-widgets/bitbucket-widget/bitbucket-icon-gradient-blue.svg'
local host = args.host or show_warning('Bitbucket host is unknown')
local uuid = args.uuid or show_warning('UUID is not set')
local workspace = args.workspace or show_warning('Workspace is not set')
local repo_slug = args.repo_slug or show_warning('Repo slug is not set')
local current_number_of_prs
local to_review_rows = {layout = wibox.layout.fixed.vertical}
local my_review_rows = {layout = wibox.layout.fixed.vertical}
local rows = {layout = wibox.layout.fixed.vertical}
local popup = awful.popup{
ontop = true,
visible = false,
shape = gears.shape.rounded_rect,
border_width = 1,
border_color = beautiful.bg_focus,
maximum_width = 400,
offset = { y = 5 },
widget = {}
}
bitbucket_widget = wibox.widget {
{ {
{ {
image = icon, id = 'icon',
widget = wibox.widget.imagebox widget = wibox.widget.imagebox
}, },
margins = 4, margins = 4,
@ -79,8 +43,47 @@ local function worker(args)
layout = wibox.layout.fixed.horizontal, layout = wibox.layout.fixed.horizontal,
set_text = function(self, new_value) set_text = function(self, new_value)
self.txt.text = new_value self.txt.text = new_value
end,
set_icon = function(self, new_value)
self:get_children_by_id('icon')[1]:set_image(new_value)
end end
} }
local function show_warning(message)
naughty.notify{
preset = naughty.config.presets.critical,
title = 'Bitbucket Widget',
text = message}
end
local popup = awful.popup{
ontop = true,
visible = false,
shape = gears.shape.rounded_rect,
border_width = 1,
border_color = beautiful.bg_focus,
maximum_width = 400,
offset = { y = 5 },
widget = {}
}
local function worker(args)
local args = args or {}
local icon = args.icon or HOME_DIR .. '/.config/awesome/awesome-wm-widgets/bitbucket-widget/bitbucket-icon-gradient-blue.svg'
local host = args.host or show_warning('Bitbucket host is not set')
local uuid = args.uuid or show_warning('UUID is not set')
local workspace = args.workspace or show_warning('Workspace is not set')
local repo_slug = args.repo_slug or show_warning('Repo slug is not set')
local current_number_of_prs
local to_review_rows = {layout = wibox.layout.fixed.vertical}
local my_review_rows = {layout = wibox.layout.fixed.vertical}
local rows = {layout = wibox.layout.fixed.vertical}
bitbucket_widget:set_icon(icon)
local update_widget = function(widget, stdout, stderr, _, _) local update_widget = function(widget, stdout, stderr, _, _)
if stderr ~= '' then if stderr ~= '' then
@ -104,31 +107,31 @@ local function worker(args)
for i = 0, #to_review_rows do to_review_rows[i]=nil end for i = 0, #to_review_rows do to_review_rows[i]=nil end
table.insert(to_review_rows, { table.insert(to_review_rows, {
{
markup = '<span size="large" color="#ffffff">PRs to review</span>', markup = '<span size="large" color="#ffffff">PRs to review</span>',
align = 'center', align = 'center',
forced_height = 20, forced_height = 20,
widget = wibox.widget.textbox widget = wibox.widget.textbox
},
bg = beautiful.bg_normal,
widget = wibox.container.background
}) })
for i = 0, #my_review_rows do my_review_rows[i]=nil end for i = 0, #my_review_rows do my_review_rows[i]=nil end
table.insert(my_review_rows, { table.insert(my_review_rows, {
{
markup = '<span size="large" color="#ffffff">My PRs</span>', markup = '<span size="large" color="#ffffff">My PRs</span>',
align = 'center', align = 'center',
forced_height = 20, forced_height = 20,
widget = wibox.widget.textbox widget = wibox.widget.textbox
},
bg = beautiful.bg_normal,
widget = wibox.container.background
}) })
for _, pr in ipairs(result) do for _, pr in ipairs(result) do
local path_to_avatar = os.getenv("HOME") ..'/.cache/awmw/bitbucket-widget/avatars/' .. pr.author.uuid local path_to_avatar = os.getenv("HOME") ..'/.cache/awmw/bitbucket-widget/avatars/' .. pr.author.uuid
if not gfs.file_readable(path_to_avatar) then
spawn.easy_async(string.format(
DOWNLOAD_AVATAR_CMD,
HOME_DIR,
pr.author.uuid,
pr.author.links.avatar.href))
end
local row = wibox.widget { local row = wibox.widget {
{ {
{ {
@ -140,14 +143,32 @@ local function worker(args)
forced_height = 40, forced_height = 40,
widget = wibox.widget.imagebox widget = wibox.widget.imagebox
}, },
id = 'avatar',
margins = 8, margins = 8,
layout = wibox.container.margin layout = wibox.container.margin
}, },
{ {
{ {
id = 'title',
markup = '<b>' .. pr.title .. '</b>', markup = '<b>' .. pr.title .. '</b>',
widget = wibox.widget.textbox widget = wibox.widget.textbox
}, },
{
{
text = pr.source.branch.name,
widget = wibox.widget.textbox
},
{
text = '->',
widget = wibox.widget.textbox
},
{
text = pr.destination.branch.name,
widget = wibox.widget.textbox
},
spacing = 8,
layout = wibox.layout.fixed.horizontal
},
{ {
text = pr.author.display_name, text = pr.author.display_name,
widget = wibox.widget.textbox widget = wibox.widget.textbox
@ -160,13 +181,23 @@ local function worker(args)
margins = 8, margins = 8,
layout = wibox.container.margin layout = wibox.container.margin
}, },
bg = beautiful.bg_normal,
widget = wibox.container.background widget = wibox.container.background
} }
if not gfs.file_readable(path_to_avatar) then
spawn.easy_async(string.format(
DOWNLOAD_AVATAR_CMD,
HOME_DIR,
pr.author.uuid,
pr.author.links.avatar.href), function() row:get_children_by_id('avatar')[1]:set_image(path_to_avatar) end)
end
row:connect_signal("mouse::enter", function(c) c:set_bg(beautiful.bg_focus) end) row:connect_signal("mouse::enter", function(c) c:set_bg(beautiful.bg_focus) end)
row:connect_signal("mouse::leave", function(c) c:set_bg(beautiful.bg_normal) end) row:connect_signal("mouse::leave", function(c) c:set_bg(beautiful.bg_normal) end)
row:buttons( row:get_children_by_id('title')[1]:buttons(
awful.util.table.join( awful.util.table.join(
awful.button({}, 1, function() awful.button({}, 1, function()
spawn.with_shell("xdg-open " .. pr.links.html.href) spawn.with_shell("xdg-open " .. pr.links.html.href)
@ -174,6 +205,40 @@ local function worker(args)
end) end)
) )
) )
row:get_children_by_id('avatar')[1]:buttons(
awful.util.table.join(
awful.button({}, 1, function()
spawn.with_shell(string.format('xdg-open "https://bitbucket.org/%s/%s/pull-requests?state=OPEN&author=%s"', workspace, repo_slug, pr.author.uuid))
popup.visible = false
end)
)
)
local old_cursor, old_wibox
row:get_children_by_id('title')[1]:connect_signal("mouse::enter", function(c)
local wb = mouse.current_wibox
old_cursor, old_wibox = wb.cursor, wb
wb.cursor = "hand1"
end)
row:get_children_by_id('title')[1]:connect_signal("mouse::leave", function(c)
if old_wibox then
old_wibox.cursor = old_cursor
old_wibox = nil
end
end)
local old_cursor, old_wibox
row:get_children_by_id('avatar')[1]:connect_signal("mouse::enter", function(c)
local wb = mouse.current_wibox
old_cursor, old_wibox = wb.cursor, wb
wb.cursor = "hand1"
end)
row:get_children_by_id('avatar')[1]:connect_signal("mouse::leave", function(c)
if old_wibox then
old_wibox.cursor = old_cursor
old_wibox = nil
end
end)
if (pr.author.uuid == '{' .. uuid .. '}') then if (pr.author.uuid == '{' .. uuid .. '}') then
table.insert(my_review_rows, row) table.insert(my_review_rows, row)
@ -202,7 +267,7 @@ local function worker(args)
) )
watch(string.format(GET_PRS_CMD, host, workspace, repo_slug, uuid, uuid), watch(string.format(GET_PRS_CMD, host, workspace, repo_slug, uuid, uuid),
10, update_widget, bitbucket_widget) 60, update_widget, bitbucket_widget)
return bitbucket_widget return bitbucket_widget
end end