aboutsummaryrefslogtreecommitdiffstats
path: root/calendar/gui
diff options
context:
space:
mode:
Diffstat (limited to 'calendar/gui')
-rw-r--r--calendar/gui/itip-utils.c166
1 files changed, 86 insertions, 80 deletions
diff --git a/calendar/gui/itip-utils.c b/calendar/gui/itip-utils.c
index 2c0621a38a..1c651ce73a 100644
--- a/calendar/gui/itip-utils.c
+++ b/calendar/gui/itip-utils.c
@@ -33,6 +33,7 @@
#include <libgnome/gnome-i18n.h>
#include <gtk/gtkwidget.h>
#include <gal/widgets/e-gui-utils.h>
+#include <gal/widgets/e-unicode.h>
#include <gal/util/e-unicode-i18n.h>
#include <gal/util/e-util.h>
#include <ical.h>
@@ -193,30 +194,6 @@ itip_strip_mailto (const gchar *address)
return address;
}
-static char *
-get_label (struct icaltimetype *tt)
-{
- char buffer[1000];
- struct tm tmp_tm = { 0 };
-
- tmp_tm.tm_year = tt->year - 1900;
- tmp_tm.tm_mon = tt->month - 1;
- tmp_tm.tm_mday = tt->day;
- tmp_tm.tm_hour = tt->hour;
- tmp_tm.tm_min = tt->minute;
- tmp_tm.tm_sec = tt->second;
- tmp_tm.tm_isdst = -1;
-
- tmp_tm.tm_wday = time_day_of_week (tt->day, tt->month - 1, tt->year);
-
- e_time_format_date_and_time (&tmp_tm,
- calendar_config_get_24_hour_format (),
- FALSE, FALSE,
- buffer, 1000);
-
- return g_strdup (buffer);
-}
-
typedef struct {
GHashTable *tzids;
icalcomponent *icomp;
@@ -301,25 +278,95 @@ comp_to_list (CalComponentItipMethod method, CalComponent *comp)
}
static CORBA_char *
-comp_subject (CalComponent *comp)
+comp_subject (CalComponentItipMethod method, CalComponent *comp)
{
CalComponentText caltext;
+ const char *description, *prefix = NULL;
+ GSList *alist;
+ int *sequence;
+ CORBA_char *subject;
+
cal_component_get_summary (comp, &caltext);
if (caltext.value != NULL)
- return CORBA_string_dup (caltext.value);
-
- switch (cal_component_get_vtype (comp)) {
- case CAL_COMPONENT_EVENT:
- return CORBA_string_dup (U_("Event information"));
- case CAL_COMPONENT_TODO:
- return CORBA_string_dup (U_("Task information"));
- case CAL_COMPONENT_JOURNAL:
- return CORBA_string_dup (U_("Journal information"));
- case CAL_COMPONENT_FREEBUSY:
- return CORBA_string_dup (U_("Free/Busy information"));
+ description = caltext.value;
+ else {
+ switch (cal_component_get_vtype (comp)) {
+ case CAL_COMPONENT_EVENT:
+ description = U_("Event information");
+ case CAL_COMPONENT_TODO:
+ description = U_("Task information");
+ case CAL_COMPONENT_JOURNAL:
+ description = U_("Journal information");
+ case CAL_COMPONENT_FREEBUSY:
+ description = U_("Free/Busy information");
+ default:
+ description = U_("Calendar information");
+ }
+ }
+
+ switch (method) {
+ case CAL_COMPONENT_METHOD_PUBLISH:
+ case CAL_COMPONENT_METHOD_REQUEST:
+ /* FIXME: If this is an update to a previous
+ * PUBLISH or REQUEST, then
+ prefix = U_("Updated");
+ */
+ break;
+
+ case CAL_COMPONENT_METHOD_REPLY:
+ cal_component_get_attendee_list (comp, &alist);
+ if (alist != NULL) {
+ CalComponentAttendee *a = alist->data;
+
+ switch (a->status) {
+ case ICAL_PARTSTAT_ACCEPTED:
+ prefix = U_("Accepted");
+ break;
+ case ICAL_PARTSTAT_TENTATIVE:
+ prefix = U_("Tentatively Accepted");
+ break;
+ case ICAL_PARTSTAT_DECLINED:
+ prefix = U_("Declined");
+ break;
+ default:
+ break;
+ }
+ cal_component_free_attendee_list (alist);
+ }
+ break;
+
+ case CAL_COMPONENT_METHOD_ADD:
+ prefix = U_("Updated");
+ break;
+
+ case CAL_COMPONENT_METHOD_CANCEL:
+ prefix = U_("Cancel");
+ break;
+
+ case CAL_COMPONENT_METHOD_REFRESH:
+ prefix = U_("Refresh");
+ break;
+
+ case CAL_COMPONENT_METHOD_COUNTER:
+ prefix = U_("Counter-proposal");
+ break;
+
+ case CAL_COMPONENT_METHOD_DECLINECOUNTER:
+ prefix = U_("Declined");
+ break;
+
default:
- return CORBA_string_dup (U_("Calendar information"));
- }
+ break;
+ }
+
+ if (prefix) {
+ subject = CORBA_string_alloc (strlen (description) +
+ strlen (prefix) + 3);
+ sprintf (subject, "%s: %s", prefix, description);
+ } else
+ subject = CORBA_string_dup (description);
+
+ return subject;
}
static CORBA_char *
@@ -334,46 +381,6 @@ comp_content_type (CalComponent *comp, CalComponentItipMethod method)
}
-static CORBA_char *
-comp_description (CalComponent *comp)
-{
- CORBA_char *description;
- CalComponentDateTime dt;
- char *start = NULL, *end = NULL;
-
- switch (cal_component_get_vtype (comp)) {
- case CAL_COMPONENT_EVENT:
- return CORBA_string_dup (U_("Event information"));
- case CAL_COMPONENT_TODO:
- return CORBA_string_dup (U_("Task information"));
- case CAL_COMPONENT_JOURNAL:
- return CORBA_string_dup (U_("Journal information"));
- case CAL_COMPONENT_FREEBUSY:
- cal_component_get_dtstart (comp, &dt);
- if (dt.value) {
- start = get_label (dt.value);
- cal_component_get_dtend (comp, &dt);
- if (dt.value)
- end = get_label (dt.value);
- }
- if (start != NULL && end != NULL) {
- char *tmp, *tmp_utf;
- tmp = g_strdup_printf (_("Free/Busy information (%s to %s)"), start, end);
- tmp_utf = e_utf8_from_locale_string (tmp);
- description = CORBA_string_dup (tmp_utf);
- g_free (tmp_utf);
- g_free (tmp);
- } else {
- description = CORBA_string_dup (U_("Free/Busy information"));
- }
- g_free (start);
- g_free (end);
- return description;
- default:
- return CORBA_string_dup (U_("iCalendar information"));
- }
-}
-
static void
foreach_tzid_callback (icalparameter *param, gpointer data)
{
@@ -692,7 +699,6 @@ itip_send_comp (CalComponentItipMethod method, CalComponent *send_comp,
CORBA_char *subject = NULL, *body = NULL, *content_type = NULL;
CORBA_char *filename = NULL, *description = NULL;
GNOME_Evolution_Composer_AttachmentData *attach_data = NULL;
- CORBA_boolean show_inline;
char *ical_string;
CORBA_Environment ev;
@@ -717,7 +723,7 @@ itip_send_comp (CalComponentItipMethod method, CalComponent *send_comp,
bcc_list->_maximum = bcc_list->_length = 0;
/* Subject information */
- subject = comp_subject (comp);
+ subject = comp_subject (method, comp);
/* Set recipients, subject */
GNOME_Evolution_Composer_setHeaders (composer_server, to_list, cc_list, bcc_list, subject, &ev);