From b2954936ac553ea42cd6bb177b7e32c3ffcb0fe8 Mon Sep 17 00:00:00 2001 From: Rodney Dawes Date: Tue, 23 Nov 2004 06:24:57 +0000 Subject: Add gtkimage.h to includes, and remove gtkhtml headers Add and remove some 2004-11-23 Rodney Dawes * gui/alarm-notify/alarm-notify-dialog.[ch]: Add gtkimage.h to includes, and remove gtkhtml headers Add and remove some widgets in the AlarmNotify struct (dialog_destroy_cb, delete_event_cb, close_clicked_cb): (snooze_clicked_cb, edit_clicked_cb, url_requested_cb): (make_html_display, write_times, write_html_heading): (alarm_notify_dialog_disable_buttons): Remove all these unneeded functions (no more GtkHTML in the dialog) (alarm_notify_dialog): Add description and location arguments Rename message argument to summary Update gtk-doc comment block to reflect API changes Clean up code to use gtk_dialog_run () and use a HIG compliant dialog * gui/alarm-notify/alarm-notify.glade: Update the alarm notify dialog to be HIG compliant and not use GtkHTML, and display more information that is relevant to the appointment we are alerting of * gui/alarm-notify/alarm-queue.c: Add new variables to the TrayIconData structure so we can access the description and location (on_dialog_objs_removed_cb): Remove alarm_dialog bits (notify_dialog_cb): Remove alarm_dialog bits (tray_icon_destroyed_cb): Free the description and location as well (open_alarm_dialog): alarm_notify_dialog does all the work now, we don't need to trap the dialog widget here (display_notification): Add code to get the description and location information from the cal component Avoid using an alarm component which has less useful API Fix a warning when creating the tray_icon widget svn path=/trunk/; revision=27971 --- calendar/gui/alarm-notify/alarm-notify-dialog.c | 346 +++++----------------- calendar/gui/alarm-notify/alarm-notify-dialog.h | 8 +- calendar/gui/alarm-notify/alarm-notify.glade | 378 +++++++++++++++++++----- calendar/gui/alarm-notify/alarm-queue.c | 83 +++--- 4 files changed, 430 insertions(+), 385 deletions(-) (limited to 'calendar/gui/alarm-notify') diff --git a/calendar/gui/alarm-notify/alarm-notify-dialog.c b/calendar/gui/alarm-notify/alarm-notify-dialog.c index a84e13f66b..77c83520d9 100644 --- a/calendar/gui/alarm-notify/alarm-notify-dialog.c +++ b/calendar/gui/alarm-notify/alarm-notify-dialog.c @@ -23,6 +23,7 @@ #include #include #include +#include #include #include #include @@ -34,8 +35,6 @@ #endif #include #include -#include -#include #include #include "alarm-notify-dialog.h" #include "config-data.h" @@ -43,238 +42,28 @@ #include -GtkWidget *make_html_display (gchar *widget_name, char *s1, char *s2, int scroll, int shadow); - /* The useful contents of the alarm notify dialog */ typedef struct { GladeXML *xml; GtkWidget *dialog; - GtkWidget *close; - GtkWidget *snooze; - GtkWidget *edit; + GtkWidget *title; GtkWidget *snooze_time; - GtkWidget *html; + GtkWidget *description; + GtkWidget *location; + GtkWidget *start; + GtkWidget *end; AlarmNotifyFunc func; gpointer func_data; } AlarmNotify; - - -/* Callback used when the notify dialog is destroyed */ -static void -dialog_destroy_cb (GtkObject *object, gpointer data) -{ - AlarmNotify *an; - - an = data; - g_object_unref (an->xml); - g_free (an); -} - -/* Delete_event handler for the alarm notify dialog */ -static gint -delete_event_cb (GtkWidget *widget, GdkEvent *event, gpointer data) -{ - AlarmNotify *an; - - an = data; - g_assert (an->func != NULL); - - (* an->func) (ALARM_NOTIFY_CLOSE, -1, an->func_data); - - gtk_widget_destroy (widget); - return TRUE; -} - -/* Callback for the close button */ -static void -close_clicked_cb (GtkWidget *widget, gpointer data) -{ - AlarmNotify *an; - - an = data; - g_assert (an->func != NULL); - - (* an->func) (ALARM_NOTIFY_CLOSE, -1, an->func_data); - - gtk_widget_destroy (an->dialog); -} - -/* Callback for the snooze button */ -static void -snooze_clicked_cb (GtkWidget *widget, gpointer data) -{ - AlarmNotify *an; - int snooze_time; - - an = data; - g_assert (an->func != NULL); - - snooze_time = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (an->snooze_time)); - (* an->func) (ALARM_NOTIFY_SNOOZE, snooze_time, an->func_data); - - gtk_widget_destroy (an->dialog); -} - -/* Callback for the edit button */ -static void -edit_clicked_cb (GtkWidget *widget, gpointer data) -{ - AlarmNotify *an; - - an = data; - g_assert (an->func != NULL); - - (* an->func) (ALARM_NOTIFY_EDIT, -1, an->func_data); - - gtk_widget_destroy (an->dialog); -} - -static void -url_requested_cb (GtkHTML *html, const char *url, GtkHTMLStream *stream, gpointer data) -{ - - if (!strncmp ("file:///", url, strlen ("file:///"))) { - FILE *fp; - const char *filename = url + strlen ("file://"); - char buf[4096]; - size_t len; - - fp = fopen (filename, "r"); - - if (fp == NULL) { - g_warning ("Error opening image: %s\n", url); - gtk_html_stream_close (stream, GTK_HTML_STREAM_ERROR); - return; - } - - while ((len = fread (buf, 1, sizeof(buf), fp)) > 0) - gtk_html_stream_write (stream, buf, len); - - if (feof (fp)) { - fclose (fp); - gtk_html_stream_close (stream, GTK_HTML_STREAM_OK); - return; - } - - fclose (fp); - } - - g_warning ("Error loading image"); - gtk_html_stream_close (stream, GTK_HTML_STREAM_ERROR); - return; -} - -GtkWidget * -make_html_display (gchar *widget_name, char *s1, char *s2, int scroll, int shadow) -{ - GtkWidget *html, *scrolled_window; - - gtk_widget_push_colormap (gdk_rgb_get_colormap ()); - - html = gtk_html_new(); - - gtk_html_set_default_content_type (GTK_HTML (html), - "charset=utf-8"); - gtk_html_load_empty (GTK_HTML (html)); - - g_signal_connect (html, "url_requested", - G_CALLBACK (url_requested_cb), - NULL); +enum { + AN_RESPONSE_EDIT = 0, + AN_RESPONSE_SNOOZE = 1 +}; - gtk_widget_pop_colormap(); - - scrolled_window = gtk_scrolled_window_new(NULL, NULL); - - gtk_scrolled_window_set_policy(GTK_SCROLLED_WINDOW(scrolled_window), - GTK_POLICY_AUTOMATIC, - GTK_POLICY_AUTOMATIC); - - - gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (scrolled_window), - GTK_SHADOW_IN); - - gtk_widget_set_size_request (scrolled_window, 300, 200); - - gtk_container_add(GTK_CONTAINER (scrolled_window), html); - - gtk_widget_show_all(scrolled_window); - - g_object_set_data (G_OBJECT (scrolled_window), "html", html); - return scrolled_window; -} - -static void -write_times (GtkHTMLStream *stream, char *start, char *end) -{ - if (start) - gtk_html_stream_printf (stream, "%s %s
", _("Starting:"), start); - if (end) - gtk_html_stream_printf (stream, "%s %s
", _("Ending:"), end); - -} - -/* Creates a heading for the alarm notification dialog */ -static void -write_html_heading (GtkHTMLStream *stream, const char *message, - ECalComponentVType vtype, time_t occur_start, time_t occur_end) -{ - char *start, *end; - char *bg_path = "file://" EVOLUTION_IMAGESDIR "/bcg.png"; - gchar *image_path; - gchar *icon_path; - icaltimezone *current_zone; - - icon_path = e_icon_factory_get_icon_filename ("stock_alarm", E_ICON_SIZE_DIALOG); - image_path = g_strdup_printf ("file://%s", icon_path); - g_free (icon_path); - - /* Stringize the times */ - - current_zone = config_data_get_timezone (); - - start = timet_to_str_with_zone (occur_start, current_zone); - end = timet_to_str_with_zone (occur_end, current_zone); - - /* Write the header */ - - gtk_html_stream_printf (stream, - "" - "" - "" - "" - "" - "" - "

