wlansecuritysettings/wlaneapsettingsui/pap/configui/inc/papuiview.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Mon, 18 Jan 2010 20:22:35 +0200
changeset 2 1c7bc153c08e
parent 0 c8830336c852
permissions -rw-r--r--
Revision: 201001 Kit: 201003

/*
* Copyright (c) 2001-2009 Nokia Corporation and/or its subsidiary(-ies).
* All rights reserved.
* This component and the accompanying materials are made available
* under the terms of the License "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: Header file of PAP UI setting dialog
*
*/

/*
* %version: 7 %
*/

#ifndef _PAPUIVIEW_H_
#define _PAPUIVIEW_H_

// INCLUDES
#include <AknDialog.h>        // AVKON components
#include <eikspane.h> // For changing status pane 
#include <akntitle.h>
#include <aknnavi.h>
#include <aknsettingitemlist.h>
#include <aknlists.h>
#include <aknselectionlist.h>
#include <eiklbo.h>
#include "papui.hrh"
#include <EapTlsPeapUiConnection.h>
#include <EapTlsPeapUiDataConnection.h>
#include <EapTlsPeapUiTlsPeapData.h>

// FORWARD DECLARATIONS
class CAknSettingStyleListBox;
class CSettingsListBoxItemDrawer;
class CPapSettingItemArray;


// CLASS DECLARATION

/**
*  Settings dialog class definition
*/
class CPapUiDialog : public CAknDialog,
                     public MEikListBoxObserver
    {
    public:
        CPapUiDialog( CEapTlsPeapUiConnection* aConnection, 
                              TInt& aButtonId );

        ~CPapUiDialog();

        /**
        * Create and launch dialog.
        * @param aResourceId The resource ID of the dialog to load.
        * @return The ID of the button that closed the dialog
        */
        TInt ConstructAndRunLD( TInt aResourceId );
        
                
    public: // From MEikListBoxObserver
        
        /**
        * Handles list box events.
        * @param aListBox   The originating list box.
        * @param aEventType A code for the event.
        */
        void HandleListBoxEventL( CEikListBox* aListBox, TListBoxEvent aEventType );                
        
        
    protected:
        void PreLayoutDynInitL();
        TBool OkToExitL( TInt aButtonId );
        void ProcessCommandL( TInt aCommand );

    private:
        void ChangeTitleL( TBool aIsStarted );
        void DrawSettingsListL();
        void ShowSettingPageL( TInt aCalledFromMenu );
        void ShowUsernameSettingPageL();
        void ShowPasswordSettingPageL(); 
        void GetHelpContext( TCoeHelpContext& aContext ) const;

        /**
        * Initialize menu pane.
        * @param aResourceId Menu pane resource id.
        * @param CEikMenuPane Menu pane.
        */
        void DynInitMenuPaneL( TInt aResourceId, CEikMenuPane* aMenuPane );
        
        /**
        * Copy the setting data to the eapol db data pointer.
        */
        void UpdateEapolData();


    private:
        CEapTlsPeapUiConnection* iConnection;
        CEapTlsPeapUiDataConnection* iDataConnection;        
        CEapTlsPeapUiTlsPeapData* iUiData;
        CPapSettingItemArray* iSettingArray;
        CAknSettingStyleListBox* iSettingListBox;
        CAknNavigationControlContainer* iNaviPane;
        CAknNavigationDecorator* iNaviDecorator;        
        HBufC* iPreviousText;
        TInt* iButtonId;
                
        // Temporary UI data as shown on the Settings UI
        TBuf<KPapUsernameMaxLength> iSettingUsername;
        TBool iSettingPwPrompt;
        TBuf<KPapPasswordMaxLength> iSettingPassword;
        
        
        // Tells the status of UI construction. TRUE if UI construction is completed.
		TBool iIsUIConstructionCompleted;
		
		TBool iUsernameCancelled;
    };


#endif // _PAPUIVIEW_H_

//  End of File