diff options
Diffstat (limited to 'mail/e-mail-paned-view.c')
-rw-r--r-- | mail/e-mail-paned-view.c | 647 |
1 files changed, 331 insertions, 316 deletions
diff --git a/mail/e-mail-paned-view.c b/mail/e-mail-paned-view.c index 6733e40182..cf13ac5514 100644 --- a/mail/e-mail-paned-view.c +++ b/mail/e-mail-paned-view.c @@ -10,7 +10,7 @@ * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public - * License along with the program; if not, see <http://www.gnu.org/licenses/> + * License along with the program; if not, see <http://www.gnu.org/licenses/> * * * Authors: @@ -24,7 +24,6 @@ # include <config.h> #endif - #include <glib.h> #include <glib/gi18n.h> #include "e-mail-paned-view.h" @@ -48,6 +47,10 @@ #include "message-list.h" #include "e-mail-reader-utils.h" +#define E_MAIL_PANED_VIEW_GET_PRIVATE(obj) \ + (G_TYPE_INSTANCE_GET_PRIVATE \ + ((obj), E_TYPE_MAIL_PANED_VIEW, EMailPanedViewPrivate)) + #define E_SHELL_WINDOW_ACTION_GROUP_MAIL(window) \ E_SHELL_WINDOW_ACTION_GROUP ((window), "mail") @@ -86,14 +89,13 @@ enum { #define STATE_KEY_SELECTED_MESSAGE "SelectedMessage" #define STATE_KEY_PREVIEW_VISIBLE "PreviewVisible" - static EMailViewClass *parent_class; static GType mail_paned_view_type; static void mail_paned_view_save_boolean (EMailPanedView *view, - const gchar *key, - gboolean value) + const gchar *key, + gboolean value) { EShellView *shell_view; EShellContent *shell_content; @@ -121,7 +123,7 @@ mail_paned_view_save_boolean (EMailPanedView *view, static void mail_paned_view_message_list_built_cb (EMailPanedView *view, - MessageList *message_list) + MessageList *message_list) { EMailPanedViewPrivate *priv = view->priv; EShellView *shell_view; @@ -169,8 +171,8 @@ mail_paned_view_message_list_built_cb (EMailPanedView *view, static void mail_paned_view_message_selected_cb (EMailPanedView *view, - const gchar *message_uid, - MessageList *message_list) + const gchar *message_uid, + MessageList *message_list) { EShellContent *shell_content; EShellView *shell_view; @@ -206,8 +208,8 @@ mail_paned_view_message_selected_cb (EMailPanedView *view, static void mail_paned_view_restore_state_cb (EShellWindow *shell_window, - EShellView *shell_view, - EMailPanedView *view) + EShellView *shell_view, + EMailPanedView *view) { EMailPanedViewPrivate *priv; GConfBridge *bridge; @@ -230,6 +232,22 @@ mail_paned_view_restore_state_cb (EShellWindow *shell_window, } static void +mail_paned_display_view_cb (EMailView *view, + GalView *gal_view) +{ + EMailReader *reader; + GtkWidget *message_list; + + reader = E_MAIL_READER (view); + message_list = e_mail_reader_get_message_list (reader); + + if (GAL_IS_VIEW_ETABLE (gal_view)) + gal_view_etable_attach_tree ( + GAL_VIEW_ETABLE (gal_view), + E_TREE (message_list)); +} + +static void mail_paned_view_notify_group_by_threads_cb (EMailReader *reader) { gboolean group_by_threads; @@ -241,28 +259,11 @@ mail_paned_view_notify_group_by_threads_cb (EMailReader *reader) STATE_KEY_GROUP_BY_THREADS, group_by_threads); } -GtkOrientation -e_mail_paned_view_get_orientation (EMailPanedView *view) -{ - return view->priv->orientation; -} - -void -e_mail_paned_view_set_orientation (EMailPanedView *view, - GtkOrientation orientation) -{ - view->priv->orientation = orientation; - - g_object_notify (G_OBJECT (view), "orientation"); - - e_mail_paned_view_update_view_instance (view); -} - static void mail_paned_view_set_property (GObject *object, - guint property_id, - const GValue *value, - GParamSpec *pspec) + guint property_id, + const GValue *value, + GParamSpec *pspec) { switch (property_id) { case PROP_GROUP_BY_THREADS: @@ -272,20 +273,20 @@ mail_paned_view_set_property (GObject *object, return; case PROP_ORIENTATION: - e_mail_paned_view_set_orientation ( - E_MAIL_PANED_VIEW (object), + e_mail_view_set_orientation ( + E_MAIL_VIEW (object), g_value_get_enum (value)); return; case PROP_PREVIEW_VISIBLE: - e_mail_paned_view_set_preview_visible ( - E_MAIL_PANED_VIEW (object), + e_mail_view_set_preview_visible ( + E_MAIL_VIEW (object), g_value_get_boolean (value)); return; case PROP_SHOW_DELETED: - e_mail_paned_view_set_show_deleted ( - E_MAIL_PANED_VIEW (object), + e_mail_view_set_show_deleted ( + E_MAIL_VIEW (object), g_value_get_boolean (value)); return; } @@ -295,9 +296,9 @@ mail_paned_view_set_property (GObject *object, static void mail_paned_view_get_property (GObject *object, - guint property_id, - GValue *value, - GParamSpec *pspec) + guint property_id, + GValue *value, + GParamSpec *pspec) { switch (property_id) { case PROP_GROUP_BY_THREADS: @@ -310,22 +311,22 @@ mail_paned_view_get_property (GObject *object, case PROP_ORIENTATION: g_value_set_enum ( value, - e_mail_paned_view_get_orientation ( - E_MAIL_PANED_VIEW (object))); + e_mail_view_get_orientation ( + E_MAIL_VIEW (object))); return; case PROP_PREVIEW_VISIBLE: g_value_set_boolean ( value, - e_mail_paned_view_get_preview_visible ( - E_MAIL_PANED_VIEW (object))); + e_mail_view_get_preview_visible ( + E_MAIL_VIEW (object))); return; case PROP_SHOW_DELETED: g_value_set_boolean ( value, - e_mail_paned_view_get_show_deleted ( - E_MAIL_PANED_VIEW (object))); + e_mail_view_get_show_deleted ( + E_MAIL_VIEW (object))); return; } @@ -337,7 +338,7 @@ mail_paned_view_dispose (GObject *object) { EMailPanedViewPrivate *priv; - priv = E_MAIL_PANED_VIEW(object)->priv; + priv = E_MAIL_PANED_VIEW (object)->priv; if (priv->paned != NULL) { g_object_unref (priv->paned); @@ -400,7 +401,7 @@ mail_paned_view_get_formatter (EMailReader *reader) static gboolean mail_paned_view_get_hide_deleted (EMailReader *reader) { - return !e_mail_paned_view_get_show_deleted (E_MAIL_PANED_VIEW(reader)); + return !e_mail_view_get_show_deleted (E_MAIL_VIEW (reader)); } static GtkWidget * @@ -539,8 +540,7 @@ mail_paned_view_set_folder (EMailReader *reader, value = FALSE; } - e_mail_paned_view_set_preview_visible ( - E_MAIL_PANED_VIEW (reader), value); + e_mail_view_set_preview_visible (E_MAIL_VIEW (reader), value); g_free (group_name); @@ -558,14 +558,14 @@ mail_paned_view_show_search_bar (EMailReader *reader) gtk_widget_show (priv->search_bar); } -static void -mail_paned_view_open_selected_mail (EMailReader *reader) +static guint +mail_paned_view_reader_open_selected_mail (EMailReader *reader) { EMailPanedViewPrivate *priv; priv = E_MAIL_PANED_VIEW (reader)->priv; - E_MAIL_PANED_VIEW_CLASS(G_OBJECT_GET_CLASS (reader))->open_selected_mail (E_MAIL_PANED_VIEW(reader)); + return E_MAIL_PANED_VIEW_CLASS (G_OBJECT_GET_CLASS (reader))->open_selected_mail (E_MAIL_PANED_VIEW (reader)); } static void @@ -586,10 +586,6 @@ mail_paned_view_constructed (GObject *object) priv = E_MAIL_PANED_VIEW (object)->priv; priv->formatter = em_format_html_display_new (); - /* Chain up to parent's constructed() method. */ - if (G_OBJECT_CLASS (parent_class)->constructed) - G_OBJECT_CLASS (parent_class)->constructed (object); - shell_content = E_MAIL_VIEW (object)->content; shell_view = e_shell_content_get_shell_view (shell_content); shell_window = e_shell_view_get_shell_window (shell_view); @@ -648,12 +644,11 @@ mail_paned_view_constructed (GObject *object) /* Load the view instance. */ - e_mail_paned_view_update_view_instance ( - E_MAIL_PANED_VIEW (object)); + e_mail_view_update_view_instance (E_MAIL_VIEW (object)); /* Message list customizations. */ - e_mail_reader_init_private (E_MAIL_READER(object)); + e_mail_reader_init_private (E_MAIL_READER (object)); reader = E_MAIL_READER (object); message_list = e_mail_reader_get_message_list (reader); @@ -673,253 +668,31 @@ mail_paned_view_constructed (GObject *object) e_mail_reader_connect_headers (reader); } -static void -mpv_open_selected_mail (EMailPanedView *view) -{ - e_mail_reader_open_selected (E_MAIL_READER(view)); -} - -static void -mail_paned_view_init (EMailPanedView *shell) -{ - shell->priv = g_new0(EMailPanedViewPrivate, 1); - - shell->priv->preview_visible = TRUE; - - g_signal_connect ( - shell, "notify::group-by-threads", - G_CALLBACK (mail_paned_view_notify_group_by_threads_cb), - NULL); - -} - -static void -mail_paned_view_class_init (EMailViewClass *klass) -{ - GObjectClass * object_class = G_OBJECT_CLASS (klass); - - parent_class = g_type_class_peek_parent (klass); - object_class->dispose = mail_paned_view_dispose; - object_class->constructed = mail_paned_view_constructed; - object_class->set_property = mail_paned_view_set_property; - object_class->get_property = mail_paned_view_get_property; - - klass->get_searchbar = e_mail_paned_view_get_searchbar; - klass->set_search_strings = e_mail_paned_view_set_search_strings; - klass->get_view_instance = e_mail_paned_view_get_view_instance; - klass->update_view_instance = e_mail_paned_view_update_view_instance; - - klass->set_orientation = e_mail_paned_view_set_orientation; - klass->get_orientation = e_mail_paned_view_get_orientation; - klass->set_show_deleted = e_mail_paned_view_set_show_deleted; - klass->get_show_deleted = e_mail_paned_view_get_show_deleted; - klass->set_preview_visible = e_mail_paned_view_set_preview_visible; - klass->get_preview_visible = e_mail_paned_view_get_preview_visible; - - E_MAIL_PANED_VIEW_CLASS(klass)->open_selected_mail = mpv_open_selected_mail; - - /* Inherited from EMailReader */ - g_object_class_override_property ( - object_class, - PROP_GROUP_BY_THREADS, - "group-by-threads"); - - g_object_class_install_property ( - object_class, - PROP_PREVIEW_VISIBLE, - g_param_spec_boolean ( - "preview-visible", - "Preview is Visible", - "Whether the preview pane is visible", - TRUE, - G_PARAM_READWRITE)); - - g_object_class_install_property ( - object_class, - PROP_SHOW_DELETED, - g_param_spec_boolean ( - "show-deleted", - "Show Deleted", - NULL, - FALSE, - G_PARAM_READWRITE)); - - g_object_class_override_property ( - object_class, PROP_ORIENTATION, "orientation"); -} - -static void -mail_paned_view_reader_init (EMailReaderIface *iface) -{ - iface->get_action_group = mail_paned_view_get_action_group; - iface->get_formatter = mail_paned_view_get_formatter; - iface->get_hide_deleted = mail_paned_view_get_hide_deleted; - iface->get_message_list = mail_paned_view_get_message_list; - iface->get_popup_menu = mail_paned_view_get_popup_menu; - iface->get_shell_backend = mail_paned_view_get_shell_backend; - iface->get_window = mail_paned_view_get_window; - iface->set_folder = mail_paned_view_set_folder; - iface->show_search_bar = mail_paned_view_show_search_bar; - iface->open_selected_mail = mail_paned_view_open_selected_mail; -} - -GType -e_mail_paned_view_get_type (void) -{ - return mail_paned_view_type; -} - -void -e_mail_paned_view_register_type (GTypeModule *type_module) -{ - static const GTypeInfo type_info = { - sizeof (EMailPanedViewClass), - (GBaseInitFunc) NULL, - (GBaseFinalizeFunc) NULL, - (GClassInitFunc) mail_paned_view_class_init, - (GClassFinalizeFunc) NULL, - NULL, /* class_data */ - sizeof (EMailPanedView), - 0, /* n_preallocs */ - (GInstanceInitFunc) mail_paned_view_init, - NULL /* value_table */ - }; -#if 0 - static const GInterfaceInfo orientable_info = { - (GInterfaceInitFunc) NULL, - (GInterfaceFinalizeFunc) NULL, - NULL /* interface_data */ - }; -#endif - static const GInterfaceInfo reader_info = { - (GInterfaceInitFunc) mail_paned_view_reader_init, - (GInterfaceFinalizeFunc) NULL, - NULL /* interface_data */ - }; - - mail_paned_view_type = g_type_module_register_type ( - type_module, E_MAIL_VIEW_TYPE, - "EMailPanedView", &type_info, 0); -#if 0 - g_type_module_add_interface ( - type_module, mail_paned_view_type, - GTK_TYPE_ORIENTABLE, &orientable_info); -#endif - g_type_module_add_interface ( - type_module, mail_paned_view_type, - E_TYPE_MAIL_READER, &reader_info); -} - - -GtkWidget * -e_mail_paned_view_new (EShellContent *content) -{ - g_return_val_if_fail (E_IS_SHELL_CONTENT (content), NULL); - - return g_object_new ( - E_MAIL_PANED_VIEW_TYPE, - "shell-content", content, NULL); -} - -gboolean -e_mail_paned_view_get_preview_visible (EMailPanedView *view) -{ - g_return_val_if_fail ( - E_IS_MAIL_PANED_VIEW (view), FALSE); - - return view->priv->preview_visible; -} - -void -e_mail_paned_view_set_preview_visible (EMailPanedView *view, - gboolean preview_visible) -{ - g_return_if_fail (E_IS_MAIL_PANED_VIEW (view)); - - if (preview_visible == view->priv->preview_visible) - return; - - /* If we're showing the preview, tell EMailReader to reload the - * selected message. This should force it to download the full - * message if necessary, so we don't get an empty preview. */ - if (preview_visible) { - EMailReader *reader; - GtkWidget *message_list; - const gchar *cursor_uid; - - reader = E_MAIL_READER (view); - message_list = e_mail_reader_get_message_list (reader); - cursor_uid = MESSAGE_LIST (message_list)->cursor_uid; - - if (cursor_uid != NULL) - e_mail_reader_set_message (reader, cursor_uid); - } - - view->priv->preview_visible = preview_visible; - - mail_paned_view_save_boolean ( - view, - STATE_KEY_PREVIEW_VISIBLE, preview_visible); - - g_object_notify (G_OBJECT (view), "preview-visible"); -} - -EShellSearchbar * -e_mail_paned_view_get_searchbar (EMailPanedView *view) +static EShellSearchbar * +mail_paned_view_get_searchbar (EMailView *view) { EShellView *shell_view; EShellContent *shell_content; GtkWidget *widget; - g_return_val_if_fail ( - E_IS_MAIL_PANED_VIEW (view), NULL); - - shell_content = E_MAIL_VIEW (view)->content; + shell_content = view->content; shell_view = e_shell_content_get_shell_view (shell_content); widget = e_shell_view_get_searchbar (shell_view); return E_SHELL_SEARCHBAR (widget); } -gboolean -e_mail_paned_view_get_show_deleted (EMailPanedView *view) -{ - g_return_val_if_fail ( - E_IS_MAIL_PANED_VIEW (view), FALSE); - - return view->priv->show_deleted; -} - -void -e_mail_paned_view_set_show_deleted (EMailPanedView *view, - gboolean show_deleted) -{ - g_return_if_fail (E_IS_MAIL_PANED_VIEW (view)); - - view->priv->show_deleted = show_deleted; - - g_object_notify (G_OBJECT (view), "show-deleted"); -} - -GalViewInstance * -e_mail_paned_view_get_view_instance (EMailPanedView *view) -{ - g_return_val_if_fail ( - E_IS_MAIL_PANED_VIEW (view), NULL); - - return view->priv->view_instance; -} - -void -e_mail_paned_view_set_search_strings (EMailPanedView *view, - GSList *search_strings) +static void +mail_paned_view_set_search_strings (EMailView *view, + GSList *search_strings) { + EMailPanedViewPrivate *priv; ESearchBar *search_bar; ESearchingTokenizer *tokenizer; - g_return_if_fail (E_IS_MAIL_PANED_VIEW (view)); + priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); - search_bar = E_SEARCH_BAR (view->priv->search_bar); + search_bar = E_SEARCH_BAR (priv->search_bar); tokenizer = e_search_bar_get_tokenizer (search_bar); e_searching_tokenizer_set_secondary_case_sensitivity (tokenizer, FALSE); @@ -934,25 +707,20 @@ e_mail_paned_view_set_search_strings (EMailPanedView *view, e_search_bar_changed (search_bar); } -static void -mail_paned_display_view_cb (EMailPanedView *view, - GalView *gal_view) +static GalViewInstance * +mail_paned_view_get_view_instance (EMailView *view) { - EMailReader *reader; - GtkWidget *message_list; + EMailPanedViewPrivate *priv; - reader = E_MAIL_READER (view); - message_list = e_mail_reader_get_message_list (reader); + priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); - if (GAL_IS_VIEW_ETABLE (gal_view)) - gal_view_etable_attach_tree ( - GAL_VIEW_ETABLE (gal_view), - E_TREE (message_list)); + return priv->view_instance; } -void -e_mail_paned_view_update_view_instance (EMailPanedView *view) +static void +mail_paned_view_update_view_instance (EMailView *view) { + EMailPanedViewPrivate *priv; EMailReader *reader; EShell *shell; EShellContent *shell_content; @@ -970,7 +738,9 @@ e_mail_paned_view_update_view_instance (EMailPanedView *view) const gchar *folder_uri; gchar *view_id; - shell_content = E_MAIL_VIEW(view)->content; + priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); + + shell_content = view->content; shell_view = e_shell_content_get_shell_view (shell_content); shell_view_class = E_SHELL_VIEW_GET_CLASS (shell_view); view_collection = shell_view_class->view_collection; @@ -990,9 +760,9 @@ e_mail_paned_view_update_view_instance (EMailPanedView *view) /* If we have a folder, we should also have a URI. */ g_return_if_fail (folder_uri != NULL); - if (view->priv->view_instance != NULL) { - g_object_unref (view->priv->view_instance); - view->priv->view_instance = NULL; + if (priv->view_instance != NULL) { + g_object_unref (priv->view_instance); + priv->view_instance = NULL; } view_id = mail_config_folder_to_safe_url (folder); @@ -1001,7 +771,7 @@ e_mail_paned_view_update_view_instance (EMailPanedView *view) else view_instance = e_shell_view_new_view_instance (shell_view, view_id); - view->priv->view_instance = view_instance; + priv->view_instance = view_instance; orientable = GTK_ORIENTABLE (view); orientation = gtk_orientable_get_orientation (orientable); @@ -1096,29 +866,274 @@ e_mail_paned_view_update_view_instance (EMailPanedView *view) g_signal_connect_swapped ( view_instance, "display-view", - G_CALLBACK (mail_paned_display_view_cb), - view); + G_CALLBACK (mail_paned_display_view_cb), view); mail_paned_display_view_cb ( - view, - gal_view_instance_get_current_view (view_instance)); + view, gal_view_instance_get_current_view (view_instance)); +} + +static void +mail_paned_view_set_orientation (EMailView *view, + GtkOrientation orientation) +{ + EMailPanedViewPrivate *priv; + + priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); + + priv->orientation = orientation; + + g_object_notify (G_OBJECT (view), "orientation"); + + e_mail_view_update_view_instance (view); +} + +static GtkOrientation +mail_paned_view_get_orientation (EMailView *view) +{ + EMailPanedViewPrivate *priv; + + priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); + + return priv->orientation; +} + +static void +mail_paned_view_set_show_deleted (EMailView *view, + gboolean show_deleted) +{ + EMailPanedViewPrivate *priv; + + priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); + + priv->show_deleted = show_deleted; + + g_object_notify (G_OBJECT (view), "show-deleted"); +} + +static gboolean +mail_paned_view_get_show_deleted (EMailView *view) +{ + EMailPanedViewPrivate *priv; + + priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); + + return priv->show_deleted; +} + +static void +mail_paned_view_set_preview_visible (EMailView *view, + gboolean preview_visible) +{ + EMailPanedViewPrivate *priv; + + priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); + + if (preview_visible == priv->preview_visible) + return; + + /* If we're showing the preview, tell EMailReader to reload the + * selected message. This should force it to download the full + * message if necessary, so we don't get an empty preview. */ + if (preview_visible) { + EMailReader *reader; + GtkWidget *message_list; + const gchar *cursor_uid; + + reader = E_MAIL_READER (view); + message_list = e_mail_reader_get_message_list (reader); + cursor_uid = MESSAGE_LIST (message_list)->cursor_uid; + + if (cursor_uid != NULL) + e_mail_reader_set_message (reader, cursor_uid); + } + + priv->preview_visible = preview_visible; + + mail_paned_view_save_boolean ( + E_MAIL_PANED_VIEW (view), + STATE_KEY_PREVIEW_VISIBLE, preview_visible); + + g_object_notify (G_OBJECT (view), "preview-visible"); +} + +static gboolean +mail_paned_view_get_preview_visible (EMailView *view) +{ + EMailPanedViewPrivate *priv; + + priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); + + return priv->preview_visible; +} + +static guint +mail_paned_view_open_selected_mail (EMailPanedView *view) +{ + return e_mail_reader_open_selected (E_MAIL_READER (view)); +} + +static void +mail_paned_view_class_init (EMailPanedViewClass *class) +{ + GObjectClass *object_class; + EMailViewClass *mail_view_class; + + parent_class = g_type_class_peek_parent (class); + g_type_class_add_private (class, sizeof (EMailPanedViewPrivate)); + + object_class = G_OBJECT_CLASS (class); + object_class->dispose = mail_paned_view_dispose; + object_class->constructed = mail_paned_view_constructed; + object_class->set_property = mail_paned_view_set_property; + object_class->get_property = mail_paned_view_get_property; + + mail_view_class = E_MAIL_VIEW_CLASS (class); + mail_view_class->get_searchbar = mail_paned_view_get_searchbar; + mail_view_class->set_search_strings = mail_paned_view_set_search_strings; + mail_view_class->get_view_instance = mail_paned_view_get_view_instance; + mail_view_class->update_view_instance = mail_paned_view_update_view_instance; + + mail_view_class->set_orientation = mail_paned_view_set_orientation; + mail_view_class->get_orientation = mail_paned_view_get_orientation; + mail_view_class->set_show_deleted = mail_paned_view_set_show_deleted; + mail_view_class->get_show_deleted = mail_paned_view_get_show_deleted; + mail_view_class->set_preview_visible = mail_paned_view_set_preview_visible; + mail_view_class->get_preview_visible = mail_paned_view_get_preview_visible; + + class->open_selected_mail = mail_paned_view_open_selected_mail; + + /* Inherited from EMailReader */ + g_object_class_override_property ( + object_class, + PROP_GROUP_BY_THREADS, + "group-by-threads"); + + g_object_class_install_property ( + object_class, + PROP_PREVIEW_VISIBLE, + g_param_spec_boolean ( + "preview-visible", + "Preview is Visible", + "Whether the preview pane is visible", + TRUE, + G_PARAM_READWRITE)); + + g_object_class_install_property ( + object_class, + PROP_SHOW_DELETED, + g_param_spec_boolean ( + "show-deleted", + "Show Deleted", + NULL, + FALSE, + G_PARAM_READWRITE)); + + g_object_class_override_property ( + object_class, PROP_ORIENTATION, "orientation"); +} + +static void +mail_paned_view_reader_init (EMailReaderIface *iface) +{ + iface->get_action_group = mail_paned_view_get_action_group; + iface->get_formatter = mail_paned_view_get_formatter; + iface->get_hide_deleted = mail_paned_view_get_hide_deleted; + iface->get_message_list = mail_paned_view_get_message_list; + iface->get_popup_menu = mail_paned_view_get_popup_menu; + iface->get_shell_backend = mail_paned_view_get_shell_backend; + iface->get_window = mail_paned_view_get_window; + iface->set_folder = mail_paned_view_set_folder; + iface->show_search_bar = mail_paned_view_show_search_bar; + iface->open_selected_mail = mail_paned_view_reader_open_selected_mail; +} + +static void +mail_paned_view_init (EMailPanedView *view) +{ + view->priv = E_MAIL_PANED_VIEW_GET_PRIVATE (view); + + view->priv->preview_visible = TRUE; + + g_signal_connect ( + view, "notify::group-by-threads", + G_CALLBACK (mail_paned_view_notify_group_by_threads_cb), + NULL); +} + +GType +e_mail_paned_view_get_type (void) +{ + return mail_paned_view_type; +} + +void +e_mail_paned_view_register_type (GTypeModule *type_module) +{ + static const GTypeInfo type_info = { + sizeof (EMailPanedViewClass), + (GBaseInitFunc) NULL, + (GBaseFinalizeFunc) NULL, + (GClassInitFunc) mail_paned_view_class_init, + (GClassFinalizeFunc) NULL, + NULL, /* class_data */ + sizeof (EMailPanedView), + 0, /* n_preallocs */ + (GInstanceInitFunc) mail_paned_view_init, + NULL /* value_table */ + }; +#if 0 + static const GInterfaceInfo orientable_info = { + (GInterfaceInitFunc) NULL, + (GInterfaceFinalizeFunc) NULL, + NULL /* interface_data */ + }; +#endif + static const GInterfaceInfo reader_info = { + (GInterfaceInitFunc) mail_paned_view_reader_init, + (GInterfaceFinalizeFunc) NULL, + NULL /* interface_data */ + }; + + mail_paned_view_type = g_type_module_register_type ( + type_module, E_TYPE_MAIL_VIEW, + "EMailPanedView", &type_info, 0); +#if 0 + g_type_module_add_interface ( + type_module, mail_paned_view_type, + GTK_TYPE_ORIENTABLE, &orientable_info); +#endif + g_type_module_add_interface ( + type_module, mail_paned_view_type, + E_TYPE_MAIL_READER, &reader_info); +} + +GtkWidget * +e_mail_paned_view_new (EShellContent *content) +{ + g_return_val_if_fail (E_IS_SHELL_CONTENT (content), NULL); + + return g_object_new ( + E_TYPE_MAIL_PANED_VIEW, + "shell-content", content, NULL); } void e_mail_paned_view_hide_message_list_pane (EMailPanedView *view, - gboolean visible) + gboolean visible) { - EMailPanedViewPrivate *priv = view->priv; + g_return_if_fail (E_IS_MAIL_PANED_VIEW (view)); if (visible) - gtk_widget_show (priv->scrolled_window); + gtk_widget_show (view->priv->scrolled_window); else - gtk_widget_hide (priv->scrolled_window); + gtk_widget_hide (view->priv->scrolled_window); } GtkWidget * e_mail_paned_view_get_preview (EMailPanedView *view) { + g_return_val_if_fail (E_IS_MAIL_PANED_VIEW (view), NULL); + return view->priv->preview; } |