diff options
Diffstat (limited to 'calendar/gui')
-rw-r--r-- | calendar/gui/e-calendar-view.c | 102 |
1 files changed, 55 insertions, 47 deletions
diff --git a/calendar/gui/e-calendar-view.c b/calendar/gui/e-calendar-view.c index 8709281820..e137fd079c 100644 --- a/calendar/gui/e-calendar-view.c +++ b/calendar/gui/e-calendar-view.c @@ -943,71 +943,79 @@ e_calendar_view_delete_selected_events (ECalendarView *cal_view) void e_calendar_view_delete_selected_occurrence (ECalendarView *cal_view) { - ECalendarViewEvent *event; GList *selected; - const char *uid, *rid = NULL; - GError *error = NULL; ECalComponent *comp; - struct icaltimetype itt; - ECalComponentDateTime dt; - icaltimezone *zone = NULL; + ECalendarViewEvent *event; selected = e_calendar_view_get_selected_events (cal_view); if (!selected) return; - + event = (ECalendarViewEvent *) selected->data; - comp = e_cal_component_new (); e_cal_component_set_icalcomponent (comp, icalcomponent_new_clone (event->comp_data->icalcomp)); - e_cal_component_get_uid (comp, &uid); - e_cal_component_get_dtstart (comp, &dt); - - if (dt.tzid) { + if (delete_component_dialog (comp, FALSE, 1, e_cal_component_get_vtype (comp), GTK_WIDGET (cal_view))) { + const char *uid, *rid = NULL; GError *error = NULL; + ECalComponentDateTime dt; + icaltimezone *zone = NULL; + gboolean is_instance = FALSE; - e_cal_get_timezone (event->comp_data->client, dt.tzid, &zone, &error); - if (error) { - zone = e_calendar_view_get_timezone (cal_view); - g_clear_error(&error); - } - } else - zone = e_calendar_view_get_timezone (cal_view); + e_cal_component_get_uid (comp, &uid); + e_cal_component_get_dtstart (comp, &dt); + is_instance = e_cal_component_is_instance (comp); - itt = icaltime_from_timet_with_zone (event->comp_data->instance_start, TRUE, zone ? zone : icaltimezone_get_utc_timezone ()); + if (dt.tzid) { + GError *error = NULL; - if (!e_cal_get_recurrences_no_master (event->comp_data->client)) - rid = icaltime_as_ical_string (itt); - else - rid = e_cal_component_get_recurid_as_string (comp); - - e_cal_component_free_datetime (&dt); - if (rid) { - if (delete_component_dialog (comp, FALSE, 1, e_cal_component_get_vtype (comp), GTK_WIDGET (cal_view))) { - - if (itip_organizer_is_user (comp, event->comp_data->client) - && cancel_component_dialog ((GtkWindow *) gtk_widget_get_toplevel (GTK_WIDGET (cal_view)), - event->comp_data->client, - comp, TRUE) && !e_cal_get_save_schedules (event->comp_data->client)) { - if (!e_cal_component_is_instance (comp)) { - ECalComponentRange range; - - /* set the recurrence ID of the object we send */ - range.type = E_CAL_COMPONENT_RANGE_SINGLE; - e_cal_component_get_dtstart (comp, &range.datetime); - range.datetime.value->is_date = 1; - e_cal_component_set_recurid (comp, &range); - - e_cal_component_free_datetime (&range.datetime); - } - itip_send_comp (E_CAL_COMPONENT_METHOD_CANCEL, comp, event->comp_data->client, NULL, NULL); + e_cal_get_timezone (event->comp_data->client, dt.tzid, &zone, &error); + if (error) { + zone = e_calendar_view_get_timezone (cal_view); + g_clear_error(&error); + } + } else + zone = e_calendar_view_get_timezone (cal_view); + + + if (is_instance) + rid = e_cal_component_get_recurid_as_string (comp); + + e_cal_component_free_datetime (&dt); + + + if (itip_organizer_is_user (comp, event->comp_data->client) + && cancel_component_dialog ((GtkWindow *) gtk_widget_get_toplevel (GTK_WIDGET (cal_view)), + event->comp_data->client, + comp, TRUE) && !e_cal_get_save_schedules (event->comp_data->client)) { + if (!e_cal_component_is_instance (comp)) { + ECalComponentRange range; + + /* set the recurrence ID of the object we send */ + range.type = E_CAL_COMPONENT_RANGE_SINGLE; + e_cal_component_get_dtstart (comp, &range.datetime); + range.datetime.value->is_date = 1; + e_cal_component_set_recurid (comp, &range); + + e_cal_component_free_datetime (&range.datetime); } + itip_send_comp (E_CAL_COMPONENT_METHOD_CANCEL, comp, event->comp_data->client, NULL, NULL); + } + if (is_instance) e_cal_remove_object_with_mod (event->comp_data->client, uid, rid, CALOBJ_MOD_THIS, &error); - delete_error_dialog (error, E_CAL_COMPONENT_EVENT); - g_clear_error (&error); + else { + struct icaltimetype instance_rid; + + instance_rid = icaltime_from_timet_with_zone (event->comp_data->instance_start, + TRUE, zone ? zone : icaltimezone_get_utc_timezone ()); + e_cal_util_remove_instances (event->comp_data->icalcomp, instance_rid, CALOBJ_MOD_THIS); + e_cal_modify_object (event->comp_data->client, event->comp_data->icalcomp, CALOBJ_MOD_THIS, + &error); } + + delete_error_dialog (error, E_CAL_COMPONENT_EVENT); + g_clear_error (&error); } /* free memory */ |