Fix 2 tasklist bugs

This commit is contained in:
Emmanuel Lepage Vallee 2014-02-08 01:31:45 -05:00
parent 4482d93c96
commit 1170ac0cc4
2 changed files with 85 additions and 78 deletions

View File

@ -69,10 +69,11 @@ local function setup_drawable(data)
end) end)
data:connect_signal("item::removed",function(_,item,old_idx) data:connect_signal("item::removed",function(_,item,old_idx)
table.remove(internal.layout.widgets,old_idx) table.remove(internal.layout.widgets,old_idx)
item.widget:disconnect_signal("widget::updated", internal.layout._emit_updated)
internal.layout:emit_signal("widget::updated") internal.layout:emit_signal("widget::updated")
end) end)
data:connect_signal("item::appended",function(_,item) data:connect_signal("item::appended",function(_,item)
internal.layout.widgets[#internal.layout.widgets+1] = item.widget internal.layout:add(item.widget)
internal.layout:emit_signal("widget::updated") internal.layout:emit_signal("widget::updated")
end) end)
end end

View File

@ -40,67 +40,9 @@ local function unmanage_callback(c)
end end
end end
local function new(screen) -- Reload <float> <ontop> and <sticky> labels
local cache,menu = setmetatable({}, { __mode = 'k' }),radical.flexbar{select_on=radical.base.event.NEVER,fg=beautiful.fg_normal,bg_focus=beautiful.taglist_bg_image_selected2} local function reload_underlay(c)
local cache = instances[c.screen].cache
function create_client_item(c)
-- If it already exist, don't waste time creating a copy
if cache[c] then
return menu:append(cache[c])
end
-- Too bad, let's create a new one
cache[c] = menu:add_item{text=c.name,icon=c.icon,button1=function()
capi.client.focus = c
c:raise()
end}
return cache[c]
end
function add_client(c)
if not (c.skip_taskbar or c.hidden or c.type == "splash" or c.type == "dock" or c.type == "desktop") and c.screen == screen then
local ret = create_client_item(c)
reload_underlay(c)
if c.focus == c then
ret.selected = true
end
end
end
-- Clear the menu and repopulate it
function load_clients(t)
if not t then return end
if t.selected and tag.getscreen(t) == screen then
menu:clear()
for k, c in ipairs(t:clients()) do
if not c.sticky then
add_client(c)
end
end
for c,_ in pairs(sticky) do
add_client(c)
end
end
end
-- Unselect the old focussed client
function unfocus(c)
local item = cache[c]
if item and item.selected then
item.selected = false
end
end
-- Select the newly focussed client
function focus(c)
local item = cache[c]
if item then
item.selected = true
end
end
-- Reload <float> <ontop> and <sticky> labels
function reload_underlay(c)
local udl,item = {},cache[c] local udl,item = {},cache[c]
if item then if item then
if c.ontop then if c.ontop then
@ -115,32 +57,91 @@ local function new(screen)
item.underlay = udl item.underlay = udl
item.widget:emit_signal("widget::updated") item.widget:emit_signal("widget::updated")
end end
end
local function create_client_item(c,screen)
local cache = instances[screen].cache
local menu = instances[screen].menu
-- If it already exist, don't waste time creating a copy
if cache[c] then
return menu:append(cache[c])
end
-- Too bad, let's create a new one
cache[c] = menu:add_item{text=c.name,icon=c.icon,button1=function()
capi.client.focus = c
c:raise()
end}
return cache[c]
end
local function add_client(c,screen)
if not (c.skip_taskbar or c.hidden or c.type == "splash" or c.type == "dock" or c.type == "desktop") and c.screen == screen then
local ret = create_client_item(c,screen)
reload_underlay(c)
if c.focus == c then
ret.selected = true
end
end
end
-- Unselect the old focussed client
local function unfocus(c)
local cache = instances[c.screen].cache
local item = cache[c]
if item and item.selected then
item.selected = false
end
end
-- Select the newly focussed client
local function focus(c)
local cache = instances[c.screen].cache
local item = cache[c]
if item then
item.selected = true
end
end
local function new(screen)
local cache,menu = setmetatable({}, { __mode = 'k' }),radical.flexbar{select_on=radical.base.event.NEVER,fg=beautiful.fg_normal,bg_focus=beautiful.taglist_bg_image_selected2}
-- Clear the menu and repopulate it
local function load_clients(t)
if not t then return end
if t.selected and tag.getscreen(t) == screen then
menu:clear()
for k, c in ipairs(t:clients()) do
if not c.sticky then
add_client(c,screen)
end
end
for c,_ in pairs(sticky) do
add_client(c,screen)
end
end
end end
-- Add and remove clients from the tasklist -- Add and remove clients from the tasklist
function tagged(c,t) local function tagged(c,t)
if t.selected and tag.getscreen(t) == screen and not c.sticky then if t.selected and not c.sticky and tag.getscreen(t) == screen then
add_client(c) add_client(c,screen)
end end
end end
function untagged(c,t) local function untagged(c,t)
local item = cache[c]
if t.selected and tag.getscreen(t) == screen then if t.selected and tag.getscreen(t) == screen then
menu:remove(cache[c]) menu:remove(item)
end end
end end
-- Connect to a bunch of signals -- Connect to a bunch of signals
tag.attached_connect_signal(screen, "property::selected" , load_clients) tag.attached_connect_signal(screen, "property::selected" , load_clients)
tag.attached_connect_signal(screen, "property::activated", load_clients) tag.attached_connect_signal(screen, "property::activated", load_clients)
capi.client.connect_signal("focus" , focus )
capi.client.connect_signal("unfocus" , unfocus )
capi.client.connect_signal("tagged" , tagged ) capi.client.connect_signal("tagged" , tagged )
capi.client.connect_signal("untagged" , untagged ) capi.client.connect_signal("untagged" , untagged )
capi.client.connect_signal("property::sticky" , reload_underlay )
capi.client.connect_signal("property::ontop" , reload_underlay )
capi.client.connect_signal("property::floating", reload_underlay )
instances[#instances+1] = {menu = menu, cache = cache } instances[screen] = {menu = menu, cache = cache }
load_clients(tag.selected(screen)) load_clients(tag.selected(screen))
@ -148,9 +149,14 @@ local function new(screen)
end end
-- Global callbacks -- Global callbacks
capi.client.connect_signal("property::sticky", sticky_callback ) capi.client.connect_signal("property::sticky" , sticky_callback )
capi.client.connect_signal("property::urgent", urgent_callback ) capi.client.connect_signal("property::urgent" , urgent_callback )
capi.client.connect_signal("unmanage" , unmanage_callback) capi.client.connect_signal("unmanage" , unmanage_callback )
capi.client.connect_signal("focus" , focus )
capi.client.connect_signal("unfocus" , unfocus )
capi.client.connect_signal("property::sticky" , reload_underlay )
capi.client.connect_signal("property::ontop" , reload_underlay )
capi.client.connect_signal("property::floating", reload_underlay )
return setmetatable(module, { __call = function(_, ...) return new(...) end }) return setmetatable(module, { __call = function(_, ...) return new(...) end })
-- kate: space-indent on; indent-width 2; replace-tabs on; -- kate: space-indent on; indent-width 2; replace-tabs on;