diff options
author | Wang Xin <jedy.wang@sun.com> | 2006-07-07 12:45:27 +0800 |
---|---|---|
committer | Jedy Jedy Wang <jedywang@src.gnome.org> | 2006-07-07 12:45:27 +0800 |
commit | 9507599a2586b17fc0e7b227d119e22613215506 (patch) | |
tree | 130ade6902c5e0358c0488a11afdd2f78232c6be /calendar | |
parent | 4b6193f676505dd3acfb1bd3ce89d70616c68bc1 (diff) | |
download | gsoc2013-evolution-9507599a2586b17fc0e7b227d119e22613215506.tar gsoc2013-evolution-9507599a2586b17fc0e7b227d119e22613215506.tar.gz gsoc2013-evolution-9507599a2586b17fc0e7b227d119e22613215506.tar.bz2 gsoc2013-evolution-9507599a2586b17fc0e7b227d119e22613215506.tar.lz gsoc2013-evolution-9507599a2586b17fc0e7b227d119e22613215506.tar.xz gsoc2013-evolution-9507599a2586b17fc0e7b227d119e22613215506.tar.zst gsoc2013-evolution-9507599a2586b17fc0e7b227d119e22613215506.zip |
Fixes #345222
2006-07-07 Wang Xin <jedy.wang@sun.com>
Fixes #345222
* gui/dialogs/alarm-dialog.c: (alarm_to_dialog),
(alarm_to_malarm_widgets); (populate_widgets_from_alarm):
Handle mail alarm.
svn path=/trunk/; revision=32248
Diffstat (limited to 'calendar')
-rw-r--r-- | calendar/ChangeLog | 8 | ||||
-rw-r--r-- | calendar/gui/dialogs/alarm-dialog.c | 48 |
2 files changed, 56 insertions, 0 deletions
diff --git a/calendar/ChangeLog b/calendar/ChangeLog index 4de3de06bc..97b9fcfea0 100644 --- a/calendar/ChangeLog +++ b/calendar/ChangeLog @@ -1,3 +1,11 @@ +2006-07-07 Wang Xin <jedy.wang@sun.com> + + Fixes #345222 + + * gui/dialogs/alarm-dialog.c: (alarm_to_dialog), + (alarm_to_malarm_widgets); (populate_widgets_from_alarm): + Handle mail alarm. + 2006-06-30 Johnny Jacob <jjohnny@novell.com> * gui/cal-search-bar.c: (get_current_category), (get_category_sexp), (notify_e_cal_view_contains), diff --git a/calendar/gui/dialogs/alarm-dialog.c b/calendar/gui/dialogs/alarm-dialog.c index 3224d4a3d3..ad53c71668 100644 --- a/calendar/gui/dialogs/alarm-dialog.c +++ b/calendar/gui/dialogs/alarm-dialog.c @@ -228,6 +228,7 @@ alarm_to_dialog (Dialog *dialog) /* Set a default address if possible */ if (!e_cal_get_static_capability (dialog->ecal, CAL_STATIC_CAPABILITY_NO_EMAIL_ALARMS) + && !e_cal_component_alarm_has_attendees (dialog->alarm) && e_cal_get_alarm_email_address (dialog->ecal, &email, NULL)) { ECalComponentAttendee *a; GSList attendee_list; @@ -482,6 +483,52 @@ malarm_widgets_to_alarm (Dialog *dialog, ECalComponentAlarm *alarm) } } +/* Fills the widgets from mail alarm data */ +static void +alarm_to_malarm_widgets (Dialog *dialog, ECalComponentAlarm *alarm ) +{ + ENameSelectorModel *name_selector_model; + EDestinationStore *destination_store; + ECalComponentText description; + GtkTextBuffer *text_buffer; + GSList *attendee_list, *l; + int len; + + /* Attendees */ + name_selector_model = e_name_selector_peek_model (dialog->name_selector); + e_name_selector_model_peek_section (name_selector_model, section_name, NULL, &destination_store); + + e_cal_component_alarm_get_attendee_list (alarm, &attendee_list); + len = g_slist_length (attendee_list); + if (len > 0) { + for (l = attendee_list; l; l = g_slist_next (l)) { + ECalComponentAttendee *a = l->data; + EDestination *dest; + + dest = e_destination_new (); + if (a->cn != NULL && *a->cn) + e_destination_set_name (dest, a->cn); + if (a->value != NULL && *a->value) { + if (!strncasecmp (a->value, "MAILTO:", 7)) + e_destination_set_email (dest, a->value + 7); + else + e_destination_set_email (dest, a->value); + } + e_destination_store_append_destination (destination_store, dest); + g_object_unref(GTK_OBJECT (dest)); + } + e_cal_component_free_attendee_list (attendee_list); + } + + /* Description */ + e_cal_component_alarm_get_description (alarm, &description); + if (description.value) { + gtk_toggle_button_set_active (GTK_TOGGLE_BUTTON (dialog->malarm_message), TRUE); + text_buffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW (dialog->malarm_description)); + gtk_text_buffer_set_text (text_buffer, description.value, -1); + } +} + /* Fills the widgets from procedure alarm data */ static void alarm_to_palarm_widgets (Dialog *dialog, ECalComponentAlarm *alarm) @@ -619,6 +666,7 @@ populate_widgets_from_alarm (Dialog *dialog) break; case E_CAL_COMPONENT_ALARM_EMAIL: + alarm_to_malarm_widgets (dialog, dialog->alarm); break; case E_CAL_COMPONENT_ALARM_PROCEDURE: |