Merge pull request #741 from psychon/systray-screen

Improvements on the systray / default to displaying the systray on the primary screen
This commit is contained in:
Daniel Hahler 2016-03-07 00:25:47 +01:00
commit d1e2cfa135
3 changed files with 84 additions and 10 deletions

View File

@ -208,7 +208,7 @@ for s = 1, screen.count() do
{ -- Right widgets { -- Right widgets
layout = wibox.layout.fixed.horizontal, layout = wibox.layout.fixed.horizontal,
mykeyboardlayout, mykeyboardlayout,
s == 1 and wibox.widget.systray(), wibox.widget.systray(),
mytextclock, mytextclock,
mylayoutbox[s], mylayoutbox[s],
}, },

View File

@ -63,7 +63,6 @@ file = {
'../lib/gears/init.lua', '../lib/gears/init.lua',
'../lib/wibox/layout/init.lua', '../lib/wibox/layout/init.lua',
'../lib/wibox/widget/init.lua', '../lib/wibox/widget/init.lua',
'../lib/wibox/widget/systray.lua',
-- Ignore some parts of the widget library -- Ignore some parts of the widget library
'../lib/awful/widget/init.lua', '../lib/awful/widget/init.lua',

View File

@ -7,18 +7,34 @@
local wbase = require("wibox.widget.base") local wbase = require("wibox.widget.base")
local beautiful = require("beautiful") local beautiful = require("beautiful")
local capi = { awesome = awesome } local capi = {
awesome = awesome,
screen = screen
}
local setmetatable = setmetatable local setmetatable = setmetatable
local error = error local error = error
local abs = math.abs local abs = math.abs
local systray = { mt = {} } local systray = { mt = {} }
local instance = nil
local horizontal = true local horizontal = true
local base_size = nil local base_size = nil
local reverse = false local reverse = false
local display_on_screen = "primary"
local function should_display_on(s)
if display_on_screen == "primary" then
return s == capi.screen.primary
end
return s == display_on_screen
end
function systray:draw(context, cr, width, height) function systray:draw(context, cr, width, height)
if not should_display_on(context.screen) then
return
end
local x, y, _, _ = wbase.rect_to_device_geometry(cr, 0, 0, width, height) local x, y, _, _ = wbase.rect_to_device_geometry(cr, 0, 0, width, height)
local num_entries = capi.awesome.systray() local num_entries = capi.awesome.systray()
local bg = beautiful.bg_systray or beautiful.bg_normal or "#000000" local bg = beautiful.bg_systray or beautiful.bg_normal or "#000000"
@ -48,7 +64,11 @@ function systray:draw(context, cr, width, height)
base, is_rotated, bg, reverse, spacing) base, is_rotated, bg, reverse, spacing)
end end
function systray:fit(_, width, height) function systray:fit(context, width, height)
if not should_display_on(context.screen) then
return 0, 0
end
local num_entries = capi.awesome.systray() local num_entries = capi.awesome.systray()
local base = base_size local base = base_size
local spacing = beautiful.systray_icon_spacing or 0 local spacing = beautiful.systray_icon_spacing or 0
@ -69,14 +89,61 @@ function systray:fit(_, width, height)
return base, base * num_entries - spacing return base, base * num_entries - spacing
end end
-- Check if the function was called like :foo() or .foo() and do the right thing
local function get_args(self, ...)
if self == instance then
return ...
end
return self, ...
end
--- Set the size of a single icon.
-- If this is set to nil, then the size is picked dynamically based on the
-- available space. Otherwise, any single icon has a size of `size`x`size`.
-- @tparam integer|nil size The base size
function systray:set_base_size(size)
base_size = get_args(self, size)
if instance then
instance:emit_signal("widget::layout_changed")
end
end
--- Decide between horizontal or vertical display.
-- @tparam boolean horiz Use horizontal mode?
function systray:set_horizontal(horiz)
horizontal = get_args(self, horiz)
if instance then
instance:emit_signal("widget::layout_changed")
end
end
--- Should the systray icons be displayed in reverse order?
-- @tparam boolean rev Display in reverse order
function systray:set_reverse(rev)
reverse = get_args(self, rev)
if instance then
instance:emit_signal("widget::redraw_needed")
end
end
--- Set the screen that the systray should be displayed on.
-- This can either be a screen, in which case the systray will be displayed on
-- exactly that screen, or the string `"primary"`, in which case it will be
-- visible on the primary screen. The default value is "primary".
-- @tparam screen|"primary" s The screen to display on.
function systray:set_screen(s)
display_on_screen = get_args(self, s)
if instance then
instance:emit_signal("widget::layout_changed")
end
end
local function new(revers) local function new(revers)
local ret = wbase.make_widget() local ret = wbase.make_widget()
ret.fit = systray.fit for k, v in pairs(systray) do
ret.draw = systray.draw ret[k] = v
ret.set_base_size = function(_, size) base_size = size end end
ret.set_horizontal = function(_, horiz) horizontal = horiz end
ret.set_reverse = function(arg) reverse = arg end
if revers then if revers then
ret:set_reverse(true) ret:set_reverse(true)
@ -86,12 +153,20 @@ local function new(revers)
ret:emit_signal("widget::layout_changed") ret:emit_signal("widget::layout_changed")
ret:emit_signal("widget::redraw_needed") ret:emit_signal("widget::redraw_needed")
end) end)
capi.screen.connect_signal("primary_changed", function()
if display_on_screen == "primary" then
ret:emit_signal("widget::layout_changed")
end
end)
return ret return ret
end end
function systray.mt:__call(...) function systray.mt:__call(...)
return new(...) if not instance then
instance = new(...)
end
return instance
end end
return setmetatable(systray, systray.mt) return setmetatable(systray, systray.mt)