aboutsummaryrefslogblamecommitdiffstats
path: root/em-format/e-mail-formatter.h
blob: c0c21c13b048b870a41112216a848759d1f230de (plain) (tree)































































































































                                                                                         

                                                                                    









































































































































                                                                                     
/*
 * e-mail-formatter.h
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public
 * License as published by the Free Software Foundation; either
 * version 2 of the License, or (at your option) version 3.
 *
 * This program is distributed in the hope that it will be useful,
 * but WITHOUT ANY WARRANTY; without even the implied warranty of
 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
 * 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/>
 *
 */

#ifndef E_MAIL_FORMATTER_H_
#define E_MAIL_FORMATTER_H_

#include <em-format/e-mail-part-list.h>
#include <em-format/e-mail-extension-registry.h>
#include <gdk/gdk.h>
#include <libemail-engine/e-mail-enums.h>

/* Standard GObject macros */
#define E_TYPE_MAIL_FORMATTER \
    (e_mail_formatter_get_type ())
#define E_MAIL_FORMATTER(obj) \
    (G_TYPE_CHECK_INSTANCE_CAST \
    ((obj), E_TYPE_MAIL_FORMATTER, EMailFormatter))
#define E_MAIL_FORMATTER_CLASS(cls) \
    (G_TYPE_CHECK_CLASS_CAST \
    ((cls), E_TYPE_MAIL_FORMATTER, EMailFormatterClass))
#define E_IS_MAIL_FORMATTER(obj) \
    (G_TYPE_CHECK_INSTANCE_TYPE \
    ((obj), E_TYPE_MAIL_FORMATTER))
#define E_IS_MAIL_FORMATTER_CLASS(cls) \
    (G_TYPE_CHECK_CLASS_TYPE \
    ((cls), E_TYPE_MAIL_FORMATTER))
#define E_MAIL_FORMATTER_GET_CLASS(obj) \
    (G_TYPE_INSTANCE_GET_CLASS \
    ((obj), E_TYPE_MAIL_FORMATTER, EMailFormatterClass))

G_BEGIN_DECLS;

typedef enum {
    E_MAIL_FORMATTER_MODE_INVALID           = -1,
    E_MAIL_FORMATTER_MODE_NORMAL            = 0,
    E_MAIL_FORMATTER_MODE_SOURCE,
    E_MAIL_FORMATTER_MODE_RAW,
    E_MAIL_FORMATTER_MODE_PRINTING,
    E_MAIL_FORMATTER_MODE_ALL_HEADERS
} EMailFormatterMode;

typedef enum {
    E_MAIL_FORMATTER_HEADER_FLAG_COLLAPSABLE    = 1 << 0,
    E_MAIL_FORMATTER_HEADER_FLAG_COLLAPSED      = 1 << 1,
    E_MAIL_FORMATTER_HEADER_FLAG_HTML       = 1 << 2,
    E_MAIL_FORMATTER_HEADER_FLAG_NOCOLUMNS      = 1 << 3,
    E_MAIL_FORMATTER_HEADER_FLAG_BOLD       = 1 << 4,
    E_MAIL_FORMATTER_HEADER_FLAG_NODEC      = 1 << 5,
    E_MAIL_FORMATTER_HEADER_FLAG_HIDDEN     = 1 << 6,
    E_MAIL_FORMATTER_HEADER_FLAG_NOLINKS        = 1 << 7,
    E_MAIL_FORMATTER_HEADER_FLAG_NOELIPSIZE     = 1 << 8
} EMailFormatterHeaderFlags;

typedef enum {
    E_MAIL_FORMATTER_COLOR_BODY,        /* header area background */
    E_MAIL_FORMATTER_COLOR_CITATION,    /* citation font color */
    E_MAIL_FORMATTER_COLOR_CONTENT,     /* message area background */
    E_MAIL_FORMATTER_COLOR_FRAME,       /* frame around message area */
    E_MAIL_FORMATTER_COLOR_HEADER,      /* header font color */
    E_MAIL_FORMATTER_COLOR_TEXT,        /* message font color */
    E_MAIL_FORMATTER_NUM_COLOR_TYPES
} EMailFormatterColorType;

typedef struct _EMailFormatter EMailFormatter;
typedef struct _EMailFormatterClass EMailFormatterClass;
typedef struct _EMailFormatterPrivate EMailFormatterPrivate;
typedef struct _EMailFormatterHeader EMailFormatterHeader;
typedef struct _EMailFormatterContext EMailFormatterContext;

struct _EMailFormatterHeader {
    guint32 flags;      /* E_MAIL_FORMATTER_HEADER_FLAG_ * */
    gchar *name;
    gchar *value;
};

struct _EMailFormatterContext {
    CamelMimeMessage *message;
    CamelFolder *folder;
    gchar *message_uid;
    GSList *parts;

    EMailFormatterMode mode;
    guint32 flags;
};

struct _EMailFormatter {
    GObject parent;
    EMailFormatterPrivate *priv;
};

struct _EMailFormatterClass {
    GObjectClass parent_class;

    EMailFormatterExtensionRegistry *extension_registry;
    guint32 text_html_flags;

    /* Colors should apply globally */
    GdkColor colors[E_MAIL_FORMATTER_NUM_COLOR_TYPES];

