aboutsummaryrefslogtreecommitdiffstats
path: root/src/bookmarks/ephy-bookmarks-editor.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/bookmarks/ephy-bookmarks-editor.c')
-rw-r--r--src/bookmarks/ephy-bookmarks-editor.c53
1 files changed, 43 insertions, 10 deletions
diff --git a/src/bookmarks/ephy-bookmarks-editor.c b/src/bookmarks/ephy-bookmarks-editor.c
index 1a145188e..93a4123cc 100644
--- a/src/bookmarks/ephy-bookmarks-editor.c
+++ b/src/bookmarks/ephy-bookmarks-editor.c
@@ -54,6 +54,7 @@ struct EphyBookmarksEditorPrivate
EphyNodeView *key_view;
EphyNodeFilter *bookmarks_filter;
GtkWidget *title_entry;
+ GtkWidget *location_entry;
GtkWidget *keywords_entry;
GtkWidget *search_entry;
};
@@ -189,6 +190,7 @@ ephy_bookmarks_editor_node_selected_cb (GtkWidget *view,
{
const char *title;
const char *keywords;
+ const char *location;
if (node != NULL)
{
@@ -198,19 +200,26 @@ ephy_bookmarks_editor_node_selected_cb (GtkWidget *view,
(node, EPHY_NODE_BMK_PROP_TITLE);
keywords = ephy_node_get_property_string
(node, EPHY_NODE_BMK_PROP_KEYWORDS);
+ location = ephy_node_get_property_string
+ (node, EPHY_NODE_BMK_PROP_LOCATION);
gtk_entry_set_text (GTK_ENTRY (editor->priv->title_entry),
title ? g_strdup (title) : "");
gtk_entry_set_text (GTK_ENTRY (editor->priv->keywords_entry),
keywords ? g_strdup (keywords) : "");
+ gtk_entry_set_text (GTK_ENTRY (editor->priv->location_entry),
+ location ? g_strdup (location) : "");
gtk_widget_set_sensitive (GTK_WIDGET (editor->priv->title_entry), TRUE);
gtk_widget_set_sensitive (GTK_WIDGET (editor->priv->keywords_entry), TRUE);
+ gtk_widget_set_sensitive (GTK_WIDGET (editor->priv->location_entry), TRUE);
}
else
{
gtk_entry_set_text (GTK_ENTRY (editor->priv->title_entry), "");
gtk_entry_set_text (GTK_ENTRY (editor->priv->keywords_entry), "");
+ gtk_entry_set_text (GTK_ENTRY (editor->priv->location_entry), "");
gtk_widget_set_sensitive (GTK_WIDGET (editor->priv->title_entry), FALSE);
gtk_widget_set_sensitive (GTK_WIDGET (editor->priv->keywords_entry), FALSE);
+ gtk_widget_set_sensitive (GTK_WIDGET (editor->priv->location_entry), FALSE);
}
}
@@ -257,7 +266,7 @@ update_prop_from_entry (EphyBookmarksEditor *editor,
GValue value = { 0, };
selection = ephy_node_view_get_selection (editor->priv->bm_view);
- if (selection)
+ if (selection != NULL)
{
EphyNode *bm = EPHY_NODE (selection->data);
char *tmp;
@@ -269,8 +278,8 @@ update_prop_from_entry (EphyBookmarksEditor *editor,
ephy_node_set_property (bm, id, &value);
g_value_unset (&value);
g_free (tmp);
+ g_list_free (selection);
}
- g_list_free (selection);
}
static void
@@ -281,6 +290,13 @@ title_entry_changed_cb (GtkWidget *entry, EphyBookmarksEditor *editor)
}
static void
+location_entry_changed_cb (GtkWidget *entry, EphyBookmarksEditor *editor)
+{
+ update_prop_from_entry (editor, editor->priv->location_entry,
+ EPHY_NODE_BMK_PROP_LOCATION);
+}
+
+static void
keywords_changed_cb (GtkWidget *entry,
EphyBookmarksEditor *editor)
{
@@ -313,6 +329,7 @@ build_editing_table (EphyBookmarksEditor *editor)
gtk_table_set_col_spacings (GTK_TABLE (table), 6);
gtk_widget_show (table);
+ /* Title entry */
label = gtk_label_new (NULL);
gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
str = g_strconcat ("<b>", _("Title:"), "</b>", NULL);
@@ -329,6 +346,24 @@ build_editing_table (EphyBookmarksEditor *editor)
G_CALLBACK (title_entry_changed_cb),
editor);
+ /* Location entry */
+ label = gtk_label_new (NULL);
+ gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
+ str = g_strconcat ("<b>", _("Location:"), "</b>", NULL);
+ gtk_label_set_markup (GTK_LABEL (label), str);
+ g_free (str);
+ gtk_widget_show (label);
+ entry = gtk_entry_new ();
+ editor->priv->location_entry = entry;
+ gtk_widget_set_sensitive (GTK_WIDGET (entry), FALSE);
+ gtk_widget_show (entry);
+ gtk_table_attach (GTK_TABLE (table), label, 0, 1, 1, 2, GTK_FILL, 0, 0, 0);
+ gtk_table_attach_defaults (GTK_TABLE (table), entry, 1, 2, 1, 2);
+ g_signal_connect (G_OBJECT (entry), "changed",
+ G_CALLBACK (location_entry_changed_cb),
+ editor);
+
+ /* Keywords entry */
label = gtk_label_new (NULL);
gtk_misc_set_alignment (GTK_MISC (label), 0.0, 0.5);
str = g_strconcat ("<b>", _("Keywords:"), "</b>", NULL);
@@ -341,8 +376,8 @@ build_editing_table (EphyBookmarksEditor *editor)
editor->priv->keywords_entry = entry;
gtk_widget_set_sensitive (GTK_WIDGET (entry), FALSE);
gtk_widget_show (entry);
- gtk_table_attach (GTK_TABLE (table), label, 0, 1, 1, 2, GTK_FILL, 0, 0, 0);
- gtk_table_attach_defaults (GTK_TABLE (table), entry, 1, 2, 1, 2);
+ gtk_table_attach (GTK_TABLE (table), label, 0, 1, 2, 3, GTK_FILL, 0, 0, 0);
+ gtk_table_attach_defaults (GTK_TABLE (table), entry, 1, 2, 2, 3);
g_signal_connect (G_OBJECT (entry), "keywords_changed",
G_CALLBACK (keywords_changed_cb),
editor);
@@ -448,9 +483,11 @@ ephy_bookmarks_editor_construct (EphyBookmarksEditor *editor)
EphyNode *selected_node;
char *selected_id_str;
+ gtk_window_set_title (GTK_WINDOW (editor), _("Bookmarks"));
+
gtk_dialog_set_has_separator (GTK_DIALOG (editor), FALSE);
gtk_container_set_border_width (GTK_CONTAINER (editor), 6);
- gtk_widget_set_size_request (GTK_WIDGET (editor), 500, 400);
+ gtk_widget_set_size_request (GTK_WIDGET (editor), 600, 400);
g_signal_connect (G_OBJECT (editor),
"response",
G_CALLBACK (ephy_bookmarks_editor_response_cb),
@@ -470,7 +507,7 @@ ephy_bookmarks_editor_construct (EphyBookmarksEditor *editor)
ephy_node_view_add_column (key_view, _("Keywords"),
EPHY_TREE_MODEL_NODE_COL_KEYWORD, FALSE);
gtk_box_pack_start (GTK_BOX (hbox), GTK_WIDGET (key_view), FALSE, TRUE, 0);
- gtk_widget_set_size_request (GTK_WIDGET (key_view), 120, -1);
+ gtk_widget_set_size_request (GTK_WIDGET (key_view), 180, -1);
gtk_widget_show (GTK_WIDGET (key_view));
editor->priv->key_view = key_view;
g_signal_connect (G_OBJECT (key_view),
@@ -494,8 +531,6 @@ ephy_bookmarks_editor_construct (EphyBookmarksEditor *editor)
ephy_node_view_add_icon_column (bm_view, EPHY_TREE_MODEL_NODE_COL_ICON);
ephy_node_view_add_column (bm_view, _("Title"),
EPHY_TREE_MODEL_NODE_COL_BOOKMARK, TRUE);
- ephy_node_view_add_column (bm_view, _("Location"),
- EPHY_TREE_MODEL_NODE_COL_LOCATION, TRUE);
gtk_box_pack_start (GTK_BOX (vbox), GTK_WIDGET (bm_view), TRUE, TRUE, 0);
gtk_widget_show (GTK_WIDGET (bm_view));
editor->priv->bm_view = bm_view;
@@ -520,8 +555,6 @@ ephy_bookmarks_editor_construct (EphyBookmarksEditor *editor)
GTK_RESPONSE_CLOSE);
gtk_dialog_set_default_response (GTK_DIALOG (editor), GTK_RESPONSE_CLOSE);
- gtk_window_set_title (GTK_WINDOW (editor), _("Bookmarks"));
-
selected_id_str = eel_gconf_get_string (CONF_BOOKMARKS_SELECTED_NODE);
selected_id = g_ascii_strtoull (selected_id_str, NULL, 10);
if (selected_id <= 0)