%s

", - bg_path, - image_path, - _("Evolution Alarm")); - - gtk_html_stream_printf (stream, "

%s

", message); - - /* Write the times */ - - switch (vtype) { - case E_CAL_COMPONENT_EVENT: - write_times (stream, start, end); - break; - - case E_CAL_COMPONENT_TODO: - write_times (stream, start, end); - break; - - default: - /* Only VEVENTs and VTODOs can have alarms */ - g_assert_not_reached (); - break; - } - - g_free (start); - g_free (end); - g_free (image_path); -} + /** * alarm_notify_dialog: @@ -282,7 +71,9 @@ write_html_heading (GtkHTMLStream *stream, const char *message, * @occur_start: Start of occurrence time for the event. * @occur_end: End of occurrence time for the event. * @vtype: Type of the component which corresponds to the alarm. - * @message; Message to display in the dialog; usually comes from the component. + * @summary: Short summary of the appointment + * @description: Long description of the appointment + * @location: Location of the appointment * @func: Function to be called when a dialog action is invoked. * @func_data: Closure data for @func. * @@ -291,23 +82,30 @@ write_html_heading (GtkHTMLStream *stream, const char *message, * * Return value: a pointer to the dialog structure if successful or NULL if an error occurs. **/ -gpointer +void alarm_notify_dialog (time_t trigger, time_t occur_start, time_t occur_end, - ECalComponentVType vtype, const char *message, + ECalComponentVType vtype, const char *summary, + const char *description, const char *location, AlarmNotifyFunc func, gpointer func_data) { AlarmNotify *an; - GtkHTMLStream *stream; + GtkWidget *image; icaltimezone *current_zone; - char *buf, *title; + char *title; + char *start, *end; + char *icon_path; GList *icon_list; + int snooze_timeout; - g_return_val_if_fail (trigger != -1, NULL); + g_return_if_fail (trigger != -1); /* Only VEVENTs or VTODOs can have alarms */ - g_return_val_if_fail (vtype == E_CAL_COMPONENT_EVENT || vtype == E_CAL_COMPONENT_TODO, NULL); - g_return_val_if_fail (message != NULL, NULL); - g_return_val_if_fail (func != NULL, NULL); + g_return_if_fail (vtype == E_CAL_COMPONENT_EVENT + || vtype == E_CAL_COMPONENT_TODO); + g_return_if_fail (summary != NULL); + g_return_if_fail (description != NULL); + g_return_if_fail (location != NULL); + g_return_if_fail (func != NULL); an = g_new0 (AlarmNotify, 1); @@ -318,65 +116,56 @@ alarm_notify_dialog (time_t trigger, time_t occur_start, time_t occur_end, if (!an->xml) { g_message ("alarm_notify_dialog(): Could not load the Glade XML file!"); g_free (an); - return NULL; + return; } an->dialog = glade_xml_get_widget (an->xml, "alarm-notify"); - an->close = glade_xml_get_widget (an->xml, "close"); - an->snooze = glade_xml_get_widget (an->xml, "snooze"); - an->edit = glade_xml_get_widget (an->xml, "edit"); + an->title = glade_xml_get_widget (an->xml, "title-label"); an->snooze_time = glade_xml_get_widget (an->xml, "snooze-time"); - an->html = g_object_get_data (G_OBJECT (glade_xml_get_widget (an->xml, "frame")), "html"); + an->description = glade_xml_get_widget (an->xml, "description-label"); + an->location = glade_xml_get_widget (an->xml, "location-label"); + an->start = glade_xml_get_widget (an->xml, "start-label"); + an->end = glade_xml_get_widget (an->xml, "end-label"); - if (!(an->dialog && an->close && an->snooze && an->edit - && an->snooze_time)) { + if (!(an->dialog && an->title && an->snooze_time + && an->description && an->location && an->start && an->end)) { g_message ("alarm_notify_dialog(): Could not find all widgets in Glade file!"); g_object_unref (an->xml); g_free (an); - return NULL; + return; } gtk_widget_realize (an->dialog); gtk_container_set_border_width (GTK_CONTAINER (GTK_DIALOG (an->dialog)->vbox), 0); gtk_container_set_border_width (GTK_CONTAINER (GTK_DIALOG (an->dialog)->action_area), 12); - g_signal_connect (G_OBJECT (an->dialog), "destroy", - G_CALLBACK (dialog_destroy_cb), - an); + image = glade_xml_get_widget (an->xml, "alarm-image"); + icon_path = e_icon_factory_get_icon_filename ("stock_alarm", E_ICON_SIZE_DIALOG); + gtk_image_set_from_file (GTK_IMAGE (image), icon_path); + g_free (icon_path); /* Title */ - current_zone = config_data_get_timezone (); + gtk_window_set_title (GTK_WINDOW (an->dialog), summary); - buf = timet_to_str_with_zone (trigger, current_zone); - title = g_strdup_printf (_("Alarm on %s"), buf); - g_free (buf); + /* Set the widget contents */ - gtk_window_set_title (GTK_WINDOW (an->dialog), title); + title = g_strdup_printf ("%s", summary); + gtk_label_set_markup (GTK_LABEL (an->title), title); g_free (title); - /* html heading */ - stream = gtk_html_begin (GTK_HTML (an->html)); - write_html_heading (stream, message, vtype, occur_start, occur_end); - gtk_html_stream_close (stream, GTK_HTML_STREAM_OK); + gtk_label_set_text (GTK_LABEL (an->description), description); + gtk_label_set_text (GTK_LABEL (an->location), location); - /* Connect actions */ - - g_signal_connect (an->dialog, "delete_event", - G_CALLBACK (delete_event_cb), - an); + /* Stringize the times */ - g_signal_connect (an->close, "clicked", - G_CALLBACK (close_clicked_cb), - an); + current_zone = config_data_get_timezone (); - g_signal_connect (an->snooze, "clicked", - G_CALLBACK (snooze_clicked_cb), - an); + start = timet_to_str_with_zone (occur_start, current_zone); + gtk_label_set_text (GTK_LABEL (an->start), start); - g_signal_connect (an->edit, "clicked", - G_CALLBACK (edit_clicked_cb), - an); + end = timet_to_str_with_zone (occur_end, current_zone); + gtk_label_set_text (GTK_LABEL (an->end), end); /* Run! */ @@ -390,15 +179,20 @@ alarm_notify_dialog (time_t trigger, time_t occur_start, time_t occur_end, g_list_free (icon_list); } - gtk_widget_show (an->dialog); - return an; -} - -void -alarm_notify_dialog_disable_buttons (gpointer dialog) -{ - AlarmNotify *an = dialog; - - gtk_widget_set_sensitive (an->snooze, FALSE); - gtk_widget_set_sensitive (an->edit, FALSE); + switch (gtk_dialog_run (GTK_DIALOG (an->dialog))) { + case AN_RESPONSE_EDIT: + (* an->func) (ALARM_NOTIFY_EDIT, -1, an->func_data); + break; + case AN_RESPONSE_SNOOZE: + snooze_timeout = gtk_spin_button_get_value_as_int (GTK_SPIN_BUTTON (an->snooze_time)); + (* an->func) (ALARM_NOTIFY_SNOOZE, snooze_timeout, an->func_data); + break; + case GTK_RESPONSE_CLOSE: + case GTK_RESPONSE_DELETE_EVENT: + break; + } + gtk_widget_destroy (an->dialog); + + g_object_unref (an->xml); + g_free (an); } diff --git a/calendar/gui/alarm-notify/alarm-notify-dialog.h b/calendar/gui/alarm-notify/alarm-notify-dialog.h index 9bebce0a08..91861aaa99 100644 --- a/calendar/gui/alarm-notify/alarm-notify-dialog.h +++ b/calendar/gui/alarm-notify/alarm-notify-dialog.h @@ -35,10 +35,10 @@ typedef enum { typedef void (* AlarmNotifyFunc) (AlarmNotifyResult result, int snooze_mins, gpointer data); -gpointer alarm_notify_dialog (time_t trigger, time_t occur_start, time_t occur_end, - ECalComponentVType vtype, const char *message, - AlarmNotifyFunc func, gpointer func_data); -void alarm_notify_dialog_disable_buttons (gpointer dialog); +void alarm_notify_dialog (time_t trigger, time_t occur_start, time_t occur_end, + ECalComponentVType vtype, const char *summary, + const char *description, const char *location, + AlarmNotifyFunc func, gpointer func_data); #endif diff --git a/calendar/gui/alarm-notify/alarm-notify.glade b/calendar/gui/alarm-notify/alarm-notify.glade index 1d53234c3e..0302458aa3 100644 --- a/calendar/gui/alarm-notify/alarm-notify.glade +++ b/calendar/gui/alarm-notify/alarm-notify.glade @@ -5,10 +5,12 @@ True - + Appointment GTK_WINDOW_TOPLEVEL GTK_WIN_POS_NONE False + 384 + 200 True False True @@ -19,18 +21,18 @@ False - + True False 0 - + True GTK_BUTTONBOX_END - + True True True @@ -39,7 +41,7 @@ 0 - + True 0.5 0.5 @@ -51,13 +53,13 @@ 0 - + True False 2 - + True gtk-properties 4 @@ -74,9 +76,9 @@ - + True - _Edit appointment + _Edit True False GTK_JUSTIFY_LEFT @@ -101,16 +103,16 @@ - + True True True GTK_RELIEF_NORMAL True - 0 + 1 - + True 0.5 0.5 @@ -122,13 +124,13 @@ 0 - + True False 2 - + True gtk-refresh 4 @@ -145,7 +147,7 @@ - + True _Snooze True @@ -172,7 +174,7 @@ - + True True True @@ -193,73 +195,48 @@ - + 12 True False 12 - + True - False - 6 - - - - True - False - 6 - - - - True - make_html_display - 0 - 0 - Thu, 11 Oct 2001 08:19:04 GMT - - - 0 - True - True - - - - - 0 - True - True - - + gtk-dialog-info + 6 + 0.5 + 0 + 0 + 0 0 - True - True + False + False - + True False - 6 + 12 - + True - Snooze _time (minutes): - True - False - GTK_JUSTIFY_CENTER + Appointment Title + False + True + GTK_JUSTIFY_LEFT False False 0 0.5 0 0 - snooze-time 0 @@ -269,28 +246,287 @@ - + True - True - 1 - 0 - False - GTK_UPDATE_ALWAYS - False - False - 5 1 1440 1 5 5 + False + 12 + + + + True + True + description of appointment + False + True + GTK_JUSTIFY_LEFT + True + True + 0 + 0.5 + 0 + 0 + + + 0 + False + False + + + + + + True + 4 + 2 + False + 6 + 6 + + + + True + Location: + False + False + GTK_JUSTIFY_LEFT + False + False + 0 + 0.5 + 0 + 0 + + + 0 + 1 + 0 + 1 + fill + + + + + + + True + Start time: + False + False + GTK_JUSTIFY_LEFT + False + False + 0 + 0.5 + 0 + 0 + + + 0 + 1 + 1 + 2 + fill + + + + + + + True + End time: + False + False + GTK_JUSTIFY_LEFT + False + False + 0 + 0.5 + 0 + 0 + + + 0 + 1 + 2 + 3 + fill + + + + + + + True + location + False + False + GTK_JUSTIFY_LEFT + False + False + 0 + 0.5 + 0 + 0 + + + 1 + 2 + 0 + 1 + fill + + + + + + + True + True + start-time + False + False + GTK_JUSTIFY_LEFT + False + True + 0 + 0.5 + 0 + 0 + + + 1 + 2 + 1 + 2 + fill + + + + + + + True + True + end-time + False + False + GTK_JUSTIFY_LEFT + False + True + 0 + 0.5 + 0 + 0 + + + 1 + 2 + 2 + 3 + fill + + + + + + + True + False + 6 + + + + True + True + 1 + 0 + False + GTK_UPDATE_ALWAYS + False + False + 5 1 60 1 10 10 + + + 0 + False + False + + + + + + True + minutes + False + False + GTK_JUSTIFY_LEFT + False + False + 0.5 + 0.5 + 0 + 0 + + + 0 + False + False + + + + + 1 + 2 + 3 + 4 + fill + fill + + + + + + True + Snooze _time: + True + False + GTK_JUSTIFY_LEFT + False + False + 0 + 0.5 + 0 + 0 + snooze-time + + + 0 + 1 + 3 + 4 + fill + + + + + + 0 + True + True + + 0 - False - False + True + True 0 - False - False + True + True diff --git a/calendar/gui/alarm-notify/alarm-queue.c b/calendar/gui/alarm-notify/alarm-queue.c index 0679d00f08..028cd8d00a 100644 --- a/calendar/gui/alarm-notify/alarm-queue.c +++ b/calendar/gui/alarm-notify/alarm-queue.c @@ -699,7 +699,9 @@ edit_component (ECal *client, ECalComponent *comp) } typedef struct { - char *message; + char *summary; + char *description; + char *location; gboolean blink_state; gint blink_id; time_t trigger; @@ -730,8 +732,6 @@ on_dialog_objs_removed_cb (ECal *client, GList *objects, gpointer data) continue; if (!strcmp (uid, our_uid)) { - if (tray_data->alarm_dialog) - alarm_notify_dialog_disable_buttons (tray_data->alarm_dialog); tray_data->cqa = NULL; tray_data->alarm_id = NULL; @@ -767,7 +767,6 @@ notify_dialog_cb (AlarmNotifyResult result, int snooze_mins, gpointer data) g_assert_not_reached (); } - tray_data->alarm_dialog = NULL; gtk_widget_destroy (tray_data->tray_icon); } @@ -782,9 +781,19 @@ tray_icon_destroyed_cb (GtkWidget *tray, gpointer user_data) if (tray_data->cqa != NULL) remove_queued_alarm (tray_data->cqa, tray_data->alarm_id, TRUE, TRUE); - if (tray_data->message != NULL) { - g_free (tray_data->message); - tray_data->message = NULL; + if (tray_data->summary != NULL) { + g_free (tray_data->summary); + tray_data->summary = NULL; + } + + if (tray_data->description != NULL) { + g_free (tray_data->description); + tray_data->description = NULL; + } + + if (tray_data->location != NULL) { + g_free (tray_data->location); + tray_data->location = NULL; } if (tray_data->blink_id) @@ -806,19 +815,17 @@ open_alarm_dialog (TrayIconData *tray_data) { QueuedAlarm *qa; - if (tray_data->alarm_dialog != NULL) - return FALSE; - qa = lookup_queued_alarm (tray_data->cqa, tray_data->alarm_id); if (qa) { gtk_widget_hide (tray_data->tray_icon); - tray_data->alarm_dialog = alarm_notify_dialog ( - tray_data->trigger, - qa->instance->occur_start, - qa->instance->occur_end, - e_cal_component_get_vtype (tray_data->comp), - tray_data->message, - notify_dialog_cb, tray_data); + alarm_notify_dialog (tray_data->trigger, + qa->instance->occur_start, + qa->instance->occur_end, + e_cal_component_get_vtype (tray_data->comp), + tray_data->summary, + tray_data->description, + tray_data->location, + notify_dialog_cb, tray_data); } return TRUE; @@ -917,12 +924,12 @@ display_notification (time_t trigger, CompQueuedAlarms *cqa, { QueuedAlarm *qa; ECalComponent *comp; - const char *message; - ECalComponentAlarm *alarm; + const char *summary, *description, *location; GtkWidget *tray_icon, *image, *ebox; GtkTooltips *tooltips; TrayIconData *tray_data; ECalComponentText text; + GSList *text_list; char *str, *start_str, *end_str, *alarm_str; icaltimezone *current_zone; GdkPixbuf *pixbuf; @@ -933,26 +940,32 @@ display_notification (time_t trigger, CompQueuedAlarms *cqa, return; /* get a sensible description for the event */ - alarm = e_cal_component_get_alarm (comp, qa->instance->auid); - g_assert (alarm != NULL); + e_cal_component_get_summary (comp, &text); - e_cal_component_alarm_get_description (alarm, &text); - e_cal_component_alarm_free (alarm); + if (text.value) + summary = text.value; + else + summary = _("No summary available."); + e_cal_component_get_description_list (comp, &text_list); + + text = *((ECalComponentText *)text_list->data); if (text.value) - message = text.value; - else { - e_cal_component_get_summary (comp, &text); - if (text.value) - message = text.value; - else - message = _("No description available."); - } + description = text.value; + else + description = _("No description available."); + + e_cal_component_free_text_list (text_list); + + e_cal_component_get_location (comp, &location); + + if (!location) + location = _("No location information available."); /* create the tray icon */ tooltips = gtk_tooltips_new (); - tray_icon = egg_tray_icon_new (qa->instance->auid); + tray_icon = GTK_WIDGET (egg_tray_icon_new (qa->instance->auid)); pixbuf = e_icon_factory_get_icon ("stock_appointment-reminder", E_ICON_SIZE_LARGE_TOOLBAR); image = gtk_image_new_from_pixbuf (pixbuf); gdk_pixbuf_unref (pixbuf); @@ -966,7 +979,7 @@ display_notification (time_t trigger, CompQueuedAlarms *cqa, start_str = timet_to_str_with_zone (qa->instance->occur_start, current_zone); end_str = timet_to_str_with_zone (qa->instance->occur_end, current_zone); str = g_strdup_printf (_("Alarm on %s\n%s\nStarting at %s\nEnding at %s"), - alarm_str, message, start_str, end_str); + alarm_str, summary, start_str, end_str); gtk_tooltips_set_tip (GTK_TOOLTIPS (tooltips), ebox, str, str); g_free (start_str); g_free (end_str); @@ -981,7 +994,9 @@ display_notification (time_t trigger, CompQueuedAlarms *cqa, /* create the private structure */ tray_data = g_new0 (TrayIconData, 1); - tray_data->message = g_strdup (message); + tray_data->summary = g_strdup (summary); + tray_data->description = g_strdup (description); + tray_data->location = g_strdup (location); tray_data->trigger = trigger; tray_data->cqa = cqa; tray_data->alarm_id = alarm_id; -- cgit v1.2.3