return dimmed;
}
+static gboolean
+_message_already_sent (ModestMsgViewWindow *view_window)
+{
+ TnyHeader *header;
+ TnyFolder *folder;
+ gboolean already_sent = FALSE;
+
+ header = modest_msg_view_window_get_header (view_window);
+ if (header) {
+ folder = tny_header_get_folder (header);
+ if (folder) {
+ if (modest_tny_folder_guess_folder_type (folder) ==
+ TNY_FOLDER_TYPE_OUTBOX) {
+ ModestTnySendQueueStatus status =
+ modest_tny_all_send_queues_get_msg_status (header);
+ if (status == MODEST_TNY_SEND_QUEUE_UNKNOWN ||
+ status == MODEST_TNY_SEND_QUEUE_SENDING)
+ already_sent = TRUE;
+ }
+ g_object_unref (folder);
+ }
+ g_object_unref (header);
+ }
+ return already_sent;
+}
+
+
gboolean
modest_ui_dimming_rules_on_delete_msg (ModestWindow *win, gpointer user_data)
{
/* This could happen if we're viewing a message of the
outbox that has been already sent */
- if (!dimmed) {
- ModestMsgViewWindow *view_window = MODEST_MSG_VIEW_WINDOW (win);
- if (modest_msg_view_window_last_message_selected (view_window) &&
- modest_msg_view_window_first_message_selected (view_window))
- dimmed = TRUE;
- }
+ if (!dimmed)
+ dimmed = _message_already_sent (MODEST_MSG_VIEW_WINDOW(win));
/* The delete button should be dimmed when viewing an attachment,
* but should be enabled when viewing a message from the list,
modest_dimming_rule_set_notification (rule, "");
}
+ } else {
+ return TRUE;
}
-
}
/* msg view window dimming rules */
/* This could happen if we're viewing a message of the outbox
that has been already sent */
- if (!dimmed) {
- ModestMsgViewWindow *view_window = MODEST_MSG_VIEW_WINDOW (win);
- if (modest_msg_view_window_last_message_selected (view_window) &&
- modest_msg_view_window_first_message_selected (view_window))
- dimmed = TRUE;
- }
+ if (!dimmed)
+ dimmed = _message_already_sent (MODEST_MSG_VIEW_WINDOW(win));
if (!dimmed) {
if (MODEST_IS_MSG_VIEW_WINDOW (win)) {
int len = -1;
sel = gtk_html_get_selection_html (GTK_HTML (focused), &len);
do_check = !((sel == NULL) || (sel[0] == '\0'));
+ } else if (MODEST_IS_ATTACHMENTS_VIEW (focused)) {
+ do_check = FALSE;
}
if (do_check) {
clipboard = gtk_clipboard_get (GDK_SELECTION_PRIMARY);