systray: Automatically fit into available space
Instead of having to set the systray's base size by hand, it now automatically uses min(avail_width, avail_height) as its base size. That's way less surprising for people. Signed-off-by: Uli Schlachter <psychon@znc.in>
This commit is contained in:
parent
35c05abe29
commit
547f732b00
|
@ -141,7 +141,7 @@ for s = 1, screen.count() do
|
||||||
|
|
||||||
-- Widgets that are aligned to the right
|
-- Widgets that are aligned to the right
|
||||||
local right_layout = wibox.layout.fixed.horizontal()
|
local right_layout = wibox.layout.fixed.horizontal()
|
||||||
if s == 1 then right_layout:add(wibox.widget.systray(true)) end
|
if s == 1 then right_layout:add(wibox.widget.systray()) end
|
||||||
right_layout:add(mytextclock)
|
right_layout:add(mytextclock)
|
||||||
right_layout:add(mylayoutbox[s])
|
right_layout:add(mylayoutbox[s])
|
||||||
|
|
||||||
|
|
|
@ -14,14 +14,13 @@ module("wibox.widget.systray")
|
||||||
|
|
||||||
local created_systray = false
|
local created_systray = false
|
||||||
local horizontal = true
|
local horizontal = true
|
||||||
local base_size = 16
|
local base_size = nil
|
||||||
|
|
||||||
function draw(box, wibox, cr, width, height)
|
function draw(box, wibox, cr, width, height)
|
||||||
local x, y, width, height = lbase.rect_to_device_geometry(cr, 0, 0, width, height)
|
local x, y, width, height = lbase.rect_to_device_geometry(cr, 0, 0, width, height)
|
||||||
local num_entries = capi.awesome.systray()
|
local num_entries = capi.awesome.systray()
|
||||||
|
|
||||||
local width, height = width, height
|
local in_dir, ortho, base
|
||||||
local in_dir, ortho, base_size
|
|
||||||
if horizontal then
|
if horizontal then
|
||||||
in_dir, ortho = width, height
|
in_dir, ortho = width, height
|
||||||
else
|
else
|
||||||
|
@ -37,16 +36,23 @@ end
|
||||||
|
|
||||||
function fit(box, width, height)
|
function fit(box, width, height)
|
||||||
local num_entries = capi.awesome.systray()
|
local num_entries = capi.awesome.systray()
|
||||||
if horizontal then
|
local base = base_size
|
||||||
return base_size * num_entries, base_size
|
if base == nil then
|
||||||
|
if width < height then
|
||||||
|
base = width
|
||||||
|
else
|
||||||
|
base = height
|
||||||
end
|
end
|
||||||
return base_size, base_size * num_entries
|
end
|
||||||
|
if horizontal then
|
||||||
|
return base * num_entries, base
|
||||||
|
end
|
||||||
|
return base, base * num_entries
|
||||||
end
|
end
|
||||||
|
|
||||||
local function new(horiz)
|
local function new()
|
||||||
local ret = wbase.make_widget()
|
local ret = wbase.make_widget()
|
||||||
|
|
||||||
horizontal = horiz
|
|
||||||
if created_systray then
|
if created_systray then
|
||||||
error("More than one systray created!")
|
error("More than one systray created!")
|
||||||
end
|
end
|
||||||
|
@ -55,6 +61,7 @@ local function new(horiz)
|
||||||
ret.fit = fit
|
ret.fit = fit
|
||||||
ret.draw = draw
|
ret.draw = draw
|
||||||
ret.set_base_size = function(_, size) base_size = size end
|
ret.set_base_size = function(_, size) base_size = size end
|
||||||
|
ret.set_horizontal = function(_, horiz) horizontal = horiz end
|
||||||
|
|
||||||
capi.awesome.connect_signal("systray::update", function()
|
capi.awesome.connect_signal("systray::update", function()
|
||||||
ret:emit_signal("widget::updated")
|
ret:emit_signal("widget::updated")
|
||||||
|
|
Loading…
Reference in New Issue