aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-history-window.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/ephy-history-window.c')
-rw-r--r--src/ephy-history-window.c24
1 files changed, 24 insertions, 0 deletions
diff --git a/src/ephy-history-window.c b/src/ephy-history-window.c
index a3f53a064..d8796c9be 100644
--- a/src/ephy-history-window.c
+++ b/src/ephy-history-window.c
@@ -65,6 +65,9 @@
#include "ephy-session.h"
#include "ephy-favicon-cache.h"
#include "eel-gconf-extensions.h"
+#include "ephy-node.h"
+#include "ephy-node-common.h"
+#include "ephy-node-view.h"
static GtkTargetEntry page_drag_types [] =
{
@@ -448,6 +451,23 @@ cmd_delete (GtkAction *action,
{
ephy_node_view_remove (EPHY_NODE_VIEW (editor->priv->pages_view));
}
+ else if (ephy_node_view_is_target (EPHY_NODE_VIEW (editor->priv->sites_view)))
+ {
+ EphyNodePriority priority;
+ GList *selected;
+ EphyNode *node;
+
+ selected = ephy_node_view_get_selection (EPHY_NODE_VIEW (editor->priv->sites_view));
+ node = selected->data;
+ priority = ephy_node_get_property_int (node, EPHY_NODE_KEYWORD_PROP_PRIORITY);
+
+ if (priority == -1) priority = EPHY_NODE_NORMAL_PRIORITY;
+
+ if (priority == EPHY_NODE_NORMAL_PRIORITY)
+ {
+ ephy_node_view_remove (EPHY_NODE_VIEW (editor->priv->sites_view));
+ }
+ }
}
static void
@@ -1259,6 +1279,10 @@ ephy_history_window_construct (EphyHistoryWindow *editor)
"node_selected",
G_CALLBACK (site_node_selected_cb),
editor);
+ g_signal_connect (G_OBJECT (sites_view),
+ "key_press_event",
+ G_CALLBACK (key_pressed_cb),
+ editor);
g_signal_connect (G_OBJECT (selection),
"changed",
G_CALLBACK (view_selection_changed_cb),