Task *tsk;
for (l0 = tskbar->area.list; l0 ; l0 = l0->next) {
tsk = l0->data;
- if (x >= tsk->area.posx && x <= (tsk->area.posx + tsk->area.width)) {
+ if (tsk->area.on_screen && x >= tsk->area.posx && x <= (tsk->area.posx + tsk->area.width)) {
return tsk;
}
}
Task *tsk;
for (l0 = tskbar->area.list; l0 ; l0 = l0->next) {
tsk = l0->data;
- if (y >= tsk->area.posy && y <= (tsk->area.posy + tsk->area.height)) {
+ if (tsk->area.on_screen && y >= tsk->area.posy && y <= (tsk->area.posy + tsk->area.height)) {
return tsk;
}
}
Panel *panel = get_panel(e->xany.window);
if (!panel) return;
- if (panel_mode == MULTI_DESKTOP)
- task_drag = click_task(panel, e->xbutton.x, e->xbutton.y);
+ task_drag = click_task(panel, e->xbutton.x, e->xbutton.y);
if (wm_menu && !task_drag && !click_clock(panel, e->xbutton.x, e->xbutton.y) && (e->xbutton.button != 1) ) {
// forward the click to the desktop window (thanks conky)
}
// Change desktop
else if (at == server.atom._NET_CURRENT_DESKTOP) {
+ int old_desktop = server.desktop;
server.desktop = server_get_current_desktop ();
for (i=0 ; i < nb_panel ; i++) {
Panel *panel = &panel1[i];
if (panel_mode == MULTI_DESKTOP && panel->g_taskbar.use_active) {
- // redraw taskbar
+ // redraw both taskbar
+ panel->taskbar[old_desktop].area.is_active = 0;
+ panel->taskbar[old_desktop].area.redraw = 1;
+ panel->taskbar[server.desktop].area.is_active = 1;
+ panel->taskbar[server.desktop].area.redraw = 1;
panel_refresh = 1;
- Taskbar *tskbar;
- Task *tsk;
- GSList *l;
- for (j=0 ; j < panel->nb_desktop ; j++) {
- tskbar = &panel->taskbar[j];
- if (tskbar->area.is_active) {
- tskbar->area.is_active = 0;
- tskbar->area.redraw = 1;
- for (l = tskbar->area.list; l ; l = l->next) {
- tsk = l->data;
- tsk->area.redraw = 1;
- }
- }
- if (j == server.desktop) {
- tskbar->area.is_active = 1;
- tskbar->area.redraw = 1;
- for (l = tskbar->area.list; l ; l = l->next) {
- tsk = l->data;
- tsk->area.redraw = 1;
- }
- }
+ }
+ // check ALLDESKTOP task => resize taskbar
+ Taskbar *tskbar;
+ Task *tsk;
+ GSList *l;
+ tskbar = &panel->taskbar[old_desktop];
+ for (l = tskbar->area.list; l ; l = l->next) {
+ tsk = l->data;
+ if (tsk->desktop == ALLDESKTOP) {
+ tsk->area.on_screen = 0;
+ tskbar->area.resize = 1;
+ panel_refresh = 1;
+ }
+ }
+ tskbar = &panel->taskbar[server.desktop];
+ for (l = tskbar->area.list; l ; l = l->next) {
+ tsk = l->data;
+ if (tsk->desktop == ALLDESKTOP) {
+ tsk->area.on_screen = 1;
+ tskbar->area.resize = 1;
}
}
}
if (tsk->win == tsk2->win && tsk != tsk2) {
tsk2->icon_width = tsk->icon_width;
tsk2->icon_height = tsk->icon_height;
- tsk2->icon_data = tsk->icon_data;
- tsk2->icon_data_active = tsk->icon_data_active;
+ tsk2->icon = tsk->icon;
+ tsk2->icon_active = tsk->icon_active;
tsk2->area.redraw = 1;
}
}
}
else if (at == server.atom.WM_HINTS) {
XWMHints* wmhints = XGetWMHints(server.dsp, win);
- if (wmhints->flags & XUrgencyHint) {
+ if (wmhints && wmhints->flags & XUrgencyHint) {
task_urgent = tsk;
tick_urgent = 0;
time_precision = 1;
break;
case ConfigureNotify:
+ //XMoveWindow(dpy, fen, pos_x, pos_y);
+ //XResizeWindow(dpy, fen, largeur, hauteur);
if (e.xconfigure.window == server.root_win)
goto load_config;
else