aboutsummaryrefslogtreecommitdiffstats
path: root/mail
diff options
context:
space:
mode:
Diffstat (limited to 'mail')
-rw-r--r--mail/ChangeLog22
-rw-r--r--mail/em-composer-prefs.c39
-rw-r--r--mail/mail-signature-editor.c85
-rw-r--r--mail/mail.error.xml12
4 files changed, 117 insertions, 41 deletions
diff --git a/mail/ChangeLog b/mail/ChangeLog
index ed4f77c765..f77edd206e 100644
--- a/mail/ChangeLog
+++ b/mail/ChangeLog
@@ -1,3 +1,25 @@
+2005-10-18 Sankar P <psankar@novell.com>
+
+ - Enhances Signature-Preferences.
+ - Added shortcuts for common operations.
+ -- Delete on Del key
+ -- Edit on Dbl.Click
+ - Prevents adding duplicate and NULL signatures
+
+ * mail-signature-editor.c (menu_file_save_cb) (mail_signature_editor)
+ (sig_name_changed) (menu_file_save_close_cb) (delete_event_cb) (do_exit):
+ Modified the functions for handling the above scenarios.
+ * mail.error.xml:
+ Added error strings for duplicate and NULL signatures.
+ * em-composer-prefs.c (em_composer_prefs_construct) (sig_delete_cb) (sig_add_cb):
+ Modified the functions so as to handle the keyboard accelarators
+ and to grab focus to the list on deletion/insertion of signatures.
+ * em-composer-prefs.c (signature_key_press)(sig_tree_event_cb):
+ Added new functions to handle the
+ keypress events on the signatures list tree.
+
+ Fixes #269749
+
2005-09-29 Parthasarathi Susarla <sparthasarathi@novell.com>
** See bug 317284
diff --git a/mail/em-composer-prefs.c b/mail/em-composer-prefs.c
index 5675ddc3b4..7e80c38284 100644
--- a/mail/em-composer-prefs.c
+++ b/mail/em-composer-prefs.c
@@ -41,6 +41,8 @@
#include <libedataserver/e-iconv.h>
#include <misc/e-gui-utils.h>
+#include <gdk/gdkkeysyms.h>
+
#include <gtk/gtkentry.h>
#include <gtk/gtktreemodel.h>
#include <gtk/gtkliststore.h>
@@ -336,19 +338,21 @@ em_composer_prefs_new_signature (GtkWindow *parent, gboolean html)
mail_signature_editor (sig, parent, TRUE);
}
-static void
+static void
sig_delete_cb (GtkWidget *widget, EMComposerPrefs *prefs)
{
GtkTreeSelection *selection;
GtkTreeModel *model;
GtkTreeIter iter;
ESignature *sig;
-
+
selection = gtk_tree_view_get_selection (prefs->sig_list);
+
if (gtk_tree_selection_get_selected (selection, &model, &iter)) {
gtk_tree_model_get (model, &iter, 1, &sig, -1);
mail_config_remove_signature (sig);
}
+ gtk_widget_grab_focus ((GtkWidget *)prefs->sig_list);
}
static void
@@ -365,6 +369,7 @@ sig_add_cb (GtkWidget *widget, EMComposerPrefs *prefs)
parent = GTK_WIDGET_TOPLEVEL (parent) ? parent : NULL;
em_composer_prefs_new_signature ((GtkWindow *) parent, send_html);
+ gtk_widget_grab_focus ((GtkWidget *)prefs->sig_list);
}
static void
@@ -815,6 +820,29 @@ emcp_free(EConfig *ec, GSList *items, void *data)
g_slist_free(items);
}
+static void
+signature_key_press (GtkTreeView *tree_view, GdkEventKey *event, EMComposerPrefs *prefs)
+{
+ /* No need to care about anything other than DEL key */
+ if (event->keyval == GDK_Delete)
+ sig_delete_cb ((GtkWidget *)tree_view, prefs);
+
+ return ;
+}
+
+static gboolean
+sig_tree_event_cb (GtkTreeView *tree_view, GdkEvent *event, EMComposerPrefs *prefs)
+{
+ gboolean ret = FALSE;
+
+ if (event->type == GDK_2BUTTON_PRESS) {
+ sig_edit_cb ((GtkWidget *)tree_view, prefs);
+ ret = TRUE;
+ }
+
+ return ret;
+}
+
static void
em_composer_prefs_construct (EMComposerPrefs *prefs)
{
@@ -949,10 +977,10 @@ em_composer_prefs_construct (EMComposerPrefs *prefs)
g_signal_connect (prefs->sig_add_script, "clicked", G_CALLBACK (sig_add_script_cb), prefs);
prefs->sig_edit = GTK_BUTTON (glade_xml_get_widget (gui, "cmdSignatureEdit"));
- g_signal_connect (prefs->sig_edit, "clicked", G_CALLBACK (sig_edit_cb), prefs);
+ g_signal_connect (prefs->sig_edit, "pressed", G_CALLBACK (sig_edit_cb), prefs);
prefs->sig_delete = GTK_BUTTON (glade_xml_get_widget (gui, "cmdSignatureDelete"));
- g_signal_connect (prefs->sig_delete, "clicked", G_CALLBACK (sig_delete_cb), prefs);
+ g_signal_connect (prefs->sig_delete, "pressed", G_CALLBACK (sig_delete_cb), prefs);
prefs->sig_list = GTK_TREE_VIEW (glade_xml_get_widget (gui, "listSignatures"));
model = gtk_list_store_new (2, G_TYPE_STRING, G_TYPE_POINTER);
@@ -964,6 +992,7 @@ em_composer_prefs_construct (EMComposerPrefs *prefs)
selection = gtk_tree_view_get_selection (prefs->sig_list);
gtk_tree_selection_set_mode (selection, GTK_SELECTION_SINGLE);
g_signal_connect (selection, "changed", G_CALLBACK (sig_selection_changed), prefs);
+ g_signal_connect (prefs->sig_list, "event", G_CALLBACK (sig_tree_event_cb), prefs);
sig_fill_list (prefs);
@@ -979,6 +1008,8 @@ em_composer_prefs_construct (EMComposerPrefs *prefs)
e_config_set_target((EConfig *)ec, (EConfigTarget *)target);
toplevel = e_config_create_widget((EConfig *)ec);
gtk_container_add (GTK_CONTAINER (prefs), toplevel);
+
+ g_signal_connect (prefs->sig_list, "key-press-event", G_CALLBACK(signature_key_press), prefs);
}
GtkWidget *
diff --git a/mail/mail-signature-editor.c b/mail/mail-signature-editor.c
index b34644676e..8ee79f9243 100644
--- a/mail/mail-signature-editor.c
+++ b/mail/mail-signature-editor.c
@@ -136,12 +136,13 @@ static void
menu_file_save_cb (BonoboUIComponent *uic, void *user_data, const char *path)
{
ESignatureEditor *editor = user_data;
+ ESignature *signature;
Bonobo_PersistStream pstream_iface;
- char *dirname, *base, *filename;
+ char *dirname, *base, *filename, *name;
CORBA_Environment ev;
GByteArray *text;
int fd;
-
+
d(printf ("editor->sig->filename = %s\n", editor->sig->filename));
dirname = g_path_get_dirname (editor->sig->filename);
d(printf ("dirname = %s\n", dirname));
@@ -151,40 +152,57 @@ menu_file_save_cb (BonoboUIComponent *uic, void *user_data, const char *path)
d(printf ("filename = %s\n", filename));
g_free (dirname);
g_free (base);
-
+
CORBA_exception_init (&ev);
pstream_iface = Bonobo_Unknown_queryInterface
- (bonobo_widget_get_objref (BONOBO_WIDGET (editor->control)),
- "IDL:Bonobo/PersistStream:1.0", &ev);
-
+ (bonobo_widget_get_objref (BONOBO_WIDGET (editor->control)),
+ "IDL:Bonobo/PersistStream:1.0", &ev);
+
if (ev._major != CORBA_NO_EXCEPTION)
goto exception;
-
+
if ((fd = open (filename, O_WRONLY | O_TRUNC | O_CREAT, 0666)) == -1)
goto exception;
-
+
text = get_text (pstream_iface, editor->html ? "text/html" : "text/plain", &ev);
if (ev._major != CORBA_NO_EXCEPTION) {
close (fd);
goto exception;
}
-
+
if (write_all (fd, text->data, text->len) == -1) {
g_byte_array_free (text, TRUE);
close (fd);
goto exception;
}
-
+
g_byte_array_free (text, TRUE);
close (fd);
-
+
if (rename (filename, editor->sig->filename) == -1)
goto exception;
-
+
g_free (filename);
-
+
editor->sig->html = editor->html;
+
+ name = g_strstrip (g_strdup (gtk_entry_get_text (GTK_ENTRY (editor->name_entry))));
+
+ if (g_str_equal(name, "") ) {
+ e_error_run ((GtkWindow *)editor->win, "mail:blank-signature", NULL);
+ return;
+ }
+ if ( (signature = (ESignature *)e_signature_list_find (mail_config_get_signatures (), E_SIGNATURE_FIND_NAME, name)) && !g_str_equal(signature->uid, editor->sig->uid) ) {
+ e_error_run ((GtkWindow *)editor->win, "mail:signature-already-exists", name, NULL);
+ return;
+ }
+
+ if (editor->sig->name)
+ g_free (editor->sig->name);
+
+ editor->sig->name = name;
+
/* if the signature isn't already saved in the config, save it there now... */
if (editor->is_new) {
mail_config_add_signature (editor->sig);
@@ -192,11 +210,12 @@ menu_file_save_cb (BonoboUIComponent *uic, void *user_data, const char *path)
} else {
e_signature_list_change (mail_config_get_signatures (), editor->sig);
}
-
+
+ destroy_editor (editor);
+
return;
-
- exception:
-
+
+exception:
menu_file_save_error (uic, &ev);
CORBA_exception_free (&ev);
unlink (filename);
@@ -220,26 +239,26 @@ static void
do_exit (ESignatureEditor *editor)
{
CORBA_Environment ev;
-
+
CORBA_exception_init (&ev);
-
- if (GNOME_GtkHTML_Editor_Engine_hasUndo (editor->engine, &ev)) {
+
+ if (GNOME_GtkHTML_Editor_Engine_hasUndo (editor->engine, &ev) || GPOINTER_TO_INT( g_object_get_data( G_OBJECT(editor->win), "name-changed"))) {
int button;
button = e_error_run((GtkWindow *)editor->win, "mail:ask-signature-changed", NULL);
exit_dialog_cb (button, editor);
- } else
+ } else
destroy_editor (editor);
-
+
CORBA_exception_free (&ev);
}
-static int
+static int
delete_event_cb (GtkWidget *w, GdkEvent *event, ESignatureEditor *editor)
{
do_exit (editor);
- return FALSE;
+ return TRUE;
}
static void
@@ -259,7 +278,6 @@ menu_file_save_close_cb (BonoboUIComponent *uic, gpointer data, const char *path
editor = E_SIGNATURE_EDITOR (data);
menu_file_save_cb (uic, editor, path);
- destroy_editor (editor);
}
static BonoboUIVerb verbs [] = {
@@ -280,8 +298,7 @@ load_signature (ESignatureEditor *editor)
Bonobo_PersistFile pfile_iface;
CORBA_exception_init (&ev);
- pfile_iface = Bonobo_Unknown_queryInterface (bonobo_widget_get_objref (BONOBO_WIDGET (editor->control)),
- "IDL:Bonobo/PersistFile:1.0", &ev);
+ pfile_iface = Bonobo_Unknown_queryInterface (bonobo_widget_get_objref (BONOBO_WIDGET (editor->control)),"IDL:Bonobo/PersistFile:1.0", &ev);
Bonobo_PersistFile_load (pfile_iface, editor->sig->filename, &ev);
CORBA_exception_free (&ev);
} else {
@@ -323,15 +340,7 @@ load_signature (ESignatureEditor *editor)
static void
sig_name_changed (GtkWidget *w, ESignatureEditor *editor)
{
- const char *name;
-
- name = gtk_entry_get_text (GTK_ENTRY (editor->name_entry));
-
- g_free (editor->sig->name);
- editor->sig->name = g_strdup (name);
-
- if (!editor->is_new)
- e_signature_list_change (mail_config_get_signatures (), editor->sig);
+ g_object_set_data ( G_OBJECT(editor->win), "name-changed", GINT_TO_POINTER(1));
}
static void
@@ -368,13 +377,15 @@ mail_signature_editor (ESignature *sig, GtkWindow *parent, gboolean is_new)
editor->sig = sig;
editor->html = sig->html;
editor->is_new = is_new;
-
+
editor->win = bonobo_window_new ("e-sig-editor", _("Edit signature"));
gtk_window_set_type_hint (GTK_WINDOW (editor->win), GDK_WINDOW_TYPE_HINT_DIALOG);
gtk_window_set_default_size (GTK_WINDOW (editor->win), DEFAULT_WIDTH, DEFAULT_HEIGHT);
if (parent != NULL)
gtk_window_set_transient_for (GTK_WINDOW (editor->win), parent);
g_object_set (editor->win, "allow_shrink", FALSE, "allow_grow", TRUE, NULL);
+
+ g_object_set_data (G_OBJECT(editor->win), "name-changed", GINT_TO_POINTER(0));
container = bonobo_window_get_ui_container (BONOBO_WINDOW(editor->win));
diff --git a/mail/mail.error.xml b/mail/mail.error.xml
index 7ab4d23209..2b23652f03 100644
--- a/mail/mail.error.xml
+++ b/mail/mail.error.xml
@@ -367,5 +367,17 @@ You can choose to ignore this folder, overwrite or append its contents, or quit.
<button stock="gtk-cancel" response="GTK_RESPONSE_CANCEL"/>
<button stock="gtk-yes" response="GTK_RESPONSE_YES"/>
</error>
+
+
+ <error id="signature-already-exists" type="error" modal="true">
+ <_primary>Signature Already Exists</_primary>
+ <_secondary>A signature already exists with the name &quot;{0}&quot;. Please specify a different name. </_secondary>
+ </error>
+
+ <error id="blank-signature" type="error" modal="true">
+ <_primary>Blank Signature</_primary>
+ <_secondary>Please provide an unique name to identify this signature.</_secondary>
+ </error>
+
</error-list>