toolbar reply refactoring: part 1
[claws.git] / src / summaryview.h
index 76c1680a7bf3a812f7dd24347f4977c897723e36..d2c28801422fa35c403aebe9f3b39fc57e7d8ce5 100644 (file)
@@ -20,6 +20,8 @@
 #ifndef __SUMMARY_H__
 #define __SUMMARY_H__
 
+#include <regex.h>
+
 #include <glib.h>
 #include <gdk/gdk.h>
 #include <gtk/gtkwidget.h>
@@ -35,14 +37,14 @@ typedef struct _SummaryColumnState  SummaryColumnState;
 #include "headerview.h"
 #include "messageview.h"
 #include "compose.h"
-#include "prefs_filter.h"
 #include "folder.h"
 #include "gtksctree.h"
+#include "prefs_filtering.h"
 
 typedef enum
 {
        S_COL_MARK,
-       S_COL_UNREAD,
+       S_COL_STATUS,
        S_COL_MIME,
        S_COL_SUBJECT,
        S_COL_FROM,
@@ -69,6 +71,14 @@ typedef enum
        TARGET_DUMMY
 } TargetInfo;
 
+typedef enum
+{
+       S_SEARCH_SUBJECT,
+       S_SEARCH_FROM,
+       S_SEARCH_TO,
+       S_SEARCH_EXTENDED
+} SummarySearchType;
+
 extern GtkTargetEntry summary_drag_types[1];
 
 struct _SummaryColumnState
@@ -84,14 +94,21 @@ struct _SummaryView
        GtkWidget *ctree;
        GtkWidget *hbox;
        GtkWidget *hbox_l;
+       GtkWidget *hbox_search;
        GtkWidget *folder_pixmap;
        GtkWidget *statlabel_folder;
        GtkWidget *statlabel_select;
        GtkWidget *statlabel_msgs;
        GtkWidget *toggle_eventbox;
        GtkWidget *toggle_arrow;
+       GtkWidget *toggle_search;
+       GtkWidget *quick_search_pixmap;
        GtkWidget *popupmenu;
        GtkWidget *colorlabel_menu;
+       GtkWidget *search_type_opt;
+       GtkWidget *search_type;
+       GtkWidget *search_string;
+       GtkWidget *search_description;
 
        GtkItemFactory *popupfactory;
 
@@ -118,12 +135,20 @@ struct _SummaryView
 
        FolderItem *folder_item;
 
-       GSList * killed_messages;
+       /* summaryview prefs */
        gint important_score;
+       FolderSortKey sort_key;
+       FolderSortType sort_type;
+       guint threaded;
+       guint thread_collapsed;
+
+       /* Extra data for summaryview */
+       regex_t *simplify_subject_preg;
 
        /* current message status */
        gint   newmsgs;
        gint   unread;
+       gint   unreadmarked;
        gint   messages;
        off_t  total_size;
        gint   deleted;
@@ -139,16 +164,14 @@ private:
 
        /* list for moving/deleting messages */
        GSList *mlist;
-       /* table for updating folder tree */
-       GHashTable *folder_table;
+       int msginfo_update_callback_id;
 };
 
 SummaryView    *summary_create(void);
 
 void summary_init                (SummaryView          *summaryview);
 gboolean summary_show            (SummaryView          *summaryview,
-                                  FolderItem           *fitem,
-                                  gboolean              update_cache);
+                                  FolderItem           *fitem);
 void summary_clear_list                  (SummaryView          *summaryview);
 void summary_clear_all           (SummaryView          *summaryview);
 
@@ -160,6 +183,8 @@ SummarySelection summary_get_selection_type (SummaryView    *summaryview);
 
 void summary_select_prev_unread          (SummaryView          *summaryview);
 void summary_select_next_unread          (SummaryView          *summaryview);
+void summary_select_prev_new     (SummaryView          *summaryview);
+void summary_select_next_new     (SummaryView          *summaryview);
 void summary_select_prev_marked          (SummaryView          *summaryview);
 void summary_select_next_marked          (SummaryView          *summaryview);
 void summary_select_prev_labeled  (SummaryView         *summaryview);
@@ -189,6 +214,8 @@ void summary_sort             (SummaryView          *summaryview,
 void summary_delete              (SummaryView          *summaryview);
 void summary_delete_duplicated   (SummaryView          *summaryview);
 
+void summary_cancel               (SummaryView          *summaryview);
+
 gboolean summary_execute         (SummaryView          *summaryview);
 
 void summary_attract_by_subject          (SummaryView          *summaryview);
@@ -214,6 +241,7 @@ void summary_move_selected_to         (SummaryView          *summaryview,
 void summary_move_to             (SummaryView          *summaryview);
 void summary_copy_selected_to    (SummaryView          *summaryview,
                                   FolderItem           *to_folder);
+GSList *summary_get_selection    (SummaryView          *summaryview);
 void summary_copy_to             (SummaryView          *summaryview);
 void summary_save_as             (SummaryView          *summaryview);
 void summary_print               (SummaryView          *summaryview);
@@ -226,8 +254,6 @@ void summary_add_address      (SummaryView          *summaryview);
 void summary_select_all                  (SummaryView          *summaryview);
 void summary_unselect_all        (SummaryView          *summaryview);
 void summary_select_thread       (SummaryView          *summaryview);
-void summary_reply               (SummaryView          *summaryview,
-                                  ComposeMode           mode);
 
 void summary_set_colorlabel      (SummaryView          *summaryview,
                                   guint                 labelcolor,
@@ -238,14 +264,22 @@ void summary_set_colorlabel_color (GtkCTree               *ctree,
 
 void summary_set_column_order    (SummaryView          *summaryview);
 
+#if 0 /* OLD PROCESSING */
 void processing_apply();
+#endif
 
-void summary_toggle_show_read_messages (SummaryView *summaryview);
+void summary_toggle_show_read_messages
+                                 (SummaryView *summaryview);
 
-void summary_toggle_view_real  (SummaryView    *summaryview);
+void summary_toggle_view_real    (SummaryView  *summaryview);
 
-void summary_reflect_prefs_pixmap_theme(SummaryView *summaryview);
+void summary_reflect_prefs_pixmap_theme
+                                  (SummaryView *summaryview);
 
-void summary_harvest_address   ( SummaryView *summaryview );
+void summary_harvest_address      (SummaryView *summaryview);
+void summary_set_prefs_from_folderitem
+                                  (SummaryView *summaryview, FolderItem *item);
+void summary_save_prefs_to_folderitem
+                                  (SummaryView *summaryview, FolderItem *item);
 
 #endif /* __SUMMARY_H__ */