imstutils/imconversationview/imcvuiapp/inc/cimcvappmessagewrapper.h
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:33:36 +0100
branchRCL_3
changeset 23 9a48e301e94b
parent 0 5e5d6b214f4f
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201033 Kit: 201035

/*
* Copyright (c) 2007-2008 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:  Message wrapper for MIMCVEngineMessage
*
*/




#ifndef CIMCVAPPMESSAGEWRAPPER_H
#define CIMCVAPPMESSAGEWRAPPER_H

//  INCLUDES
#include <e32base.h>
#include <frmtlay.h> // TCursorSelection

// FORWARD DECLARATIONS
class MIMCVEngineMessage;

// CLASS DECLARATION

/**
*  Message wrapper for MIMCVEngineMessage
*  stores information about highlight items inside this message etc
*
*  @imcvuiapp.exe
*  @since Series 60 3.0
*/
class CIMCVAppMessageWrapper : public CBase 
    {   
    public:  // Constructors and destructor

        /**
         * Two-phased constructor.
         * @param aWrappedMessage Wrapped message
         * @param aContainer Message container interface 
         *                   (for informing about changed message)
         */
        static CIMCVAppMessageWrapper* NewL( MIMCVEngineMessage& aWrappedMessage );

        /**
         * Destructor.
         */
        virtual ~CIMCVAppMessageWrapper();

    public: // New functions
    
        /**
         * @return Modifiable position for thumbnail 
         *         of this message in rich text
         *
         * Note that these are not used within this class, 
         * so it's safe to return non-const reference.
         */
        TCursorSelection& ThumbPos();

        /**
         * @return Modifiable selection for this message in rich text 
         *         (for highlighting)
         *
         * Note that these are not used within this class, 
         * so it's safe to return non-const reference.
         */
        TCursorSelection& Selection();
        
        /**
         * @return Modifiable whole selection for this message in rich text.
         * use this to remove message from rich text 
         * as this contains the whole text.
         *
         * Note that these are not used within this class, 
         * so it's safe to return non-const reference.
         */
        TCursorSelection& WholeSelection();

         /**
         * @return Modifiable message selection for this message in rich text.
         * use this to identify the message part from the nick part
         *
         * Note that these are not used within this class, 
         * so it's safe to return non-const reference.
         */
        TCursorSelection& MessageSelection();
       
        /**
         * @return Modifiable array of highlights for this message
         *
         * Note that these are not used within this class, 
         * so it's safe to return non-const reference.
         */
        RArray<TCursorSelection>& Highlights();
        
        /**
         * @return Modifiable array of highlight types for this message
         *
         * Note that these are not used within this class, 
         * so it's safe to return non-const reference.
         */
        RArray<TInt>& HighlightTypes();
        
        /**
         * @return Wrapped message
         *
         * Note that these are not used within this class, 
         * so it's safe to return non-const reference.
         */
        MIMCVEngineMessage& Message();

        /**
         * Sets wrapper to be inserted or added.
         * @since S60 v3.2
         * @param aInserted ETrue to set wrapper inserted,
         *                  EFalse to set added.
         */
        void SetInserted( TBool aInserted );
        
        /**
         * Is wrapper inserted or added.
         * @since S60 v3.2
         * @return ETrue if this wrapper is inserted,
         *         EFalse otherwise.
         */
        TBool IsInserted() const;
        
    protected:  // Functions from MIMCVAPPImageLoaderObserver

        /**
         * @see MIMCVAPPImageLoaderObserver
         */
        //void Handleplaaplaplaa

    private:

        /**
         * C++ default constructor.
         */
        CIMCVAppMessageWrapper( MIMCVEngineMessage& aWrappedMessage);

    private:    // Data
    
        // Note that these shouldn't be used within this class,
        // these are only contained in this wrapper class
        
        // Position of thumbnail in rich text
        TCursorSelection iThumbPosition;
        
        // doesn't own. reference to wrapped message
        MIMCVEngineMessage& iMessage;
                
        // Highlight selection for this text
        TCursorSelection iSelection;
        
        // Whole selection for this text
        TCursorSelection iWholeSelection;

        // Message part selection for this text
        TCursorSelection iMessageSelection;
        
        // Selections inside this message
        RArray<TCursorSelection> iHighlights;
        
        // Selection types inside this message
        RArray<TInt> iTypes;
        
         // Is this wrapper inserted (ETrue) or added (EFalse)
        TBool iInserted;
    };

#endif      // CIMCVAPPMESSAGEWRAPPER_H

// End of File