diff options
Diffstat (limited to 'src/bookmarks')
-rw-r--r-- | src/bookmarks/Makefile.am | 2 | ||||
-rw-r--r-- | src/bookmarks/ephy-bookmark-action.c | 90 | ||||
-rw-r--r-- | src/bookmarks/ephy-bookmark-toolitem.c | 177 | ||||
-rw-r--r-- | src/bookmarks/ephy-bookmark-toolitem.h | 60 |
4 files changed, 81 insertions, 248 deletions
diff --git a/src/bookmarks/Makefile.am b/src/bookmarks/Makefile.am index 16bf2c5d2..4425d0aa5 100644 --- a/src/bookmarks/Makefile.am +++ b/src/bookmarks/Makefile.am @@ -32,8 +32,6 @@ libephybookmarks_la_SOURCES = \ ephy-bookmarks-menu.h \ ephy-bookmark-properties.c \ ephy-bookmark-properties.h \ - ephy-bookmark-toolitem.c \ - ephy-bookmark-toolitem.h \ ephy-new-bookmark.c \ ephy-new-bookmark.h \ ephy-topic-action.c \ diff --git a/src/bookmarks/ephy-bookmark-action.c b/src/bookmarks/ephy-bookmark-action.c index 1362b8d02..a2fa0c7ac 100644 --- a/src/bookmarks/ephy-bookmark-action.c +++ b/src/bookmarks/ephy-bookmark-action.c @@ -24,7 +24,6 @@ #include <libgnomevfs/gnome-vfs-uri.h> #include "ephy-bookmark-action.h" -#include "ephy-bookmark-toolitem.h" #include "ephy-bookmarks.h" #include "ephy-shell.h" #include "ephy-string.h" @@ -90,6 +89,47 @@ ephy_bookmark_action_get_type (void) return type; } +static GtkWidget * +create_tool_item (EggAction *action) +{ + GtkWidget *item, *button, *hbox, *label, *icon, *entry; + + LOG ("Creating tool item for action %p", action) + + item = (* EGG_ACTION_CLASS (parent_class)->create_tool_item) (action); + + hbox = gtk_hbox_new (FALSE, 0); + gtk_widget_show (hbox); + gtk_container_add (GTK_CONTAINER (item), hbox); + + button = gtk_button_new (); + gtk_button_set_relief (GTK_BUTTON (button), GTK_RELIEF_NONE); + gtk_widget_show (button); + gtk_container_add (GTK_CONTAINER (hbox), button); + g_object_set_data (G_OBJECT (item), "button", button); + + entry = gtk_entry_new (); + gtk_widget_set_size_request (entry, 120, -1); + gtk_box_pack_start (GTK_BOX (hbox), entry, TRUE, TRUE, 0); + g_object_set_data (G_OBJECT (item), "entry", entry); + + hbox = gtk_hbox_new (FALSE, 0); + gtk_widget_show (hbox); + gtk_container_add (GTK_CONTAINER (button), hbox); + + icon = gtk_image_new (); + gtk_widget_show (icon); + gtk_box_pack_start (GTK_BOX (hbox), icon, TRUE, TRUE, 0); + g_object_set_data (G_OBJECT (item), "icon", icon); + + label = gtk_label_new (NULL); + gtk_widget_show (label); + gtk_box_pack_start (GTK_BOX (hbox), label, TRUE, TRUE, 0); + g_object_set_data (G_OBJECT (item), "label", label); + + return item; +} + static void ephy_bookmark_action_sync_smart_url (EggAction *action, GParamSpec *pspec, GtkWidget *proxy) { @@ -165,7 +205,8 @@ ephy_bookmark_action_sync_label (EggAction *action, GParamSpec *pspec, GtkWidget title = ephy_string_shorten (action->label, MAX_LABEL_LENGTH); - if (EPHY_BOOKMARK_ACTION (action)->priv->smart_url) + if (EPHY_BOOKMARK_ACTION (action)->priv->smart_url + && EGG_IS_TOOL_ITEM (proxy)) { label_text = g_strdup_printf (_("%s:"), title); } @@ -196,9 +237,15 @@ ephy_bookmark_action_sync_label (EggAction *action, GParamSpec *pspec, GtkWidget } static void -activate_cb (GtkWidget *widget, const char *text, EggAction *action) +activate_cb (GtkWidget *widget, EggAction *action) { char *location = NULL; + char *text = NULL; + + if (GTK_IS_EDITABLE (widget)) + { + text = gtk_editable_get_chars (GTK_EDITABLE (widget), 0, -1); + } if (text != NULL && text[0] != '\0') { @@ -240,17 +287,35 @@ activate_cb (GtkWidget *widget, const char *text, EggAction *action) 0, location); g_free (location); + g_free (text); } -static void -menu_activate_cb (GtkWidget *widget, EggAction *action) +static gboolean +create_menu_proxy (EggToolItem *item, EggAction *action) { - activate_cb (widget, NULL, action); + EphyBookmarkAction *bm_action = EPHY_BOOKMARK_ACTION (action); + GtkWidget *menu_item; + char *menu_id; + + LOG ("create_menu_proxy item %p, action %p", item, action); + + menu_item = EGG_ACTION_GET_CLASS (action)->create_menu_item (action); + + EGG_ACTION_GET_CLASS (action)->connect_proxy (action, menu_item); + + menu_id = g_strdup_printf ("ephy-bookmark-action-%d-menu-id", + bm_action->priv->bookmark_id); + + egg_tool_item_set_proxy_menu_item (item, menu_id, menu_item); + + return TRUE; } static void connect_proxy (EggAction *action, GtkWidget *proxy) { + GtkWidget *button, *entry; + LOG ("Connecting action %p to proxy %p", action, proxy) (* EGG_ACTION_CLASS (parent_class)->connect_proxy) (action, proxy); @@ -269,11 +334,17 @@ connect_proxy (EggAction *action, GtkWidget *proxy) if (EGG_IS_TOOL_ITEM (proxy)) { - g_signal_connect (proxy, "activate", G_CALLBACK (activate_cb), action); + button = GTK_WIDGET (g_object_get_data (G_OBJECT (proxy), "button")); + g_signal_connect (button, "clicked", G_CALLBACK (activate_cb), action); + + entry = GTK_WIDGET (g_object_get_data (G_OBJECT (proxy), "entry")); + g_signal_connect (entry, "activate", G_CALLBACK (activate_cb), action); + + g_signal_connect (proxy, "create_menu_proxy", G_CALLBACK (create_menu_proxy), action); } else if (GTK_IS_MENU_ITEM (proxy)) { - g_signal_connect (proxy, "activate", G_CALLBACK (menu_activate_cb), action); + g_signal_connect (proxy, "activate", G_CALLBACK (activate_cb), action); } } @@ -356,7 +427,8 @@ ephy_bookmark_action_class_init (EphyBookmarkActionClass *class) parent_class = g_type_class_peek_parent (class); action_class = EGG_ACTION_CLASS (class); - action_class->toolbar_item_type = EPHY_TYPE_BOOKMARK_TOOLITEM; + action_class->toolbar_item_type = EGG_TYPE_TOOL_ITEM; + action_class->create_tool_item = create_tool_item; action_class->menu_item_type = GTK_TYPE_IMAGE_MENU_ITEM; action_class->connect_proxy = connect_proxy; diff --git a/src/bookmarks/ephy-bookmark-toolitem.c b/src/bookmarks/ephy-bookmark-toolitem.c deleted file mode 100644 index b4245de29..000000000 --- a/src/bookmarks/ephy-bookmark-toolitem.c +++ /dev/null @@ -1,177 +0,0 @@ -/* - * Copyright (C) 2003 Christian Persch - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. - */ - -#ifdef HAVE_CONFIG_H -#include <config.h> -#endif - -#include "ephy-bookmark-toolitem.h" -#include "ephy-marshal.h" -#include "ephy-debug.h" - -#include <gtk/gtk.h> -#include <gtk/gtkimagemenuitem.h> - -static GObjectClass *parent_class = NULL; - -static void ephy_bookmark_toolitem_class_init (EphyBookmarkToolitemClass *klass); -static void ephy_bookmark_toolitem_init (EphyBookmarkToolitem *item); - -enum -{ - ACTIVATE, - LAST_SIGNAL -}; -static guint EphyBookmarkToolitemSignals[LAST_SIGNAL]; - -#define MENU_ID "ephy-bookmark-toolitem-menu-id" - -/** - * EphyBookmarkToolitem object - */ - -GType -ephy_bookmark_toolitem_get_type (void) -{ - static GType ephy_bookmark_toolitem_type = 0; - - if (ephy_bookmark_toolitem_type == 0) - { - static const GTypeInfo our_info = - { - sizeof (EphyBookmarkToolitemClass), - NULL, /* base_init */ - NULL, /* base_finalize */ - (GClassInitFunc) ephy_bookmark_toolitem_class_init, - NULL, - NULL, /* class_data */ - sizeof (EphyBookmarkToolitem), - 0, /* n_preallocs */ - (GInstanceInitFunc) ephy_bookmark_toolitem_init, - }; - - ephy_bookmark_toolitem_type = g_type_register_static (EGG_TYPE_TOOL_ITEM, - "EphyBookmarkToolitem", - &our_info, 0); - } - - return ephy_bookmark_toolitem_type; -} - -static void -activated_cb (GtkWidget *widget, EggToolItem *item) -{ - char *text = NULL; - - if (GTK_IS_EDITABLE (widget)) - { - text = gtk_editable_get_chars (GTK_EDITABLE (widget), 0, -1); - } - - g_signal_emit (item, EphyBookmarkToolitemSignals[ACTIVATE], 0, text); - - g_free (text); -} - -static gboolean -ephy_bookmark_toolitem_create_menu_proxy (EggToolItem *item) -{ - GtkWidget *menu_item, *label, *icon, *image; - GdkPixbuf *pixbuf; - const char *text; - - LOG ("create menu proxy for %p", item) - - icon = g_object_get_data (G_OBJECT (item), "icon"); - pixbuf = gtk_image_get_pixbuf (GTK_IMAGE (icon)); - image = gtk_image_new_from_pixbuf (pixbuf); - - label = g_object_get_data (G_OBJECT (item), "label"); - text = gtk_label_get_label (GTK_LABEL (label)); - - menu_item = gtk_image_menu_item_new_with_mnemonic (text); - gtk_image_menu_item_set_image (GTK_IMAGE_MENU_ITEM (menu_item), image); - - g_signal_connect (menu_item, "activate", G_CALLBACK (activated_cb), item); - - egg_tool_item_set_proxy_menu_item (item, MENU_ID, menu_item); - - return TRUE; -} - -static void -ephy_bookmark_toolitem_init (EphyBookmarkToolitem *item) -{ - GtkWidget *button, *hbox, *label, *icon, *entry; - - LOG ("Initialising bookmark toolitem %p", item) - - hbox = gtk_hbox_new (FALSE, 0); - gtk_widget_show (hbox); - gtk_container_add (GTK_CONTAINER (item), hbox); - - button = gtk_button_new (); - gtk_button_set_relief (GTK_BUTTON (button), GTK_RELIEF_NONE); - gtk_widget_show (button); - gtk_container_add (GTK_CONTAINER (hbox), button); - g_object_set_data (G_OBJECT (item), "button", button); - - entry = gtk_entry_new (); - gtk_widget_set_size_request (entry, 120, -1); - gtk_box_pack_start (GTK_BOX (hbox), entry, TRUE, TRUE, 0); - g_object_set_data (G_OBJECT (item), "entry", entry); - - hbox = gtk_hbox_new (FALSE, 0); - gtk_widget_show (hbox); - gtk_container_add (GTK_CONTAINER (button), hbox); - - icon = gtk_image_new (); - gtk_widget_show (icon); - gtk_box_pack_start (GTK_BOX (hbox), icon, TRUE, TRUE, 0); - g_object_set_data (G_OBJECT (item), "icon", icon); - - label = gtk_label_new (NULL); - gtk_widget_show (label); - gtk_box_pack_start (GTK_BOX (hbox), label, TRUE, TRUE, 0); - g_object_set_data (G_OBJECT (item), "label", label); - - g_signal_connect (button, "clicked", G_CALLBACK (activated_cb), item); - g_signal_connect (entry, "activate", G_CALLBACK (activated_cb), item); -} - -static void -ephy_bookmark_toolitem_class_init (EphyBookmarkToolitemClass *klass) -{ - EggToolItemClass *tool_item_class; - - parent_class = g_type_class_peek_parent (klass); - - tool_item_class = (EggToolItemClass *)klass; - - tool_item_class->create_menu_proxy = ephy_bookmark_toolitem_create_menu_proxy; - - EphyBookmarkToolitemSignals[ACTIVATE] = g_signal_new ( - "activate", G_OBJECT_CLASS_TYPE (klass), - G_SIGNAL_RUN_FIRST, - G_STRUCT_OFFSET (EphyBookmarkToolitemClass, activated), - NULL, NULL, - ephy_marshal_VOID__STRING, - G_TYPE_NONE, - 1, - G_TYPE_STRING); -} diff --git a/src/bookmarks/ephy-bookmark-toolitem.h b/src/bookmarks/ephy-bookmark-toolitem.h deleted file mode 100644 index f8248637e..000000000 --- a/src/bookmarks/ephy-bookmark-toolitem.h +++ /dev/null @@ -1,60 +0,0 @@ -/* - * Copyright (C) 2003 Christian Persch - * - * This program is free software; you can redistribute it and/or modify - * it under the terms of the GNU General Public License as published by - * the Free Software Foundation; either version 2, or (at your option) - * any later version. - * - * This program is distributed in the hope that it will be useful, - * but WITHOUT ANY WARRANTY; without even the implied warranty of - * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the - * GNU General Public License for more details. - * - * You should have received a copy of the GNU General Public License - * along with this program; if not, write to the Free Software - * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA 02111-1307, USA. - */ - -#ifndef EPHY_BOOKMARK_TOOLITEM_H -#define EPHY_BOOKMARK_TOOLITEM_H - -#include "eggtoolitem.h" - -G_BEGIN_DECLS - -/* object forward declarations */ - -typedef struct _EphyBookmarkToolitem EphyBookmarkToolitem; -typedef struct _EphyBookmarkToolitemClass EphyBookmarkToolitemClass; -typedef struct _EphyBookmarkToolitemPrivate EphyBookmarkToolitemPrivate; - -/** - * EphyBookmarkToolitem object - */ - -#define EPHY_TYPE_BOOKMARK_TOOLITEM (ephy_bookmark_toolitem_get_type()) -#define EPHY_BOOKMARK_TOOLITEM(object) (G_TYPE_CHECK_INSTANCE_CAST((object), EPHY_TYPE_BOOKMARK_TOOLITEM, EphyBookmarkToolitem)) -#define EPHY_BOOKMARK_TOOLITEM_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST((klass), EPHY_TYPE_BOOKMARK_TOOLITEM, EphyBookmarkToolitemClass)) -#define EPHY_IS_BOOKMARK_TOOLITEM(object) (G_TYPE_CHECK_INSTANCE_TYPE((object), EPHY_TYPE_BOOKMARK_TOOLITEM)) -#define EPHY_IS_BOOKMARK_TOOLITEM_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE((klass), EPHY_TYPE_BOOKMARK_TOOLITEM)) -#define EPHY_BOOKMARK_TOOLITEM_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), EPHY_TYPE_BOOKMARK_TOOLITEM, EphyBookmarkToolitemClass)) - -struct _EphyBookmarkToolitemClass -{ - EggToolItemClass parent_class; - - void (* activated) (EphyBookmarkToolitem *item, - const char *text); -}; - -struct _EphyBookmarkToolitem -{ - EggToolItem parent_object; -}; - -GType ephy_bookmark_toolitem_get_type (void); - -G_END_DECLS - -#endif |