    void            (*run)          (EMailFormatter *formatter,
                             EMailFormatterContext *context,
                             CamelStream *stream,
                             GCancellable *cancellable);

    EMailFormatterContext * (*create_context)   (EMailFormatter *formatter);

    void            (*free_context)     (EMailFormatter *formatter,
                             EMailFormatterContext *context);

    void            (*set_style)        (EMailFormatter *formatter,
                             GtkStyle *style,
                             GtkStateType state);

    /* Signals */
    void            (*need_redraw)      (EMailFormatter *formatter);
};

GType       e_mail_formatter_get_type   (void);

EMailFormatter *
        e_mail_formatter_new        (void);

void        e_mail_formatter_format_sync    (EMailFormatter *formatter,
                         EMailPartList *parts_list,
                         CamelStream *stream,
                         guint32 flags,
                         EMailFormatterMode mode,
                         GCancellable *cancellable);

void        e_mail_formatter_format     (EMailFormatter *formatter,
                         EMailPartList *parts_list,
                         CamelStream *stream,
                         guint32 flags,
                         EMailFormatterMode mode,
                         GAsyncReadyCallback callback,
                         GCancellable *cancellable,
                         gpointer user_data);

CamelStream *   e_mail_formatter_format_finished
                        (EMailFormatter *formatter,
                         GAsyncResult *result,
                         GError *error);

gboolean    e_mail_formatter_format_as  (EMailFormatter *formatter,
                         EMailFormatterContext *context,
                         EMailPart *part,
                         CamelStream *stream,
                         const gchar *as_mime_type,
                         GCancellable *cancellable);

void        e_mail_formatter_format_text    (EMailFormatter *formatter,
                         EMailPart *part,
                         CamelStream *stream,
                         GCancellable *cancellable);
gchar *     e_mail_formatter_get_html_header
                        (EMailFormatter *formatter);
EMailExtensionRegistry *
        e_mail_formatter_get_extension_registry
                        (EMailFormatter *formatter);

guint32     e_mail_formatter_get_text_format_flags
                        (EMailFormatter *formatter);

const GdkColor *
        e_mail_formatter_get_color  (EMailFormatter *formatter,
                         EMailFormatterColorType type);
void        e_mail_formatter_set_color  (EMailFormatter *efh,
                         EMailFormatterColorType type,
                         const GdkColor *color);
void        e_mail_formatter_set_style  (EMailFormatter *formatter,
                         GtkStyle *style,
                         GtkStateType state);

EMailImageLoadingPolicy
        e_mail_formatter_get_image_loading_policy
                        (EMailFormatter *formatter);
void        e_mail_formatter_set_image_loading_policy
                        (EMailFormatter *formatter,
                         EMailImageLoadingPolicy policy);

gboolean    e_mail_formatter_get_mark_citations
                        (EMailFormatter *formatter);
void        e_mail_formatter_set_mark_citations
                        (EMailFormatter *formatter,
                         gboolean mark_citations);

gboolean    e_mail_formatter_get_only_local_photos
                        (EMailFormatter *formatter);
void        e_mail_formatter_set_only_local_photos
                        (EMailFormatter *formatter,
                         gboolean only_local_photos);

gboolean    e_mail_formatter_get_show_sender_photo
                        (EMailFormatter *formatter);
void        e_mail_formatter_set_show_sender_photo
                        (EMailFormatter *formatter,
                         gboolean show_sender_photo);

gboolean        e_mail_formatter_get_animate_images
                                                (EMailFormatter *formatter);
void            e_mail_formatter_set_animate_images
                                                (EMailFormatter *formatter,
                                                 gboolean animate_images);

gboolean    e_mail_formatter_get_show_real_date
                        (EMailFormatter *formatter);
void        e_mail_formatter_set_show_real_date
                        (EMailFormatter *formatter,
                         gboolean show_real_date);

const gchar *   e_mail_formatter_get_charset    (EMailFormatter *formatter);
void        e_mail_formatter_set_charset    (EMailFormatter *formatter,
                         const gchar *charset);

const gchar *   e_mail_formatter_get_default_charset
                        (EMailFormatter *formatter);
void        e_mail_formatter_set_default_charset
                        (EMailFormatter *formatter,
                         const gchar *charset);

const GQueue *  e_mail_formatter_get_headers    (EMailFormatter *formatter);

void        e_mail_formatter_clear_headers  (EMailFormatter *formatter);

void        e_mail_formatter_set_default_headers
                        (EMailFormatter *formatter);

void        e_mail_formatter_add_header (EMailFormatter *formatter,
                         const gchar *name,
                         const gchar *value,
                         guint32 flags);

void        e_mail_formatter_add_header_struct
                        (EMailFormatter *formatter,
                         const EMailFormatterHeader *header);

void        e_mail_formatter_remove_header  (EMailFormatter *formatter,
                         const gchar *name,
                         const gchar *value);

void        e_mail_formatter_remove_header_struct
                        (EMailFormatter *formatter,
                         const EMailFormatterHeader *header);

EMailFormatterHeader *
        e_mail_formatter_header_new (const gchar *name,
                         const gchar *value);

void        e_mail_formatter_header_free    (EMailFormatterHeader *header);

G_END_DECLS

#endif /* E_MAIL_FORMATTER_H_ */