aboutsummaryrefslogtreecommitdiffstats
path: root/src/ephy-toolbar.c
diff options
context:
space:
mode:
Diffstat (limited to 'src/ephy-toolbar.c')
-rwxr-xr-xsrc/ephy-toolbar.c64
1 files changed, 12 insertions, 52 deletions
diff --git a/src/ephy-toolbar.c b/src/ephy-toolbar.c
index 41368a6c4..0137a477e 100755
--- a/src/ephy-toolbar.c
+++ b/src/ephy-toolbar.c
@@ -35,8 +35,8 @@
#include "ephy-dnd.h"
#include "ephy-shell.h"
#include "ephy-stock-icons.h"
+#include "ephy-action-helper.h"
#include "window-commands.h"
-#include "eel-gconf-extensions.h"
#include "ephy-debug.h"
#include <glib/gi18n.h>
@@ -58,6 +58,11 @@ enum
LAST_ACTION
};
+enum
+{
+ SENS_FLAG = 1 << 0
+};
+
#define EPHY_TOOLBAR_GET_PRIVATE(object)(G_TYPE_INSTANCE_GET_PRIVATE ((object), EPHY_TYPE_TOOLBAR, EphyToolbarPrivate))
struct _EphyToolbarPrivate
@@ -65,29 +70,26 @@ struct _EphyToolbarPrivate
EphyWindow *window;
GtkActionGroup *action_group;
GtkAction *actions[LAST_ACTION];
- gboolean updating_address;
GtkWidget *fixed_toolbar;
GtkWidget *spinner;
GtkToolItem *spinner_item;
GtkToolItem *sep_item;
GtkToolItem *exit_button;
- guint disable_arbitrary_url_notifier_id;
gulong set_focus_handler;
+ gboolean updating_address;
gboolean show_lock;
gboolean lock_visible;
gboolean leave_fullscreen_visible;
gboolean spinning;
};
-static GtkTargetEntry drag_targets[] =
+static const GtkTargetEntry drag_targets [] =
{
{ EGG_TOOLBAR_ITEM_TYPE, GTK_TARGET_SAME_APP, 0 },
- { EPHY_DND_TOPIC_TYPE, 0, 1 },
+ { EPHY_DND_TOPIC_TYPE, 0, 1 },
{ EPHY_DND_URL_TYPE, 0, 2 }
};
-#define CONF_LOCKDOWN_DISABLE_ARBITRARY_URL "/apps/epiphany/lockdown/disable_arbitrary_url"
-
enum
{
PROP_0,
@@ -204,32 +206,6 @@ maybe_finish_activation_cb (EphyWindow *window,
}
static void
-update_location_editable (EphyToolbar *toolbar)
-{
- EphyToolbarPrivate *priv = toolbar->priv;
- EphyEmbed *embed;
- char *address;
- gboolean editable;
-
- editable = !eel_gconf_get_boolean (CONF_LOCKDOWN_DISABLE_ARBITRARY_URL);
-
- g_object_set (priv->actions[LOCATION_ACTION], "editable", editable, NULL);
-
- /* Restore the real web page address when disabling entry */
- if (editable == FALSE)
- {
- embed = ephy_window_get_active_embed (priv->window);
- /* embed is NULL on startup */
- if (EPHY_IS_EMBED (embed))
- {
- address = ephy_embed_get_location (embed, TRUE);
- ephy_toolbar_set_location (toolbar, address);
- g_free (address);
- }
- }
-}
-
-static void
sync_user_input_cb (EphyLocationAction *action,
GParamSpec *pspec,
EphyToolbar *toolbar)
@@ -268,15 +244,6 @@ zoom_to_level_cb (GtkAction *action,
}
static void
-arbitrary_url_notifier (GConfClient *client,
- guint cnxn_id,
- GConfEntry *entry,
- EphyToolbar *toolbar)
-{
- update_location_editable (toolbar);
-}
-
-static void
ephy_toolbar_set_window (EphyToolbar *toolbar,
EphyWindow *window)
{
@@ -367,7 +334,6 @@ ephy_toolbar_set_window (EphyToolbar *toolbar,
g_signal_connect (action, "lock-clicked",
G_CALLBACK (lock_clicked_cb), toolbar);
gtk_action_group_add_action (priv->action_group, action);
- update_location_editable (toolbar);
g_object_unref (action);
action = priv->actions[ZOOM_ACTION] =
@@ -405,10 +371,6 @@ ephy_toolbar_set_window (EphyToolbar *toolbar,
G_CALLBACK (ephy_link_open), toolbar);
gtk_action_group_add_action_with_accel (priv->action_group, action, "<alt>Home");
g_object_unref (action);
-
- priv->disable_arbitrary_url_notifier_id = eel_gconf_notification_add
- (CONF_LOCKDOWN_DISABLE_ARBITRARY_URL,
- (GConfClientNotifyFunc) arbitrary_url_notifier, toolbar);
}
/* public functions */
@@ -500,9 +462,9 @@ ephy_toolbar_set_navigation_actions (EphyToolbar *toolbar,
{
EphyToolbarPrivate *priv = toolbar->priv;
- g_object_set (priv->actions[BACK_ACTION], "sensitive", back, NULL);
- g_object_set (priv->actions[FORWARD_ACTION], "sensitive", forward, NULL);
- g_object_set (priv->actions[UP_ACTION], "sensitive", up, NULL);
+ ephy_action_change_sensitivity_flags (priv->actions[BACK_ACTION], SENS_FLAG, !back);
+ ephy_action_change_sensitivity_flags (priv->actions[FORWARD_ACTION], SENS_FLAG, !forward);
+ ephy_action_change_sensitivity_flags (priv->actions[UP_ACTION], SENS_FLAG, !up);
}
void
@@ -689,8 +651,6 @@ ephy_toolbar_finalize (GObject *object)
priv->set_focus_handler);
}
- eel_gconf_notification_remove (priv->disable_arbitrary_url_notifier_id);
-
g_signal_handlers_disconnect_by_func
(egg_editable_toolbar_get_model (etoolbar),
G_CALLBACK (toolbar_added_cb), toolbar);