diff options
Diffstat (limited to 'src/bookmarks')
-rw-r--r-- | src/bookmarks/Makefile.am | 4 | ||||
-rw-r--r-- | src/bookmarks/ephy-bookmark-factory-action.c | 303 | ||||
-rw-r--r-- | src/bookmarks/ephy-bookmark-factory-action.h | 56 | ||||
-rw-r--r-- | src/bookmarks/ephy-bookmarks-ui.c | 2 | ||||
-rw-r--r-- | src/bookmarks/ephy-topic-factory-action.c | 302 | ||||
-rw-r--r-- | src/bookmarks/ephy-topic-factory-action.h | 56 |
6 files changed, 0 insertions, 723 deletions
diff --git a/src/bookmarks/Makefile.am b/src/bookmarks/Makefile.am index 14ea7c728..e8dac3130 100644 --- a/src/bookmarks/Makefile.am +++ b/src/bookmarks/Makefile.am @@ -19,8 +19,6 @@ NOINST_H_FILES = \ ephy-topic-action.h \ ephy-related-action.h \ ephy-open-tabs-action.h \ - ephy-topic-factory-action.h \ - ephy-bookmark-factory-action.h \ ephy-topic-action-group.h \ ephy-bookmark-action-group.h \ ephy-topics-entry.h \ @@ -39,8 +37,6 @@ libephybookmarks_la_SOURCES = \ ephy-topic-action.c \ ephy-related-action.c \ ephy-open-tabs-action.c \ - ephy-topic-factory-action.c \ - ephy-bookmark-factory-action.c \ ephy-topic-action-group.c \ ephy-bookmark-action-group.c \ ephy-topics-entry.c \ diff --git a/src/bookmarks/ephy-bookmark-factory-action.c b/src/bookmarks/ephy-bookmark-factory-action.c deleted file mode 100644 index 4a17cf5df..000000000 --- a/src/bookmarks/ephy-bookmark-factory-action.c +++ /dev/null @@ -1,303 +0,0 @@ -/* - * Copyright © 2005 Peter Harvey - * - * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. - * - */ - -#include "config.h" - -#include <gtk/gtk.h> -#include <glib/gi18n.h> - -#include "ephy-bookmark-factory-action.h" -#include "ephy-bookmark-action.h" -#include "ephy-bookmarks-ui.h" -#include "ephy-node-common.h" -#include "ephy-shell.h" -#include "ephy-stock-icons.h" -#include "egg-editable-toolbar.h" - -static void ephy_bookmark_factory_action_init (EphyBookmarkFactoryAction *action); -static void ephy_bookmark_factory_action_class_init (EphyBookmarkFactoryActionClass *class); - -#define EPHY_BOOKMARK_FACTORY_ACTION_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_BOOKMARK_FACTORY_ACTION, EphyBookmarkActionPrivate)) -#define EGG_TOOLBARS_MODEL_DATA "ephy-bookmark-factory-menu" - -G_DEFINE_TYPE (EphyBookmarkFactoryAction, ephy_bookmark_factory_action, GTK_TYPE_ACTION) - -static void -activate_item_cb (GtkWidget *menuitem, GtkWidget *placeholder) -{ - GtkWidget *toolbar, *etoolbar, *item; - EggToolbarsModel *model; - GList *children; - gint index, pos; - char *id; - - item = gtk_widget_get_ancestor (placeholder, GTK_TYPE_TOOL_ITEM); - g_return_if_fail (item); - toolbar = gtk_widget_get_ancestor (item, GTK_TYPE_TOOLBAR); - g_return_if_fail (toolbar); - etoolbar = gtk_widget_get_ancestor (toolbar, EGG_TYPE_EDITABLE_TOOLBAR); - g_return_if_fail (etoolbar); - model = egg_editable_toolbar_get_model (EGG_EDITABLE_TOOLBAR (etoolbar)); - g_return_if_fail (model); - - children = gtk_container_get_children (GTK_CONTAINER (etoolbar)); - pos = g_list_index (children, gtk_widget_get_parent (toolbar)); - index = gtk_toolbar_get_item_index (GTK_TOOLBAR (toolbar), GTK_TOOL_ITEM (item)); - g_list_free (children); - - id = g_object_get_data (G_OBJECT (menuitem), "ephy-action"); - egg_toolbars_model_add_item (model, pos, index, id); -} - -static GtkWidget * -build_menu_for_topic (GtkWidget *placeholder, EggToolbarsModel *model, EphyNode *topic) -{ - GtkWidget *menu, *item; - EphyNode *node; - GPtrArray *children, *bookmarks; - const char *name; - char action[EPHY_BOOKMARK_ACTION_NAME_BUFFER_SIZE]; - gint i, flags; - - children = ephy_node_get_children (topic); - bookmarks = g_ptr_array_sized_new (children->len); - for (i = 0; i < children->len; i++) - g_ptr_array_add (bookmarks, g_ptr_array_index (children, i)); - g_ptr_array_sort (bookmarks, (GCompareFunc)ephy_bookmarks_compare_bookmark_pointers); - - menu = NULL; - - for (i = 0; i < bookmarks->len; i++) - { - node = g_ptr_array_index (bookmarks, i); - - EPHY_BOOKMARK_ACTION_NAME_PRINTF (action, node); - - flags = egg_toolbars_model_get_name_flags (model, action); - if (flags & EGG_TB_MODEL_NAME_USED) - continue; - - name = ephy_node_get_property_string (node, EPHY_NODE_BMK_PROP_TITLE); - item = gtk_menu_item_new_with_label (name); - - /* FIXME: set the |node| instead here! */ - g_object_set_data_full (G_OBJECT (item), "ephy-action", - g_strdup (action), g_free); - g_signal_connect (item, "activate", G_CALLBACK (activate_item_cb), placeholder); - gtk_widget_show (item); - - if (menu == NULL) menu = gtk_menu_new (); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), item); - } - g_ptr_array_free (bookmarks, TRUE); - - return menu; -} - -static GtkWidget * -build_menu (GtkWidget *placeholder, EggToolbarsModel *model) -{ - GtkWidget *menu, *submenu, *item; - - EphyBookmarks *eb; - EphyNode *node; - GPtrArray *children, *topics; - - const char *name; - gint i, priority = -1, ptmp; - - /* Get a sorted list of topics. */ - eb = ephy_shell_get_bookmarks (ephy_shell); - node = ephy_bookmarks_get_keywords (eb); - children = ephy_node_get_children (node); - topics = g_ptr_array_sized_new (children->len); - for (i = 0; i < children->len; i++) - g_ptr_array_add (topics, g_ptr_array_index (children, i)); - g_ptr_array_sort (topics, (GCompareFunc)ephy_bookmarks_compare_topic_pointers); - - menu = gtk_menu_new (); - for (i = 0; i < topics->len; i++) - { - node = g_ptr_array_index (topics, i); - - ptmp = ephy_node_get_property_int (node, EPHY_NODE_KEYWORD_PROP_PRIORITY); - if (ptmp == EPHY_NODE_ALL_PRIORITY) - continue; - - submenu = build_menu_for_topic (placeholder, model, node); - if (submenu == NULL) - continue; - - if (ptmp != priority && priority >= 0) - { - item = gtk_separator_menu_item_new (); - gtk_widget_show (item); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), item); - } - priority = ptmp; - - name = ephy_node_get_property_string (node, EPHY_NODE_KEYWORD_PROP_NAME); - item = gtk_menu_item_new_with_label (name); - gtk_menu_item_set_submenu (GTK_MENU_ITEM (item), submenu); - - gtk_widget_show (item); - - gtk_menu_shell_append (GTK_MENU_SHELL (menu), item); - } - g_ptr_array_free (topics, TRUE); - - return menu; -} - -static void -remove_placeholder_cb (GtkMenuShell *menushell, - GtkWidget *placeholder) -{ - GtkWidget *toolbar, *etoolbar, *item; - EggToolbarsModel *model; - GList *children; - gint index, pos; - - item = gtk_widget_get_ancestor (placeholder, GTK_TYPE_TOOL_ITEM); - g_return_if_fail (item); - toolbar = gtk_widget_get_ancestor (item, GTK_TYPE_TOOLBAR); - g_return_if_fail (toolbar); - etoolbar = gtk_widget_get_ancestor (toolbar, EGG_TYPE_EDITABLE_TOOLBAR); - g_return_if_fail (etoolbar); - model = egg_editable_toolbar_get_model (EGG_EDITABLE_TOOLBAR (etoolbar)); - g_return_if_fail (model); - - g_object_set_data (G_OBJECT (model), EGG_TOOLBARS_MODEL_DATA, NULL); - - children = gtk_container_get_children (GTK_CONTAINER (etoolbar)); - pos = g_list_index (children, gtk_widget_get_parent (toolbar)); - index = gtk_toolbar_get_item_index (GTK_TOOLBAR (toolbar), GTK_TOOL_ITEM (item)); - g_list_free (children); - - egg_toolbars_model_remove_item (model, pos, index); -} - -static gboolean -activate_placeholder_cb (GtkWidget *placeholder) -{ - GtkWidget *toolbar, *etoolbar, *item, *menu; - EggToolbarsModel *model; - gint index; - - /* Get our position on a toolbar. */ - item = gtk_widget_get_ancestor (placeholder, GTK_TYPE_TOOL_ITEM); - g_return_val_if_fail (item, FALSE); - toolbar = gtk_widget_get_ancestor (item, GTK_TYPE_TOOLBAR); - g_return_val_if_fail (toolbar, FALSE); - etoolbar = gtk_widget_get_ancestor (toolbar, EGG_TYPE_EDITABLE_TOOLBAR); - g_return_val_if_fail (etoolbar, FALSE); - model = egg_editable_toolbar_get_model (EGG_EDITABLE_TOOLBAR (etoolbar)); - g_return_val_if_fail (model, FALSE); - - /* If we are not yet on the toolbar, abort. */ - index = gtk_toolbar_get_item_index (GTK_TOOLBAR (toolbar), GTK_TOOL_ITEM (item)); - if (index < 0 || index >= gtk_toolbar_get_n_items (GTK_TOOLBAR (toolbar))) - return FALSE; - - /* If there is already a popup menu, abort. */ - menu = g_object_get_data (G_OBJECT (model), EGG_TOOLBARS_MODEL_DATA); - if (menu != NULL) return FALSE; - - /* Create the menu and store it's pointer to ensure noone else creates a menu. */ - menu = build_menu (placeholder, model); - g_object_set_data (G_OBJECT (model), EGG_TOOLBARS_MODEL_DATA, menu); - - g_signal_connect (menu, "selection-done", - G_CALLBACK (remove_placeholder_cb), placeholder); - - gtk_menu_popup (GTK_MENU (menu), NULL, NULL, NULL, NULL, 0, - gtk_get_current_event_time ()); - - return FALSE; -} - -static void -clicked_placeholder_cb (GtkWidget *placeholder, GdkEventButton *event, gpointer user) -{ - activate_placeholder_cb (placeholder); -} - -static void -realize_placeholder_cb (GtkWidget *placeholder, gpointer user) -{ - g_idle_add ((GSourceFunc) activate_placeholder_cb, placeholder); -} - -static GtkWidget * -create_tool_item (GtkAction *action) -{ - GtkWidget *item = GTK_WIDGET (gtk_tool_item_new ()); - GtkWidget *widget = gtk_button_new_with_label (" ? "); - gtk_button_set_relief (GTK_BUTTON (widget), GTK_RELIEF_NONE); - - gtk_container_add (GTK_CONTAINER (item), widget); - gtk_widget_show (widget); - - return item; -} - -static void -connect_proxy (GtkAction *action, GtkWidget *proxy) -{ - GtkWidget *widget; - - GTK_ACTION_CLASS (ephy_bookmark_factory_action_parent_class)->connect_proxy (action, proxy); - - g_return_if_fail (GTK_IS_TOOL_ITEM (proxy)); - - widget = gtk_bin_get_child (GTK_BIN (proxy)); - - g_signal_connect (widget, "realize", - G_CALLBACK (realize_placeholder_cb), - action); - g_signal_connect (widget, "clicked", - G_CALLBACK (clicked_placeholder_cb), - action); -} - -static void -ephy_bookmark_factory_action_init (EphyBookmarkFactoryAction *action) -{ - /* Empty, needed for G_DEFINE_TYPE macro */ -} - -static void -ephy_bookmark_factory_action_class_init (EphyBookmarkFactoryActionClass *class) -{ - GtkActionClass *action_class = GTK_ACTION_CLASS (class); - - action_class->toolbar_item_type = GTK_TYPE_TOOL_ITEM; - action_class->connect_proxy = connect_proxy; - action_class->create_tool_item = create_tool_item; -} - -GtkAction * -ephy_bookmark_factory_action_new (const char *name) -{ - return GTK_ACTION (g_object_new (EPHY_TYPE_BOOKMARK_FACTORY_ACTION, - "name", name, - "label", _("Bookmark"), - "stock-id", GTK_STOCK_ADD, - NULL)); -} diff --git a/src/bookmarks/ephy-bookmark-factory-action.h b/src/bookmarks/ephy-bookmark-factory-action.h deleted file mode 100644 index f685609b1..000000000 --- a/src/bookmarks/ephy-bookmark-factory-action.h +++ /dev/null @@ -1,56 +0,0 @@ -/* - * Copyright © 2004 Peter Harvey - * - * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. - * - */ - -#if !defined (__EPHY_EPIPHANY_H_INSIDE__) && !defined (EPIPHANY_COMPILATION) -#error "Only <epiphany/epiphany.h> can be included directly." -#endif - -#ifndef EPHY_BOOKMARK_FACTORY_ACTION_H -#define EPHY_BOOKMARK_FACTORY_ACTION_H - -#include "ephy-node.h" -#include "ephy-window.h" - -#include <gtk/gtk.h> - -#define EPHY_TYPE_BOOKMARK_FACTORY_ACTION (ephy_bookmark_factory_action_get_type ()) -#define EPHY_BOOKMARK_FACTORY_ACTION(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), EPHY_TYPE_BOOKMARK_FACTORY_ACTION, EphyBookmarkFactoryAction)) -#define EPHY_BOOKMARK_FACTORY_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), EPHY_TYPE_BOOKMARK_FACTORY_ACTION, EphyBookmarkFactoryActionClass)) -#define EPHY_IS_BOOKMARK_FACTORY_ACTION(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EPHY_TYPE_BOOKMARK_FACTORY_ACTION)) -#define EPHY_IS_BOOKMARK_FACTORY_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((obj), EPHY_TYPE_BOOKMARK_FACTORY_ACTION)) -#define EPHY_BOOKMARK_FACTORY_ACTION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), EPHY_TYPE_BOOKMARK_FACTORY_ACTION, EphyBookmarkFactoryActionClass)) - -typedef struct _EphyBookmarkFactoryAction EphyBookmarkFactoryAction; -typedef struct _EphyBookmarkFactoryActionClass EphyBookmarkFactoryActionClass; - -struct _EphyBookmarkFactoryAction -{ - GtkAction parent; -}; - -struct _EphyBookmarkFactoryActionClass -{ - GtkActionClass parent_class; -}; - -GType ephy_bookmark_factory_action_get_type (void); - -GtkAction * ephy_bookmark_factory_action_new (const char *name); - -#endif diff --git a/src/bookmarks/ephy-bookmarks-ui.c b/src/bookmarks/ephy-bookmarks-ui.c index f7970d9ce..bbee1517a 100644 --- a/src/bookmarks/ephy-bookmarks-ui.c +++ b/src/bookmarks/ephy-bookmarks-ui.c @@ -24,7 +24,6 @@ #include "ephy-bookmark-action-group.h" #include "ephy-bookmark-action.h" -#include "ephy-bookmark-factory-action.h" #include "ephy-bookmark-properties.h" #include "ephy-bookmarks-menu.h" #include "ephy-bookmarks.h" @@ -45,7 +44,6 @@ #include "ephy-string.h" #include "ephy-topic-action-group.h" #include "ephy-topic-action.h" -#include "ephy-topic-factory-action.h" #include <string.h> #include <glib/gi18n.h> diff --git a/src/bookmarks/ephy-topic-factory-action.c b/src/bookmarks/ephy-topic-factory-action.c deleted file mode 100644 index e8b8e583c..000000000 --- a/src/bookmarks/ephy-topic-factory-action.c +++ /dev/null @@ -1,302 +0,0 @@ -/* - * Copyright © 2004 Peter Harvey - * - * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. - * - */ - -#ifdef HAVE_CONFIG_H -#include "config.h" -#endif - -#include <gtk/gtk.h> -#include <glib/gi18n.h> - -#include "ephy-topic-factory-action.h" -#include "ephy-topic-action.h" -#include "ephy-bookmarks-ui.h" -#include "ephy-shell.h" -#include "ephy-stock-icons.h" -#include "egg-editable-toolbar.h" - -static void ephy_topic_factory_action_init (EphyTopicFactoryAction *factory); -static void ephy_topic_factory_action_class_init (EphyTopicFactoryActionClass *class); - -#define EPHY_TOPIC_FACTORY_ACTION_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_TOPIC_FACTORY_ACTION, EphyTopicActionPrivate)) -#define EGG_TOOLBARS_MODEL_DATA "ephy-topic-factory-menu" - -G_DEFINE_TYPE (EphyTopicFactoryAction, ephy_topic_factory_action, GTK_TYPE_ACTION) - -static int -sort_topics (gconstpointer a, gconstpointer b) -{ - EphyNode *node_a = *(EphyNode **)a; - EphyNode *node_b = *(EphyNode **)b; - const char *title1, *title2; - int priority1, priority2; - - priority1 = ephy_node_get_property_int (node_a, EPHY_NODE_KEYWORD_PROP_PRIORITY); - priority2 = ephy_node_get_property_int (node_b, EPHY_NODE_KEYWORD_PROP_PRIORITY); - - if (priority1 > priority2) - { - return 1; - } - else if (priority1 < priority2) - { - return -1; - } - else - { - title1 = ephy_node_get_property_string (node_a, EPHY_NODE_KEYWORD_PROP_NAME); - title2 = ephy_node_get_property_string (node_b, EPHY_NODE_KEYWORD_PROP_NAME); - - if (title1 == NULL) - { - return -1; - } - else if (title2 == NULL) - { - return 1; - } - else - { - return g_utf8_collate (title1, title2); - } - } - - return 0; -} - -static void -activate_item_cb (GtkWidget *menuitem, GtkWidget *placeholder) -{ - GtkWidget *toolbar, *etoolbar, *item; - EggToolbarsModel *model; - GList *children; - gint index, pos; - char *id; - - item = gtk_widget_get_ancestor (placeholder, GTK_TYPE_TOOL_ITEM); - g_return_if_fail (item); - toolbar = gtk_widget_get_ancestor (item, GTK_TYPE_TOOLBAR); - g_return_if_fail (toolbar); - etoolbar = gtk_widget_get_ancestor (toolbar, EGG_TYPE_EDITABLE_TOOLBAR); - g_return_if_fail (etoolbar); - model = egg_editable_toolbar_get_model (EGG_EDITABLE_TOOLBAR (etoolbar)); - g_return_if_fail (model); - - children = gtk_container_get_children (GTK_CONTAINER (etoolbar)); - pos = g_list_index (children, gtk_widget_get_parent (toolbar)); - index = gtk_toolbar_get_item_index (GTK_TOOLBAR (toolbar), GTK_TOOL_ITEM (item)); - g_list_free (children); - - id = g_object_get_data (G_OBJECT (menuitem), "ephy-action"); - egg_toolbars_model_add_item (model, pos, index, id); -} - -static GtkWidget * -build_menu (GtkWidget *placeholder, EggToolbarsModel *model) -{ - GtkWidget *menu, *item; - - EphyBookmarks *eb; - EphyNode *node; - GPtrArray *children, *topics; - - const char *name; - char action[EPHY_TOPIC_ACTION_NAME_BUFFER_SIZE]; - gint i, priority = -1, ptmp, flags; - - /* Get a sorted list of topics. */ - eb = ephy_shell_get_bookmarks (ephy_shell); - node = ephy_bookmarks_get_keywords (eb); - children = ephy_node_get_children (node); - topics = g_ptr_array_sized_new (children->len); - for (i = 0; i < children->len; i++) - g_ptr_array_add (topics, g_ptr_array_index (children, i)); - g_ptr_array_sort (topics, (GCompareFunc)sort_topics); - - menu = gtk_menu_new (); - for (i = 0; i < topics->len; i++) - { - node = g_ptr_array_index (topics, i); - - EPHY_TOPIC_ACTION_NAME_PRINTF (action, node); - - flags = egg_toolbars_model_get_name_flags (model, action); - if (flags & EGG_TB_MODEL_NAME_USED) - continue; - - ptmp = ephy_node_get_property_int (node, EPHY_NODE_KEYWORD_PROP_PRIORITY); - if (ptmp != priority && priority >= 0) - { - item = gtk_separator_menu_item_new (); - gtk_widget_show (item); - gtk_menu_shell_append (GTK_MENU_SHELL (menu), item); - } - priority = ptmp; - - name = ephy_node_get_property_string (node, EPHY_NODE_KEYWORD_PROP_NAME); - item = gtk_menu_item_new_with_label (name); - - /* FIXME: set the |node| instead here! */ - g_object_set_data_full (G_OBJECT (item), "ephy-action", - g_strdup (action), g_free); - g_signal_connect (item, "activate", G_CALLBACK (activate_item_cb), placeholder); - gtk_widget_show (item); - - gtk_menu_shell_append (GTK_MENU_SHELL (menu), item); - } - g_ptr_array_free (topics, TRUE); - - return menu; -} - -static void -remove_placeholder_cb (GtkMenuShell *menushell, GtkWidget *placeholder) -{ - GtkWidget *toolbar, *etoolbar, *item; - EggToolbarsModel *model; - GList *children; - gint index, pos; - - item = gtk_widget_get_ancestor (placeholder, GTK_TYPE_TOOL_ITEM); - g_return_if_fail (item); - toolbar = gtk_widget_get_ancestor (item, GTK_TYPE_TOOLBAR); - g_return_if_fail (toolbar); - etoolbar = gtk_widget_get_ancestor (toolbar, EGG_TYPE_EDITABLE_TOOLBAR); - g_return_if_fail (etoolbar); - model = egg_editable_toolbar_get_model (EGG_EDITABLE_TOOLBAR (etoolbar)); - g_return_if_fail (model); - - g_object_set_data (G_OBJECT (model), EGG_TOOLBARS_MODEL_DATA, NULL); - - children = gtk_container_get_children (GTK_CONTAINER (etoolbar)); - pos = g_list_index (children, gtk_widget_get_parent (toolbar)); - index = gtk_toolbar_get_item_index (GTK_TOOLBAR (toolbar), GTK_TOOL_ITEM (item)); - g_list_free (children); - - egg_toolbars_model_remove_item (model, pos, index); -} - -static gboolean -activate_placeholder_cb (GtkWidget *placeholder) -{ - GtkWidget *toolbar, *etoolbar, *item, *menu; - EggToolbarsModel *model; - gint index; - - /* Get our position on a toolbar. */ - item = gtk_widget_get_ancestor (placeholder, GTK_TYPE_TOOL_ITEM); - g_return_val_if_fail (item, FALSE); - toolbar = gtk_widget_get_ancestor (item, GTK_TYPE_TOOLBAR); - g_return_val_if_fail (toolbar, FALSE); - etoolbar = gtk_widget_get_ancestor (toolbar, EGG_TYPE_EDITABLE_TOOLBAR); - g_return_val_if_fail (etoolbar, FALSE); - model = egg_editable_toolbar_get_model (EGG_EDITABLE_TOOLBAR (etoolbar)); - g_return_val_if_fail (model, FALSE); - - /* If we are not yet on the toolbar, abort. */ - index = gtk_toolbar_get_item_index (GTK_TOOLBAR (toolbar), GTK_TOOL_ITEM (item)); - if (index < 0 || index >= gtk_toolbar_get_n_items (GTK_TOOLBAR (toolbar))) - return FALSE; - - /* If there is already a popup menu, abort. */ - menu = g_object_get_data (G_OBJECT (model), EGG_TOOLBARS_MODEL_DATA); - if (menu != NULL) return FALSE; - - /* Create the menu and store it's pointer to ensure noone else creates a menu. */ - menu = build_menu (placeholder, model); - g_object_set_data (G_OBJECT (model), EGG_TOOLBARS_MODEL_DATA, menu); - - g_signal_connect (menu, "selection-done", - G_CALLBACK (remove_placeholder_cb), placeholder); - - gtk_menu_popup (GTK_MENU (menu), NULL, NULL, NULL, NULL, 0, - gtk_get_current_event_time ()); - - return FALSE; -} - -static void -clicked_placeholder_cb (GtkWidget *placeholder, GdkEventButton *event, gpointer user) -{ - activate_placeholder_cb (placeholder); -} - -static void -realize_placeholder_cb (GtkWidget *placeholder, gpointer user) -{ - g_idle_add ((GSourceFunc) activate_placeholder_cb, placeholder); -} - -static GtkWidget * -create_tool_item (GtkAction *action) -{ - GtkWidget *item = GTK_WIDGET (gtk_tool_item_new ()); - GtkWidget *widget = gtk_button_new_with_label (" ? "); - gtk_button_set_relief (GTK_BUTTON (widget), GTK_RELIEF_NONE); - - gtk_container_add (GTK_CONTAINER (item), widget); - gtk_widget_show (widget); - - return item; -} - -static void -connect_proxy (GtkAction *action, GtkWidget *proxy) -{ - GtkWidget *widget; - - GTK_ACTION_CLASS (ephy_topic_factory_action_parent_class)->connect_proxy (action, proxy); - - g_return_if_fail (GTK_IS_TOOL_ITEM (proxy)); - - widget = gtk_bin_get_child (GTK_BIN (proxy)); - - g_signal_connect (G_OBJECT (widget), "realize", - G_CALLBACK (realize_placeholder_cb), - G_OBJECT (action)); - g_signal_connect (G_OBJECT (widget), "clicked", - G_CALLBACK (clicked_placeholder_cb), - G_OBJECT (action)); -} - -static void -ephy_topic_factory_action_init (EphyTopicFactoryAction *factory) -{ - /* Empty, needed for G_DEFINE_TYPE macro */ -} - -static void -ephy_topic_factory_action_class_init (EphyTopicFactoryActionClass *class) -{ - GtkActionClass *action_class = GTK_ACTION_CLASS (class); - - action_class->toolbar_item_type = GTK_TYPE_TOOL_ITEM; - action_class->connect_proxy = connect_proxy; - action_class->create_tool_item = create_tool_item; -} - -GtkAction * -ephy_topic_factory_action_new (const char *name) -{ - return GTK_ACTION (g_object_new (EPHY_TYPE_TOPIC_FACTORY_ACTION, - "name", name, - "label", _("Topic"), - "stock-id", GTK_STOCK_ADD, - NULL)); -} diff --git a/src/bookmarks/ephy-topic-factory-action.h b/src/bookmarks/ephy-topic-factory-action.h deleted file mode 100644 index 7f6668cd3..000000000 --- a/src/bookmarks/ephy-topic-factory-action.h +++ /dev/null @@ -1,56 +0,0 @@ -/* - * Copyright © 2004 Peter Harvey - * - * 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., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA. - * - */ - -#if !defined (__EPHY_EPIPHANY_H_INSIDE__) && !defined (EPIPHANY_COMPILATION) -#error "Only <epiphany/epiphany.h> can be included directly." -#endif - -#ifndef EPHY_TOPIC_FACTORY_ACTION_H -#define EPHY_TOPIC_FACTORY_ACTION_H - -#include "ephy-node.h" -#include "ephy-window.h" - -#include <gtk/gtk.h> - -#define EPHY_TYPE_TOPIC_FACTORY_ACTION (ephy_topic_factory_action_get_type ()) -#define EPHY_TOPIC_FACTORY_ACTION(obj) (G_TYPE_CHECK_INSTANCE_CAST ((obj), EPHY_TYPE_TOPIC_FACTORY_ACTION, EphyTopicFactoryAction)) -#define EPHY_TOPIC_FACTORY_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_CAST ((klass), EPHY_TYPE_TOPIC_FACTORY_ACTION, EphyTopicFactoryActionClass)) -#define EPHY_IS_TOPIC_FACTORY_ACTION(obj) (G_TYPE_CHECK_INSTANCE_TYPE ((obj), EPHY_TYPE_TOPIC_FACTORY_ACTION)) -#define EPHY_IS_TOPIC_FACTORY_ACTION_CLASS(klass) (G_TYPE_CHECK_CLASS_TYPE ((obj), EPHY_TYPE_TOPIC_FACTORY_ACTION)) -#define EPHY_TOPIC_FACTORY_ACTION_GET_CLASS(obj) (G_TYPE_INSTANCE_GET_CLASS((obj), EPHY_TYPE_TOPIC_FACTORY_ACTION, EphyTopicFactoryActionClass)) - -typedef struct _EphyTopicFactoryAction EphyTopicFactoryAction; -typedef struct _EphyTopicFactoryActionClass EphyTopicFactoryActionClass; - -struct _EphyTopicFactoryAction -{ - GtkAction parent; -}; - -struct _EphyTopicFactoryActionClass -{ - GtkActionClass parent_class; -}; - -GType ephy_topic_factory_action_get_type (void); - -GtkAction * ephy_topic_factory_action_new (const char *name); - -#endif |