[evolution-patches] patch for bug #309508 [calendar]
- From: lviren <lviren novell com>
- To: evolution-patches gnome org
- Subject: [evolution-patches] patch for bug #309508 [calendar]
- Date: Tue, 13 Sep 2005 20:26:45 +0530
Hi,
Attached patch fixex bug
http://bugzilla.gnome.org/show_bug.cgi?id=309508
Thanks,
Viren.
Index: calendar.error.xml
===================================================================
RCS file: /cvs/gnome/evolution/calendar/calendar.error.xml,v
retrieving revision 1.3
diff -u -p -r1.3 calendar.error.xml
--- calendar.error.xml 6 Jul 2005 07:14:57 -0000 1.3
+++ calendar.error.xml 17 Aug 2005 09:31:48 -0000
@@ -227,4 +227,12 @@
<_secondary>You are connecting to an unsupported GroupWise server and may encounter problems using Evolution. For best results the server should be upgraded to a supported version</_secondary>
</error>
+<error id="prompt-save-delegated-item" type="question" default="GTK_RESPONSE_YES">
+ <title>Delegate</title>
+ <_primary>Meeting delegated</_primary>
+ <_secondary>Keep the original item ?</_secondary>
+ <button stock="gtk-no" response="GTK_RESPONSE_NO"/>
+ <button stock="gtk-yes" response="GTK_RESPONSE_YES"/>
+</error>
+
</error-list>
Index: ChangeLog
===================================================================
RCS file: /cvs/gnome/evolution/calendar/ChangeLog,v
retrieving revision 1.2795
diff -u -p -r1.2795 ChangeLog
--- ChangeLog 12 Aug 2005 14:33:55 -0000 1.2795
+++ ChangeLog 17 Aug 2005 09:32:02 -0000
@@ -1,3 +1,15 @@
+2005-08-17 Viren.L <lviren novell com>
+
+ Fixes #309508
+ * calendar.error.xml:
+ Defined a error id prompt-save-delegated-item.
+ * gui/dialogs/comp-editor.c: (response_cb),(prompt_to_save_changes),
+ (prompt_to_remove_delegated_meeting):
+ Added parameter to hold the response value of the save changes dialog,
+ and added the parameter wherever the call was made.
+ Added function prompt_to_remove_delegated_meeting.
+ Added check for delegate in response_cb and invoked prompt_to_save_changes.
+
2005-08-12 Viren.L <lviren novell com>
Fixes #312739
Index: gui/dialogs/comp-editor.c
===================================================================
RCS file: /cvs/gnome/evolution/calendar/gui/dialogs/comp-editor.c,v
retrieving revision 1.147
diff -u -p -r1.147 comp-editor.c
--- gui/dialogs/comp-editor.c 12 Aug 2005 21:19:52 -0000 1.147
+++ gui/dialogs/comp-editor.c 17 Aug 2005 09:32:04 -0000
@@ -130,7 +130,7 @@ static void comp_editor_show_help (CompE
static void real_set_e_cal (CompEditor *editor, ECal *client);
static void real_edit_comp (CompEditor *editor, ECalComponent *comp);
static gboolean real_send_comp (CompEditor *editor, ECalComponentItipMethod method);
-static gboolean prompt_to_save_changes (CompEditor *editor, gboolean send);
+static gboolean prompt_to_save_changes (CompEditor *editor, gboolean send, GtkResponseType *response);
static void delete_comp (CompEditor *editor);
static void close_dialog (CompEditor *editor);
@@ -844,8 +844,42 @@ save_comp_with_send (CompEditor *editor)
return TRUE;
}
+static void
+prompt_to_remove_delegated_meeting (CompEditor *editor)
+{
+ CompEditorPrivate *priv;
+
+ priv = editor->priv;
+
+ if (e_error_run (NULL, "calendar:prompt-save-delegated-item", NULL) == GTK_RESPONSE_NO) {
+ const char *uid;
+ GError *error = NULL;
+
+ e_cal_component_get_uid (priv->comp, &uid);
+
+ if (!e_cal_component_is_instance (priv->comp)) {
+ e_cal_remove_object (priv->client, uid, &error);
+ } else {
+ if (priv->mod == CALOBJ_MOD_ALL) {
+ e_cal_remove_object_with_mod (priv->client, uid, NULL,
+ CALOBJ_MOD_ALL, &error);
+ } else {
+ const char *rid = e_cal_component_get_recurid_as_string (priv->comp);
+
+ e_cal_remove_object_with_mod (priv->client, uid, rid,
+ CALOBJ_MOD_THIS, &error);
+ }
+ }
+
+ if (error) {
+ g_warning ("Could not remove the Object: %s", error->message);
+ g_clear_error (&error);
+ }
+ }
+}
+
static gboolean
-prompt_to_save_changes (CompEditor *editor, gboolean send)
+prompt_to_save_changes (CompEditor *editor, gboolean send, GtkResponseType *response)
{
CompEditorPrivate *priv;
gboolean read_only;
@@ -857,8 +891,9 @@ prompt_to_save_changes (CompEditor *edit
if (!e_cal_is_read_only (priv->client, &read_only, NULL) || read_only)
return TRUE;
-
- switch (save_component_dialog (GTK_WINDOW(editor), priv->comp)) {
+ *response = save_component_dialog (GTK_WINDOW(editor), priv->comp);
+
+ switch (*response) {
case GTK_RESPONSE_YES: /* Save */
if (e_cal_component_is_instance (priv->comp))
if (!recur_component_dialog (priv->client, priv->comp, &priv->mod, GTK_WINDOW (editor), FALSE))
@@ -886,6 +921,7 @@ response_cb (GtkWidget *widget, int resp
ECalComponentText text;
gboolean delegated;
ECalComponent *comp;
+ GtkResponseType res;
priv = editor->priv;
delegated = (priv->flags & COMP_EDITOR_DELEGATE);
@@ -924,6 +960,9 @@ response_cb (GtkWidget *widget, int resp
return;
if (save_comp_with_send (editor))
close_dialog (editor);
+ if (delegated)
+ prompt_to_remove_delegated_meeting (editor);
+
break;
case GTK_RESPONSE_HELP:
@@ -933,8 +972,11 @@ response_cb (GtkWidget *widget, int resp
case GTK_RESPONSE_CANCEL:
commit_all_fields (editor);
- if (prompt_to_save_changes (editor, TRUE))
+ if (prompt_to_save_changes (editor, TRUE, &res)) {
close_dialog (editor);
+ if (res == GTK_RESPONSE_YES && (priv->flags & COMP_EDITOR_DELEGATE))
+ prompt_to_remove_delegated_meeting (editor);
+ }
break;
default:
/* We handle delete event below */
@@ -947,12 +989,13 @@ delete_event_cb (GtkWidget *widget, GdkE
{
CompEditor *editor = COMP_EDITOR (data);
CompEditorPrivate *priv;
+ GtkResponseType res;
priv = editor->priv;
commit_all_fields (editor);
- if (prompt_to_save_changes (editor, TRUE))
+ if (prompt_to_save_changes (editor, TRUE, &res))
close_dialog (editor);
return TRUE;
@@ -2356,7 +2399,8 @@ comp_editor_get_current_comp (CompEditor
gboolean
comp_editor_save_comp (CompEditor *editor, gboolean send)
{
- return prompt_to_save_changes (editor, send);
+ GtkResponseType res;
+ return prompt_to_save_changes (editor, send, &res);
}
/**
@@ -2398,13 +2442,14 @@ gboolean
comp_editor_close (CompEditor *editor)
{
gboolean close;
+ GtkResponseType res;
g_return_val_if_fail (editor != NULL, FALSE);
g_return_val_if_fail (IS_COMP_EDITOR (editor), FALSE);
commit_all_fields (editor);
- close = prompt_to_save_changes (editor, TRUE);
+ close = prompt_to_save_changes (editor, TRUE, &res);
if (close)
close_dialog (editor);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]