[Xfce4-commits] <midori:master> Hide the combobox arrow if the history unset or is empty
Christian Dywan
noreply at xfce.org
Fri Jan 29 21:14:02 CET 2010
Updating branch refs/heads/master
to 32a62a7057788f493f6fc7205ea7132fa3cb727f (commit)
from e5c65a160c0cc0bc53707de574d5af03df90df94 (commit)
commit 32a62a7057788f493f6fc7205ea7132fa3cb727f
Author: Christian Dywan <christian at twotoasts.de>
Date: Thu Jan 28 23:56:54 2010 +0100
Hide the combobox arrow if the history unset or is empty
midori/midori-browser.c | 7 ++-----
midori/midori-locationaction.c | 34 +++++++++++++++++++++++++++++++++-
2 files changed, 35 insertions(+), 6 deletions(-)
diff --git a/midori/midori-browser.c b/midori/midori-browser.c
index ed8b230..0e46061 100644
--- a/midori/midori-browser.c
+++ b/midori/midori-browser.c
@@ -499,10 +499,7 @@ midori_view_notify_load_status_cb (GtkWidget* widget,
action = _action_by_name (browser, "Location");
if (midori_view_get_load_status (view) == MIDORI_LOAD_COMMITTED)
- {
- if (browser->maximum_history_age)
- midori_location_action_add_uri (MIDORI_LOCATION_ACTION (action), uri);
- }
+ midori_location_action_add_uri (MIDORI_LOCATION_ACTION (action), uri);
if (widget == midori_browser_get_current_tab (browser))
{
@@ -5586,9 +5583,9 @@ midori_browser_history_clear_cb (KatzeArray* history,
MidoriBrowser* browser)
{
GtkAction* location_action = _action_by_name (browser, "Location");
- midori_location_action_clear (MIDORI_LOCATION_ACTION (location_action));
g_object_set (_action_by_name (browser, "RecentlyVisited"),
"array", NULL, NULL);
+ midori_location_action_clear (MIDORI_LOCATION_ACTION (location_action));
}
static void
diff --git a/midori/midori-locationaction.c b/midori/midori-locationaction.c
index a3e5cd8..6cf9f0a 100644
--- a/midori/midori-locationaction.c
+++ b/midori/midori-locationaction.c
@@ -601,6 +601,32 @@ midori_location_action_finalize (GObject* object)
}
static void
+midori_location_action_toggle_arrow_cb (GtkWidget* widget,
+ MidoriLocationAction* location_action)
+{
+ if (GTK_IS_BUTTON (widget))
+ {
+ gboolean show = location_action->history
+ && katze_array_get_nth_item (location_action->history, 0);
+ sokoke_widget_set_visible (widget, show);
+ gtk_widget_set_size_request (widget, show ? -1 : 1, show ? -1 : 1);
+ }
+}
+
+static void
+midori_location_action_toggle_arrow (MidoriLocationAction* location_action)
+{
+ GSList* proxies = gtk_action_get_proxies (GTK_ACTION (location_action));
+ for (; proxies != NULL; proxies = g_slist_next (proxies))
+ if (GTK_IS_TOOL_ITEM (proxies->data))
+ {
+ GtkWidget* entry = midori_location_action_entry_for_proxy (proxies->data);
+ gtk_container_forall (GTK_CONTAINER (entry),
+ (GtkCallback)midori_location_action_toggle_arrow_cb, location_action);
+ }
+}
+
+static void
midori_location_action_set_property (GObject* object,
guint prop_id,
const GValue* value,
@@ -621,6 +647,8 @@ midori_location_action_set_property (GObject* object,
case PROP_HISTORY:
{
katze_assign (location_action->history, g_value_dup_object (value));
+
+ midori_location_action_toggle_arrow (location_action);
break;
}
default:
@@ -1207,6 +1235,8 @@ midori_location_action_connect_proxy (GtkAction* action,
renderer, midori_location_entry_render_text_cb, child, NULL);
gtk_combo_box_set_active (GTK_COMBO_BOX (entry), -1);
+ gtk_container_forall (GTK_CONTAINER (entry),
+ (GtkCallback)midori_location_action_toggle_arrow_cb, action);
g_signal_connect (entry, "changed",
G_CALLBACK (midori_location_action_entry_changed_cb), action);
g_signal_connect (entry, "popup",
@@ -1405,6 +1435,8 @@ midori_location_action_add_uri (MidoriLocationAction* location_action,
g_return_if_fail (uri != NULL);
katze_assign (location_action->uri, g_strdup (uri));
+
+ midori_location_action_toggle_arrow (location_action);
}
void
@@ -1583,5 +1615,5 @@ midori_location_action_clear (MidoriLocationAction* location_action)
{
g_return_if_fail (MIDORI_IS_LOCATION_ACTION (location_action));
- /* Nothing to do */
+ midori_location_action_toggle_arrow (location_action);
}
More information about the Xfce4-commits
mailing list