else if (panel_position & RIGHT) fputs(" right\n", fp);
else fputs(" center\n", fp);
fprintf(fp, "panel_size = %d %d\n", (int)panel_config->initial_width, (int)panel_config->initial_height);
- fprintf(fp, "panel_margin = %d %d\n", panel_config->marginx, panel_config->marginy);
+ fprintf(fp, "panel_margin = %d %d\n", panel_config->marginx, panel_config->marginy);
fprintf(fp, "panel_padding = %d %d %d\n", panel_config->area.paddingxlr, panel_config->area.paddingy, panel_config->area.paddingx);
fprintf(fp, "font_shadow = %d\n", panel_config->g_task.font_shadow);
fputs("panel_background_id = 1\n", fp);
Window id;
opcode = e->data.l[1];
-
switch (opcode) {
case SYSTEM_TRAY_REQUEST_DOCK:
id = e->data.l[2];
break;
case SYSTEM_TRAY_BEGIN_MESSAGE:
- printf("message from dockapp\n");
- id = e->window;
- break;
-
case SYSTEM_TRAY_CANCEL_MESSAGE:
- printf("message cancelled\n");
- id = e->window;
+ // we don't show baloons messages.
break;
default:
if (opcode == server.atom._NET_SYSTEM_TRAY_MESSAGE_DATA) {
- printf("message from dockapp:\n %s\n", e->data.b);
- id = e->window;
+ printf("message from dockapp: %s\n", e->data.b);
}
- // unknown message type. not in the spec
+ else
+ printf("SYSTEM_TRAY : unknown message type\n");
break;
}
}
+void refresh_systray()
+{
+ TrayWindow *traywin;
+ GSList *l;
+ for (l = systray.list_icons; l ; l = l->next) {
+ traywin = (TrayWindow*)l->data;
+ XClearArea(server.dsp, traywin->id, 0, 0, traywin->width, traywin->height, True);
+ }
+}
+
}
panel_refresh = 1;
}
- // Wallpaper changed
else if (at == server.atom._XROOTPMAP_ID) {
+ // change Wallpaper
for (i=0 ; i < nb_panel ; i++) {
set_panel_background(&panel1[i]);
}
+ refresh_systray();
panel_refresh = 1;
}
}
panel = get_panel(e->xany.window);
if (!panel) return;
+ // TODO : one panel_refresh per panel ?
+ panel_refresh = 1;
/*
if (systray.area.on_screen) {
// force trayer refresh
//x11_refresh_window(tray_data.dpy, ti->wid, ti->l.wnd_sz.x, ti->l.wnd_sz.y, True);
}
*/
- panel_refresh = 1;
- //XCopyArea (server.dsp, panel->temp_pmap, panel->main_win, server.gc, 0, 0, panel->area.width, panel->area.height, 0, 0);
-
}
void event_configure_notify (Window win)
{
+ // check 'win' move in systray
+ TrayWindow *traywin;
+ GSList *l;
+ for (l = systray.list_icons; l ; l = l->next) {
+ traywin = (TrayWindow*)l->data;
+ if (traywin->id == win) {
+ XMoveResizeWindow(server.dsp, traywin->id, traywin->x, traywin->y, traywin->width, traywin->height);
+ return;
+ }
+ }
+
+ // check 'win' move in another monitor
if (nb_panel == 1) return;
if (server.nb_monitor == 1) return;
-
Task *tsk = task_get_task (win);
if (!tsk) return;
Panel *p = tsk->area.panel;
if (p->monitor != window_get_monitor (win)) {
- // task on another monitor
remove_task (tsk);
add_task (win);
if (win == window_get_active ()) {
event_configure_notify (e.xconfigure.window);
break;
+ case ReparentNotify:
+ if (e.xany.window == server.root_win) // reparented to us
+ break;
case UnmapNotify:
case DestroyNotify:
- if (!systray.area.on_screen) break;
+ if (!systray.area.on_screen)
+ break;
for (it = systray.list_icons; it; it = g_slist_next(it)) {
if (((TrayWindow*)it->data)->id == e.xany.window) {
remove_icon((TrayWindow*)it->data);
case ClientMessage:
if (!systray.area.on_screen) break;
- //printf("ClientMessage\n");
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);
}