panel_items : fixed change number of desktop

git-svn-id: http://tint2.googlecode.com/svn/trunk@554 121b4492-b84c-0410-8b4c-0d4edfb3f3cc
This commit is contained in:
thilor77 2010-09-19 08:34:24 +00:00
parent 1bd5fd9937
commit d44628b16c
3 changed files with 28 additions and 17 deletions

View file

@ -126,7 +126,7 @@ void cleanup_panel()
void init_panel()
{
int i;
int i, k;
Panel *p;
if (panel_config.monitor > (server.nb_monitor-1)) {
@ -174,7 +174,24 @@ void init_panel()
p->g_task.area.panel = p;
init_panel_size_and_position(p);
// add childs according to panel_items
set_panel_items(p);
for (k=0 ; k < strlen(panel_items_order) ; k++) {
if (panel_items_order[k] == 'L')
init_launcher_panel(p);
if (panel_items_order[k] == 'T')
init_taskbar_panel(p);
#ifdef ENABLE_BATTERY
if (panel_items_order[k] == 'B')
init_battery_panel(p);
#endif
if (panel_items_order[k] == 'S') {
// TODO : check systray is only on 1 panel
init_systray_panel(p);
refresh_systray = 1;
}
if (panel_items_order[k] == 'C')
init_clock_panel(p);
}
set_panel_items_order(p);
// catch some events
XSetWindowAttributes att = { .colormap=server.colormap, .background_pixel=0, .border_pixel=0 };
@ -453,7 +470,7 @@ void update_strut(Panel* p)
}
void set_panel_items(Panel *p)
void set_panel_items_order(Panel *p)
{
int k, j;
@ -463,32 +480,23 @@ void set_panel_items(Panel *p)
}
for (k=0 ; k < strlen(panel_items_order) ; k++) {
if (panel_items_order[k] == 'L') {
init_launcher_panel(p);
if (panel_items_order[k] == 'L')
p->area.list = g_slist_append(p->area.list, &p->launcher);
}
if (panel_items_order[k] == 'T') {
init_taskbar_panel(p);
for (j=0 ; j < p->nb_desktop ; j++)
p->area.list = g_slist_append(p->area.list, &p->taskbar[j]);
}
#ifdef ENABLE_BATTERY
if (panel_items_order[k] == 'B') {
init_battery_panel(p);
if (panel_items_order[k] == 'B')
p->area.list = g_slist_append(p->area.list, &p->battery);
}
#endif
if (panel_items_order[k] == 'S') {
// TODO : check systray is only on 1 panel
init_systray_panel(p);
refresh_systray = 1;
p->area.list = g_slist_append(p->area.list, &systray);
}
if (panel_items_order[k] == 'C') {
init_clock_panel(p);
if (panel_items_order[k] == 'C')
p->area.list = g_slist_append(p->area.list, &p->clock);
}
}
}

View file

@ -137,7 +137,7 @@ void init_panel();
void init_panel_size_and_position(Panel *panel);
int resize_panel(void *obj);
void set_panel_items(Panel *p);
void set_panel_items_order(Panel *p);
void set_panel_properties(Panel *p);
void visible_object();

View file

@ -487,11 +487,13 @@ void event_property_notify (XEvent *e)
// Change number of desktops
else if (at == server.atom._NET_NUMBER_OF_DESKTOPS) {
if (!taskbar_enabled) return;
server.nb_desktop = server_get_number_of_desktop ();
cleanup_taskbar();
init_taskbar();
for (i=0 ; i < nb_panel ; i++) {
set_panel_items(&panel1[i]);
init_taskbar_panel(&panel1[i]);
set_panel_items_order(&panel1[i]);
panel1[i].area.resize = 1;
}
visible_object();
@ -501,6 +503,7 @@ void event_property_notify (XEvent *e)
}
// Change desktop
else if (at == server.atom._NET_CURRENT_DESKTOP) {
if (!taskbar_enabled) return;
int old_desktop = server.desktop;
server.desktop = server_get_current_desktop ();
for (i=0 ; i < nb_panel ; i++) {