* src/modest-address-book.h:
[modest] / src / widgets / modest-recpt-editor.c
index 6e66489..5449a57 100644 (file)
 
 #include <modest-text-utils.h>
 #include <modest-recpt-editor.h>
+#include <modest-scroll-text.h>
+#include <pango/pango-attributes.h>
+#include <string.h>
 
 static GObjectClass *parent_class = NULL;
 
-/* /\* signals *\/ */
-/* enum { */
-/*     LAST_SIGNAL */
-/* }; */
+#define RECIPIENT_TAG_ID "recpt-id"
+
+/* signals */
+enum {
+       OPEN_ADDRESSBOOK_SIGNAL,
+       LAST_SIGNAL
+};
 
 typedef struct _ModestRecptEditorPrivate ModestRecptEditorPrivate;
 
@@ -59,13 +65,17 @@ struct _ModestRecptEditorPrivate
 #define MODEST_RECPT_EDITOR_GET_PRIVATE(o)     \
        (G_TYPE_INSTANCE_GET_PRIVATE ((o), MODEST_TYPE_RECPT_EDITOR, ModestRecptEditorPrivate))
 
-/* static guint signals[LAST_SIGNAL] = {0}; */
+static guint signals[LAST_SIGNAL] = {0};
 
 /* static functions: GObject */
 static void modest_recpt_editor_instance_init (GTypeInstance *instance, gpointer g_class);
 static void modest_recpt_editor_finalize (GObject *object);
 static void modest_recpt_editor_class_init (ModestRecptEditorClass *klass);
 
+/* widget events */
+static void modest_recpt_editor_on_abook_clicked (GtkButton *button,
+                                                 ModestRecptEditor *editor);
+
 /**
  * modest_recpt_editor_new:
  *
@@ -99,12 +109,90 @@ modest_recpt_editor_set_recipients (ModestRecptEditor *recpt_editor, const gchar
 
 }
 
+void
+modest_recpt_editor_add_recipients (ModestRecptEditor *recpt_editor, const gchar *recipients)
+{
+       ModestRecptEditorPrivate *priv;
+       GtkTextBuffer *buffer = NULL;
+       GtkTextIter iter;
+       gchar * string_to_add;
+
+       g_return_if_fail (MODEST_IS_RECPT_EDITOR (recpt_editor));
+       priv = MODEST_RECPT_EDITOR_GET_PRIVATE (recpt_editor);
+
+       if (recipients == NULL)
+               return;
+
+       buffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW (priv->text_view));
+
+       if (gtk_text_buffer_get_char_count (buffer) > 0) {
+               string_to_add = g_strconcat (";\n", recipients, NULL);
+       } else {
+               string_to_add = g_strdup (recipients);
+       }
+
+       gtk_text_buffer_get_end_iter (buffer, &iter);
+
+       gtk_text_buffer_insert (buffer, &iter, recipients, -1);
+       if (GTK_WIDGET_REALIZED (recpt_editor))
+               gtk_widget_queue_resize (GTK_WIDGET (recpt_editor));
+
+}
+
+void 
+modest_recpt_editor_add_resolved_recipient (ModestRecptEditor *recpt_editor, GSList *email_list, const gchar * recipient_id)
+{
+       ModestRecptEditorPrivate *priv;
+       GtkTextBuffer *buffer = NULL;
+       GtkTextIter start, end, iter;
+       GtkTextTag *tag = NULL;
+       gboolean is_first_recipient = TRUE;
+       GSList *node;
+      
+       g_return_if_fail (MODEST_IS_RECPT_EDITOR (recpt_editor));
+       priv = MODEST_RECPT_EDITOR_GET_PRIVATE (recpt_editor);
+
+       buffer = gtk_text_view_get_buffer (GTK_TEXT_VIEW (priv->text_view));
+
+       gtk_text_buffer_get_bounds (buffer, &start, &end);
+       if (!gtk_text_iter_equal (&start, &end))
+               gtk_text_buffer_insert (buffer, &end, ";\n", -1);
+
+       gtk_text_buffer_get_end_iter (buffer, &iter);
+
+       tag = gtk_text_buffer_create_tag (buffer, NULL, 
+                                         "underline", PANGO_UNDERLINE_SINGLE,
+                                         "wrap-mode", GTK_WRAP_NONE,
+                                         "editable", TRUE, NULL);
+
+       g_object_set_data (G_OBJECT (tag), "recipient-tag-id", GINT_TO_POINTER (RECIPIENT_TAG_ID));
+       g_object_set_data_full (G_OBJECT (tag), "recipient-id", g_strdup (recipient_id), (GDestroyNotify) g_free);
+
+       for (node = email_list; node != NULL; node = g_slist_next (node)) {
+               gchar *recipient = (gchar *) email_list->data;
+
+               if ((recipient) && (strlen (recipient) != 0)) {
+
+                       if (!is_first_recipient) {
+                               gtk_text_buffer_insert (buffer, &iter, ";\n", -1);
+                       } else {
+                               is_first_recipient = FALSE;
+                       }
+
+                       gtk_text_buffer_insert_with_tags (buffer, &iter, recipient, -1, tag, NULL);
+               }
+       }
+
+}
+
+
 const gchar *
 modest_recpt_editor_get_recipients (ModestRecptEditor *recpt_editor)
 {
        ModestRecptEditorPrivate *priv;
        GtkTextBuffer *buffer = NULL;
        GtkTextIter start, end;
+       gchar *c;
 
        g_return_val_if_fail (MODEST_IS_RECPT_EDITOR (recpt_editor), NULL);
        priv = MODEST_RECPT_EDITOR_GET_PRIVATE (recpt_editor);
@@ -120,6 +208,10 @@ modest_recpt_editor_get_recipients (ModestRecptEditor *recpt_editor)
        gtk_text_buffer_get_end_iter (buffer, &end);
 
        priv->recipients = gtk_text_buffer_get_text (buffer, &start, &end, FALSE);
+       for (c = priv->recipients; *c == '\0'; c++) {
+               if (*c == '\n')
+                       *c = ' ';
+       }
 
        return priv->recipients;
 
@@ -141,19 +233,25 @@ modest_recpt_editor_instance_init (GTypeInstance *instance, gpointer g_class)
        gtk_container_add (GTK_CONTAINER (priv->abook_button), abook_icon);
 
        priv->text_view = gtk_text_view_new ();
-       priv->scrolled_window = gtk_scrolled_window_new (NULL, NULL);
-       gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (priv->scrolled_window), GTK_POLICY_NEVER, GTK_POLICY_NEVER);
+       priv->scrolled_window = modest_scroll_text_new (GTK_TEXT_VIEW (priv->text_view), 5);
+       gtk_scrolled_window_set_policy (GTK_SCROLLED_WINDOW (priv->scrolled_window), GTK_POLICY_NEVER, GTK_POLICY_AUTOMATIC);
        gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (priv->scrolled_window), GTK_SHADOW_IN);
-       gtk_container_add (GTK_CONTAINER (priv->scrolled_window), priv->text_view);
+/*     gtk_container_add (GTK_CONTAINER (priv->scrolled_window), priv->text_view); */
 
        gtk_box_pack_start (GTK_BOX (instance), priv->scrolled_window, TRUE, TRUE, 0);
