diff options
-rw-r--r-- | my-evolution/ChangeLog | 12 | ||||
-rw-r--r-- | my-evolution/e-summary-mail.c | 84 | ||||
-rw-r--r-- | my-evolution/e-summary-mail.h | 8 | ||||
-rw-r--r-- | my-evolution/e-summary-preferences.c | 71 | ||||
-rw-r--r-- | my-evolution/my-evolution.glade | 8 |
5 files changed, 171 insertions, 12 deletions
diff --git a/my-evolution/ChangeLog b/my-evolution/ChangeLog index 787d5df475..43f4942464 100644 --- a/my-evolution/ChangeLog +++ b/my-evolution/ChangeLog @@ -1,5 +1,17 @@ 2001-07-06 Iain Holmes <iain@ximian.com> + * e-summary-preferences.c (str_list_from_vector): Change the delimiter + (vector_from_str_list): Change the delimiter. + (fill_mail_all_clist): Fill the mail folder clist. + (fill_mail_shown_clist): Use nicer names. + (mail_add_clicked_cb): Add folders to the shown list. + + * e-summary-mail.c (e_summary_mail_fill_list): Flatten the hashtable + into the CList. + (e_summary_mail_uri_to_name): Get the pretty name for a uri. + +2001-07-06 Iain Holmes <iain@ximian.com> + * e-summary-preferences.c (fill_rdf_shown_list): Attach data (rdf_add_clicked_cb): Allow multiple rows to be removed. (rdf_remove_clicked_cb): Use the data. diff --git a/my-evolution/e-summary-mail.c b/my-evolution/e-summary-mail.c index 4ce4fd90c9..bf00686f1e 100644 --- a/my-evolution/e-summary-mail.c +++ b/my-evolution/e-summary-mail.c @@ -356,3 +356,87 @@ e_summary_mail_reconfigure (ESummary *summary) e_summary_draw (summary); } + +static void +free_row_data (gpointer data) +{ + ESummaryMailRowData *rd = data; + + g_free (rd->name); + g_free (rd->uri); + g_free (rd); +} + +static void +hash_to_list (gpointer key, + gpointer value, + gpointer data) +{ + ESummaryMailRowData *rd; + ESummaryMailFolder *folder; + GList **p; + + p = (GList **) data; + folder = (ESummaryMailFolder *) value; + + rd = g_new (ESummaryMailRowData, 1); + rd->name = g_strdup (folder->name); + rd->uri = g_strdup (key); + + *p = g_list_prepend (*p, rd); +} + +static int +str_compare (gconstpointer a, + gconstpointer b) +{ + ESummaryMailRowData *rda, *rdb; + + rda = a; + rdb = b; + return strcmp (rda->name, rdb->name); +} + +void +e_summary_mail_fill_list (GtkCList *clist, + ESummary *summary) +{ + ESummaryMail *mail; + GList *names = NULL, *p; + + mail = summary->mail; + if (mail == NULL) { + return; + } + + g_hash_table_foreach (mail->folders, hash_to_list, &names); + + names = g_list_sort (names, str_compare); + for (p = names; p; p = p->next) { + ESummaryMailRowData *rd; + char *text[1]; + int row; + + rd = p->data; + text[0] = rd->name + 1; + row = gtk_clist_append (clist, text); + gtk_clist_set_row_data_full (clist, row, rd, free_row_data); + } + + g_list_free (names); +} + +const char * +e_summary_mail_uri_to_name (ESummary *summary, + const char *uri) +{ + ESummaryMailFolder *folder; + + folder = g_hash_table_lookup (summary->mail->folders, uri); + if (folder == NULL) { + return NULL; + } else { + return folder->name; + } +} + diff --git a/my-evolution/e-summary-mail.h b/my-evolution/e-summary-mail.h index 67090b4271..09a79ec1f3 100644 --- a/my-evolution/e-summary-mail.h +++ b/my-evolution/e-summary-mail.h @@ -17,9 +17,15 @@ enum _ESummaryMailMode { E_SUMMARY_MAIL_MODE_ONLY, E_SUMMARY_MAIL_MODE_EXCLUDING }; - + +typedef struct _ESummaryMailRowData ESummaryMailRowData; typedef struct _ESummaryMail ESummaryMail; +struct _ESummaryMailRowData { + char *name; + char *uri; +}; + const char *e_summary_mail_get_html (ESummary *summary); void e_summary_mail_init (ESummary *summary, GNOME_Evolution_Shell corba_shell); diff --git a/my-evolution/e-summary-preferences.c b/my-evolution/e-summary-preferences.c index 0b66b231de..1e8c899150 100644 --- a/my-evolution/e-summary-preferences.c +++ b/my-evolution/e-summary-preferences.c @@ -79,7 +79,7 @@ vector_from_str_list (GList *strlist) /* No space at end */ if (strlist->next) { - g_string_append (str, " "); + g_string_append (str, " !<-->! "); } } @@ -95,7 +95,7 @@ str_list_from_vector (const char *vector) GList *strlist = NULL; char **tokens, **t; - t = tokens = g_strsplit (vector, " ", 8196); + t = tokens = g_strsplit (vector, " !<-->! ", 8196); if (tokens == NULL) { return NULL; @@ -600,6 +600,13 @@ fill_weather_shown_clist (GtkCList *clist, } static void +fill_mail_all_clist (GtkCList *clist, + PropertyData *pd) +{ + e_summary_mail_fill_list (clist, pd->summary); +} + +static void fill_mail_shown_clist (GtkCList *clist, PropertyData *pd) { @@ -607,9 +614,41 @@ fill_mail_shown_clist (GtkCList *clist, for (p = pd->summary->preferences->display_folders; p; p = p->next) { char *text[1]; + char *name, *uri; + int row; - text[0] = p->data; - gtk_clist_append (clist, text); + uri = g_strconcat ("file://", p->data, NULL); + name = e_summary_mail_uri_to_name (pd->summary, uri); + g_free (uri); + if (name == NULL) { + text[0] = p->data; + } else { + text[0] = name + 1; + } + row = gtk_clist_append (clist, text); + gtk_clist_set_row_data (clist, row, p); + } +} + +static void +mail_all_select_row_cb (GtkCList *clist, + int row, + int column, + GdkEvent *event, + PropertyData *pd) +{ + gtk_widget_set_sensitive (pd->mail->add, TRUE); +} + +static void +mail_all_unselect_row_cb (GtkCList *clist, + int row, + int column, + GdkEvent *event, + PropertyData *pd) +{ + if (clist->selection == NULL) { + gtk_widget_set_sensitive (pd->mail->add, FALSE); } } @@ -639,7 +678,20 @@ static void mail_add_clicked_cb (GtkButton *button, PropertyData *pd) { + int row; + ESummaryMailRowData *rd; + char *text[1]; + char *uri; + row = GPOINTER_TO_INT (GTK_CLIST (pd->mail->all)->selection->data); + rd = gtk_clist_get_row_data (GTK_CLIST (pd->mail->all), row); + g_return_if_fail (rd != NULL); + + text[0] = rd->name + 1; + row = gtk_clist_append (GTK_CLIST (pd->mail->shown), text); + pd->summary->preferences->display_folders = g_list_prepend (pd->summary->preferences->display_folders, + g_strdup (rd->uri + 7)); + gtk_clist_set_row_data (GTK_CLIST (pd->mail->shown), row, pd->summary->preferences->display_folders); } static void @@ -650,7 +702,7 @@ mail_remove_clicked_cb (GtkButton *button, GList *p; row = GPOINTER_TO_INT (GTK_CLIST (pd->mail->shown)->selection->data); - p = g_list_nth (pd->summary->preferences->display_folders, row); + p = gtk_clist_get_row_data (GTK_CLIST (pd->mail->shown), row); gtk_clist_remove (GTK_CLIST (pd->mail->shown), row); pd->summary->preferences->display_folders = g_list_remove_link (pd->summary->preferences->display_folders, p); @@ -728,7 +780,7 @@ rdf_add_clicked_cb (GtkButton *button, GList *p, *rows; char *text[1]; int row; - + for (rows = GTK_CLIST (pd->rdf->all)->selection; rows; rows = rows->next) { row = GPOINTER_TO_INT (rows->data); info = gtk_clist_get_row_data (GTK_CLIST (pd->rdf->all), row); @@ -1063,8 +1115,13 @@ make_property_dialog (PropertyData *pd) mail = pd->mail = g_new (struct _MailPage, 1); /* I think this should be a fancy bonobo thingy */ - mail->all = glade_xml_get_widget (pd->xml, "clist2"); + mail->all = glade_xml_get_widget (pd->xml, "clist7"); g_return_val_if_fail (mail->all != NULL, FALSE); + fill_mail_all_clist (GTK_CLIST (mail->all), pd); + gtk_signal_connect (GTK_OBJECT (mail->all), "select-row", + GTK_SIGNAL_FUNC (mail_all_select_row_cb), pd); + gtk_signal_connect (GTK_OBJECT (mail->all), "unselect-row", + GTK_SIGNAL_FUNC (mail_all_unselect_row_cb), pd); mail->shown = glade_xml_get_widget (pd->xml, "clist1"); g_return_val_if_fail (mail->shown != NULL, FALSE); diff --git a/my-evolution/my-evolution.glade b/my-evolution/my-evolution.glade index cf2b8416bc..b3d07300cc 100644 --- a/my-evolution/my-evolution.glade +++ b/my-evolution/my-evolution.glade @@ -273,19 +273,19 @@ <widget> <class>GtkCList</class> - <name>clist2</name> + <name>clist7</name> <can_focus>True</can_focus> <columns>1</columns> <column_widths>80</column_widths> - <selection_mode>GTK_SELECTION_EXTENDED</selection_mode> + <selection_mode>GTK_SELECTION_SINGLE</selection_mode> <show_titles>False</show_titles> <shadow_type>GTK_SHADOW_IN</shadow_type> <widget> <class>GtkLabel</class> <child_name>CList:title</child_name> - <name>label13</name> - <label>label26</label> + <name>label40</name> + <label>label40</label> <justify>GTK_JUSTIFY_CENTER</justify> <wrap>False</wrap> <xalign>0.5</xalign> |