summaryrefslogtreecommitdiff
path: root/logout-widget/logout.lua
diff options
context:
space:
mode:
authorstreetturtle <streetturtle@gmail.com>2020-09-29 22:23:02 -0400
committerstreetturtle <streetturtle@gmail.com>2020-09-29 22:23:02 -0400
commitce04667af3ec0f9704e806af400e543863780095 (patch)
tree566d2dd1b4b05435863089db9dd5e3b4dc42cafa /logout-widget/logout.lua
parent7ed1d35d3193574ee29dbbe981460ba8a21880fd (diff)
[logout] add shorcuts
Diffstat (limited to 'logout-widget/logout.lua')
-rw-r--r--logout-widget/logout.lua33
1 files changed, 24 insertions, 9 deletions
diff --git a/logout-widget/logout.lua b/logout-widget/logout.lua
index 3468673..b8835a6 100644
--- a/logout-widget/logout.lua
+++ b/logout-widget/logout.lua
@@ -74,18 +74,20 @@ local function launch(args)
local onpoweroff = args.onpoweroff or function() awful.spawn.with_shell("shutdown now") end
w:set_bg(bg_color)
- phrase_widget:set_markup('<span color="'.. text_color .. '" size="20000">' .. phrases[ math.random( #phrases ) ] .. '</span>')
+ if #phrases > 0 then
+ phrase_widget:set_markup('<span color="'.. text_color .. '" size="20000">' .. phrases[ math.random( #phrases ) ] .. '</span>')
+ end
w:setup {
{
phrase_widget,
{
{
- create_button('log-out', 'Log Out', accent_color, onlogout, icon_size, icon_margin),
- create_button('lock', 'Lock', accent_color, onlock, icon_size, icon_margin),
- create_button('refresh-cw', 'Reboot', accent_color, onreboot, icon_size, icon_margin),
- create_button('moon', 'Suspend', accent_color, onsuspend, icon_size, icon_margin),
- create_button('power', 'Power Off', accent_color, onpoweroff, icon_size, icon_margin),
+ create_button('log-out', 'Log Out (l)', accent_color, onlogout, icon_size, icon_margin),
+ create_button('lock', 'Lock (k)', accent_color, onlock, icon_size, icon_margin),
+ create_button('refresh-cw', 'Reboot (r)', accent_color, onreboot, icon_size, icon_margin),
+ create_button('moon', 'Suspend (u)', accent_color, onsuspend, icon_size, icon_margin),
+ create_button('power', 'Power Off (s)', accent_color, onpoweroff, icon_size, icon_margin),
id = 'buttons',
spacing = 8,
layout = wibox.layout.fixed.horizontal
@@ -113,9 +115,22 @@ local function launch(args)
capi.keygrabber.run(function(_, key, event)
if event == "release" then return end
if key then
- phrase_widget:set_text('')
- capi.keygrabber.stop()
- w.visible = false
+ if key == 'Escape' then
+ phrase_widget:set_text('')
+ capi.keygrabber.stop()
+ w.visible = false
+ elseif key == 's' then onpoweroff()
+ elseif key == 'r' then onreboot()
+ elseif key == 'u' then onsuspend()
+ elseif key == 'k' then onlock()
+ elseif key == 'l' then onlogout()
+ end
+
+ if key == 'Escape' or string.match("srukl", key) then
+ phrase_widget:set_text('')
+ capi.keygrabber.stop()
+ w.visible = false
+ end
end
end)
end