summaryrefslogtreecommitdiff
path: root/tests/testrevealer2.c
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2016-02-23 20:53:23 -0500
committerMatthias Clasen <mclasen@redhat.com>2016-02-23 20:53:23 -0500
commit566010e91d9337b947320afe80f41c63197cc49f (patch)
tree420f04eaaf8a28f05a52a17d5c285e1a74812757 /tests/testrevealer2.c
parent0c25c5d43d3a299698a54b31107339861e556a2d (diff)
downloadgtk+-566010e91d9337b947320afe80f41c63197cc49f.tar.gz
Add a testcase for revealer size allocation
This was taken from https://bugzilla.gnome.org/show_bug.cgi?id=761760
Diffstat (limited to 'tests/testrevealer2.c')
-rw-r--r--tests/testrevealer2.c82
1 files changed, 82 insertions, 0 deletions
diff --git a/tests/testrevealer2.c b/tests/testrevealer2.c
new file mode 100644
index 0000000000..23613b64f8
--- /dev/null
+++ b/tests/testrevealer2.c
@@ -0,0 +1,82 @@
+/* Written by Florian Muellner
+ * https://bugzilla.gnome.org/show_bug.cgi?id=761760
+ */
+
+#include <gtk/gtk.h>
+
+static void
+on_activate (GApplication *app,
+ gpointer data)
+{
+ static GtkWidget *window = NULL;
+
+ if (window == NULL)
+ {
+ GtkWidget *header, *sidebar_toggle, *animation_switch;
+ GtkWidget *hbox, *revealer, *sidebar, *img;
+
+ window = gtk_application_window_new (GTK_APPLICATION (app));
+ gtk_window_set_default_size (GTK_WINDOW (window), 400, 300);
+
+ /* titlebar */
+ header = gtk_header_bar_new ();
+ gtk_header_bar_set_show_close_button (GTK_HEADER_BAR (header), TRUE);
+ gtk_window_set_titlebar (GTK_WINDOW (window), header);
+
+ sidebar_toggle = gtk_toggle_button_new_with_label ("Show Sidebar");
+ gtk_header_bar_pack_start (GTK_HEADER_BAR (header), sidebar_toggle);
+
+ animation_switch = gtk_switch_new ();
+ gtk_widget_set_valign (animation_switch, GTK_ALIGN_CENTER);
+ gtk_header_bar_pack_end (GTK_HEADER_BAR (header), animation_switch);
+ gtk_header_bar_pack_end (GTK_HEADER_BAR (header),
+ gtk_label_new ("Animations"));
+
+ gtk_widget_show_all (header);
+
+ /* content */
+ hbox = gtk_box_new (GTK_ORIENTATION_HORIZONTAL, 0);
+ gtk_container_add (GTK_CONTAINER (window), hbox);
+
+ revealer = gtk_revealer_new ();
+ gtk_revealer_set_transition_type (GTK_REVEALER (revealer),
+ GTK_REVEALER_TRANSITION_TYPE_SLIDE_LEFT);
+ gtk_container_add (GTK_CONTAINER (hbox), revealer);
+
+ sidebar = gtk_box_new (GTK_ORIENTATION_VERTICAL, 0);
+ gtk_widget_set_size_request (sidebar, 150, -1);
+ gtk_style_context_add_class (gtk_widget_get_style_context (sidebar),
+ GTK_STYLE_CLASS_SIDEBAR);
+ gtk_container_add (GTK_CONTAINER (revealer), sidebar);
+
+ img = gtk_image_new ();
+ g_object_set (img, "icon-name", "face-smile-symbolic",
+ "pixel-size", 128,
+ "hexpand", TRUE,
+ "halign", GTK_ALIGN_CENTER,
+ "valign", GTK_ALIGN_CENTER,
+ NULL);
+ gtk_container_add (GTK_CONTAINER (hbox), img);
+ gtk_widget_show_all (hbox);
+
+ g_object_bind_property (sidebar_toggle, "active",
+ revealer, "reveal-child",
+ G_BINDING_SYNC_CREATE);
+ g_object_bind_property (gtk_settings_get_default(), "gtk-enable-animations",
+ animation_switch, "active",
+ G_BINDING_SYNC_CREATE | G_BINDING_BIDIRECTIONAL);
+
+ }
+ gtk_window_present (GTK_WINDOW (window));
+}
+
+int
+main (int argc, char *argv[])
+{
+ GtkApplication *app = gtk_application_new ("org.gtk.fmuellner.Revealer", 0);
+
+ g_signal_connect (app, "activate", G_CALLBACK (on_activate), NULL);
+
+ return g_application_run (G_APPLICATION (app), argc, argv);
+}
+