locationlandmarksrefappfors60/Inc/LandmarksInfoModel.h
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:31:27 +0100
branchRCL_3
changeset 18 870918037e16
parent 0 522cd55cc3d7
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201033 Kit: 201035

/*
* Copyright (c) 2004-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:  
*     See class description below
*
*/


#ifndef __LANDMARKS_INFOMODEL_H__
#define __LANDMARKS_INFOMODEL_H__


#include <e32base.h>


class TLocality;
class CPosLandmark;
class CLandmarksApplicationEngine;



/**
*  Contains the data model of the landmarks view.
*  
*/
class CLandmarksInfoModel : public CBase
	{
    public: // Constructors and destructor

        /**
        * C++ constructor.
        */
	    CLandmarksInfoModel(CLandmarksApplicationEngine& aEngine);

        /**
        * Destructor.
        */
	    ~CLandmarksInfoModel();

    public: // New functions

        /**
        * Generates descriptor array from landmark's info.
        * Caller takes ownership of returned object
        *
        * @param aLandmark The landmark to get info of.
        * @param aFieldIds On return, landmark info field ids.
        * @return The landmark's info as descriptor array
        */
        CDesCArray* GetLandmarkInfoL(
            CPosLandmark& aLandmark,
            RArray<TInt>& aFieldIds);

    private:

        /**
        * Adds new string describing landmark field to the info array.
        * Adds also field's ID to array of field IDs.
        * @param aCaption The caption of the field
        * @param aText The value of the field
        * @param aArray Target array
        * @param aFieldIds Target field IDs array
        */
        void AddInfoFieldL(
            const TDesC& aCaption, 
            const TDesC& aText,
            CDesCArray& aArray,
            RArray<TInt>& aFieldIds);

        /**
        * Adds location fields of the landmark to arrays.
        *
        * @param aLocation contains the location data to update location fields
        * with.
        * @param aArray Target array
        * @param aFieldIds Target field IDs array
        */
        void AddLocationFieldsL(
            TLocality& aLocation,
            CDesCArray& aArray,
            RArray<TInt>& aFieldIds);

        /**
        * Adds the category fields to arrays.
        * @param aLandmark used to retrieve category information
        * @param aArray Target array
        * @param aFieldIds Target field IDs array
        */
        void AddCategoryFieldsL(
            CPosLandmark& aLandmark, 
            CDesCArray& aArray,
            RArray<TInt>& aFieldIds);

        /**
        * Adds other text field and to arrays.
        * @param aCaptionId Caption string resource ID
        * @param aText The value of the field
        * @param aArray Target array
        * @param aFieldIds Target field IDs array
        */
        void AddTextFieldL(
            TInt aCaptionId, 
            TDesC& aText,
            CDesCArray& aArray,
            RArray<TInt>& aFieldIds);

    private: // Data

        //! The application engine used for accessing landmarks
        CLandmarksApplicationEngine& iEngine;

        //! Defines how real numbers are displayed
        TRealFormat iRealFormat;
	};

#endif // __LANDMARKS_INFOMODEL_H__