textinput/peninputcommonlayout/inc/peninputuistatebase.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 02 Feb 2010 01:02:04 +0200
changeset 0 eb1f2e154e89
permissions -rw-r--r--
Revision: 201003 Kit: 201005

/*
* Copyright (c) 2002-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:  Interface of ui state
*
*/


#ifndef C_CPENINPUTUISTATEBASE_H
#define C_CPENINPUTUISTATEBASE_H

// System includes
#include <e32base.h>
#include <w32std.h>
#include <peninputcmd.h>

// Forward declarations
class MPeninputUiStateMgr;
class MPeninputLayoutContext;

/**
 *  Basic class of ui state
 *
 *  @lib peninputcommonlayout.lib
 *  @since S60 v3.2
 */
class CPeninputUiStateBase : public CBase
    {

public:

    /**
     * Two-phased constructor
     *
     * @since S60 v3.2
     * @param aUiStateMgr The ui state manager
     * @param aContext The layout context
     * @return The pointer to CPeninputUiStateBase object
     */
    IMPORT_C static CPeninputUiStateBase* NewL( 
        MPeninputUiStateMgr* aUiStateMgr, 
        MPeninputLayoutContext* aContext );
        
    /**
     * Destructor
     *
     * @since S60 v3.2
     * @return None
     */
    IMPORT_C virtual ~CPeninputUiStateBase();
        
    /**
     * Handle key event
     *
     * @since S60 v3.2
     * @param aData Carry information of key pressed
     * @return ETrue means event was consumed, otherwise EFalse
     */
    IMPORT_C virtual TBool HandleKeyEventL( const TRawEvent& aData );
    
    /**
     * Handle control event
     *
     * @since S60 v3.2
     * @param aEventType The event type
     * @param aEventData The event data
     * @return ETrue means event was consumed, otherwise EFalse
     */
    IMPORT_C virtual TBool HandleControlEvent( TInt aEventType, 
                                               const TDesC& aEventData );
    
protected:

    /**
     * Constructor
     *
     * @since S60 v3.2
     * @param aUiStateMgr The ui state manager
     * @param aContext The layout context
     * @return None
     */
    IMPORT_C CPeninputUiStateBase( MPeninputUiStateMgr* aUiStateMgr, 
                                   MPeninputLayoutContext* aContext );
    
    /**
     * Symbian second-phase constructor
     *
     * @since S60 v3.2
     * @return None
     */
    IMPORT_C void Construct(); 
    
    /**
     * Send key event through layout context
     *
     * @since S60 v3.2
     * @param aEventData Event data, the left most is unicode
     * @return ETrue if key event was consumed, otherwise EFalse
     */
    IMPORT_C TBool SendKey( const TDesC& aEventData );
    
protected:

    /**
     * Ui state manager 
     * Not own
     */
    MPeninputUiStateMgr* iUiStateMgr;
    
    /**
     * Layout context 
     * Not own
     */
    MPeninputLayoutContext* iContext;    

    };
          
#endif  // C_CPENINPUTUISTATEBASE_H