[almanah/tagsupport] Return to the entry GtkTextView when the user add a tag
- From: Ãlvaro PeÃa <alvaropg src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [almanah/tagsupport] Return to the entry GtkTextView when the user add a tag
- Date: Wed, 6 Feb 2013 12:28:59 +0000 (UTC)
commit eba6e082df69ba1f6d8e988cb5ff51b137b5ca3e
Author: Ãlvaro PeÃa <alvaropg gmail com>
Date: Wed Feb 6 13:28:35 2013 +0100
Return to the entry GtkTextView when the user add a tag
src/main-window.c | 2 +
src/widgets/entry-tags-area.c | 187 ++++++++++++++++++++++++-----------------
src/widgets/entry-tags-area.h | 1 +
3 files changed, 113 insertions(+), 77 deletions(-)
---
diff --git a/src/main-window.c b/src/main-window.c
index 6cb6b08..bb1a36b 100644
--- a/src/main-window.c
+++ b/src/main-window.c
@@ -265,6 +265,8 @@ almanah_main_window_new (AlmanahApplication *application)
storage_manager = almanah_application_dup_storage_manager (application);
almanah_entry_tags_area_set_storage_manager (priv->entry_tags_area, storage_manager);
g_object_unref (storage_manager);
+ /* The entry GtkTextView is the widget that grab the focus after a tag was added */
+ almanah_entry_tags_area_set_back_widget (priv->entry_tags_area, priv->entry_view);
/* Connect up the formatting actions */
g_signal_connect (priv->bold_action, "toggled", G_CALLBACK (mw_bold_toggled_cb), main_window);
diff --git a/src/widgets/entry-tags-area.c b/src/widgets/entry-tags-area.c
index 7dc01fb..417793f 100644
--- a/src/widgets/entry-tags-area.c
+++ b/src/widgets/entry-tags-area.c
@@ -24,14 +24,16 @@
#include "storage-manager.h"
enum {
- PROP_ENTRY = 1,
- PROP_STORAGE_MANAGER
+ PROP_ENTRY = 1,
+ PROP_STORAGE_MANAGER,
+ PROP_BACK_WIDGET
};
struct _AlmanahEntryTagsAreaPrivate {
- AlmanahEntry *entry;
- AlmanahStorageManager *storage_manager;
- guint tags_number;
+ AlmanahEntry *entry;
+ AlmanahStorageManager *storage_manager;
+ GtkWidget *back_widget;
+ guint tags_number;
AlmanahTagEntry *tag_entry;
};
@@ -54,37 +56,43 @@ G_DEFINE_TYPE (AlmanahEntryTagsArea, almanah_entry_tags_area, GTK_TYPE_GRID)
static void
almanah_entry_tags_area_class_init (AlmanahEntryTagsAreaClass *klass)
{
- GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
+ GObjectClass *gobject_class = G_OBJECT_CLASS (klass);
GtkWidgetClass *widget_class = GTK_WIDGET_CLASS (klass);
- g_type_class_add_private (klass, sizeof (AlmanahEntryTagsAreaPrivate));
+ g_type_class_add_private (klass, sizeof (AlmanahEntryTagsAreaPrivate));
- gobject_class->get_property = almanah_entry_tags_area_get_property;
- gobject_class->set_property = almanah_entry_tags_area_set_property;
- gobject_class->finalize = almanah_entry_tags_area_finalize;
+ gobject_class->get_property = almanah_entry_tags_area_get_property;
+ gobject_class->set_property = almanah_entry_tags_area_set_property;
+ gobject_class->finalize = almanah_entry_tags_area_finalize;
widget_class->draw = almanah_entry_tags_area_draw;
- g_object_class_install_property (gobject_class, PROP_ENTRY,
- g_param_spec_object ("entry",
- "Entry", "The entry from which show the tag list",
- ALMANAH_TYPE_ENTRY,
- G_PARAM_READWRITE));
-
- g_object_class_install_property (gobject_class, PROP_STORAGE_MANAGER,
- g_param_spec_object ("storage-manager",
- "Storage manager", "The storage manager whose entries should be listed.",
- ALMANAH_TYPE_STORAGE_MANAGER,
- G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
+ g_object_class_install_property (gobject_class, PROP_ENTRY,
+ g_param_spec_object ("entry",
+ "Entry", "The entry from which show the tag list",
+ ALMANAH_TYPE_ENTRY,
+ G_PARAM_READWRITE));
+
+ g_object_class_install_property (gobject_class, PROP_STORAGE_MANAGER,
+ g_param_spec_object ("storage-manager",
+ "Storage manager", "The storage manager whose entries should be listed.",
+ ALMANAH_TYPE_STORAGE_MANAGER,
+ G_PARAM_READWRITE | G_PARAM_STATIC_STRINGS));
+
+ g_object_class_install_property (gobject_class, PROP_BACK_WIDGET,
+ g_param_spec_object ("back-widget",
+ "Back Widget", "The widget to grab the focus after a tag was added to an entry.",
+ GTK_TYPE_WIDGET,
+ G_PARAM_READWRITE));
}
static void
almanah_entry_tags_area_init (AlmanahEntryTagsArea *self)
{
- self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, ALMANAH_TYPE_ENTRY_TAGS_AREA, AlmanahEntryTagsAreaPrivate);
+ self->priv = G_TYPE_INSTANCE_GET_PRIVATE (self, ALMANAH_TYPE_ENTRY_TAGS_AREA, AlmanahEntryTagsAreaPrivate);
- /* There is no tags showed right now. */
- self->priv->tags_number = 0;
+ /* There is no tags showed right now. */
+ self->priv->tags_number = 0;
/* The tag entry widget */
self->priv->tag_entry = g_object_new (ALMANAH_TYPE_TAG_ENTRY, NULL);
@@ -96,55 +104,61 @@ almanah_entry_tags_area_init (AlmanahEntryTagsArea *self)
static void
almanah_entry_tags_area_finalize (GObject *object)
{
- AlmanahEntryTagsAreaPrivate *priv = ALMANAH_ENTRY_TAGS_AREA (object)->priv;
+ AlmanahEntryTagsAreaPrivate *priv = ALMANAH_ENTRY_TAGS_AREA (object)->priv;
- g_clear_object (&priv->entry);
- g_clear_object (&priv->storage_manager);
+ g_clear_object (&priv->entry);
+ g_clear_object (&priv->storage_manager);
- G_OBJECT_CLASS (almanah_entry_tags_area_parent_class)->finalize (object);
+ G_OBJECT_CLASS (almanah_entry_tags_area_parent_class)->finalize (object);
}
static void
almanah_entry_tags_area_get_property (GObject *object, guint property_id, GValue *value, GParamSpec *pspec)
{
- AlmanahEntryTagsAreaPrivate *priv = ALMANAH_ENTRY_TAGS_AREA (object)->priv;
-
- switch (property_id) {
- case PROP_ENTRY:
- g_value_set_object (value, priv->entry);
- break;
- case PROP_STORAGE_MANAGER:
- g_value_set_object (value, priv->storage_manager);
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
- break;
- }
+ AlmanahEntryTagsAreaPrivate *priv = ALMANAH_ENTRY_TAGS_AREA (object)->priv;
+
+ switch (property_id) {
+ case PROP_ENTRY:
+ g_value_set_object (value, priv->entry);
+ break;
+ case PROP_STORAGE_MANAGER:
+ g_value_set_object (value, priv->storage_manager);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+ break;
+ }
}
static void
almanah_entry_tags_area_set_property (GObject *object, guint property_id, const GValue *value, GParamSpec *pspec)
{
- AlmanahEntryTagsAreaPrivate *priv = ALMANAH_ENTRY_TAGS_AREA (object)->priv;
-
- switch (property_id) {
- case PROP_ENTRY:
- g_clear_object (&priv->entry);
- priv->entry = ALMANAH_ENTRY (g_value_get_object (value));
- g_object_ref (priv->entry);
- almanah_entry_tags_area_update (ALMANAH_ENTRY_TAGS_AREA (object));
- break;
- case PROP_STORAGE_MANAGER:
+ AlmanahEntryTagsAreaPrivate *priv = ALMANAH_ENTRY_TAGS_AREA (object)->priv;
+
+ switch (property_id) {
+ case PROP_ENTRY:
+ g_clear_object (&priv->entry);
+ priv->entry = ALMANAH_ENTRY (g_value_get_object (value));
+ g_object_ref (priv->entry);
+ almanah_entry_tags_area_update (ALMANAH_ENTRY_TAGS_AREA (object));
+ break;
+ case PROP_STORAGE_MANAGER:
g_return_if_fail (ALMANAH_IS_STORAGE_MANAGER (g_value_get_object (value)));
- g_clear_object (&priv->storage_manager);
- priv->storage_manager = ALMANAH_STORAGE_MANAGER (g_value_get_object (value));
- g_object_ref (priv->storage_manager);
+ g_clear_object (&priv->storage_manager);
+ priv->storage_manager = ALMANAH_STORAGE_MANAGER (g_value_get_object (value));
+ g_object_ref (priv->storage_manager);
almanah_tag_entry_set_storage_manager (priv->tag_entry, priv->storage_manager);
- break;
- default:
- G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
- break;
- }
+ break;
+ case PROP_BACK_WIDGET:
+ g_return_if_fail (GTK_IS_WIDGET (g_value_get_object (value)) && gtk_widget_get_can_focus (g_value_get_object (value)));
+ g_clear_object (&priv->back_widget);
+ priv->back_widget = GTK_WIDGET (g_value_get_object (value));
+ g_object_ref (priv->back_widget);
+ break;
+ default:
+ G_OBJECT_WARN_INVALID_PROPERTY_ID (object, property_id, pspec);
+ break;
+ }
}
static void
@@ -167,7 +181,7 @@ almanah_entry_tags_area_load_tags (AlmanahEntryTagsArea *self)
static void
almanah_entry_tags_area_update (AlmanahEntryTagsArea *self)
{
- gtk_container_foreach (GTK_CONTAINER (self), (GtkCallback) entry_tags_area_remove_foreach_cb, self);
+ gtk_container_foreach (GTK_CONTAINER (self), (GtkCallback) entry_tags_area_remove_foreach_cb, self);
}
static gint
@@ -210,6 +224,7 @@ tag_entry_activate_cb (GtkEntry *entry, AlmanahEntryTagsArea *self)
if (almanah_storage_manager_entry_check_tag (self->priv->storage_manager, self->priv->entry, tag) == FALSE) {
if (almanah_storage_manager_entry_add_tag (self->priv->storage_manager, self->priv->entry, tag)) {
almanah_entry_tags_area_add_tag (self, (const gchar*) tag);
+ gtk_widget_grab_focus (self->priv->back_widget);
}
}
g_free (tag);
@@ -218,29 +233,29 @@ tag_entry_activate_cb (GtkEntry *entry, AlmanahEntryTagsArea *self)
void
entry_tags_area_remove_foreach_cb (GtkWidget *tag_widget, AlmanahEntryTagsArea *self)
{
- if (ALMANAH_IS_TAG (tag_widget)) {
- gtk_widget_destroy (tag_widget);
- self->priv->tags_number--;
- }
-
- /* Show the tags for the entry */
- if (self->priv->tags_number == 0) {
- almanah_entry_tags_area_load_tags (self);
- }
+ if (ALMANAH_IS_TAG (tag_widget)) {
+ gtk_widget_destroy (tag_widget);
+ self->priv->tags_number--;
+ }
+
+ /* Show the tags for the entry */
+ if (self->priv->tags_number == 0) {
+ almanah_entry_tags_area_load_tags (self);
+ }
}
void
almanah_entry_tags_area_set_entry (AlmanahEntryTagsArea *entry_tags_area, AlmanahEntry *entry)
{
- GValue entry_value = G_VALUE_INIT;
+ GValue entry_value = G_VALUE_INIT;
- g_return_if_fail (ALMANAH_IS_ENTRY_TAGS_AREA (entry_tags_area));
- g_return_if_fail (ALMANAH_IS_ENTRY (entry));
+ g_return_if_fail (ALMANAH_IS_ENTRY_TAGS_AREA (entry_tags_area));
+ g_return_if_fail (ALMANAH_IS_ENTRY (entry));
- g_value_init (&entry_value, G_TYPE_OBJECT);
- g_value_set_object (&entry_value, entry);
- g_object_set_property (G_OBJECT (entry_tags_area), "entry", &entry_value);
- g_value_unset (&entry_value);
+ g_value_init (&entry_value, G_TYPE_OBJECT);
+ g_value_set_object (&entry_value, entry);
+ g_object_set_property (G_OBJECT (entry_tags_area), "entry", &entry_value);
+ g_value_unset (&entry_value);
}
void
@@ -263,16 +278,34 @@ tag_remove (AlmanahTag *tag_widget, AlmanahEntryTagsArea *self)
}
}
+/**
+ * TODO: Document
+ */
void
almanah_entry_tags_area_set_storage_manager (AlmanahEntryTagsArea *entry_tags_area, AlmanahStorageManager *storage_manager)
{
GValue storage_value = G_VALUE_INIT;
g_return_if_fail (ALMANAH_IS_ENTRY_TAGS_AREA (entry_tags_area));
- g_return_if_fail (ALMANAH_IS_STORAGE_MANAGER (storage_manager));
g_value_init (&storage_value, G_TYPE_OBJECT);
g_value_set_object (&storage_value, storage_manager);
g_object_set_property (G_OBJECT (entry_tags_area), "storage-manager", &storage_value);
g_value_unset (&storage_value);
}
+
+/**
+ * TODO: Document
+ */
+void
+almanah_entry_tags_area_set_back_widget (AlmanahEntryTagsArea *entry_tags_area, GtkWidget *back_widget)
+{
+ GValue back_w_value = G_VALUE_INIT;
+
+ g_return_if_fail (ALMANAH_IS_ENTRY_TAGS_AREA (entry_tags_area));
+
+ g_value_init (&back_w_value, G_TYPE_OBJECT);
+ g_value_set_object (&back_w_value, back_widget);
+ g_object_set_property (G_OBJECT (entry_tags_area), "back-widget", &back_w_value);
+ g_value_unset (&back_w_value);
+}
diff --git a/src/widgets/entry-tags-area.h b/src/widgets/entry-tags-area.h
index 3ba006f..f991cb4 100644
--- a/src/widgets/entry-tags-area.h
+++ b/src/widgets/entry-tags-area.h
@@ -47,6 +47,7 @@ typedef struct {
GType almanah_entry_tags_area_get_type (void) G_GNUC_CONST;
void almanah_entry_tags_area_set_entry (AlmanahEntryTagsArea *entry_tags_area, AlmanahEntry *entry);
void almanah_entry_tags_area_set_storage_manager (AlmanahEntryTagsArea *entry_tags_area, AlmanahStorageManager *storage_manager);
+void almanah_entry_tags_area_set_back_widget (AlmanahEntryTagsArea *entry_tags_area, GtkWidget *back_widget);
G_END_DECLS
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]