aboutsummaryrefslogtreecommitdiffstats
path: root/calendar
diff options
context:
space:
mode:
Diffstat (limited to 'calendar')
-rw-r--r--calendar/ChangeLog9
-rw-r--r--calendar/gui/dialogs/comp-editor.c16
2 files changed, 24 insertions, 1 deletions
diff --git a/calendar/ChangeLog b/calendar/ChangeLog
index f9ae4f0b26..4f640ebb48 100644
--- a/calendar/ChangeLog
+++ b/calendar/ChangeLog
@@ -1,3 +1,12 @@
+2009-01-20 Milan Crha <mcrha@redhat.com>
+
+ ** Fix for bug #568331
+
+ * gui/dialogs/comp-editor.c: (classification_changed_cb),
+ (comp_editor_init): Notify changes of the classification.
+ * gui/dialogs/comp-editor.c: (fill_widgets): Block classification
+ change signal when filling widgets with values from a component.
+
2009-01-19 Milan Crha <mcrha@redhat.com>
** Fix for bug #567850
diff --git a/calendar/gui/dialogs/comp-editor.c b/calendar/gui/dialogs/comp-editor.c
index 4799895b84..dcdff0947e 100644
--- a/calendar/gui/dialogs/comp-editor.c
+++ b/calendar/gui/dialogs/comp-editor.c
@@ -1766,6 +1766,14 @@ comp_editor_class_init (CompEditorClass *class)
}
static void
+classification_changed_cb (GtkRadioAction *action, GtkRadioAction *current, CompEditor *editor)
+{
+ g_return_if_fail (IS_COMP_EDITOR (editor));
+
+ comp_editor_set_changed (editor, TRUE);
+}
+
+static void
comp_editor_init (CompEditor *editor)
{
CompEditorPrivate *priv;
@@ -1814,7 +1822,7 @@ comp_editor_init (CompEditor *editor)
action_group, classification_radio_entries,
G_N_ELEMENTS (classification_radio_entries),
E_CAL_COMPONENT_CLASS_PUBLIC,
- NULL, NULL); /* no callback */
+ G_CALLBACK (classification_changed_cb), editor);
action = e_attachment_bar_recent_action_new (
E_ATTACHMENT_BAR (priv->attachment_bar),
"attach-recent", _("Recent _Documents"));
@@ -2939,6 +2947,7 @@ fill_widgets (CompEditor *editor)
{
CompEditorPrivate *priv;
GList *l;
+ GtkAction *action;
priv = editor->priv;
@@ -2953,8 +2962,13 @@ fill_widgets (CompEditor *editor)
g_slist_free (attachment_list);
}
+ action = comp_editor_get_action (editor, "classify-public");
+ g_signal_handlers_block_by_func (action, G_CALLBACK (classification_changed_cb), editor);
+
for (l = priv->pages; l != NULL; l = l->next)
comp_editor_page_fill_widgets (l->data, priv->comp);
+
+ g_signal_handlers_unblock_by_func (action, G_CALLBACK (classification_changed_cb), editor);
}
static void