phoneapp/phoneuicontrol/inc/cphonecallheadermanager.h
author Pat Downey <patd@symbian.org>
Wed, 01 Sep 2010 12:30:10 +0100
branchRCL_3
changeset 25 5266b1f337bd
parent 24 41a7f70b3818
permissions -rw-r--r--
Revert incorrect RCL_3 drop: Revision: 201033 Kit: 201035

/*
* 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:  Bubble manager wrapper.
*
*/


#ifndef CPHONECALLHEADERMANAGER_H
#define CPHONECALLHEADERMANAGER_H

//INCLUDES
#include <e32base.h>
#include <bmbubblemanager.h>

#include "mphonecallheadermanagerutility.h"
#include "mphonestatemachine.h"
#include "mphoneviewcommandhandle.h"
#include "mphonecustomization.h"

class TPhoneCmdParamCallHeaderData;
class TPhoneCallHeaderParam;

/**
 * Class contains helper functions for bubble manager.
 *
 * @lib phoneuicontrol
 * @since S60 v9.1
 */
NONSHARABLE_CLASS( CPhoneCallHeaderManager ) :  public CBase,
                                                public MPhoneCallHeaderManagerUtility
    {
    public:
        
        /**
        * Creates new instance of CPhoneCallHeaderManager
        * @param aStateMachine: a state machine
        * @param aViewCommandHandle: handle to the PhoneUIView
        * @param aCustomization: handle to customization.
        * @return CPhoneCallHeaderManager* object  
        */
        static CPhoneCallHeaderManager* NewL(
                    MPhoneViewCommandHandle& aViewCommandHandle,
                    MPhoneStateMachine& aStateMachine,
                    MPhoneCustomization* aCustomization );
        /**
        * Destructor.
        */
        virtual ~CPhoneCallHeaderManager();
        
    public:
        
        /**
        * Returns updated remote information data.
        * @param aCallId - Call Id.
        */
        TPhoneCmdParamCallHeaderData UpdateCallHeaderInfoL( 
                const TInt aCallId );
        
        void GetRemoteInfoDataL(  const TInt aCallId, TDes& aData ) const;
       
        /**
        * Display call header for call coming in ( the remote info data 
        * and picture is displayed immediately )
        * @param aCallid call id
        * @param aWaitingCall waiting call indication
        */
        void DisplayHeaderForCallComingInL(
                const TInt aCallId, 
                const TBool aWaitingCall );
       
        /**
        * Display call header for outgoing call (the phone number is initially
        * displayed)
        * @param aCallid call id
        */
        void DisplayHeaderForOutgoingCallL(
                const TInt aCallId );
       
        /**
        * Sets the call header type used in the call bubble.
        * @param aCallHeaderType, call header type.
        */
        void SetCallHeaderType( 
                const CBubbleManager::TPhoneCallTypeFlags aCallHeaderType );
        
        /**
        * Returns the set call header type.
        */
        CBubbleManager::TPhoneCallTypeFlags CallHeaderType() const;
                
        /**
        * Checks if call is waiting, returns ETrue if call is waiting
        * otherwise EFalse.
        * @param aCallId, call id.
        */
        TBool IsWaitingCallL( const TInt aCallId ) const;
        
        /**
        * Checks if call is video, returns ETrue if call is video
        * otherwise EFalse.
        * @param aCallId, call id.
        */
        TBool IsVideoCall( const TInt aCallId ) const;
 
		/**
        * Sets texts to call header
        * @param aCallId - Call Id.
		* @param aWaitingCall waiting call indication
        * @param aCallHeaderData - Call header where indication will be set
        *                          if needed.
        */         
        void SetCallHeaderTextsForCallComingIn(
                const TInt aCallId, 
                const TBool aWaitingCall,
                TPhoneCmdParamCallHeaderData* aCallHeaderData );
        
    public:  // Functions from base class
        
        /**
        * @see MPhoneBubbleManagerUtility.
        */
        void SetPhoneNumberAvailabilityL( 
                const TInt aNumberLength,
                const TBool aContactInfoAvailable );
        
        /**
        * @see MPhoneBubbleManagerUtility.
        */
        void GetInCallNumberTextL( TInt aCallId, TDes& aData ) const;
        
        /**
        * @see MPhoneBubbleManagerUtility.
        */
        void LoadCallHeaderTexts(
            const TInt aLabelId, 
            const TInt aShortLabelId,
            TPhoneCmdParamCallHeaderData* aCallHeaderData ); 
        
        /**
        * @see MPhoneBubbleManagerUtility.
        */
        MPhoneCustomization* Customization(){ return iCustomization; }
        
        /**
        * @see MPhoneBubbleManagerUtility.
        */
        void LoadResource( TDes& aData, const TInt aResource );
        
    private:
    
        /**
        * C++ default constructor.
        */
        CPhoneCallHeaderManager(
                MPhoneViewCommandHandle& aViewCommandHandle,
                MPhoneStateMachine& aStateMachine,
                MPhoneCustomization* aCustomization );
        
        /**
        * Symbian constructor
        */
        void ConstructL();
        
    private:
        
        MPhoneViewCommandHandle& iViewCommandHandle;
        MPhoneStateMachine& iStateMachine;
        MPhoneCustomization* iCustomization;
        TPhoneCallHeaderParam* iCallHeaderParam;
    };


#endif // CPHONECALLHEADERMANAGER_H