X-Git-Url: https://git.brokenzipper.com/gitweb?a=blobdiff_plain;f=plugins%2Fmenu%2Fclient_menu.c;h=142c665427b4401c4a96942c58c8e1d0c633c3d3;hb=cd12a2eae5b5b72df08d588ac71d1f6cf6725dfb;hp=2578129ec393a3933ab959154ebb555e0d0a402c;hpb=04a85677e535e6759ecde14b52e75789d8b8191e;p=chaz%2Fopenbox diff --git a/plugins/menu/client_menu.c b/plugins/menu/client_menu.c index 2578129e..142c6654 100644 --- a/plugins/menu/client_menu.c +++ b/plugins/menu/client_menu.c @@ -7,6 +7,8 @@ #include "kernel/frame.h" +#include "render/theme.h" + static char *PLUGIN_NAME = "client_menu"; static Menu *send_to_menu; @@ -45,14 +47,15 @@ void client_menu_show(Menu *self, int x, int y, Client *client) g_assert(!self->invalid); g_assert(client); - newy = client->frame->area.y + client->frame->a_focused_title->area.height; + newy = MAX(client->frame->area.y + client->frame->size.top, + y - theme_bwidth); - XMoveWindow(ob_display, self->frame, - MIN(x, screen_physical_size.width - self->size.width), - MIN(newy, screen_physical_size.height - self->size.height)); POINT_SET(self->location, - MIN(x, screen_physical_size.width - self->size.width), - MIN(newy, screen_physical_size.height - self->size.height)); + MIN(x, screen_physical_size.width - self->size.width - + theme_bwidth * 2), + MIN(newy, screen_physical_size.height - self->size.height - + theme_bwidth * 2)); + XMoveWindow(ob_display, self->frame, self->location.x, self->location.y); if (!self->shown) { XMapWindow(ob_display, self->frame); @@ -91,6 +94,8 @@ void *plugin_create() /* TODO: need config */ action_from_string("toggleshade"))); menu_add_entry(m, menu_entry_new("Omnipresent", action_from_string("toggleomnipresent"))); + menu_add_entry(m, menu_entry_new("Decorations", + action_from_string("toggledecorations"))); menu_add_entry(m, menu_entry_new_submenu("Layers", layer_menu)); layer_menu->parent = m;