--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/email/mail/UtilsSrc/MsgMailPreferences.h	Thu Dec 17 08:44:11 2009 +0200
@@ -0,0 +1,175 @@
+/*
+* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: 
+*     Declares storage class for mail preferences
+*
+*/
+
+
+#ifndef MSGMAILPREFERENCES_H
+#define MSGMAILPREFERENCES_H
+
+//  INCLUDES
+#include <e32base.h>
+#include <msvstd.h>
+#include <MsgEditor.hrh>
+
+// FORWARD DECLARATIONS
+class CMsvSession;
+class TMsvEmailEntry;
+class CImSmtpSettings;
+
+// CONSTANTS
+enum EHeaderStatus
+	{
+	EHeaderHidden,
+	EHeaderVisible,
+	EHeaderOnlySave
+	};
+
+class TAdditionalHeaderStatus
+    {
+    public:
+    TAdditionalHeaderStatus();
+    TAdditionalHeaderStatus(TMsgControlId aControlID);
+    TMsgControlId iHeaderValue;
+	EHeaderStatus iStatus;
+	TBool iHasContent;
+    };
+
+// CLASS DECLARATION
+
+/**
+*  Storage class for sending related mail settings. 
+*  This class is used to store user-configurable information about sending.
+*  These include the remote mailbox to be used, whether the message should
+*  be sent immediately or upon next connection. 
+*/
+class CMsgMailPreferences : public CBase
+    {
+    public: // Enumerations
+
+        /** 
+        * Possible mail scheduling values. 
+        */
+        enum TMsgMailScheduling {
+            EMsgMailSchedulingNow,
+            EMsgMailSchedulingNextConn
+        }; 
+
+    public: // Constructors and destructor
+        /**
+        * Constructor.
+        * Sets default values.
+        */
+        IMPORT_C CMsgMailPreferences();
+
+    public: // New functions
+        /**
+        * Retrieves Character set ID for outgoing mails.
+        * @return Character set ID.
+        */
+        TUid SendingCharacterSet() const;
+        
+        /**
+        * Set Sending character set id
+        * @param aSendingCharacterSet Character set id
+        */
+        void SetSendingCharacterSet(TUid aSendingCharacterSet);
+        
+        /**
+        * Retrieves remote mailbox ID.
+        * @return Service ID of the remote mailbox.
+        */
+        TMsvId ServiceId() const;
+
+        /**
+        * Retrieves mail scheduling value.
+        * @return Mail scheduling value.
+        */
+        TMsgMailScheduling MessageScheduling() const;
+
+        /**
+        * Sets remote mailbox service ID.
+        * @param Remote mailbox service ID.
+        */
+        void SetServiceId(TMsvId aServiceId);
+
+        /**
+        * Sets mail scheduling value.
+        * @param aScheduling New mail scheduling value.
+        */
+        void SetMessageScheduling(TMsgMailScheduling aScheduling);
+
+        /**
+        * inline
+        * Sets encoding supported flag.
+        * @param aSupported ETrue if encoding setting is supported.
+        */
+        void SetEncodingSupport( TBool aSupported );
+                
+        /**
+        * Gets default preferences from account settings.
+        * @param aServiceId Remote mailbox service ID from where the settings
+        * will be retrieved. If it is KMsvUnknownServiceIndexEntryId, class
+        * defaults will be used. 
+        * @param aSession Session to Message Server for fetching settings
+        */
+        IMPORT_C void DefaultAccountSettingsL(const TMsvId aServiceId, 
+                                     CMsvSession& aSession);
+
+        /**
+        * Exports current preferences.
+        * @param aEntry Email service entry where the 
+		* current setting will be exported.
+        */
+        IMPORT_C void ExportSendOptionsL(const TMsvEmailEntry& aEntry);
+
+        /**
+        * Imports current preferences.
+        * @param aEntry Email service entry from 
+		* where the settings will be read.
+        */
+        IMPORT_C void ImportSendOptionsL(TMsvEmailEntry& aEntry);
+
+        IMPORT_C void SetAdditionalHeaders(TInt aValue);
+
+        IMPORT_C EHeaderStatus GetAdditionalHeaderVisibility( TMsgControlId aHeader);
+    
+    private: // implementation
+        TUid SolveCharacterSet(const CImSmtpSettings& aSmtpSettings ) const;
+
+    private: // Data   
+        /// The message scheduling type
+        TMsgMailScheduling      iScheduling;       
+
+        /// The service ID of remote mailbox to be used in sending.
+        TMsvId                  iServiceId;
+		
+		/// Additional headers settings
+     	TInt iHeaderResults;
+	
+	    // Character set for outgoing mails
+	    TUid iSendingCharacterSet;
+	    
+	    // Encoding setting supported
+	    TBool iEncodingSupported;
+
+    };
+
+#include "MsgMailPreferences.inl" // inline functions
+
+#endif // MSGMAILPREFERENCES_H   
+            
+// End of File