+/*     gtk_box_pack_start (GTK_BOX (instance), priv->text_view, TRUE, TRUE, 0); */
        gtk_box_pack_end (GTK_BOX (instance), priv->abook_button, FALSE, FALSE, 0);
 
        gtk_text_view_set_accepts_tab (GTK_TEXT_VIEW (priv->text_view), FALSE);
        gtk_text_view_set_cursor_visible (GTK_TEXT_VIEW (priv->text_view), TRUE);
        gtk_text_view_set_editable (GTK_TEXT_VIEW (priv->text_view), TRUE);
+
        gtk_text_view_set_justification (GTK_TEXT_VIEW (priv->text_view), GTK_JUSTIFY_LEFT);
-       gtk_text_view_set_wrap_mode (GTK_TEXT_VIEW (priv->text_view), GTK_WRAP_WORD_CHAR);
+       gtk_text_view_set_wrap_mode (GTK_TEXT_VIEW (priv->text_view), GTK_WRAP_CHAR);
+
+       gtk_widget_set_size_request (priv->text_view, 75, -1);
+
+       g_signal_connect (G_OBJECT (priv->abook_button), "clicked", G_CALLBACK (modest_recpt_editor_on_abook_clicked), instance);
 
        return;
 }
@@ -171,6 +269,14 @@ modest_recpt_editor_set_field_size_group (ModestRecptEditor *recpt_editor, GtkSi
 }
 
 static void
+modest_recpt_editor_on_abook_clicked (GtkButton *button, ModestRecptEditor *editor)
+{
+       g_return_if_fail (MODEST_IS_RECPT_EDITOR (editor));
+
+       g_signal_emit_by_name (G_OBJECT (editor), "open-addressbook");
+}
+
+static void
 modest_recpt_editor_finalize (GObject *object)
 {
        (*parent_class->finalize) (object);
@@ -192,6 +298,15 @@ modest_recpt_editor_class_init (ModestRecptEditorClass *klass)
 
        g_type_class_add_private (object_class, sizeof (ModestRecptEditorPrivate));
 
+       signals[OPEN_ADDRESSBOOK_SIGNAL] = 
+               g_signal_new ("open-addressbook",
+                             G_TYPE_FROM_CLASS (object_class),
+                             G_SIGNAL_RUN_FIRST | G_SIGNAL_ACTION,
+                             G_STRUCT_OFFSET (ModestRecptEditorClass, open_addressbook),
+                             NULL, NULL,
+                             g_cclosure_marshal_VOID__VOID,
+                             G_TYPE_NONE, 0);
+
        return;
 }