diff options
Diffstat (limited to 'composer/e-msg-composer.c')
-rw-r--r-- | composer/e-msg-composer.c | 111 |
1 files changed, 82 insertions, 29 deletions
diff --git a/composer/e-msg-composer.c b/composer/e-msg-composer.c index 4cce2eecb7..9ec314cb7a 100644 --- a/composer/e-msg-composer.c +++ b/composer/e-msg-composer.c @@ -81,6 +81,7 @@ #include "e-util/e-dialog-utils.h" #include "widgets/misc/e-charset-picker.h" +#include "widgets/misc/e-expander.h" #include <camel/camel-session.h> #include <camel/camel-charset-map.h> @@ -104,6 +105,8 @@ #include "evolution-shell-component-utils.h" +#include "art/attachment.xpm" + #include "Editor.h" #include "listener.h" @@ -1109,20 +1112,7 @@ static void show_attachments (EMsgComposer *composer, gboolean show) { - if (show) { - gtk_widget_show (composer->attachment_scrolled_window); - gtk_widget_show (composer->attachment_bar); - } else { - gtk_widget_hide (composer->attachment_scrolled_window); - gtk_widget_hide (composer->attachment_bar); - } - - composer->attachment_bar_visible = show; - - /* Update the GUI. */ - bonobo_ui_component_set_prop ( - composer->uic, "/commands/ViewAttach", - "state", show ? "1" : "0", NULL); + e_expander_set_expanded (E_EXPANDER (composer->attachment_expander), show); } static void @@ -2204,15 +2194,25 @@ static void attachment_bar_changed_cb (EMsgComposerAttachmentBar *bar, void *data) { - EMsgComposer *composer; - gboolean show = FALSE; - - composer = E_MSG_COMPOSER (data); - - if (e_msg_composer_attachment_bar_get_num_attachments (bar) > 0) - show = TRUE; + EMsgComposer *composer = E_MSG_COMPOSER (data); + + guint attachment_num = e_msg_composer_attachment_bar_get_num_attachments ( + E_MSG_COMPOSER_ATTACHMENT_BAR (composer->attachment_bar)); + if (attachment_num) { + gchar *num_text = g_strdup_printf ( + ngettext ("<b>%d</b> File Attached", "<b>%d</b> Files Attached", attachment_num), + attachment_num); + gtk_label_set_markup (GTK_LABEL (composer->attachment_expander_num), + num_text); + g_free (num_text); + + gtk_widget_show (composer->attachment_expander_icon); + + } else { + gtk_label_set_text (GTK_LABEL (composer->attachment_expander_num), ""); + gtk_widget_hide (composer->attachment_expander_icon); + } - e_msg_composer_show_attachments (composer, show); /* Mark the composer as changed so it prompts about unsaved changes on close */ @@ -2220,6 +2220,27 @@ attachment_bar_changed_cb (EMsgComposerAttachmentBar *bar, } static void +attachment_expander_activate_cb (EExpander *expander, + void *data) +{ + EMsgComposer *composer = E_MSG_COMPOSER (data); + gboolean show = e_expander_get_expanded (expander); + + /* Update the expander label */ + if (show) + gtk_label_set_text_with_mnemonic (GTK_LABEL (composer->attachment_expander_label), + _("Hide _Attachment Bar (drop attachments here)")); + else + gtk_label_set_text_with_mnemonic (GTK_LABEL (composer->attachment_expander_label), + _("Show _Attachment Bar (drop attachments here)")); + + /* Update the GUI. */ + bonobo_ui_component_set_prop ( + composer->uic, "/commands/ViewAttach", + "state", show ? "1" : "0", NULL); +} + +static void subject_changed_cb (EMsgComposerHdrs *hdrs, gchar *subject, void *data) @@ -2919,12 +2940,13 @@ static EMsgComposer * create_composer (int visible_mask) { EMsgComposer *composer; - GtkWidget *vbox; + GtkWidget *vbox, *expander_hbox; Bonobo_Unknown editor_server; CORBA_Environment ev; GConfClient *gconf; int vis; BonoboControlFrame *control_frame; + GdkPixbuf *attachment_pixbuf; composer = g_object_new (E_TYPE_MSG_COMPOSER, "win_name", _("Compose a message"), NULL); gtk_window_set_title ((GtkWindow *) composer, _("Compose a message")); @@ -3024,8 +3046,8 @@ create_composer (int visible_mask) gtk_box_pack_start (GTK_BOX (vbox), composer->editor, TRUE, TRUE, 0); - /* Attachment editor, wrapped into an EScrollFrame. We don't - show it for now. */ + /* Attachment editor, wrapped into an EScrollFrame. It's + hidden in an EExpander. */ composer->attachment_scrolled_window = gtk_scrolled_window_new (NULL, NULL); gtk_scrolled_window_set_shadow_type (GTK_SCROLLED_WINDOW (composer->attachment_scrolled_window), @@ -3037,12 +3059,43 @@ create_composer (int visible_mask) GTK_WIDGET_SET_FLAGS (composer->attachment_bar, GTK_CAN_FOCUS); gtk_container_add (GTK_CONTAINER (composer->attachment_scrolled_window), composer->attachment_bar); - gtk_box_pack_start (GTK_BOX (vbox), - composer->attachment_scrolled_window, - FALSE, FALSE, GNOME_PAD_SMALL); - + gtk_widget_show (composer->attachment_bar); g_signal_connect (composer->attachment_bar, "changed", G_CALLBACK (attachment_bar_changed_cb), composer); + + composer->attachment_expander_label = + gtk_label_new_with_mnemonic (_("Show _Attachment Bar (drop attachments here)")); + composer->attachment_expander_num = gtk_label_new (""); + gtk_label_set_use_markup (GTK_LABEL (composer->attachment_expander_num), TRUE); + gtk_misc_set_alignment (GTK_MISC (composer->attachment_expander_label), 0.0, 0.5); + gtk_misc_set_alignment (GTK_MISC (composer->attachment_expander_num), 1.0, 0.5); + expander_hbox = gtk_hbox_new (FALSE, 0); + + attachment_pixbuf = gdk_pixbuf_new_from_xpm_data (attachment_xpm); + composer->attachment_expander_icon = gtk_image_new_from_pixbuf (attachment_pixbuf); + gtk_misc_set_alignment (GTK_MISC (composer->attachment_expander_icon), 1, 0.5); + gtk_widget_set_size_request (composer->attachment_expander_icon, 100, -1); + gdk_pixbuf_unref (attachment_pixbuf); + + gtk_box_pack_start (GTK_BOX (expander_hbox), composer->attachment_expander_label, + TRUE, TRUE, 0); + gtk_box_pack_start (GTK_BOX (expander_hbox), composer->attachment_expander_icon, + TRUE, TRUE, 0); + gtk_box_pack_start (GTK_BOX (expander_hbox), composer->attachment_expander_num, + TRUE, TRUE, 0); + gtk_widget_show_all (expander_hbox); + gtk_widget_hide (composer->attachment_expander_icon); + + composer->attachment_expander = e_expander_new (""); + e_expander_set_label_widget (E_EXPANDER (composer->attachment_expander), expander_hbox); + + gtk_container_add (GTK_CONTAINER (composer->attachment_expander), + composer->attachment_scrolled_window); + gtk_box_pack_start (GTK_BOX (vbox), composer->attachment_expander, + FALSE, FALSE, GNOME_PAD_SMALL); + gtk_widget_show (composer->attachment_expander); + g_signal_connect_after (composer->attachment_expander, "activate", + G_CALLBACK (attachment_expander_activate_cb), composer); bonobo_window_set_contents (BONOBO_WINDOW (composer), vbox); gtk_widget_show (vbox); |