fep/aknfep/UiPlugins/AknFepUiInterface/AvkonImpl/inc/AknFepUIAvkonCtrlDualLanguageSettingList.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Fri, 19 Feb 2010 23:09:27 +0200
branchRCL_3
changeset 3 f5a1e66df979
parent 0 eb1f2e154e89
permissions -rw-r--r--
Revision: 201003 Kit: 201007

/*
* 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:          
*
*/










#ifndef __AKNFEPDUALLANGUAGESETTINGLIST_H
#define __AKNFEPDUALLANGUAGESETTINGLIST_H


#include <coecntrl.h>
#include <aknsettingitemlist.h> 
#include <akncheckboxsettingpage.h>
#include "AknFepUIAvkonCtrlDualLanguageSettingModel.h"
#include "AknFepUIAvkonCtrlDualLanguageSettingData.h"

class CAknFepDualLanguageSettingDialog;

class CAknFepDualLanguageSettingItem : public CAknEnumeratedTextPopupSettingItem
    {
public:
    CAknFepDualLanguageSettingItem( TInt aResourceId, TBool aPrimary, CAknFepDualLanguageSettingData* aData );
    virtual ~CAknFepDualLanguageSettingItem();
protected:
    virtual void CompleteConstructionL();
private:
    CAknFepDualLanguageSettingData* iData;
    TBool iPrimary;
    };

/**
 * Class: CAknFepDualLanguageSettingList
 *
 * Discussion:  A specialised subclass of CAknSettingItemList. This class is
 *              the control used to both display the current values of the
 *              settings and to launch the relevant editor for those items.
 *
 */
class CAknFepDualLanguageSettingList : public CAknSettingItemList
    {
public:
    /**
    * Function:     NewL
    *
    * Discussion:   Factory function used to create a new instance of
    *               CAknFepDualLanguageSettingList
    *
    * Params:       aData - reference to the data to be displayed and edited.
    *
    * Returns:      A newly created instance of CAknFepDualLanguageSettingList
    */
    static CAknFepDualLanguageSettingList* NewL(CAknFepDualLanguageSettingData* aData, CAknFepDualLanguageSettingDialog* aDialog);

    /**
    * Function:     NewLC
    *
    * Discussion:   Factory function used to create a new instance of
    *               CAknFepDualLanguageSettingList and leave a pointer to it on the
    *               cleanup stack.
    *
    * Params:       aData - reference to the data to be displayed and edited.
    *
    * Returns:      A newly created instance of CAknFepDualLanguageSettingList
    */
    static CAknFepDualLanguageSettingList* NewLC(CAknFepDualLanguageSettingData* aData, CAknFepDualLanguageSettingDialog* aDialog);

    /**
    * Function:     ~CAknFepDualLanguageSettingList
    *
    * Discussion:   Virtual destructor for CAknFepDualLanguageSettingList. Ensures that
    *               all allocated memory is returned to the heap before
    *               deletion of object.
    *
    */
    virtual ~CAknFepDualLanguageSettingList();


    /**
    * Function:     SizeChanged
    *
    * Discussion:   Inherited from CCoeControl. Calculates size based on
    *               contained control required sizes.
    *
    */
    void SizeChanged();

    /**
     * Function:    EditCurrentItemL
     * Params:      aCalledFromMenu - ETrue if called from menu, EFalse otherwise.
     *
     *
     * Discussion:  Starts the setting page for the currently selected item 
     *              in the list.
     */
    void EditCurrentItemL(TBool aCalledFromMenu);
    
    // Toggle whether secondary input item is visible
    void HideSecondaryInputL(TBool aHidden);
    
private:
    /**
    * Function:     CAknFepDualLanguageSettingList
    *
    * Discussion:   Hidden, first-stage non-leaving constructor.
    *
    * Params:       aData - reference to the data to be displayed and edited.
    *
    */
    CAknFepDualLanguageSettingList(CAknFepDualLanguageSettingData* aData, CAknFepDualLanguageSettingDialog* aDialog);

    /**
    * Function:     CreateSettingItemL
    *
    * Discussion:   Factory function for creating CAknSettingItem derived
    *               SettingItem classes used t display current values
    *
    * Params:       aSettingId - the id of the control which should be created
    *
    */
    CAknSettingItem* CreateSettingItemL (TInt aSettingId);
    
    void HandleListBoxEventL(CEikListBox* /*aListBox*/, TListBoxEvent aEventType);

private:
    CAknFepDualLanguageSettingData* iData;
	CAknFepDualLanguageSettingDialog* iDialog;
    TInt iPrimaryValue;
    TInt iSecondaryValue;
    };

#endif // __AKNFEPDUALLANGUAGESETTINGLIST_H