meetingrequest/mrgui/mrfieldevent/inc/mesmrfieldevent.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 31 Mar 2010 21:08:33 +0300
branchRCL_3
changeset 12 4ce476e64c59
parent 0 8466d47a6819
permissions -rw-r--r--
Revision: 201011 Kit: 201013

/*
* Copyright (c) 2009 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:  Definition of the class MESMRFieldEvent
*
*/

#ifndef MESMRFIELDEVENT_H
#define MESMRFIELDEVENT_H


#include <e32std.h>

class MESMRFieldEventNotifier;
class CESMRField;

/**
 *  Interface for field events
 *
 *  @lib esmrfieldbuildercommon.lib
 */
class MESMRFieldEvent
    {

public:

    /**  Event types */
    enum TEventType
        {
        /**
         * Triggers command from field.
         * @param Command value. TInt.
         */
        EESMRFieldCommandEvent = 0,
        /**
         * Notifies that field value has changed
         * @param Field that has changed. TESMREntryFieldId as TInt.
         * @param New field value. MESMRFieldEventValue*.
         */
        EESMRFieldChangeEvent
        };

    
    /**
     * Gets the event type.
     *
     * @return Event type from TEventType enumeration.
     */
    virtual TEventType Type() const = 0;
    
    /**
     * Gets the event source.
     * 
     * @return pointer to the sender or NULL.
     */
    virtual MESMRFieldEventNotifier* Source() const = 0;
    
    /**
     * Gets the event parameter count.
     * 
     * @return the parameter count.
     */
    virtual TInt ParamCount() const = 0;
    
    /**
     * Gets the event parameter.
     * 
     * @param aIndex parameter index.
     * @return the parameter.
     */
    virtual TAny* Param( TInt aIndex ) const = 0;

    /**
     * Destructor.
     */
    virtual ~MESMRFieldEvent() {}
    };

/**
 *  Generic field event value interface.
 *  
 *  @lib esmrfieldbuildercommon.lib
 */
class MESMRFieldEventValue
    {
    
public:
    
    /**
     * Value type definition.
     */
    enum TValueType
        {
        /**
         * TInt
         */
        EESMRInteger = 0,
        /**
         * TDesC16*. Not owned.
         */
        EESMRStringRef,
        /**
         * TDesC16*. Owned.
         */
        EESMRString,
        /**
         * TDesC8*. Not owned.
         */
        EESMRString8Ref,
        /**
         * TDesC8*. Owned.
         */
        EESMRString8,
        /**
         * CESMRField*. Not owned.
         */
        EESMRFieldRef,
        /**
         * MESMRFieldEventValue*. Owned.
         */
        EESMRFieldEventValue,
        /**
         * CBase*. Not owned.
         */
        EESMRCBaseRef,
        /**
         * CBase*. Owned.
         */
        EESMRCBase,
        /**
         * TTime.
         */
        EESMRTTime
        };
    
    /**
     * Destructor.
     */
    virtual ~MESMRFieldEventValue() {}

    /**
     * Gets the value type
     */
    virtual TValueType Type() const = 0;
    
    /**
     * Gets the value.
     */
    virtual TAny* Value() const = 0;
    
    /**
     * Gets the value as TInt.
     */
    virtual TInt IntValue() const = 0;
    
    /**
     * Gets the value as TDesC16&.
     */
    virtual const TDesC& StringValue() const = 0;
    
    /**
     * Gets the value as TDesC8&.
     */
    virtual const TDesC8& String8Value() const = 0;
    
    /**
     * Gets the value as CESMRField&.
     */
    virtual const CESMRField& FieldValue() const = 0;
    
    /**
     * Gets the value as CBase*.
     */
    virtual const CBase* CBaseValue() const = 0;
    
    /**
     * Gets the value as TTime.
     */
    virtual TTime TimeValue() const = 0;

    };



#endif // MESMRFIELDEVENT_H