/*
* Copyright (c) 2005 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: Container for the decryption view.
*
*/
#ifndef __DEVENCUI_GRAPHIC_VIEW_CONTAINER_H__
#define __DEVENCUI_GRAPHIC_VIEW_CONTAINER_H__
//INCLUDES
//System Includes
#include <coecntrl.h>
#include <aknview.h>
#include <eiklbo.h>
//User Includes
//FORWARD DECLARATIONS
class CAknDoubleStyle2ListBox;
class CDevEncUiDecrViewContainer : public CCoeControl,
public MEikListBoxObserver
{
public:
/**
* @function NewLC
* @abstract Creates a CDevEncUiEncrViewContainer object, which will
* draw itself to aRect
* @param aRect A rectangle that defines the size and location of the
* displayable area for the view
* @param aDocument the document
**/
static CDevEncUiDecrViewContainer* NewL(const TRect& aRect, CAknView& aOwningView);
/**
* @function NewL
* @abstract Creates a CDevEncUiEncrViewContainer object, which will draw
* itself to aRect
* @param aRect A rectangle that defines the size and location of the
* displayable area for the view
* @param aDocument the document
**/
static CDevEncUiDecrViewContainer* NewLC(const TRect& aRect, CAknView& aOwningView);
/**
* Destructor.
**/
~CDevEncUiDecrViewContainer();
// from MEikListBoxObserver
void HandleListBoxEventL( CEikListBox* aListBox,
TListBoxEvent aEventType );
/**
* From CCoeControl. Called by the framework in compound controls
* @return The number of controls in this CSimpleListContainer
*/
TInt CountComponentControls() const;
/**
* From CCoeControl. Called by the framework in compound controls
* @param The index of the control to return
* @return The control for aIndex
*/
CCoeControl* ComponentControl( TInt aIndex ) const;
/**
* Called by the framework to draw this control. Clears the area in
* aRect.
* @param aRect in which to draw
*/
void Draw( const TRect& aRect ) const;
/**
* Called by the framework whenever a key event occurs.
* @param aKeyEvent the Key event which occured, e.g. select key pressed
* @param aType the type of Key event which occurred, e.g. key up, key down
* @return TKeyResponse EKeyWasNotConsumed if the key was not processed,
* EKeyWasConsumed if it was
*/
TKeyResponse OfferKeyEventL( const TKeyEvent& aKeyEvent,
TEventCode aType );
/**
* Called by framework when the view size is changed. Resizes the
* iLabel accordingly.
*/
void SizeChanged();
private:
/**
* @function CDevEncUiEncrViewContainer
* @abstract Performs the first stage construction
* @param aOwningView the view that owns this container
**/
CDevEncUiDecrViewContainer(CAknView& aOwningView/*CDevEncUiDocument* aDocument*/);
/**
* @function ConstructL
* @abstract Performs the second phase construction, setting the bounding
* rectangle to aRect
* @param aRect the display area for the view
**/
void ConstructL(const TRect& aRect);
/**
* Constructs the iListBox, setting its window.
*/
void CreateListL();
private:
CAknView& iOwningView;
CAknDoubleStyle2ListBox* iListBox;
};
#endif // __DEVENCUI_GRAPHIC_VIEW_CONTAINER_H__