textinput/peninputcommonlayout/inc/peninputlayoutcontext.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 21 Jun 2010 16:02:35 +0300
branchRCL_3
changeset 29 857bebeecec0
parent 0 eb1f2e154e89
permissions -rw-r--r--
Revision: 201023 Kit: 2010125

/*
* 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 layout context
*
*/


#ifndef M_MPENINPUTLAYOUTCONTEXT_H
#define M_MPENINPUTLAYOUTCONTEXT_H

// System includes
#include <e32base.h>

// User includes
#include "peninputdataprovider.h"

// Class forward decalaration
class CFepUiBaseCtrl;

/**
 *  Peninput common layout interface
 *
 *  @lib peninputcommonlayout.lib
 *  @since S60 v3.2
 */
class MPeninputLayoutContext
    {

public:

    /**
     * Send event to window
     *
     * @since S60 v3.2
     * @param aEventType The event type
     * @param aCtrl The sender control
     * @param aEventData The event data
     * @return None 
     */
    virtual void SendEventToWindow( TInt aEventType, 
                                    CFepUiBaseCtrl* aCtrl, 
                                    const TDesC& aEventData = KNullDesC ) = 0;
                        
    virtual TBool IsShiftPermitted() = 0;
    virtual TBool IsCapsLockPermitted() = 0;

    /**
     * Send key to fep
     *
     * @since S60 v3.2
     * @param aEventType The event type
     * @param aEventData The event data
     * @return None
     */
    virtual void Sendkey( TInt aEventType, 
                          const TDesC& aEventData = KNullDesC ) = 0;
    
    /**
     * Request data from data provider
     *
     * @since S60 v3.2
     * @param aDataType The data type request 
     * @return The pointer to TAny type data requested
     */
    virtual TAny* RequestData( TPeninputDataType aDataType ) = 0;

    /**
     * Set data for data provider
     *
     * @since S60 v3.2
     * @param aDataType The data type to set value 
     * @param aData The pointer to TAny type data
     * @return None
     */
    virtual void SetData( TPeninputDataType aDataType, TAny* aData ) = 0;

    /**
     * Save key into CenRep(AknFep)
     *
     * @since S60 v3.2
     * @param aKey The key name
     * @param aValue The new value
     * @return None
     */
    virtual void SaveKey( TInt aKey, TInt aValue ) = 0;

    /**
     * Get the layout type, vkb or hwr.
     * 
     * @since S60 v3.2
     * @return The layout type
     */    
    virtual TInt LayoutType() = 0;
    
    };

#endif  // End of M_PENINPUTLAYOUTCONTEXT_H