titlebar: add widget layout support

Signed-off-by: Gregor Best <farhaven@googlemail.com>
Signed-off-by: Julien Danjou <julien@danjou.info>
This commit is contained in:
Gregor Best 2009-07-02 01:41:26 +02:00 committed by Julien Danjou
parent 50ee299aef
commit 7c78e91a5b
1 changed files with 36 additions and 21 deletions

View File

@ -24,6 +24,7 @@ local util = require("awful.util")
local widget = require("awful.widget") local widget = require("awful.widget")
local mouse = require("awful.mouse") local mouse = require("awful.mouse")
local client = require("awful.client") local client = require("awful.client")
local layout = require("awful.widget.layout")
--- Titlebar module for awful --- Titlebar module for awful
module("awful.titlebar") module("awful.titlebar")
@ -72,7 +73,7 @@ function add(c, args)
local tb = capi.wibox(args) local tb = capi.wibox(args)
local title = capi.widget({ type = "textbox", align = "flex" }) local title = capi.widget({ type = "textbox" })
if c.name then if c.name then
title.text = "<span font_desc='" .. data[c].font .. "'> " .. title.text = "<span font_desc='" .. data[c].font .. "'> " ..
util.escape(c.name) .. " </span>" util.escape(c.name) .. " </span>"
@ -85,7 +86,7 @@ function add(c, args)
button({ args.modkey }, 3, button_callback_resize)) button({ args.modkey }, 3, button_callback_resize))
title:buttons(bts) title:buttons(bts)
local appicon = capi.widget({ type = "imagebox", align = "left" }) local appicon = capi.widget({ type = "imagebox" })
appicon.image = c.icon appicon.image = c.icon
-- for each button group, call create for the client. -- for each button group, call create for the client.
@ -93,8 +94,10 @@ function add(c, args)
-- data[c].button_sets for late updates and add the -- data[c].button_sets for late updates and add the
-- individual buttons to the array part of the widget -- individual buttons to the array part of the widget
-- list -- list
local widget_list = { appicon = appicon, title = title } local widget_list = {
local iw = #widget_list layout = layout.horizontal.rightleft
}
local iw = 1
local is = 1 local is = 1
data[c].button_sets = {} data[c].button_sets = {}
for i = 1, #button_groups do for i = 1, #button_groups do
@ -109,7 +112,16 @@ function add(c, args)
end end
end end
tb.widgets = widget_list tb.widgets = {
widget_list,
{
appicon = appicon,
title = title,
layout = layout.horizontal.flex
},
layout = layout.horizontal.rightleft
}
c.titlebar = tb c.titlebar = tb
update(c) update(c)
@ -122,13 +134,13 @@ function update(c, prop)
if type(c) == "client" and c.titlebar and data[c] then if type(c) == "client" and c.titlebar and data[c] then
local widgets = c.titlebar.widgets local widgets = c.titlebar.widgets
if prop == "name" then if prop == "name" then
if widgets.title then if widgets[2].title then
widgets.title.text = "<span font_desc='" .. data[c].font .. widgets[2].title.text = "<span font_desc='" .. data[c].font ..
"'> ".. util.escape(c.name) .. " </span>" "'> ".. util.escape(c.name) .. " </span>"
end end
elseif prop == "icon" then elseif prop == "icon" then
if widgets.appicon then if widgets[2].appicon then
widgets.appicon.image = c.icon widgets[2].appicon.image = c.icon
end end
end end
if capi.client.focus == c then if capi.client.focus == c then
@ -208,7 +220,9 @@ local function button_group_create(c, group, modkey, theme )
local s = {} local s = {}
s.name = group.name s.name = group.name
s.select_state = group.select_state s.select_state = group.select_state
s.buttons = {} s.buttons = {
layout = layout.horizontal.rightleft
}
for n,state in pairs(group.states) do for n,state in pairs(group.states) do
s.buttons[n] = button_new(c, s.name, modkey, theme, state) s.buttons[n] = button_new(c, s.name, modkey, theme, state)
if (s.buttons[n] == nil) then return end if (s.buttons[n] == nil) then return end
@ -328,14 +342,6 @@ end
-- Finally the last parameter is the action for mouse -- Finally the last parameter is the action for mouse
-- button 1 -- button 1
local close_buttons = button_group("close",
{ align = "left" },
select_state_focus,
{ idx = "n", img = "normal",
action = function (w, t) t.client:kill() end },
{ idx = "f", img = "focus",
action = function (w, t) t.client:kill() end })
local ontop_buttons = button_group("ontop", local ontop_buttons = button_group("ontop",
{ align = "right" }, { align = "right" },
function(c,p) return select_state(c, p, "ontop") end, function(c,p) return select_state(c, p, "ontop") end,
@ -375,6 +381,15 @@ local maximized_buttons = button_group("maximized",
{ idx = "f/a", img = "focus_active", { idx = "f/a", img = "focus_active",
action = function(w, t) t.client.maximized_horizontal = false action = function(w, t) t.client.maximized_horizontal = false
t.client.maximized_vertical = false end }) t.client.maximized_vertical = false end })
local close_buttons = button_group("close",
{ align = "left" },
select_state_focus,
{ idx = "n", img = "normal",
action = function (w, t) t.client:kill() end },
{ idx = "f", img = "focus",
action = function (w, t) t.client:kill() end })
local function floating_update(w, t) local function floating_update(w, t)
client.floating.toggle(t.client) client.floating.toggle(t.client)
end end
@ -387,11 +402,11 @@ local floating_buttons = button_group("floating",
{ idx = "n/a", img = "normal_active", action = floating_update }, { idx = "n/a", img = "normal_active", action = floating_update },
{ idx = "f/a", img = "focus_active", action = floating_update }) { idx = "f/a", img = "focus_active", action = floating_update })
button_groups = { ontop_buttons, button_groups = { close_buttons,
ontop_buttons,
sticky_buttons, sticky_buttons,
maximized_buttons, maximized_buttons,
floating_buttons, floating_buttons }
close_buttons }
-- Register standards hooks -- Register standards hooks
hooks.focus.register(update) hooks.focus.register(update)