diff --git a/lib/naughty/core.lua b/lib/naughty/core.lua index be2f46ae..24f7c960 100644 --- a/lib/naughty/core.lua +++ b/lib/naughty/core.lua @@ -543,7 +543,7 @@ function naughty.notify(args) actionmarginbox:set_widget(actiontextbox) actiontextbox:set_valign("middle") actiontextbox:set_font(font) - actiontextbox:set_markup(string.format('%s', action)) + actiontextbox:set_markup(string.format('☛ %s', action)) -- calculate the height and width local w, h = actiontextbox:get_preferred_size(s) local action_height = h + 2 * margin diff --git a/lib/naughty/dbus.lua b/lib/naughty/dbus.lua index 9f749f9d..fe0b694c 100644 --- a/lib/naughty/dbus.lua +++ b/lib/naughty/dbus.lua @@ -137,24 +137,20 @@ capi.dbus.connect_signal("org.freedesktop.Notifications", function (data, appnam if actions then args.actions = {} - local actionid - -- create actions callbacks - for i , v in ipairs(actions) do - if i % 2 == 1 then - actionid = v - elseif actionid == "default" then + for i = 1,#actions,2 do + local action_id = actions[i] + local action_text = actions[i + 1] + + if action_id == "default" then args.run = function() sendActionInvoked(notification.id, "default") naughty.destroy(notification, naughty.notificationClosedReason.dismissedByUser) end - actionid = nil - elseif actionid ~= nil then - local action = actionid - args.actions[actionid] = function() - sendActionInvoked(notification.id, action) + elseif action_id ~= nil and action_text ~= nil then + args.actions[action_text] = function() + sendActionInvoked(notification.id, action_id) naughty.destroy(notification, naughty.notificationClosedReason.dismissedByUser) end - actionid = nil end end end