aboutsummaryrefslogtreecommitdiffstats
path: root/src
diff options
context:
space:
mode:
Diffstat (limited to 'src')
-rw-r--r--src/ephy-window.c357
1 files changed, 174 insertions, 183 deletions
diff --git a/src/ephy-window.c b/src/ephy-window.c
index 36b44730b..57e4671e7 100644
--- a/src/ephy-window.c
+++ b/src/ephy-window.c
@@ -81,15 +81,6 @@
static void ephy_window_view_popup_windows_cb (GtkAction *action,
EphyWindow *window);
-static void sync_tab_load_status (EphyWebView *view,
- GParamSpec *pspec,
- EphyWindow *window);
-static void sync_tab_security (EphyWebView *view,
- GParamSpec *pspec,
- EphyWindow *window);
-static void sync_tab_zoom (WebKitWebView *web_view,
- GParamSpec *pspec,
- EphyWindow *window);
static const GtkActionEntry ephy_menu_entries [] = {
@@ -814,6 +805,124 @@ sync_chromes_visibility (EphyWindow *window)
}
static void
+sync_tab_load_status (EphyWebView *view,
+ GParamSpec *pspec,
+ EphyWindow *window)
+{
+ EphyWindowPrivate *priv = window->priv;
+ GtkActionGroup *action_group = priv->action_group;
+ GtkAction *action;
+ gboolean loading;
+
+ if (window->priv->closing) return;
+
+ loading = ephy_web_view_is_loading (view);
+
+ action = gtk_action_group_get_action (action_group, "ViewStop");
+ gtk_action_set_sensitive (action, loading);
+
+ /* disable print while loading, see bug #116344 */
+ action = gtk_action_group_get_action (action_group, "FilePrint");
+ ephy_action_change_sensitivity_flags (action, SENS_FLAG_LOADING, loading);
+
+ action = gtk_action_group_get_action (priv->toolbar_action_group,
+ "ViewCombinedStopReload");
+ ephy_combined_stop_reload_action_set_loading (EPHY_COMBINED_STOP_RELOAD_ACTION (action),
+ loading);
+}
+
+static void
+_ephy_window_set_security_state (EphyWindow *window,
+ gboolean show_lock,
+ const char *stock_id,
+ const char *tooltip)
+{
+ EphyWindowPrivate *priv = window->priv;
+
+ priv->show_lock = show_lock != FALSE;
+
+ g_object_set (priv->location_controller,
+ "lock-stock-id", stock_id,
+ "lock-tooltip", tooltip,
+ "show-lock", priv->show_lock,
+ NULL);
+}
+
+static void
+sync_tab_security (EphyWebView *view,
+ GParamSpec *pspec,
+ EphyWindow *window)
+{
+ EphyWindowPrivate *priv = window->priv;
+ EphyWebViewSecurityLevel level;
+ char *description = NULL;
+ char *state = NULL;
+ char *tooltip;
+ const char *stock_id = STOCK_LOCK_INSECURE;
+ gboolean show_lock = FALSE;
+
+ if (priv->closing) return;
+
+ ephy_web_view_get_security_level (view, &level, &description);
+
+ switch (level)
+ {
+ case EPHY_WEB_VIEW_STATE_IS_UNKNOWN:
+ state = _("Unknown");
+ break;
+ case EPHY_WEB_VIEW_STATE_IS_INSECURE:
+ state = _("Insecure");
+ g_free (description);
+ description = NULL;
+ break;
+ case EPHY_WEB_VIEW_STATE_IS_BROKEN:
+ state = _("Broken");
+ stock_id = STOCK_LOCK_BROKEN;
+ show_lock = TRUE;
+ g_free (description);
+ description = NULL;
+ break;
+ case EPHY_WEB_VIEW_STATE_IS_SECURE_LOW:
+ case EPHY_WEB_VIEW_STATE_IS_SECURE_MED:
+ state = _("Low");
+ /* We deliberately don't show the 'secure' icon
+ * for low & medium secure sites; see bug #151709.
+ */
+ stock_id = STOCK_LOCK_INSECURE;
+ break;
+ case EPHY_WEB_VIEW_STATE_IS_SECURE_HIGH:
+ state = _("High");
+ stock_id = STOCK_LOCK_SECURE;
+ show_lock = TRUE;
+ break;
+ default:
+ g_assert_not_reached ();
+ break;
+ }
+
+ tooltip = g_strdup_printf (_("Security level: %s"), state);
+ if (description != NULL)
+ {
+ char *tmp = tooltip;
+
+ tooltip = g_strconcat (tmp, "\n", description, NULL);
+ g_free (description);
+ g_free (tmp);
+ }
+
+ _ephy_window_set_security_state (window, show_lock, stock_id, tooltip);
+
+ if (priv->fullscreen_popup != NULL)
+ {
+ ephy_fullscreen_popup_set_security_state
+ (EPHY_FULLSCREEN_POPUP (priv->fullscreen_popup),
+ show_lock, stock_id, tooltip);
+ }
+
+ g_free (tooltip);
+}
+
+static void
ephy_window_fullscreen (EphyWindow *window)
{
EphyWindowPrivate *priv = window->priv;
@@ -1584,6 +1693,62 @@ sync_tab_address (EphyWebView *view,
}
static void
+_ephy_window_action_set_zoom (EphyWindow *window,
+ gboolean can_zoom,
+ float zoom)
+{
+ EphyWindowPrivate *priv = window->priv;
+ GtkAction *action = gtk_action_group_get_action (priv->toolbar_action_group,
+ "Zoom");
+
+ gtk_action_set_sensitive (action, can_zoom);
+ g_object_set (action, "zoom", can_zoom ? zoom : 1.0, NULL);
+}
+
+static void
+sync_tab_zoom (WebKitWebView *web_view, GParamSpec *pspec, EphyWindow *window)
+{
+ GtkActionGroup *action_group;
+ GtkAction *action;
+ EphyWebViewDocumentType type;
+ gboolean can_zoom_in = TRUE, can_zoom_out = TRUE, can_zoom_normal = FALSE, can_zoom;
+ float zoom;
+ EphyEmbed *embed = window->priv->active_embed;
+
+ if (window->priv->closing) return;
+
+ g_object_get (web_view,
+ "zoom-level", &zoom,
+ NULL);
+
+ type = ephy_web_view_get_document_type (ephy_embed_get_web_view (embed));
+ can_zoom = (type != EPHY_WEB_VIEW_DOCUMENT_IMAGE);
+
+ if (zoom >= ZOOM_MAXIMAL)
+ {
+ can_zoom_in = FALSE;
+ }
+ if (zoom <= ZOOM_MINIMAL)
+ {
+ can_zoom_out = FALSE;
+ }
+ if (zoom != 1.0)
+ {
+ can_zoom_normal = TRUE;
+ }
+
+ _ephy_window_action_set_zoom (window, can_zoom, zoom);
+
+ action_group = window->priv->action_group;
+ action = gtk_action_group_get_action (action_group, "ViewZoomIn");
+ gtk_action_set_sensitive (action, can_zoom_in && can_zoom);
+ action = gtk_action_group_get_action (action_group, "ViewZoomOut");
+ gtk_action_set_sensitive (action, can_zoom_out && can_zoom);
+ action = gtk_action_group_get_action (action_group, "ViewZoomNormal");
+ gtk_action_set_sensitive (action, can_zoom_normal && can_zoom);
+}
+
+static void
sync_tab_document_type (EphyWebView *view,
GParamSpec *pspec,
EphyWindow *window)
@@ -1739,97 +1904,6 @@ sync_tab_navigation (EphyWebView *view,
}
static void
-_ephy_window_set_security_state (EphyWindow *window,
- gboolean show_lock,
- const char *stock_id,
- const char *tooltip)
-{
- EphyWindowPrivate *priv = window->priv;
-
- priv->show_lock = show_lock != FALSE;
-
- g_object_set (priv->location_controller,
- "lock-stock-id", stock_id,
- "lock-tooltip", tooltip,
- "show-lock", priv->show_lock,
- NULL);
-}
-
-static void
-sync_tab_security (EphyWebView *view,
- GParamSpec *pspec,
- EphyWindow *window)
-{
- EphyWindowPrivate *priv = window->priv;
- EphyWebViewSecurityLevel level;
- char *description = NULL;
- char *state = NULL;
- char *tooltip;
- const char *stock_id = STOCK_LOCK_INSECURE;
- gboolean show_lock = FALSE;
-
- if (priv->closing) return;
-
- ephy_web_view_get_security_level (view, &level, &description);
-
- switch (level)
- {
- case EPHY_WEB_VIEW_STATE_IS_UNKNOWN:
- state = _("Unknown");
- break;
- case EPHY_WEB_VIEW_STATE_IS_INSECURE:
- state = _("Insecure");
- g_free (description);
- description = NULL;
- break;
- case EPHY_WEB_VIEW_STATE_IS_BROKEN:
- state = _("Broken");
- stock_id = STOCK_LOCK_BROKEN;
- show_lock = TRUE;
- g_free (description);
- description = NULL;
- break;
- case EPHY_WEB_VIEW_STATE_IS_SECURE_LOW:
- case EPHY_WEB_VIEW_STATE_IS_SECURE_MED:
- state = _("Low");
- /* We deliberately don't show the 'secure' icon
- * for low & medium secure sites; see bug #151709.
- */
- stock_id = STOCK_LOCK_INSECURE;
- break;
- case EPHY_WEB_VIEW_STATE_IS_SECURE_HIGH:
- state = _("High");
- stock_id = STOCK_LOCK_SECURE;
- show_lock = TRUE;
- break;
- default:
- g_assert_not_reached ();
- break;
- }
-
- tooltip = g_strdup_printf (_("Security level: %s"), state);
- if (description != NULL)
- {
- char *tmp = tooltip;
-
- tooltip = g_strconcat (tmp, "\n", description, NULL);
- g_free (description);
- g_free (tmp);
- }
-
- _ephy_window_set_security_state (window, show_lock, stock_id, tooltip);
-
- if (priv->fullscreen_popup != NULL)
- {
- ephy_fullscreen_popup_set_security_state
- (EPHY_FULLSCREEN_POPUP (priv->fullscreen_popup),
- show_lock, stock_id, tooltip);
- }
-
- g_free (tooltip);
-}
-
-static void
sync_tab_popup_windows (EphyWebView *view,
GParamSpec *pspec,
EphyWindow *window)
@@ -1868,33 +1942,6 @@ sync_tab_popups_allowed (EphyWebView *view,
}
static void
-sync_tab_load_status (EphyWebView *view,
- GParamSpec *pspec,
- EphyWindow *window)
-{
- EphyWindowPrivate *priv = window->priv;
- GtkActionGroup *action_group = priv->action_group;
- GtkAction *action;
- gboolean loading;
-
- if (window->priv->closing) return;
-
- loading = ephy_web_view_is_loading (view);
-
- action = gtk_action_group_get_action (action_group, "ViewStop");
- gtk_action_set_sensitive (action, loading);
-
- /* disable print while loading, see bug #116344 */
- action = gtk_action_group_get_action (action_group, "FilePrint");
- ephy_action_change_sensitivity_flags (action, SENS_FLAG_LOADING, loading);
-
- action = gtk_action_group_get_action (priv->toolbar_action_group,
- "ViewCombinedStopReload");
- ephy_combined_stop_reload_action_set_loading (EPHY_COMBINED_STOP_RELOAD_ACTION (action),
- loading);
-}
-
-static void
sync_tab_title (EphyWebView *view,
GParamSpec *pspec,
EphyWindow *window)
@@ -1908,62 +1955,6 @@ sync_tab_title (EphyWebView *view,
}
static void
-_ephy_window_action_set_zoom (EphyWindow *window,
- gboolean can_zoom,
- float zoom)
-{
- EphyWindowPrivate *priv = window->priv;
- GtkAction *action = gtk_action_group_get_action (priv->toolbar_action_group,
- "Zoom");
-
- gtk_action_set_sensitive (action, can_zoom);
- g_object_set (action, "zoom", can_zoom ? zoom : 1.0, NULL);
-}
-
-static void
-sync_tab_zoom (WebKitWebView *web_view, GParamSpec *pspec, EphyWindow *window)
-{
- GtkActionGroup *action_group;
- GtkAction *action;
- EphyWebViewDocumentType type;
- gboolean can_zoom_in = TRUE, can_zoom_out = TRUE, can_zoom_normal = FALSE, can_zoom;
- float zoom;
- EphyEmbed *embed = window->priv->active_embed;
-
- if (window->priv->closing) return;
-
- g_object_get (web_view,
- "zoom-level", &zoom,
- NULL);
-
- type = ephy_web_view_get_document_type (ephy_embed_get_web_view (embed));
- can_zoom = (type != EPHY_WEB_VIEW_DOCUMENT_IMAGE);
-
- if (zoom >= ZOOM_MAXIMAL)
- {
- can_zoom_in = FALSE;
- }
- if (zoom <= ZOOM_MINIMAL)
- {
- can_zoom_out = FALSE;
- }
- if (zoom != 1.0)
- {
- can_zoom_normal = TRUE;
- }
-
- _ephy_window_action_set_zoom (window, can_zoom, zoom);
-
- action_group = window->priv->action_group;
- action = gtk_action_group_get_action (action_group, "ViewZoomIn");
- gtk_action_set_sensitive (action, can_zoom_in && can_zoom);
- action = gtk_action_group_get_action (action_group, "ViewZoomOut");
- gtk_action_set_sensitive (action, can_zoom_out && can_zoom);
- action = gtk_action_group_get_action (action_group, "ViewZoomNormal");
- gtk_action_set_sensitive (action, can_zoom_normal && can_zoom);
-}
-
-static void
sync_network_status (EphyEmbedSingle *single,
GParamSpec *pspec,
EphyWindow *window)