aboutsummaryrefslogtreecommitdiffstats
path: root/src/bookmarks
diff options
context:
space:
mode:
Diffstat (limited to 'src/bookmarks')
-rw-r--r--src/bookmarks/ephy-bookmark-action.c10
-rw-r--r--src/bookmarks/ephy-bookmark-properties.c208
2 files changed, 8 insertions, 210 deletions
diff --git a/src/bookmarks/ephy-bookmark-action.c b/src/bookmarks/ephy-bookmark-action.c
index 678c5d609..888b3b4ce 100644
--- a/src/bookmarks/ephy-bookmark-action.c
+++ b/src/bookmarks/ephy-bookmark-action.c
@@ -159,6 +159,8 @@ ephy_bookmark_action_sync_smart_url (GtkAction *gaction, GParamSpec *pspec, GtkW
EphyBookmarkAction *action = EPHY_BOOKMARK_ACTION (gaction);
EphyBookmarkActionPrivate *priv = action->priv;
gboolean is_smart_url = priv->smart_url;
+ gboolean has_icon = (gboolean) ephy_node_get_property_string
+ (priv->node, EPHY_NODE_BMK_PROP_ICON);
GtkWidget *entry, *icon;
guint width;
@@ -168,6 +170,7 @@ ephy_bookmark_action_sync_smart_url (GtkAction *gaction, GParamSpec *pspec, GtkW
icon = GTK_WIDGET (g_object_get_data (G_OBJECT (proxy), "icon"));
g_object_set (entry, "visible", is_smart_url, NULL);
+ g_object_set (icon, "visible", !is_smart_url || has_icon, NULL);
gtk_entry_set_width_chars (GTK_ENTRY (entry),
width > 0 ? width : ENTRY_WIDTH_CHARS);
}
@@ -205,12 +208,7 @@ ephy_bookmark_action_sync_icon (GtkAction *action, GParamSpec *pspec, GtkWidget
g_return_if_fail (bma->priv->node != NULL);
icon_location = ephy_node_get_property_string (bma->priv->node,
- EPHY_NODE_BMK_PROP_USERICON);
- if (icon_location == NULL)
- {
- icon_location = ephy_node_get_property_string (bma->priv->node,
- EPHY_NODE_BMK_PROP_ICON);
- }
+ EPHY_NODE_BMK_PROP_ICON);
cache = EPHY_FAVICON_CACHE (ephy_embed_shell_get_favicon_cache
(EPHY_EMBED_SHELL (ephy_shell)));
diff --git a/src/bookmarks/ephy-bookmark-properties.c b/src/bookmarks/ephy-bookmark-properties.c
index dea6defb1..7c64339cd 100644
--- a/src/bookmarks/ephy-bookmark-properties.c
+++ b/src/bookmarks/ephy-bookmark-properties.c
@@ -27,8 +27,8 @@
#include "ephy-shell.h"
#include "ephy-state.h"
#include "ephy-gui.h"
-#include "ephy-dnd.h"
#include "ephy-favicon-cache.h"
+#include "ephy-dnd.h"
#include <gtk/gtkcheckbutton.h>
#include <gtk/gtktogglebutton.h>
@@ -38,18 +38,10 @@
#include <gtk/gtktable.h>
#include <gtk/gtklabel.h>
#include <gtk/gtkmisc.h>
-#include <gtk/gtkliststore.h>
#include <gtk/gtkscrolledwindow.h>
#include <glib/gi18n.h>
#include <string.h>
-enum
-{
- LIST_SEPARATOR,
- LIST_ICON,
- LIST_FROMFILE
-};
-
static const GtkTargetEntry dest_drag_types[] = {
{EPHY_DND_URL_TYPE, 0, 0},
};
@@ -296,7 +288,6 @@ update_window_title (EphyBookmarkProperties *properties)
g_free (title);
}
-
static void
combo_changed_cb (GtkComboBox *combobox, GtkWidget *palette)
{
@@ -351,189 +342,6 @@ set_window_icon (EphyBookmarkProperties *properties)
}
static void
-refresh_icon (GtkComboBox *combobox, const char *location, gboolean set, gboolean create)
-{
- EphyFaviconCache *cache;
- GtkListStore *store;
- GtkTreeIter iter;
- GdkPixbuf *icon;
- gboolean valid;
- const char *filename;
-
- store = GTK_LIST_STORE (gtk_combo_box_get_model (combobox));
- valid = gtk_tree_model_get_iter_first (GTK_TREE_MODEL (store), &iter);
- while (valid)
- {
- int type;
- char *tmp;
-
- // Check that this is really an icon
- gtk_tree_model_get (GTK_TREE_MODEL (store), &iter, 3, &type, -1);
- if (type == LIST_ICON)
- {
- // Check if it's the icon we're looking for
- gtk_tree_model_get (GTK_TREE_MODEL (store), &iter, 0, &tmp, -1);
- if (location == tmp || (tmp != NULL && location != NULL && strcmp (location, tmp) == 0))
- {
- g_free (tmp);
- break;
- }
- g_free (tmp);
- }
- valid = gtk_tree_model_iter_next (GTK_TREE_MODEL (store), &iter);
- }
-
- if (!valid && !create) return;
-
- cache = EPHY_FAVICON_CACHE (ephy_embed_shell_get_favicon_cache (embed_shell));
- icon = (location && *location) ? ephy_favicon_cache_get (cache, location) : NULL;
-
- if (!valid)
- {
- filename = g_strrstr (location, "/");
- filename = filename ? (filename+1) : "";
- filename = *filename ? filename : location;
- gtk_list_store_insert_with_values (store, &iter, 0, 0, location, 1, filename, 2, icon, 3, LIST_ICON, -1);
- }
- else
- {
- gtk_list_store_set (store, &iter, 2, icon, -1);
- }
-
- if (set)
- {
- gtk_combo_box_set_active_iter (combobox, &iter);
- }
-}
-
-static void
-icon_changed_cb (GtkComboBox *combobox,
- EphyBookmarkProperties *properties)
-{
- GValue value = { 0, };
- GtkTreeIter iter;
- int type;
- char *location;
-
- gtk_combo_box_get_active_iter (combobox, &iter);
- gtk_tree_model_get (gtk_combo_box_get_model (combobox), &iter, 0, &location, 3, &type, -1);
-
- if (type == LIST_ICON)
- {
- g_value_init (&value, G_TYPE_STRING);
- g_value_set_string (&value, location);
- ephy_node_set_property (properties->priv->bookmark,
- EPHY_NODE_BMK_PROP_USERICON,
- &value);
- g_value_unset (&value);
- }
- else if (type == LIST_FROMFILE)
- {
- GtkWidget *widget = gtk_file_chooser_dialog_new
- (_("Open Icon"), GTK_WINDOW (properties), GTK_FILE_CHOOSER_ACTION_OPEN,
- GTK_STOCK_CANCEL, GTK_RESPONSE_CANCEL, GTK_STOCK_OPEN, GTK_RESPONSE_ACCEPT, NULL);
- gtk_widget_show (widget);
- }
-
- g_free (location);
-
- refresh_icon (GTK_COMBO_BOX (combobox),
- ephy_node_get_property_string (properties->priv->bookmark, EPHY_NODE_BMK_PROP_USERICON),
- TRUE, TRUE);
-}
-
-static void
-icon_drag_data_received_cb (GObject *widget,
- GdkDragContext *context,
- gint x,
- gint y,
- GtkSelectionData *selection_data,
- guint info,
- guint time,
- gpointer user)
-{
- gchar **netscape_url;
-
- netscape_url = g_strsplit ((char *)selection_data->data, "\n", 2);
- if (!netscape_url || !netscape_url[0])
- {
- g_strfreev (netscape_url);
- gtk_drag_finish (context, FALSE, FALSE, time);
- return;
- }
-
- refresh_icon (GTK_COMBO_BOX (widget), netscape_url[0], TRUE, TRUE);
- g_strfreev (netscape_url);
- gtk_drag_finish (context, TRUE, TRUE, time);
-}
-
-static void
-icon_cache_changed (EphyFaviconCache *cache, const char *url, GtkComboBox *combobox)
-{
- refresh_icon (combobox, url, FALSE, FALSE);
-}
-
-
-static gboolean
-is_separator (GtkTreeModel *model,
- GtkTreeIter *iter,
- gpointer data)
-{
- int type;
- gtk_tree_model_get (model, iter, 3, &type, -1);
- return (type == LIST_SEPARATOR);
-}
-
-static GtkWidget *
-build_icon (EphyBookmarkProperties *properties)
-{
- EphyFaviconCache *cache;
- GtkWidget *combobox;
- GtkListStore *store;
- GtkTreeIter iter;
- GtkCellLayout *layout;
- GtkCellRenderer *renderer;
- const char *location;
-
- store = gtk_list_store_new (4, G_TYPE_STRING, G_TYPE_STRING, GDK_TYPE_PIXBUF, G_TYPE_INT);
- combobox = gtk_combo_box_new_with_model (GTK_TREE_MODEL (store));
- gtk_combo_box_set_row_separator_func (GTK_COMBO_BOX (combobox), is_separator, NULL, NULL);
- layout = GTK_CELL_LAYOUT (combobox);
-
- cache = EPHY_FAVICON_CACHE (ephy_embed_shell_get_favicon_cache (embed_shell));
- g_signal_connect (cache, "changed", G_CALLBACK (icon_cache_changed), combobox);
-
- gtk_list_store_insert_with_values (store, &iter, 0, 0, NULL, 1, _("From file..."), 2, NULL, 3, LIST_FROMFILE, -1);
- gtk_list_store_insert_with_values (store, &iter, 0, 0, NULL, 1, NULL, 2, NULL, 3, LIST_SEPARATOR, -1);
- gtk_list_store_insert_with_values (store, &iter, 0, 0, "", 1, _("None"), 2, NULL, 3, LIST_ICON, -1);
- gtk_list_store_insert_with_values (store, &iter, 0, 0, NULL, 1, _("Default"), 2, NULL, 3, LIST_ICON, -1);
-
- location = ephy_node_get_property_string (properties->priv->bookmark, EPHY_NODE_BMK_PROP_ICON);
- refresh_icon (GTK_COMBO_BOX (combobox), location, FALSE, TRUE);
-
- location = ephy_node_get_property_string (properties->priv->bookmark, EPHY_NODE_BMK_PROP_USERICON);
- refresh_icon (GTK_COMBO_BOX (combobox), location, TRUE, TRUE);
-
- renderer = gtk_cell_renderer_text_new ();
- gtk_cell_layout_pack_start (layout, renderer, TRUE);
- gtk_cell_layout_add_attribute (layout, renderer, "text", 1);
-
- renderer = gtk_cell_renderer_pixbuf_new ();
- gtk_cell_layout_pack_start (layout, renderer, FALSE);
- gtk_cell_layout_add_attribute (layout, renderer, "pixbuf", 2);
-
- g_signal_connect (G_OBJECT (combobox), "changed", G_CALLBACK (icon_changed_cb), properties);
- gtk_widget_show (combobox);
-
- g_signal_connect (G_OBJECT (combobox), "drag_data_received",
- G_CALLBACK (icon_drag_data_received_cb), NULL);
- gtk_drag_dest_set (combobox, GTK_DEST_DEFAULT_ALL, dest_drag_types,
- G_N_ELEMENTS (dest_drag_types), GDK_ACTION_COPY);
-
- return combobox;
-}
-
-static void
build_ui (EphyBookmarkProperties *properties)
{
GtkWidget *table, *label, *entry, *palette;
@@ -599,14 +407,6 @@ build_ui (EphyBookmarkProperties *properties)
gtk_widget_show (label);
gtk_table_attach (GTK_TABLE (table), label, 0, 1, 1, 2, GTK_FILL, 0, 0, 0);
gtk_table_attach (GTK_TABLE (table), entry, 1, 2, 1, 2, GTK_FILL, 0, 0, 0);
-
- entry = build_icon (properties);
- label = gtk_label_new_with_mnemonic (_("I_con:"));
- gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
- gtk_label_set_mnemonic_widget (GTK_LABEL (label), entry);
- gtk_widget_show (label);
- gtk_table_attach (GTK_TABLE (table), label, 0, 1, 2, 3, GTK_FILL, 0, 0, 0);
- gtk_table_attach (GTK_TABLE (table), entry, 1, 2, 2, 3, GTK_FILL, 0, 0, 0);
cbox = GTK_COMBO_BOX (gtk_combo_box_new_text ());
gtk_widget_show (GTK_WIDGET (cbox));
@@ -616,8 +416,8 @@ build_ui (EphyBookmarkProperties *properties)
gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
gtk_label_set_mnemonic_widget (GTK_LABEL (label), GTK_WIDGET (cbox));
gtk_widget_show (label);
- gtk_table_attach (GTK_TABLE (table), label, 0, 1, 3, 4, GTK_FILL, 0, 0, 0);
- gtk_table_attach (GTK_TABLE (table), GTK_WIDGET (cbox), 1, 2, 3, 4, GTK_FILL, 0, 0, 0);
+ gtk_table_attach (GTK_TABLE (table), label, 0, 1, 2, 3, GTK_FILL, 0, 0, 0);
+ gtk_table_attach (GTK_TABLE (table), GTK_WIDGET (cbox), 1, 2, 2, 3, GTK_FILL, 0, 0, 0);
palette = ephy_topics_palette_new (properties->priv->bookmarks,
properties->priv->bookmark);
@@ -636,7 +436,7 @@ build_ui (EphyBookmarkProperties *properties)
g_signal_connect_object (G_OBJECT (cbox), "changed", G_CALLBACK (combo_changed_cb),
palette, G_CONNECT_AFTER);
- gtk_table_attach (GTK_TABLE (table), scrolled_window, 1, 2, 4, 5,
+ gtk_table_attach (GTK_TABLE (table), scrolled_window, 1, 2, 3, 4,
GTK_FILL | GTK_EXPAND, GTK_FILL | GTK_EXPAND, 0, 0);
gtk_table_set_row_spacing (GTK_TABLE (table), 3, 3);