javaextensions/pim/common/inc.s60/mpimcontactitem.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 27 Apr 2010 16:30:29 +0300
branchRCL_3
changeset 14 04becd199f91
permissions -rw-r--r--
Revision: v2.1.22 Kit: 201017

/*
* Copyright (c) 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:  Contact item access interface.
 *
*/


#ifndef MPIMCONTACTITEM_H
#define MPIMCONTACTITEM_H

// INTERNAL INCLUDES
#include "e32def.h"
#include "pimcommon.h"
#include "pimcontact.h"

//  FORWARD DECLARATIONS
class MPIMItemData;

/**
 *  Interface for accessing Contact-specific parts of an item.
 *  See \ref MPIMItemData class.
 */
class MPIMContactItem
{
public:
    // Destructor

    /**
     * Destructor.
     */
    virtual ~MPIMContactItem()
    {
    }

public:
    // New functions

    //@{
    /**
     * Provides access to the \ref MPIMItemData representation of this
     * MPIMContactItemData object.
     * There are const and non-const versions of this method.
     *
     * @return The \ref MPIMItemData representation of the item.
     */
    virtual MPIMItemData& ItemData() = 0;
    virtual const MPIMItemData& ItemData() const = 0;
    //@}

    /**
     * Provides a single preferred index among the indexes in the value
     * array of a specific field.
     *
     * @param aField The field.
     *
     * @return Preferred index in the value array. KPIMNoPreferredIndex
     *         if no preferred index is set.
     *
     * @par Leaving:
     * The method leaves on error. Error codes should be interpreted as
     * follows:
     * @li \c KErrArgument - \a aField is not valid for the implementing
     *     PIM item type.
     * @li \c KErrNotSupported - \a aField is not supported by this
     *     particular implementation.
     */
    virtual TInt getPreferredIndex(TPIMField aField) const = 0;

    /**
     * Sets new contact item id for this contact item
     *
     * @param aContactItemId New id for this contact item. Old is to
     *        be owerwriten
     */
    virtual void SetContactItemIdL(const TPIMItemID& aContactItemId) = 0;

    /**
     * Sets new contact item id for this contact item
     * This function was introduces for easier item id handling
     *
     * @param aContactItemId New id for this contact item. Old is to
     *        be owerwriten
     */
    virtual void SetContactItemIdL(const TUint aContactItemId) = 0;

    /**
     * Returns contact item id
     * The existing PIM item id is converted to a contact
     * contact database item id, so it is easier to use it
     *
     * @return Contact item id
     */
    virtual TUint ContactItemIdL() const = 0;

    /**
     * Sets the last modified date/time of the item
     * @param aLastModified Last modification date of this item
     */
    virtual void SetLastModifiedL(TPIMDate aLastModified) = 0;

    /**
     * Resets the item's internal state and remove all data
     * associated with this item. The item is ready for use
     * after reset
     */
    virtual void PrepareForLoadL() = 0;

protected:
    // Non-public operations

    // Allow derivation with protected default constructor.
    MPIMContactItem()
    {
    }

private:
    // Prohibited operations
    // Prohibit copy constructor.
    MPIMContactItem(const MPIMContactItem&)
    {
    }

    // Prohibit assigment operator.
    MPIMContactItem& operator=(const MPIMContactItem&)
    {
        return *this;
    }

};

#endif // MPIMCONTACTITEM_H
// End of File