aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui/dialogs/calendar-setup.c
diff options
context:
space:
mode:
authorMilan Crha <mcrha@redhat.com>2007-08-23 14:59:49 +0800
committerChenthill Palanisamy <pchen@src.gnome.org>2007-08-23 14:59:49 +0800
commit7690fe3b47564b16c3e47d6ebadaa213e4297491 (patch)
treed3032de99a9bc636ed7e11bc8bbf5319af543db5 /calendar/gui/dialogs/calendar-setup.c
parent158e09129c78477afd7fbdb645c237c2a4ee6993 (diff)
downloadgsoc2013-evolution-7690fe3b47564b16c3e47d6ebadaa213e4297491.tar
gsoc2013-evolution-7690fe3b47564b16c3e47d6ebadaa213e4297491.tar.gz
gsoc2013-evolution-7690fe3b47564b16c3e47d6ebadaa213e4297491.tar.bz2
gsoc2013-evolution-7690fe3b47564b16c3e47d6ebadaa213e4297491.tar.lz
gsoc2013-evolution-7690fe3b47564b16c3e47d6ebadaa213e4297491.tar.xz
gsoc2013-evolution-7690fe3b47564b16c3e47d6ebadaa213e4297491.tar.zst
gsoc2013-evolution-7690fe3b47564b16c3e47d6ebadaa213e4297491.zip
** Fix for bug #308636
2007-08-23 Milan Crha <mcrha@redhat.com> ** Fix for bug #308636 * gui/dialogs/calendar-setup.c: (eccp_get_source_type): Add only source groups without property 'create_source=no'. * gui/dialogs/calendar-setup.c: (cs_load_sources): New helper function avoids code copying. * gui/dialogs/calendar-setup.c: (calendar_setup_edit_calendar), (calendar_setup_edit_task_list), (calendar_setup_edit_memo_list): Uses 'cs_load_sources'. * gui/calendar-component.c: (ensure_sources): Sets 'create_source=no' for contacts when not set before. svn path=/trunk/; revision=34068
Diffstat (limited to 'calendar/gui/dialogs/calendar-setup.c')
-rw-r--r--calendar/gui/dialogs/calendar-setup.c120
1 files changed, 41 insertions, 79 deletions
diff --git a/calendar/gui/dialogs/calendar-setup.c b/calendar/gui/dialogs/calendar-setup.c
index e186156163..022414ff75 100644
--- a/calendar/gui/dialogs/calendar-setup.c
+++ b/calendar/gui/dialogs/calendar-setup.c
@@ -177,12 +177,16 @@ eccp_get_source_type (EConfig *ec, EConfigItem *item, GtkWidget *parent, GtkWidg
for (l = sdialog->menu_source_groups; l; l = g_slist_next (l)) {
/* Reuse previously defined *group here? */
ESourceGroup *group = l->data;
-
- gtk_list_store_append (store, &iter);
- gtk_list_store_set (store, &iter, 0, e_source_group_peek_name (group), 1, group, -1);
- if (!strcmp (e_source_group_peek_uid (sdialog->source_group), e_source_group_peek_uid (group)))
- active = i;
- i++;
+ gchar *create_source = e_source_group_get_property (group, "create_source");
+
+ if ( !(create_source && !strcmp (create_source, "no"))) {
+ gtk_list_store_append (store, &iter);
+ gtk_list_store_set (store, &iter, 0, e_source_group_peek_name (group), 1, group, -1);
+ if (!strcmp (e_source_group_peek_uid (sdialog->source_group), e_source_group_peek_uid (group)))
+ active = i;
+ i++;
+ }
+ g_free (create_source);
}
gtk_cell_layout_pack_start ((GtkCellLayout *) type, cell, TRUE);
@@ -393,6 +397,34 @@ static ECalConfigItem ecmp_items[] = {
{ 0 },
};
+/**
+ * cs_load_sources:
+ * @sdialog: dialog where to load sources list
+ * @conf_key: configuration key where to get sources' list
+ * @group: can be NULL
+ *
+ * Loads list of sources from @conf_key.
+ */
+
+static void
+cs_load_sources (CalendarSourceDialog *sdialog, const gchar *conf_key, ESourceGroup *group)
+{
+ GConfClient *gconf;
+
+ g_return_if_fail (sdialog != NULL && conf_key != NULL);
+
+ sdialog->source = e_source_new ("", "");
+ gconf = gconf_client_get_default ();
+ sdialog->source_list = e_source_list_new_for_gconf (gconf, conf_key);
+ sdialog->menu_source_groups = g_slist_copy (e_source_list_peek_groups (sdialog->source_list));
+ sdialog->source_group = (ESourceGroup *)sdialog->menu_source_groups->data;
+
+ g_object_unref (gconf);
+
+ if (group)
+ sdialog->source_group = (ESourceGroup *)group;
+}
+
/**
* calendar_setup_edit_calendar:
* @parent: parent window for dialog (current unused)
@@ -424,38 +456,7 @@ calendar_setup_edit_calendar (struct _GtkWindow *parent, ESource *source, ESourc
if (color_spec != NULL)
e_source_set_color_spec (sdialog->source, color_spec);
} else {
- GConfClient *gconf;
- GSList *l, *ptr, *temp = NULL;
-
- sdialog->source = e_source_new ("", "");
- gconf = gconf_client_get_default ();
- sdialog->source_list = e_source_list_new_for_gconf (gconf, "/apps/evolution/calendar/sources");
- l = e_source_list_peek_groups (sdialog->source_list);
- /* Skip GW as it supports only one calendar */
- ptr = l;
- if (!strncmp (e_source_group_peek_base_uri ((ESourceGroup *)ptr->data),
- "groupwise://", 12 )) {
- l = l->next;
- g_object_unref (ptr->data);
- g_slist_free_1 (ptr);
- }
- for (ptr=l; ptr->next;) {
- if (!strncmp (e_source_group_peek_base_uri ((ESourceGroup *)ptr->next->data),
- "groupwise://", 12 )) {
- temp = ptr->next;
- ptr->next = temp->next;
- g_object_unref (temp->data);
- g_slist_free_1 (temp);
- } else {
- ptr = ptr->next;
- }
- }
- sdialog->menu_source_groups = g_slist_copy(l);
-
- sdialog->source_group = (ESourceGroup *)sdialog->menu_source_groups->data;
- g_object_unref (gconf);
- if (group)
- sdialog->source_group = (ESourceGroup *)group;
+ cs_load_sources (sdialog, "/apps/evolution/calendar/sources", group);
}
/* HACK: doesn't work if you don't do this */
@@ -514,36 +515,7 @@ calendar_setup_edit_task_list (struct _GtkWindow *parent, ESource *source)
color_spec = e_source_peek_color_spec (source);
e_source_set_color_spec (sdialog->source, color_spec);
} else {
- GConfClient *gconf;
- GSList *l, *ptr, *temp = NULL;
-
- sdialog->source = e_source_new ("", "");
- gconf = gconf_client_get_default ();
- sdialog->source_list = e_source_list_new_for_gconf (gconf, "/apps/evolution/tasks/sources");
- l = e_source_list_peek_groups (sdialog->source_list);
-
- /* Skip GW as it supports only one task list */
- ptr = l;
- if (!strncmp (e_source_group_peek_base_uri ((ESourceGroup *)ptr->data),
- "groupwise://", 12 )) {
- l = l->next;
- g_object_unref (ptr->data);
- g_slist_free_1 (ptr);
- }
- for (ptr=l; ptr->next;) {
- if (!strncmp (e_source_group_peek_base_uri ((ESourceGroup *)ptr->next->data),
- "groupwise://", 12 )) {
- temp = ptr->next;
- ptr->next = temp->next;
- g_object_unref (temp->data);
- g_slist_free_1 (temp);
- } else {
- ptr = ptr->next;
- }
- }
- sdialog->menu_source_groups = g_slist_copy(l);
- sdialog->source_group = (ESourceGroup *)sdialog->menu_source_groups->data;
- g_object_unref (gconf);
+ cs_load_sources (sdialog, "/apps/evolution/tasks/sources", NULL);
}
/* HACK: doesn't work if you don't do this */
@@ -599,17 +571,7 @@ calendar_setup_edit_memo_list (struct _GtkWindow *parent, ESource *source)
color_spec = e_source_peek_color_spec (source);
e_source_set_color_spec (sdialog->source, color_spec);
} else {
- GConfClient *gconf;
- GSList *l;
-
- sdialog->source = e_source_new ("", "");
- gconf = gconf_client_get_default ();
- sdialog->source_list = e_source_list_new_for_gconf (gconf, "/apps/evolution/memos/sources");
- l = e_source_list_peek_groups (sdialog->source_list);
- sdialog->menu_source_groups = g_slist_copy(l);
-
- sdialog->source_group = (ESourceGroup *)sdialog->menu_source_groups->data;
- g_object_unref (gconf);
+ cs_load_sources (sdialog, "/apps/evolution/memos/sources", NULL);
}
/* HACK: doesn't work if you don't do this */