#include "config.h"
#include "task.h"
#include "taskbar.h"
+#include "systraybar.h"
#include "panel.h"
-#include "docker.h"
-#include "net.h"
-#include "kde.h"
void signal_handler(int sig)
XSetErrorHandler ((XErrorHandler) server_catch_error);
- // init systray
- //display = server.dsp;
- //root = RootWindow(display, DefaultScreen(display));
- //create_main_window();
- //kde_init();
- //net_init();
- //printf("ici 4\n");
-
imlib_context_set_display (server.dsp);
imlib_context_set_visual (server.visual);
imlib_context_set_colormap (DefaultColormap (server.dsp, server.screen));
if (panel_mode != MULTI_DESKTOP) {
// drag and drop disabled
- //XLowerWindow (server.dsp, panel.main_win);
+ XLowerWindow (server.dsp, panel->main_win);
return;
}
int y = e->xbutton.y;
for (l0 = panel->area.list; l0 ; l0 = l0->next) {
tskbar = l0->data;
+ if (!tskbar->area.visible) continue;
if (x >= tskbar->area.posx && x <= (tskbar->area.posx + tskbar->area.width))
break;
}
}
}
- //XLowerWindow (server.dsp, panel.main_win);
+ XLowerWindow (server.dsp, panel->main_win);
}
GSList *l0;
for (l0 = panel->area.list; l0 ; l0 = l0->next) {
tskbar = l0->data;
+ if (!tskbar->area.visible) continue;
if (x >= tskbar->area.posx && x <= (tskbar->area.posx + tskbar->area.width))
goto suite;
}
// TODO: check better solution to keep window below
- //XLowerWindow (server.dsp, panel.main_win);
+ XLowerWindow (server.dsp, panel->main_win);
task_drag = 0;
return;
}
// to keep window below
- //XLowerWindow (server.dsp, panel.main_win);
+ XLowerWindow (server.dsp, panel->main_win);
}
cleanup_taskbar();
init_taskbar();
visible_object();
+ for (i=0 ; i < nb_panel ; i++) {
+ panel1[i].area.resize = 1;
+ }
task_refresh_tasklist();
panel_refresh = 1;
}
// task on another monitor
remove_task (tsk);
add_task (win);
+ if (win == window_get_active ()) {
+ Task *tsk = task_get_task (win);
+ tsk->area.is_active = 1;
+ task_active = tsk;
+ }
panel_refresh = 1;
}
}
int i;
for (i=0 ; i < nb_panel ; i++) {
- panel1[i].clock.area.redraw = 1;
+ panel1[i].clock.area.resize = 1;
}
panel_refresh = 1;
}
}
config_finish();
- // BUG: refresh(clock) is needed here, but 'on the paper' it's not necessary.
- for (i=0 ; i < nb_panel ; i++) {
- refresh(&panel1[i].clock.area);
- }
-
x11_fd = ConnectionNumber(server.dsp);
XSync(server.dsp, False);
case Expose:
panel = get_panel(e.xany.window);
if (!panel) break;
- //XCopyArea (server.dsp, panel.area.pix.pmap, server.root_win, server.gc_root, 0, 0, panel.area.width, panel.area.height, server.posx, server.posy);
- //XCopyArea (server.dsp, server.pmap, panel.main_win, server.gc, panel.area.paddingxlr, 0, panel.area.width-(2*panel.area.paddingxlr), panel.area.height, 0, 0);
- XCopyArea (server.dsp, panel->root_pmap, panel->main_win, server.gc, 0, 0, panel->area.width, panel->area.height, 0, 0);
+ XCopyArea (server.dsp, panel->temp_pmap, panel->main_win, server.gc, 0, 0, panel->area.width, panel->area.height, 0, 0);
break;
case PropertyNotify:
- //printf("PropertyNotify %lx\n", e.xproperty.window);
event_property_notify (e.xproperty.window, e.xproperty.atom);
break;
goto load_config;
else
event_configure_notify (e.xconfigure.window);
+ break;
+
+ case UnmapNotify:
+ case DestroyNotify:
+ /*
+ GSList *it;
+ for (it = icons; it; it = g_slist_next(it)) {
+ if (((TrayWindow*)it->data)->id == e.xany.window) {
+ icon_remove(it);
+ break;
+ }
+ }*/
+ break;
+
+ case ClientMessage:
+ break;
+ if (e.xclient.message_type == server.atom._NET_SYSTEM_TRAY_OPCODE && e.xclient.format == 32)
+ // && e.xclient.window == net_sel_win)
+ net_message(&e.xclient);
break;
}
}
}
if (panel_refresh) {
- for (i=0 ; i < nb_panel ; i++)
- visual_refresh(&panel1[i]);
- XFlush (server.dsp);
panel_refresh = 0;
+
+ for (i=0 ; i < nb_panel ; i++) {
+ panel = &panel1[i];
+
+ if (panel->temp_pmap) XFreePixmap(server.dsp, panel->temp_pmap);
+ panel->temp_pmap = XCreatePixmap(server.dsp, server.root_win, panel->area.width, panel->area.height, server.depth);
+
+ refresh(panel);
+ XCopyArea(server.dsp, panel->temp_pmap, panel->main_win, server.gc, 0, 0, panel->area.width, panel->area.height, 0, 0);
+ }
+ XFlush (server.dsp);
}
}
}
+// ****************************************************
+// main_win doesn't include panel.area.paddingx, so we have WM capabilities on left and right.
+// this feature is disabled !
+//XCopyArea (server.dsp, server.pmap, p->main_win, server.gc, p->area.paddingxlr, 0, p->area.width-(2*p->area.paddingxlr), p->area.height, 0, 0);
+//XCopyArea (server.dsp, panel.area.pix.pmap, server.root_win, server.gc_root, 0, 0, panel.area.width, panel.area.height, server.posx, server.posy);
+//XCopyArea (server.dsp, server.pmap, panel.main_win, server.gc, panel.area.paddingxlr, 0, panel.area.width-(2*panel.area.paddingxlr), panel.area.height, 0, 0);