diff --git a/experiments/logout-widget/README.md b/experiments/logout-widget/README.md index f848e5f..d9a3ea9 100644 --- a/experiments/logout-widget/README.md +++ b/experiments/logout-widget/README.md @@ -4,12 +4,38 @@ Clone repo (if not cloned yet) under ~/.config/awesome, then -```lua -local logout = require("awesome-wm-widgets.experiments.logout-widget.logout") - -- define a shorcut in globalkey - awful.key({ modkey }, "l", function() logout.launch() end, {description = "Show logout screen", group = "custom"}), -``` +- to show by shortcut: + + ```lua + local logout = require("awesome-wm-widgets.experiments.logout-widget.logout") + + -- define a shorcut in globalkey + awful.key({ modkey }, "l", function() logout.launch() end, {description = "Show logout screen", group = "custom"}), + ``` + +- to show by clicking on a widget in wibar: + + ```lua + local logout = require("awesome-wm-widgets.experiments.logout-widget.logout") + + s.mytasklist, -- Middle widget + { -- Right widgets + layout = wibox.layout.fixed.horizontal, + ... + logout.widget{ + bg_color = "#000000", + accent_color = "#888888", + text_color = '#ffffff', + phrases = {'Yippee ki yay!', 'Hasta la vista, baby', 'See you later, alligator!', 'After a while, crocodile.'}, + onlogout = function() naughty.notify{text = "Logged out!"} end + }, + ... + ``` # Customisation + +## Phrase + +You can provide a phrase which appears on the widget. diff --git a/experiments/logout-widget/logout.lua b/experiments/logout-widget/logout.lua index fb0e06e..3b15274 100644 --- a/experiments/logout-widget/logout.lua +++ b/experiments/logout-widget/logout.lua @@ -39,7 +39,7 @@ local action = wibox.widget { local function create_button(icon_name, action_name, color, onclick) - local button = fancybuttons.with_icon{ type = 'basic', shape = 'circle', icon = ICONS_DIR .. icon_name, color = color, onclick = onclick } + local button = fancybuttons.with_icon{ type = 'basic', shape = 'rectangle', icon = icon_name, color = color, onclick = onclick } button:connect_signal("mouse::enter", function(c) action:set_text(action_name) end) button:connect_signal("mouse::leave", function(c) action:set_text(' ') end) return button @@ -55,25 +55,27 @@ local function launch(args) local onlogout = args.onlogout or function () awesome.quit() end local onlock = args.onlock local onreboot = args.onreboot - local onsuspend = args.onsuspend + local onsuspend = args.onsuspend or function () awful.spawn.with_shell("systemctl suspend") end local onpoweroff = args.onpoweroff or function () awful.spawn.with_shell("shutdown now") end w:set_bg(bg_color) + local phrase_widget = wibox.widget{ + markup = '' .. phrases[ math.random( #phrases ) ] .. '', + align = 'center', + widget = wibox.widget.textbox + } + w:setup { { - { - markup = '' .. phrases[ math.random( #phrases ) ] .. '', - align = 'center', - widget = wibox.widget.textbox - }, + phrase_widget, { { - create_button('log-out.svg', 'Log Out', accent_color, onlogout), - create_button('lock.svg', 'Lock', accent_color, onlock), - create_button('refresh-cw.svg', 'Reboot', accent_color, onreboot), - create_button('moon.svg', 'Suspend', accent_color, onsuspend), - create_button('power.svg', 'Power Off', accent_color, onpoweroff), + create_button('log-out', 'Log Out', accent_color, onlogout), + create_button('lock', 'Lock', accent_color, onlock), + create_button('refresh-cw', 'Reboot', accent_color, onreboot), + create_button('moon', 'Suspend', accent_color, onsuspend), + create_button('power', 'Power Off', accent_color, onpoweroff), id = 'buttons', spacing = 8, layout = wibox.layout.fixed.horizontal @@ -101,12 +103,38 @@ 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 end end) end +local function widget(args) + local res = wibox.widget { + { + { + image = WIDGET_DIR .. '/power.svg', + widget = wibox.widget.imagebox + }, + margins = 4, + layout = wibox.container.margin + }, + layout = wibox.layout.fixed.horizontal, + } + + res:buttons( + awful.util.table.join( + awful.button({}, 1, function() + launch(args) + end) + )) + + return res + +end + return { - launch = launch + launch = launch, + widget = widget } diff --git a/experiments/logout-widget/power.svg b/experiments/logout-widget/power.svg new file mode 100644 index 0000000..1f9c4e3 --- /dev/null +++ b/experiments/logout-widget/power.svg @@ -0,0 +1 @@ + \ No newline at end of file