[gtk+] about dialog: Add a "system" tab
- From: Matthias Clasen <matthiasc src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+] about dialog: Add a "system" tab
- Date: Thu, 12 Jan 2017 20:30:46 +0000 (UTC)
commit 3024956df11fde9d4879e595c6fda911073a95e3
Author: Matthias Clasen <mclasen redhat com>
Date: Thu Dec 29 23:12:42 2016 -0500
about dialog: Add a "system" tab
This is a free-form tab that can contain information about the
system environment. To see it, set GtkAboutDialog::system-information
to a non-NULL value.
https://bugzilla.gnome.org/show_bug.cgi?id=776604
gtk/gtkaboutdialog.c | 102 +++++++++++++++++++++++++++++++++++++++++++++-
gtk/gtkaboutdialog.h | 5 ++
gtk/ui/gtkaboutdialog.ui | 49 +++++++++++++++++-----
3 files changed, 144 insertions(+), 12 deletions(-)
---
diff --git a/gtk/gtkaboutdialog.c b/gtk/gtkaboutdialog.c
index c527949..490a66d 100644
--- a/gtk/gtkaboutdialog.c
+++ b/gtk/gtkaboutdialog.c
@@ -142,6 +142,7 @@ struct _GtkAboutDialogPrivate
gchar *website_text;
gchar *translator_credits;
gchar *license;
+ gchar *system_information;
gchar **authors;
gchar **documenters;
@@ -151,11 +152,13 @@ struct _GtkAboutDialogPrivate
gboolean credits_page_initialized;
gboolean license_page_initialized;
+ gboolean system_page_initialized;
GtkWidget *stack;
GtkWidget *stack_switcher;
GtkWidget *credits_button;
GtkWidget *license_button;
+ GtkWidget *system_button;
GtkWidget *logo_image;
GtkWidget *name_label;
@@ -167,9 +170,11 @@ struct _GtkAboutDialogPrivate
GtkWidget *credits_page;
GtkWidget *license_page;
+ GtkWidget *system_page;
GtkWidget *credits_grid;
GtkWidget *license_view;
+ GtkWidget *system_view;
GdkCursor *hand_cursor;
GdkCursor *regular_cursor;
@@ -194,6 +199,7 @@ enum
PROP_WEBSITE,
PROP_WEBSITE_LABEL,
PROP_LICENSE,
+ PROP_SYSTEM_INFORMATION,
PROP_AUTHORS,
PROP_DOCUMENTERS,
PROP_TRANSLATOR_CREDITS,
@@ -228,6 +234,7 @@ static void set_cursor_if_appropriate (GtkAboutDialog
gint y);
static void populate_credits_page (GtkAboutDialog *about);
static void populate_license_page (GtkAboutDialog *about);
+static void populate_system_page (GtkAboutDialog *about);
static void close_cb (GtkAboutDialog *about);
static gboolean gtk_about_dialog_activate_link (GtkAboutDialog *about,
const gchar *uri);
@@ -282,6 +289,14 @@ stack_visible_child_notify (GtkStack *stack,
priv->license_page_initialized = TRUE;
}
}
+ else if (child == priv->system_page)
+ {
+ if (!priv->system_page_initialized)
+ {
+ populate_system_page (about);
+ priv->system_page_initialized = TRUE;
+ }
+ }
return FALSE;
}
@@ -399,6 +414,10 @@ gtk_about_dialog_class_init (GtkAboutDialogClass *klass)
* #GtkAboutDialog:license-type property is set to %GTK_LICENSE_CUSTOM
* as a side effect.
*
+ * The text may contain links in this format <http://www.some.place/>
+ * and email references in the form <mail-to some body>, and these will
+ * be converted into clickable links.
+ *
* Since: 2.6
*/
props[PROP_LICENSE] =
@@ -409,6 +428,27 @@ gtk_about_dialog_class_init (GtkAboutDialogClass *klass)
GTK_PARAM_READWRITE | G_PARAM_EXPLICIT_NOTIFY);
/**
+ * GtkAboutDialog:system-information:
+ *
+ * Information about the system on which the program is running.
+ * This is displayed in a separate tab, therefore it is fine to use
+ * a long multi-paragraph text. Note that the text should contain
+ * the intended linebreaks.
+ *
+ * The text may contain links in this format <http://www.some.place/>
+ * and email references in the form <mail-to some body>, and these will
+ * be converted into clickable links.
+ *
+ * Since: 3.90
+ */
+ props[PROP_SYSTEM_INFORMATION] =
+ g_param_spec_string ("system-information",
+ P_("System Information"),
+ P_("Information about the system on which the program is running"),
+ NULL,
+ GTK_PARAM_READWRITE | G_PARAM_EXPLICIT_NOTIFY);
+
+ /**
* GtkAboutDialog:license-type:
*
* The license of the program, as a value of the %GtkLicense enumeration.
@@ -592,8 +632,10 @@ gtk_about_dialog_class_init (GtkAboutDialogClass *klass)
gtk_widget_class_bind_template_child_private (widget_class, GtkAboutDialog, website_label);
gtk_widget_class_bind_template_child_private (widget_class, GtkAboutDialog, credits_page);
gtk_widget_class_bind_template_child_private (widget_class, GtkAboutDialog, license_page);
+ gtk_widget_class_bind_template_child_private (widget_class, GtkAboutDialog, system_page);
gtk_widget_class_bind_template_child_private (widget_class, GtkAboutDialog, credits_grid);
gtk_widget_class_bind_template_child_private (widget_class, GtkAboutDialog, license_view);
+ gtk_widget_class_bind_template_child_private (widget_class, GtkAboutDialog, system_view);
gtk_widget_class_bind_template_callback (widget_class, emit_activate_link);
gtk_widget_class_bind_template_callback (widget_class, text_view_event_after);
@@ -619,7 +661,8 @@ update_stack_switcher_visibility (GtkAboutDialog *about)
GtkAboutDialogPrivate *priv = about->priv;
if (gtk_widget_get_visible (priv->credits_page) ||
- gtk_widget_get_visible (priv->license_page))
+ gtk_widget_get_visible (priv->license_page) ||
+ gtk_widget_get_visible (priv->system_page))
gtk_widget_show (priv->stack_switcher);
else
gtk_widget_hide (priv->stack_switcher);
@@ -639,6 +682,19 @@ update_license_button_visibility (GtkAboutDialog *about)
}
static void
+update_system_button_visibility (GtkAboutDialog *about)
+{
+ GtkAboutDialogPrivate *priv = about->priv;
+
+ if (priv->system_information != NULL && priv->system_information[0] != '\0')
+ gtk_widget_show (priv->system_page);
+ else
+ gtk_widget_hide (priv->system_page);
+
+ update_stack_switcher_visibility (about);
+}
+
+static void
update_credits_button_visibility (GtkAboutDialog *about)
{
GtkAboutDialogPrivate *priv = about->priv;
@@ -841,6 +897,9 @@ gtk_about_dialog_set_property (GObject *object,
case PROP_LICENSE:
gtk_about_dialog_set_license (about, g_value_get_string (value));
break;
+ case PROP_SYSTEM_INFORMATION:
+ gtk_about_dialog_set_system_information (about, g_value_get_string (value));
+ break;
case PROP_LICENSE_TYPE:
gtk_about_dialog_set_license_type (about, g_value_get_enum (value));
break;
@@ -906,6 +965,9 @@ gtk_about_dialog_get_property (GObject *object,
case PROP_LICENSE:
g_value_set_string (value, priv->license);
break;
+ case PROP_SYSTEM_INFORMATION:
+ g_value_set_string (value, priv->system_information);
+ break;
case PROP_LICENSE_TYPE:
g_value_set_enum (value, priv->license_type);
break;
@@ -1354,6 +1416,30 @@ gtk_about_dialog_set_license (GtkAboutDialog *about,
g_object_notify_by_pspec (G_OBJECT (about), props[PROP_LICENSE_TYPE]);
}
+const gchar *
+gtk_about_dialog_get_system_information (GtkAboutDialog *about)
+{
+ g_return_val_if_fail (GTK_IS_ABOUT_DIALOG (about), NULL);
+
+ return about->priv->system_information;
+}
+
+void
+gtk_about_dialog_set_system_information (GtkAboutDialog *about,
+ const gchar *system_information)
+{
+ GtkAboutDialogPrivate *priv;
+
+ g_return_if_fail (GTK_IS_ABOUT_DIALOG (about));
+
+ priv = about->priv;
+
+ priv->system_information = g_strdup (system_information);
+ update_system_button_visibility (about);
+
+ g_object_notify_by_pspec (G_OBJECT (about), props[PROP_SYSTEM_INFORMATION]);
+}
+
/**
* gtk_about_dialog_get_wrap_license:
* @about: a #GtkAboutDialog
@@ -2354,6 +2440,20 @@ populate_license_page (GtkAboutDialog *about)
g_object_unref (buffer);
}
+static void
+populate_system_page (GtkAboutDialog *about)
+{
+ GtkAboutDialogPrivate *priv = about->priv;
+ GtkTextBuffer *buffer;
+ gchar *strings[2];
+
+ strings[0] = priv->system_information;
+ strings[1] = NULL;
+ buffer = text_buffer_new (about, strings);
+ gtk_text_view_set_buffer (GTK_TEXT_VIEW (priv->system_view), buffer);
+ g_object_unref (buffer);
+}
+
/**
* gtk_about_dialog_new:
*
diff --git a/gtk/gtkaboutdialog.h b/gtk/gtkaboutdialog.h
index d00ea09..98a532e 100644
--- a/gtk/gtkaboutdialog.h
+++ b/gtk/gtkaboutdialog.h
@@ -163,6 +163,11 @@ void gtk_about_dialog_set_wrap_license (GtkAboutDialog
gboolean wrap_license);
GDK_AVAILABLE_IN_ALL
+const gchar * gtk_about_dialog_get_system_information (GtkAboutDialog *about);
+GDK_AVAILABLE_IN_ALL
+void gtk_about_dialog_set_system_information (GtkAboutDialog *about,
+ const gchar *system_information);
+GDK_AVAILABLE_IN_ALL
const gchar * gtk_about_dialog_get_website (GtkAboutDialog *about);
GDK_AVAILABLE_IN_ALL
void gtk_about_dialog_set_website (GtkAboutDialog *about,
diff --git a/gtk/ui/gtkaboutdialog.ui b/gtk/ui/gtkaboutdialog.ui
index 5c795a4..3a27296 100644
--- a/gtk/ui/gtkaboutdialog.ui
+++ b/gtk/ui/gtkaboutdialog.ui
@@ -87,7 +87,6 @@
</object>
<packing>
<property name="fill">0</property>
- <property name="position">1</property>
</packing>
</child>
<child>
@@ -99,13 +98,11 @@
</object>
<packing>
<property name="fill">0</property>
- <property name="position">2</property>
</packing>
</child>
<child>
- <object class="GtkLabel" id="license_label">
- <property name="label">license</property>
- <property name="use-markup">1</property>
+ <object class="GtkLabel" id="copyright_label">
+ <property name="label">copyright</property>
<property name="justify">center</property>
<property name="wrap">1</property>
<property name="selectable">1</property>
@@ -114,13 +111,12 @@
</object>
<packing>
<property name="fill">0</property>
- <property name="pack-type">end</property>
- <property name="position">3</property>
</packing>
</child>
<child>
- <object class="GtkLabel" id="copyright_label">
- <property name="label">copyright</property>
+ <object class="GtkLabel" id="license_label">
+ <property name="label">license</property>
+ <property name="use-markup">1</property>
<property name="justify">center</property>
<property name="wrap">1</property>
<property name="selectable">1</property>
@@ -129,8 +125,6 @@
</object>
<packing>
<property name="fill">0</property>
- <property name="pack-type">end</property>
- <property name="position">4</property>
</packing>
</child>
</object>
@@ -212,6 +206,39 @@
<property name="title" translatable="yes">License</property>
</packing>
</child>
+ <child>
+ <object class="GtkBox" id="system_page">
+ <property name="no-show-all">1</property>
+ <property name="orientation">vertical</property>
+ <property name="spacing">8</property>
+ <child>
+ <object class="GtkScrolledWindow">
+ <property name="visible">1</property>
+ <property name="hscrollbar-policy">never</property>
+ <property name="shadow-type">in</property>
+ <child>
+ <object class="GtkTextView" id="system_view">
+ <property name="visible">1</property>
+ <property name="editable">0</property>
+ <property name="left-margin">8</property>
+ <property name="right-margin">8</property>
+ <property name="cursor-visible">0</property>
+ <signal name="event-after" handler="text_view_event_after" swapped="no"/>
+ <signal name="key-press-event" handler="text_view_key_press_event" swapped="no"/>
+ <signal name="motion-notify-event" handler="text_view_motion_notify_event"
swapped="no"/>
+ </object>
+ </child>
+ </object>
+ <packing>
+ <property name="expand">1</property>
+ </packing>
+ </child>
+ </object>
+ <packing>
+ <property name="name">system</property>
+ <property name="title" translatable="yes">System</property>
+ </packing>
+ </child>
</object>
<packing>
<property name="expand">1</property>
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]