[bijiben/wip/sadiq/modernize] empty-results-box: Use GtkBuilder templates
- From: Mohammed Sadiq <pksadiq src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [bijiben/wip/sadiq/modernize] empty-results-box: Use GtkBuilder templates
- Date: Sat, 28 Oct 2017 13:52:43 +0000 (UTC)
commit 6aa155d6b50875366333a50f626ac51f3e2cc041
Author: Mohammed Sadiq <sadiq sadiqpk org>
Date: Sat Oct 28 15:23:04 2017 +0530
empty-results-box: Use GtkBuilder templates
Move UI code to xml GtkBuilder templates.
Also, use G_DECLARE_FINAL_TYPE to remove lots of boilerplate code.
src/bjb-empty-results-box.c | 115 +++++++----------------------------
src/bjb-empty-results-box.h | 38 +-----------
src/bjb.gresource.xml | 3 +-
src/resources/empty-results-box.ui | 50 ++++++++++++++++
4 files changed, 77 insertions(+), 129 deletions(-)
---
diff --git a/src/bjb-empty-results-box.c b/src/bjb-empty-results-box.c
index fc00759..805ee6a 100644
--- a/src/bjb-empty-results-box.c
+++ b/src/bjb-empty-results-box.c
@@ -1,6 +1,7 @@
/*
* Bijiben
* Copyright © 2012, 2013 Red Hat, Inc.
+ * Copyright © 2017 Mohammed Sadiq <sadiq sadiqpk org>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
@@ -30,86 +31,18 @@
#include "bjb-empty-results-box.h"
-G_DEFINE_TYPE (BjbEmptyResultsBox, bjb_empty_results_box, GTK_TYPE_GRID);
-struct _BjbEmptyResultsBoxPrivate
+struct _BjbEmptyResultsBox
{
+ GtkGrid parent_instance;
+
GtkWidget *primary_label;
GtkWidget *image;
GtkLabel *details_label;
BjbEmptyResultsBoxType type;
};
-
-static void
-bjb_empty_results_box_constructed (GObject *object)
-{
- BjbEmptyResultsBox *self;
- BjbEmptyResultsBoxPrivate *priv;
- GtkStyleContext *context;
- GtkWidget *labels_grid;
- const gchar *label;
- gchar *markup;
- GFile *note_icon_file;
- GIcon *icon;
-
- G_OBJECT_CLASS (bjb_empty_results_box_parent_class)->constructed (object);
- self = BJB_EMPTY_RESULTS_BOX (object);
- priv = self->priv;
-
- gtk_widget_set_halign (GTK_WIDGET (self), GTK_ALIGN_CENTER);
- gtk_widget_set_hexpand (GTK_WIDGET (self), TRUE);
- gtk_widget_set_valign (GTK_WIDGET (self), GTK_ALIGN_CENTER);
- gtk_widget_set_vexpand (GTK_WIDGET (self), TRUE);
-
- gtk_orientable_set_orientation (GTK_ORIENTABLE (self), GTK_ORIENTATION_HORIZONTAL);
- gtk_grid_set_column_spacing (GTK_GRID (self), 12);
-
- context = gtk_widget_get_style_context (GTK_WIDGET (self));
- gtk_style_context_add_class (context, "dim-label");
-
- note_icon_file = g_file_new_for_uri ("resource://org/gnome/bijiben/note-symbolic.svg");
- icon = g_file_icon_new (note_icon_file);
- g_object_unref (note_icon_file);
-
- priv->image = gtk_image_new_from_gicon (icon, GTK_ICON_SIZE_DIALOG);
- g_object_unref (icon);
-
- gtk_container_add (GTK_CONTAINER (self), priv->image);
-
- labels_grid = gtk_grid_new ();
- gtk_orientable_set_orientation (GTK_ORIENTABLE (labels_grid), GTK_ORIENTATION_VERTICAL);
- gtk_grid_set_row_spacing (GTK_GRID (labels_grid), 0);
- gtk_widget_set_valign (labels_grid, GTK_ALIGN_START);
- gtk_container_add (GTK_CONTAINER (self), labels_grid);
-
- label = _("No notes");
- markup = g_markup_printf_escaped ("<big><b>%s</b></big>", label);
-
- priv->primary_label = gtk_label_new (NULL);
- gtk_label_set_markup (GTK_LABEL (priv->primary_label), markup);
- g_free (markup);
-
- gtk_widget_set_halign (priv->primary_label, GTK_ALIGN_START);
- gtk_widget_set_vexpand (priv->primary_label, TRUE);
- gtk_label_set_use_markup (GTK_LABEL (priv->primary_label), TRUE);
- gtk_container_add (GTK_CONTAINER (labels_grid), priv->primary_label);
-
-
- self->priv->type = BJB_EMPTY_RESULTS_TYPE;
- label = "";
- self->priv->details_label = GTK_LABEL (gtk_label_new (label));
- gtk_label_set_use_markup (GTK_LABEL (self->priv->details_label), TRUE);
- gtk_widget_set_halign (priv->primary_label, GTK_ALIGN_START);
- // xalign: 0,
- // max_width_chars: 24,
- // wrap: true
-
- gtk_container_add (GTK_CONTAINER (labels_grid), GTK_WIDGET (self->priv->details_label));
-
- gtk_widget_set_valign (priv->primary_label, GTK_ALIGN_CENTER);
- gtk_widget_show_all (GTK_WIDGET (self));
-}
+G_DEFINE_TYPE (BjbEmptyResultsBox, bjb_empty_results_box, GTK_TYPE_GRID);
void
bjb_empty_results_box_set_type (BjbEmptyResultsBox *self,
@@ -119,26 +52,26 @@ bjb_empty_results_box_set_type (BjbEmptyResultsBox *self,
g_return_if_fail (BJB_IS_EMPTY_RESULTS_BOX (self));
- if (type == self->priv->type)
+ if (type == self->type)
return;
switch (type)
{
case BJB_EMPTY_RESULTS_NO_NOTE:
gtk_label_set_label (
- self->priv->details_label,
+ self->details_label,
_("Press the New button to create a note."));
- gtk_widget_show (GTK_WIDGET (self->priv->details_label));
- gtk_widget_show (self->priv->image);
+ gtk_widget_show (GTK_WIDGET (self->details_label));
+ gtk_widget_show (self->image);
break;
case BJB_EMPTY_RESULTS_NO_RESULTS:
gtk_label_set_label (
- self->priv->details_label, NULL);
+ self->details_label, NULL);
- gtk_widget_hide (GTK_WIDGET (self->priv->details_label));
- gtk_widget_hide (self->priv->image);
+ gtk_widget_hide (GTK_WIDGET (self->details_label));
+ gtk_widget_hide (self->image);
break;
@@ -151,14 +84,14 @@ bjb_empty_results_box_set_type (BjbEmptyResultsBox *self,
case BJB_EMPTY_RESULTS_TRACKER:
label = _("Oops");
gtk_label_set_label (
- GTK_LABEL (self->priv->primary_label), label);
+ GTK_LABEL (self->primary_label), label);
gtk_label_set_label (
- self->priv->details_label,
+ self->details_label,
_("Please install 'Tracker' then restart the application."));
- gtk_widget_show (GTK_WIDGET (self->priv->details_label));
- gtk_widget_show (self->priv->image);
+ gtk_widget_show (GTK_WIDGET (self->details_label));
+ gtk_widget_show (self->image);
break;
case BJB_EMPTY_RESULTS_TYPE:
@@ -166,26 +99,25 @@ bjb_empty_results_box_set_type (BjbEmptyResultsBox *self,
break;
}
- self->priv->type = type;
+ self->type = type;
}
static void
bjb_empty_results_box_init (BjbEmptyResultsBox *self)
{
- self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self,
- BJB_TYPE_EMPTY_RESULTS_BOX,
- BjbEmptyResultsBoxPrivate);
+ gtk_widget_init_template (GTK_WIDGET (self));
}
-
static void
bjb_empty_results_box_class_init (BjbEmptyResultsBoxClass *klass)
{
- GObjectClass *object_class = G_OBJECT_CLASS (klass);
+ GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
- g_type_class_add_private (klass, sizeof (BjbEmptyResultsBoxPrivate));
+ gtk_widget_class_set_template_from_resource (widget_class, "/org/gnome/bijiben/ui/empty-results-box.ui");
- object_class->constructed = bjb_empty_results_box_constructed;
+ gtk_widget_class_bind_template_child (widget_class, BjbEmptyResultsBox, primary_label);
+ gtk_widget_class_bind_template_child (widget_class, BjbEmptyResultsBox, details_label);
+ gtk_widget_class_bind_template_child (widget_class, BjbEmptyResultsBox, image);
}
@@ -194,4 +126,3 @@ bjb_empty_results_box_new (void)
{
return g_object_new (BJB_TYPE_EMPTY_RESULTS_BOX, NULL);
}
-
diff --git a/src/bjb-empty-results-box.h b/src/bjb-empty-results-box.h
index c08132c..67c37ae 100644
--- a/src/bjb-empty-results-box.h
+++ b/src/bjb-empty-results-box.h
@@ -1,6 +1,7 @@
/*
* Bijiben
* Copyright © 2012, 2013 Red Hat, Inc.
+ * Copyright © 2017 Mohammed Sadiq <sadiq sadiqpk org>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License
@@ -39,42 +40,7 @@ typedef enum {
#define BJB_TYPE_EMPTY_RESULTS_BOX (bjb_empty_results_box_get_type ())
-#define BJB_EMPTY_RESULTS_BOX(obj) \
- (G_TYPE_CHECK_INSTANCE_CAST ((obj), \
- BJB_TYPE_EMPTY_RESULTS_BOX, BjbEmptyResultsBox))
-
-#define BJB_EMPTY_RESULTS_BOX_CLASS(klass) \
- (G_TYPE_CHECK_CLASS_CAST ((klass), \
- BJB_TYPE_EMPTY_RESULTS_BOX, BjbEmptyResultsBoxClass))
-
-#define BJB_IS_EMPTY_RESULTS_BOX(obj) \
- (G_TYPE_CHECK_INSTANCE_TYPE ((obj), \
- BJB_TYPE_EMPTY_RESULTS_BOX))
-
-#define BJB_IS_EMPTY_RESULTS_BOX_CLASS(klass) \
- (G_TYPE_CHECK_CLASS_TYPE ((klass), \
- BJB_TYPE_EMPTY_RESULTS_BOX))
-
-#define BJB_EMPTY_RESULTS_BOX_GET_CLASS(obj) \
- (G_TYPE_INSTANCE_GET_CLASS ((obj), \
- BJB_TYPE_EMPTY_RESULTS_BOX, BjbEmptyResultsBoxClass))
-
-typedef struct _BjbEmptyResultsBox BjbEmptyResultsBox;
-typedef struct _BjbEmptyResultsBoxClass BjbEmptyResultsBoxClass;
-typedef struct _BjbEmptyResultsBoxPrivate BjbEmptyResultsBoxPrivate;
-
-struct _BjbEmptyResultsBox
-{
- GtkGrid parent_instance;
- BjbEmptyResultsBoxPrivate *priv;
-};
-
-struct _BjbEmptyResultsBoxClass
-{
- GtkGridClass parent_class;
-};
-
-GType bjb_empty_results_box_get_type (void) G_GNUC_CONST;
+G_DECLARE_FINAL_TYPE (BjbEmptyResultsBox, bjb_empty_results_box, BJB, EMPTY_RESULTS_BOX, GtkGrid)
GtkWidget *bjb_empty_results_box_new (void);
diff --git a/src/bjb.gresource.xml b/src/bjb.gresource.xml
index 96bed3e..53ca5ca 100644
--- a/src/bjb.gresource.xml
+++ b/src/bjb.gresource.xml
@@ -5,10 +5,11 @@
<file alias="gtk/menus.ui">resources/app-menu.ui</file>
<file alias="editor-toolbar.ui" compressed="true"
preprocess="xml-stripblanks">resources/editor-toolbar.ui</file>
<file alias="thumbnail-frame.png">resources/thumbnail-frame.png</file>
- <file alias="note-symbolic.svg">resources/note-symbolic.svg</file>
+ <file alias="icons/scalable/emblems/note-symbolic.svg">resources/note-symbolic.svg</file>
</gresource>
<gresource prefix="/org/gnome/bijiben/ui">
<file alias="settings-dialog.ui">resources/settings-dialog.ui</file>
+ <file alias="empty-results-box.ui">resources/empty-results-box.ui</file>
</gresource>
</gresources>
diff --git a/src/resources/empty-results-box.ui b/src/resources/empty-results-box.ui
new file mode 100644
index 0000000..0653a6c
--- /dev/null
+++ b/src/resources/empty-results-box.ui
@@ -0,0 +1,50 @@
+<?xml version="1.0" encoding="UTF-8"?>
+<interface>
+ <template class="BjbEmptyResultsBox" parent="GtkGrid">
+ <property name="visible">True</property>
+ <property name="halign">center</property>
+ <property name="valign">center</property>
+ <property name="hexpand">True</property>
+ <property name="vexpand">True</property>
+ <property name="column-spacing">12</property>
+ <style>
+ <class name="dim-label" />
+ </style>
+
+ <child>
+ <object class="GtkImage" id="image">
+ <property name="visible">True</property>
+ <property name="icon-name">note-symbolic</property>
+ <property name="pixel-size">48</property>
+ </object>
+ </child>
+
+ <child>
+ <object class="GtkGrid">
+ <property name="visible">True</property>
+ <property name="row-spacing">0</property>
+ <property name="valign">start</property>
+ <property name="orientation">vertical</property>
+ <child>
+ <object class="GtkLabel" id="primary_label">
+ <property name="visible">True</property>
+ <property name="halign">start</property>
+ <property name="vexpand">True</property>
+ <property name="label" translatable="yes">No notes</property>
+ <attributes>
+ <attribute name="weight" value="bold"/>
+ <attribute name="scale" value="1.2"/>
+ </attributes>
+ </object>
+ </child>
+ <child>
+ <object class="GtkLabel" id="details_label">
+ <property name="halign">start</property>
+ <property name="visible">True</property>
+ </object>
+ </child>
+ </object>
+ </child>
+
+ </template>
+</interface>
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]