Factor out titlebar click actions
So they can be made configurable. https://bugzilla.gnome.org/show_bug.cgi?id=729782
This commit is contained in:
@ -1354,6 +1354,32 @@ popover_destroy (GtkWindowPopover *popover)
|
|||||||
g_free (popover);
|
g_free (popover);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
static gboolean
|
||||||
|
gtk_window_titlebar_action (GtkWindow *window,
|
||||||
|
const GdkEvent *event,
|
||||||
|
guint button,
|
||||||
|
gint n_press)
|
||||||
|
{
|
||||||
|
switch (button)
|
||||||
|
{
|
||||||
|
case GDK_BUTTON_PRIMARY:
|
||||||
|
if (n_press == 2)
|
||||||
|
{
|
||||||
|
_gtk_window_toggle_maximized (window);
|
||||||
|
return TRUE;
|
||||||
|
}
|
||||||
|
return FALSE;
|
||||||
|
case GDK_BUTTON_MIDDLE:
|
||||||
|
gdk_window_lower (gtk_widget_get_window (GTK_WIDGET (window)));
|
||||||
|
return TRUE;
|
||||||
|
case GDK_BUTTON_SECONDARY:
|
||||||
|
gtk_window_do_popup (window, (GdkEventButton*) event);
|
||||||
|
return TRUE;
|
||||||
|
default:
|
||||||
|
return FALSE;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
static void
|
static void
|
||||||
multipress_gesture_pressed_cb (GtkGestureMultiPress *gesture,
|
multipress_gesture_pressed_cb (GtkGestureMultiPress *gesture,
|
||||||
gint n_press,
|
gint n_press,
|
||||||
@ -1383,14 +1409,14 @@ multipress_gesture_pressed_cb (GtkGestureMultiPress *gesture,
|
|||||||
|
|
||||||
if (button == GDK_BUTTON_SECONDARY && region == GTK_WINDOW_REGION_TITLE)
|
if (button == GDK_BUTTON_SECONDARY && region == GTK_WINDOW_REGION_TITLE)
|
||||||
{
|
{
|
||||||
gtk_window_do_popup (window, (GdkEventButton*) event);
|
if (gtk_window_titlebar_action (window, event, button, n_press))
|
||||||
gtk_gesture_set_sequence_state (GTK_GESTURE (gesture),
|
gtk_gesture_set_sequence_state (GTK_GESTURE (gesture),
|
||||||
sequence, GTK_EVENT_SEQUENCE_CLAIMED);
|
sequence, GTK_EVENT_SEQUENCE_CLAIMED);
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
else if (button == GDK_BUTTON_MIDDLE && region == GTK_WINDOW_REGION_TITLE)
|
else if (button == GDK_BUTTON_MIDDLE && region == GTK_WINDOW_REGION_TITLE)
|
||||||
{
|
{
|
||||||
gdk_window_lower (gtk_widget_get_window (GTK_WIDGET (window)));
|
if (gtk_window_titlebar_action (window, event, button, n_press))
|
||||||
gtk_gesture_set_sequence_state (GTK_GESTURE (gesture),
|
gtk_gesture_set_sequence_state (GTK_GESTURE (gesture),
|
||||||
sequence, GTK_EVENT_SEQUENCE_CLAIMED);
|
sequence, GTK_EVENT_SEQUENCE_CLAIMED);
|
||||||
return;
|
return;
|
||||||
@ -1404,8 +1430,7 @@ multipress_gesture_pressed_cb (GtkGestureMultiPress *gesture,
|
|||||||
{
|
{
|
||||||
case GTK_WINDOW_REGION_CONTENT:
|
case GTK_WINDOW_REGION_CONTENT:
|
||||||
if (event_widget != widget)
|
if (event_widget != widget)
|
||||||
gtk_widget_style_get (event_widget, "window-dragging",
|
gtk_widget_style_get (event_widget, "window-dragging", &window_drag, NULL);
|
||||||
&window_drag, NULL);
|
|
||||||
|
|
||||||
if (!window_drag)
|
if (!window_drag)
|
||||||
{
|
{
|
||||||
@ -1416,7 +1441,7 @@ multipress_gesture_pressed_cb (GtkGestureMultiPress *gesture,
|
|||||||
/* fall thru */
|
/* fall thru */
|
||||||
case GTK_WINDOW_REGION_TITLE:
|
case GTK_WINDOW_REGION_TITLE:
|
||||||
if (n_press == 2)
|
if (n_press == 2)
|
||||||
_gtk_window_toggle_maximized (window);
|
gtk_window_titlebar_action (window, event, button, n_press);
|
||||||
if (n_press == 1)
|
if (n_press == 1)
|
||||||
priv->drag_possible = TRUE;
|
priv->drag_possible = TRUE;
|
||||||
break;
|
break;
|
||||||
|
Reference in New Issue
Block a user