diff options
Diffstat (limited to 'lib/ephy-state.c')
-rw-r--r-- | lib/ephy-state.c | 62 |
1 files changed, 58 insertions, 4 deletions
diff --git a/lib/ephy-state.c b/lib/ephy-state.c index d74ca4f7f..ce1dc75bb 100644 --- a/lib/ephy-state.c +++ b/lib/ephy-state.c @@ -32,6 +32,7 @@ #include <gtk/gtkwindow.h> #include <gtk/gtkpaned.h> #include <gtk/gtkexpander.h> +#include <gtk/gtktogglebutton.h> #define EPHY_STATES_XML_FILE "states.xml" #define EPHY_STATES_XML_ROOT (const xmlChar *)"ephy_states" @@ -47,7 +48,7 @@ enum EPHY_NODE_STATE_PROP_POSITION_Y = 7, EPHY_NODE_STATE_PROP_SIZE = 8, EPHY_NODE_STATE_PROP_POSITION = 9, - EPHY_NODE_STATE_PROP_EXPANDED = 10 + EPHY_NODE_STATE_PROP_ACTIVE = 10 }; static EphyNode *states = NULL; @@ -463,7 +464,7 @@ sync_expander_cb (GtkExpander *expander, g_value_init (&value, G_TYPE_BOOLEAN); g_value_set_boolean (&value, gtk_expander_get_expanded (expander)); - ephy_node_set_property (node, EPHY_NODE_STATE_PROP_EXPANDED, &value); + ephy_node_set_property (node, EPHY_NODE_STATE_PROP_ACTIVE, &value); g_value_unset (&value); } @@ -494,12 +495,12 @@ ephy_state_add_expander (GtkWidget *expander, g_value_init (&value, G_TYPE_BOOLEAN); g_value_set_boolean (&value, default_state); ephy_node_set_property - (node, EPHY_NODE_STATE_PROP_EXPANDED, &value); + (node, EPHY_NODE_STATE_PROP_ACTIVE, &value); g_value_unset (&value); } expanded = ephy_node_get_property_boolean - (node, EPHY_NODE_STATE_PROP_EXPANDED); + (node, EPHY_NODE_STATE_PROP_ACTIVE); gtk_expander_set_expanded (GTK_EXPANDER (expander), expanded); @@ -507,6 +508,59 @@ ephy_state_add_expander (GtkWidget *expander, G_CALLBACK (sync_expander_cb), node); } +static void +sync_toggle_cb (GtkToggleButton *toggle, + GParamSpec *pspec, + EphyNode *node) +{ + GValue value = { 0, }; + + g_value_init (&value, G_TYPE_BOOLEAN); + g_value_set_boolean (&value, gtk_toggle_button_get_active (toggle)); + ephy_node_set_property (node, EPHY_NODE_STATE_PROP_ACTIVE, &value); + g_value_unset (&value); +} + +void +ephy_state_add_toggle (GtkWidget *toggle, + const char *name, + gboolean default_state) +{ + EphyNode *node; + gboolean active; + + ensure_states (); + + node = find_by_name (name); + if (node == NULL) + { + GValue value = { 0, }; + + node = ephy_node_new (states_db); + ephy_node_add_child (states, node); + + g_value_init (&value, G_TYPE_STRING); + g_value_set_string (&value, name); + ephy_node_set_property (node, EPHY_NODE_STATE_PROP_NAME, + &value); + g_value_unset (&value); + + g_value_init (&value, G_TYPE_BOOLEAN); + g_value_set_boolean (&value, default_state); + ephy_node_set_property + (node, EPHY_NODE_STATE_PROP_ACTIVE, &value); + g_value_unset (&value); + } + + active = ephy_node_get_property_boolean + (node, EPHY_NODE_STATE_PROP_ACTIVE); + + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (toggle), active); + + g_signal_connect (toggle, "notify::active", + G_CALLBACK (sync_toggle_cb), node); +} + void ephy_state_save (void) { |