/* -*- Mode: IDL; tab-width: 8; indent-tabs-mode: t; c-basic-offset: 8 -*- */
/*
 * Evolution-Composer.idl: Mail composer interfaces for Evolution
 *
 * Author:
 *   Dan Winship <danw@ximian.com>
 * 
 * (C) 2000 Ximian, Inc.
 */

#include <Bonobo.idl>

module GNOME {
module Evolution {
	
	interface Composer : Bonobo::Unknown {
		struct Recipient {
			string name;	/* UTF-8 */
			string address;
		};
		typedef sequence<Recipient> RecipientList;

		typedef sequence<char> AttachmentData;

		enum MultipartType {
			MIXED,
			ALTERNATIVE
		};

		/**
		 * setHeaders:
		 * @from: the "From" account or address
		 * @to: the "To" recipients
		 * @cc: the "CC" recipients
		 * @bcc: the "Bcc" recipients
		 * @subject: the subject of the message
		 *
		 * Sets the composer headers. Any of @to, @cc, and
		 * @bcc may be an empty list, and @subject may be an
		 * empty string. If @from is empty or invalid, the
		 * default account will be used. Otherwise is
		 * specifies an account name or email address to send
		 * from.
		 **/
		void setHeaders (in string from, in RecipientList to,
				 in RecipientList cc, in RecipientList bcc,
				 in string subject);

		/**
		 * setMultipartType:
		 * @type: a multipart subtype
		 *
		 * Sets the kind of multipart message that is being
		 * created.
		 *
		 * If @type is MIXED (the default), setBody()
		 * will create the body, and attachMIME() and
		 * attachData() will create attachments.
		 *
		 * If @type is ALTERNATIVE, setBody() will create
		 * text/plain alternative, and each following
		 * attachMIME() or attachData() call will create
		 * another alternative.
		 *
		 * Other values of @type are not currently supported,
		 * although "related" probably should be.
		 **/
		void setMultipartType (in MultipartType type);

		/**
		 * setBody:
		 * @body: the body
		 * @mime_type: the MIME type of @body
		 *
		 * Sets the body of the composer to @body. If
		 * @mime_type is something other than "text/plain" or
		 * "text/html", the composer will not be editable
		 * and it will not attempt to assign a non-UTF8
		 * character set to the data. However, @mime_type may
		 * include parameters in that case.
		 **/
		void setBody (in string body, in string mime_type);

		/**
		 * attachMIME:
		 * @data: the attachment data
		 *
		 * This adds an attachment to the composer. @data
		 * should be a fully-formed MIME body part.
		 **/
		exception CouldNotParse {};
		void attachMIME (in string data)
			raises (CouldNotParse);

		/**
		 * attachData:
		 * @content_type: the Content-Type header
		 * @filename: the suggested filename, or ""
		 * @description: a description of the data, or ""
		 * @show_inline: whether the attachment should be
		 * displayed inline or not.
		 * @data: the raw attachment data
		 *
		 * This adds @data as an attachment, using the provided
		 * information to generate MIME headers. @content_type
		 * may contain just a MIME content type, or it may
		 * contain a complete Content-Type header. @filename
		 * is a filename for the Content-Disposition header
		 * @description (if not "") provides the
		 * Content-Description, and @show_inline determines if the
		 * Content-Disposition is "inline" or "attachment".
		 *
		 * If you need to specify headers or values other than
		 * what this function can do, you will need to generate
		 * all of the MIME headers yourself and use
		 * add_attachment ().
		 **/
		void attachData (in string content_type,
				 in string filename,
				 in string description,
				 in boolean show_inline,
				 in AttachmentData data);

		/**
		 * show:
		 *
		 * Shows the composer and lets the user edit things
		 * and send the message.
		 **/
		void show ();


		/**
		 * send:
		 *
		 * Send the message without showing the user the composer
		 **/
		void send ();
	};
};
};