summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorScott Moynes <smoynes@nexus.carleton.ca>2003-07-28 02:52:56 +0000
committerScott Moynes <smoynes@nexus.carleton.ca>2003-07-28 02:52:56 +0000
commitf37a9190959279d0f3c1cd7e62099e74930d36d2 (patch)
treea67d2d9a0de5ef4d5eec0f283b4257c3e143e3a0
parent632b2af7a8283eff025456d3bb39a362311f4182 (diff)
Menu stuff.
Testing may begin.
-rw-r--r--openbox/event.c1
-rw-r--r--openbox/menu.c33
-rw-r--r--plugins/menu/client_menu.c2
3 files changed, 23 insertions, 13 deletions
diff --git a/openbox/event.c b/openbox/event.c
index 69c85100..ce5be14d 100644
--- a/openbox/event.c
+++ b/openbox/event.c
@@ -1008,6 +1008,7 @@ static void event_handle_menu(ObClient *client, XEvent *e)
e->xbutton.y_root);
break;
}
+ break;
}
}
diff --git a/openbox/menu.c b/openbox/menu.c
index 7220c37b..03bca026 100644
--- a/openbox/menu.c
+++ b/openbox/menu.c
@@ -297,7 +297,7 @@ void menu_show_full(ObMenu *self, int x, int y, ObClient *client)
{
g_assert(self != NULL);
- menu_render(self);
+ self->update(self);
self->client = client;
@@ -319,7 +319,6 @@ void menu_hide(ObMenu *self) {
if (self->open_submenu)
menu_hide(self->open_submenu);
if (self->parent && self->parent->open_submenu == self) {
- self->over = NULL;
self->parent->open_submenu = NULL;
}
@@ -328,6 +327,11 @@ void menu_hide(ObMenu *self) {
grab_pointer(FALSE, None);
}
menu_visible = g_list_remove(menu_visible, self);
+ if (self->over) {
+ ((ObMenuEntry *)self->over->data)->hilite = FALSE;
+ menu_entry_render(self->over->data);
+ self->over = NULL;
+ }
}
}
@@ -385,7 +389,7 @@ void menu_entry_fire(ObMenuEntry *self, unsigned int button, unsigned int x,
{
ObMenu *m;
- if (button > 3) return;
+ if (button != 1) return;
if (self->action) {
self->action->data.any.c = self->parent->client;
@@ -461,7 +465,7 @@ void menu_control_mouseover(ObMenuEntry *self, gboolean enter)
ob_rr_theme->bwidth - ob_rr_theme->menu_overlap;
/* need to get the width. is this bad?*/
- menu_render(self->submenu);
+ self->parent->update(self->submenu);
a = screen_physical_area_monitor(self->parent->xin_area);
@@ -485,6 +489,7 @@ void menu_control_mouseover(ObMenuEntry *self, gboolean enter)
void menu_control_keyboard_nav(unsigned int key)
{
static ObMenu *current_menu = NULL;
+ ObMenuEntry *e = NULL;
ObKey obkey = OB_NUM_KEYS;
@@ -532,25 +537,29 @@ void menu_control_keyboard_nav(unsigned int key)
break;
}
case OB_KEY_RIGHT: {
- ObMenuEntry *e;
if (current_menu->over == NULL)
return;
-
e = (ObMenuEntry *)current_menu->over->data;
if (e->submenu) {
current_menu = e->submenu;
current_menu->over = current_menu->entries;
if (current_menu->over)
current_menu->mouseover(current_menu->over->data, TRUE);
- } else {
- current_menu->mouseover(e, FALSE);
- current_menu->over = NULL;
-
- /* zero is enter */
- menu_entry_fire(e, 0, 0, 0);
}
break;
}
+
+ case OB_KEY_RETURN: {
+ if (current_menu->over == NULL)
+ return;
+ e = (ObMenuEntry *)current_menu->over->data;
+
+ current_menu->mouseover(e, FALSE);
+ current_menu->over = NULL;
+ /* zero is enter */
+ menu_entry_fire(e, 0, 0, 0);
+
+ }
case OB_KEY_LEFT: {
if (current_menu->over != NULL) {
current_menu->mouseover(current_menu->over->data, FALSE);
diff --git a/plugins/menu/client_menu.c b/plugins/menu/client_menu.c
index 9edb3929..d48d1f05 100644
--- a/plugins/menu/client_menu.c
+++ b/plugins/menu/client_menu.c
@@ -52,7 +52,7 @@ void client_send_to_update(ObMenu *self)
menu_add_entry(self, e);
}
- self->update(self);
+ menu_render(self);
}
}