summaryrefslogtreecommitdiff
path: root/charpick/charpick.c
diff options
context:
space:
mode:
Diffstat (limited to 'charpick/charpick.c')
-rw-r--r--charpick/charpick.c41
1 files changed, 5 insertions, 36 deletions
diff --git a/charpick/charpick.c b/charpick/charpick.c
index 1c4c8539..17ce55d0 100644
--- a/charpick/charpick.c
+++ b/charpick/charpick.c
@@ -329,40 +329,6 @@ populate_menu (charpick_data *curr_data)
}
static void
-get_menu_pos (GtkMenu *menu, gint *x, gint *y, gboolean *push_in, gpointer data)
-{
- charpick_data *curr_data = data;
- GtkRequisition reqmenu;
- gint tempx, tempy, width, height;
- gint screen_width, screen_height;
-
- gtk_widget_get_preferred_size (GTK_WIDGET (menu), NULL, &reqmenu);
- gdk_window_get_origin (GDK_WINDOW (gtk_widget_get_window(curr_data->applet)), &tempx, &tempy);
- gdk_window_get_geometry (GDK_WINDOW (gtk_widget_get_window(curr_data->applet)), NULL, NULL,
- &width, &height
- );
-
- switch (mate_panel_applet_get_orient (MATE_PANEL_APPLET (curr_data->applet))) {
- case MATE_PANEL_APPLET_ORIENT_DOWN:
- tempy += height;
- break;
- case MATE_PANEL_APPLET_ORIENT_UP:
- tempy -= reqmenu.height;
- break;
- case MATE_PANEL_APPLET_ORIENT_LEFT:
- tempx -= reqmenu.width;
- break;
- case MATE_PANEL_APPLET_ORIENT_RIGHT:
- tempx += width;
- break;
- }
- screen_width = WidthOfScreen (gdk_x11_screen_get_xscreen (gdk_screen_get_default ()));
- screen_height = HeightOfScreen (gdk_x11_screen_get_xscreen (gdk_screen_get_default ()));
- *x = CLAMP (tempx, 0, MAX (0, screen_width - reqmenu.width));
- *y = CLAMP (tempy, 0, MAX (0, screen_height - reqmenu.height));
-}
-
-static void
chooser_button_clicked (GtkButton *button, charpick_data *curr_data)
{
if (gtk_widget_get_visible (curr_data->menu))
@@ -371,8 +337,11 @@ chooser_button_clicked (GtkButton *button, charpick_data *curr_data)
gtk_menu_set_screen (GTK_MENU (curr_data->menu),
gtk_widget_get_screen (GTK_WIDGET (curr_data->applet)));
- gtk_menu_popup (GTK_MENU (curr_data->menu), NULL, NULL, get_menu_pos, curr_data,
- 0, gtk_get_current_event_time());
+ gtk_menu_popup_at_widget (GTK_MENU (curr_data->menu),
+ GTK_WIDGET (button),
+ GDK_GRAVITY_SOUTH_WEST,
+ GDK_GRAVITY_NORTH_WEST,
+ NULL);
}
}