cmmanager/cmmgr/Framework/Inc/cmlistbox.h
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:23:51 +0100
branchRCL_3
changeset 58 83ca720e2b9a
parent 0 5a93021fdf25
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201033 Kit: 201035

/*
* Copyright (c) 2006 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:  Declaration of class CCmListbox.
*
*/

#ifndef CM_LISTBOX_H
#define CM_LISTBOX_H

// INCLUDE FILES
#include <aknlists.h>

// FORWARD DECLARATION
class CCmListboxModel;

/**
 *  Model for the connection methods listbox. It is an array of CCmListItem
 *  pointers; items are owned.
 *  @lib cmmanager.lib
 *  @since S60 v3.2
 */
NONSHARABLE_CLASS( CCmListbox ) : public CAknDoubleGraphicStyleListBox
    {
    public:     // Construct / cmruct

        /**
        * Two-phased constructor. Leaves on failure.
        * @param aParent Parent control.
        * @return The constructed listbox.
        */
        static CCmListbox* NewL
            ( const CCoeControl* aParent );

        /**
        * Cmructor.
        */
        virtual ~CCmListbox();

        /**
        * Constructor.
        */
        CCmListbox();

    public :
        /**
        * Handle key event.
        * @param aKeyEvent The key event.
        * @param aType Key event type.
        * @return Response (was the key event consumed?).
        */
        TKeyResponse OfferKeyEventL
            ( const TKeyEvent& aKeyEvent, TEventCode aType );

        /**
        * Handle focus change.
        * @param aDrawNow Draw now?
        */
        void FocusChanged( TDrawNow aDrawNow );

        /**
        * Gets the UID from a given item
        * @param    The index of the item
        * @return   The UID of the item given by itemindex
        */
        TUint32 Uid4Item( TInt aItem ) const;

        /**
        * Gets the UID of the current item
        * @return  The UID of the current item
        */
        TUint32 CurrentItemUid() const;

        /**
        * Gets the name of the current item
        * @return The name of the current item
        */
        const TDesC& CurrentItemNameL();
        
        // from CCoeControl
        void HandleResourceChange(TInt aType);
    };


#endif

// End of file