From f045668198a98d744c88af508c4c5a8d0a51346d Mon Sep 17 00:00:00 2001 From: Teemu Ikonen <tpikonen@mailbox.org> Date: Mon, 20 Feb 2023 19:35:17 +0200 Subject: [PATCH 1/2] window: Maximize resizable transient windows on small screens Based on Purism adaptive patches by Alexander Mikhaylenko, https://source.puri.sm/Librem5/debs/gtk4/-/blob/pureos/byzantium/debian/patches/pureos/adaptive/ Only maximize transients on small (< 120 mm) screens --- gtk/gtkwindow.c | 11 +++++++++++ 1 file changed, 11 insertions(+) diff --git a/gtk/gtkwindow.c b/gtk/gtkwindow.c index bac2a25b89..e7d43f033e 100644 --- a/gtk/gtkwindow.c +++ b/gtk/gtkwindow.c @@ -32,6 +32,7 @@ #include "gtkbuildable.h" #include "gtkcheckbutton.h" #include "gtkcssshadowvalueprivate.h" +#include "deprecated/gtkdialog.h" #include "gtkdroptargetasync.h" #include "gtkeventcontrollerlegacy.h" #include "gtkeventcontrollerkey.h" @@ -64,6 +65,7 @@ #include "inspector/window.h" +#include "gdk/gdkmonitor.h" #include "gdk/gdkprofilerprivate.h" #include "gdk/gdksurfaceprivate.h" #include "gdk/gdktextureprivate.h" @@ -3989,6 +3991,8 @@ gtk_window_map (GtkWidget *widget) GtkWindow *window = GTK_WINDOW (widget); GtkWindowPrivate *priv = gtk_window_get_instance_private (window); GtkWidget *child = priv->child; + GdkMonitor *monitor; + gboolean is_dialog, on_small_screen; GTK_WIDGET_CLASS (gtk_window_parent_class)->map (widget); @@ -4002,6 +4006,13 @@ gtk_window_map (GtkWidget *widget) gtk_window_present_toplevel (window); + /* Transient windows can be considered pseudo-dialogs. */ + monitor = gdk_display_get_monitor_at_surface (priv->display, priv->surface); + on_small_screen = gdk_monitor_get_width_mm (monitor) < 120; + is_dialog = GTK_IS_DIALOG (widget) || !!gtk_window_get_transient_for (window); + if (on_small_screen && is_dialog && gtk_window_get_resizable (window)) + gtk_window_maximize (window); + if (priv->minimize_initially) gdk_toplevel_minimize (GDK_TOPLEVEL (priv->surface)); -- 2.41.0