aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
-rw-r--r--widgets/misc/ChangeLog5
-rw-r--r--widgets/misc/e-source-selector.c25
2 files changed, 19 insertions, 11 deletions
diff --git a/widgets/misc/ChangeLog b/widgets/misc/ChangeLog
index 8db55ee74c..f8fc8bbef3 100644
--- a/widgets/misc/ChangeLog
+++ b/widgets/misc/ChangeLog
@@ -1,3 +1,8 @@
+2004-01-24 JP Rosevear <jpr@ximian.com>
+
+ * e-source-selector.c (cell_toggled_callback): if the source is
+ primary, don't allow it to be un-selected
+
2004-01-20 Rodney Dawes <dobey@ximian.com>
* e-combo-button.c (paint): Be even more exactly like the GtkButton
diff --git a/widgets/misc/e-source-selector.c b/widgets/misc/e-source-selector.c
index f64c192bd4..f26ce4030b 100644
--- a/widgets/misc/e-source-selector.c
+++ b/widgets/misc/e-source-selector.c
@@ -475,17 +475,20 @@ cell_toggled_callback (GtkCellRendererToggle *renderer,
gtk_tree_path_free (path);
} else {
source = E_SOURCE (data);
- if (source_is_selected (selector, source))
- unselect_source (selector, source);
- else
- select_source (selector, source);
-
- selector->priv->toggled_last = TRUE;
-
- gtk_tree_model_row_changed (model, path, &iter);
- g_signal_emit (selector, signals[SELECTION_CHANGED], 0);
-
- gtk_tree_path_free (path);
+
+ if (e_source_selector_peek_primary_selection (selector) != source) {
+ if (source_is_selected (selector, source))
+ unselect_source (selector, source);
+ else
+ select_source (selector, source);
+
+ selector->priv->toggled_last = TRUE;
+
+ gtk_tree_model_row_changed (model, path, &iter);
+ g_signal_emit (selector, signals[SELECTION_CHANGED], 0);
+
+ gtk_tree_path_free (path);
+ }
}
g_object_unref (data);