phonebookui/Phonebook2/ccapplication/ccacommlauncherplugin/inc/ccappcommlauncherplugin.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Wed, 13 Oct 2010 14:15:33 +0300
branchRCL_3
changeset 85 38bb213f60ba
parent 63 f4a778e096c2
child 64 c1e8ba0c2b16
permissions -rw-r--r--
Revision: 201039 Kit: 201041

/*
* Copyright (c) 2007-2007 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:  Implementation of comm launcher view plugin
*
*/


#ifndef C_CCAPPCOMMLAUNCHERPLUGIN_H
#define C_CCAPPCOMMLAUNCHERPLUGIN_H

#include <mccacontactobserver.h>

#include "ccappcommlauncherheaders.h"
#include <mccappviewpluginbase2.h>

class CCCAppCommLauncherContactHandler;
class CCCAppCommLauncherMenuHandler;
class CCAContactorService;
class TCSParameter;

/**
 * A helper class to keep up the command running state correct.
 * Only one command should be able to run at a time.
 */
class TCCAppCommandState
    {
public:
    /**
     * Constructor
     */
    TCCAppCommandState();
    /**
     * Returns ETrue if a command is running.
     * @return ETrue if a command is running.
     */
    inline TBool IsRunning() const { return iState; }
    /**
     * Change to Running state.
     */
    void SetRunning();
    /**
     * Change to Not Running state.
     */
    void SetNotRunning();
    /**
     * Sets state to Running and pushes a cleanup item to the CleanupStack.
     * The state will be changed to 'Not Running' in case of leave.
     */
    void SetRunningAndPushCleanupL();
    /**
     * Change to Not Running state and pops up the cleanup item previously
     * pushed by PushCleanupL or SetRunningAndPushCleanupL.
     */
    void SetNotRunningAndPopCleanup();
    /**
     * Pushes a cleanup item to the CleanupStack. 
     * The state will be changed to 'Not Running' in case of leave.
     */
    void PushCleanupL();
    /**
     * Pops up the cleanup item previously pushed by 
     * PushCleanupL or SetRunningAndPushCleanupL.
     */
    void PopCleanup();
private:
    TCCAppCommandState& operator=(const TCCAppCommandState&);
    TCCAppCommandState(const TCCAppCommandState&);
    static void CleanupOperation( TAny* aCommanState );
private:
    /// Own: ETrue if command is running, false otherwise.
    TBool iState;
    };
   

/**
 *  Class implementing CCCAppViewPluginBase interface. This is
 *  the main class and controlling the other classes of the plugin.
 *
 *  @code
 *   ?good_class_usage_example(s)
 *  @endcode
 *
 *  @lib ccappcommlauncherplugin.dll
 *  @since S60 v3.2
 */
class CCCAppCommLauncherPlugin :
    public CCCAppViewPluginBase,
    public MCCAppPluginsContactObserver,
    public MCCAppViewPluginBase2
    {
#ifdef __COMMLAUNCHERPLUGINUNITTESTMODE
    friend class T_CCCAppCommLauncherPlugin;
#endif// __COMMLAUNCHERPLUGINUNITTESTMODE
    
public:

    /**
     * Two-phased constructor.
     */
    static CCCAppCommLauncherPlugin* NewL();

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

public: //From MCCAppPluginsContactObserver

    void NotifyPluginOfContactEventL();

public:

// from base class CCCAppViewPluginBase

    /**
     * From CCCAppViewPluginBase
     */
    void PreparePluginViewL(
        MCCAppPluginParameter& aPluginParameter );

    /**
     * From CCCAppViewPluginBase
     * NEW API
     */
    void ProvideBitmapL(
        TCCAppIconType aIconType,
        CAknIcon& aIcon );

    /**
     * From CCCAppViewPluginBase
     */
    TAny* CCCAppViewPluginBaseExtension( TUid aExtensionUid );

// from base class CAknView

    /**
     * From CAknView
     */
    void DynInitMenuPaneL(
        TInt aResourceId,
        CEikMenuPane* aMenuPane );

    /**
     * From CAknView
     */
    void HandleCommandL(
        TInt aCommand );

    /**
     * From CAknView
     */
    void DoActivateL(
        const TVwsViewId& aPrevViewId,
        TUid aCustomMessageId,
        const TDesC8& aCustomMessage );

    /**
     * From CAknView
     */
    void DoDeactivate();

    /**
     * From CAknView
     */
    TUid Id() const;

// from base class CCCAppViewPluginAknView

    /**
     * From CCCAppViewPluginAknView
     */
    void PrepareViewResourcesL();

    /**
     * From CCCAppViewPluginAknView
     */
    void NewContainerL();
    
public: //From MCCAppViewPluginBase2
    
    TBool PluginBusy();

public: // From CAknView
    void HandleForegroundEventL( TBool aForeground );
    
public:

    /**
     * Returns a pointer to preferred comm methods
     *
     * @since S60 v5.0
     * @return pointer to preferred comm method array
     */
    RArray<VPbkFieldTypeSelectorFactory::TVPbkContactActionTypeSelector>&
        PreferredCommMethods();

   /**
     * Classes enumerated, see ErrorNotifierL() below
     *
     * @since S60 v5.0
     */
    enum TCCAppCommLauncherPluginErrorSource
        {
        ECCAppCommLauncherContactHandler = 1
        };

   /**
     * Error handler for errors coming from differen classes
     *
     * @since S60 v5.0
     */
    void ErrorNotifierL(
        TCCAppCommLauncherPluginErrorSource aErrorSource,
        TInt aError );

    /**
     * For getting information if the contact is Top Contact
     *
     * @since S60 v5.0
     * @return TBool
     */
    TBool IsTopContactL();

    /**
     * For getting information if the contact is from the contacts db
     *
     * @since S60 v5.0
     * @return TBool
     */
    TBool IsContactL();

    /**
     * For getting reference to container-class
     *
     * @since S60 v5.0
     * @return reference to container-class
     */
    CCCAppCommLauncherContainer& Container();

    /**
     * For getting reference to contacthandler-class
     *
     * @since S60 v5.0
     * @return reference to contacthandler-class
     */
    CCCAppCommLauncherContactHandler& ContactHandler();

    /**
     * Helper function for get the reference
     * to container data.
     *
     * return container
     */
    CCCAppViewPluginAknContainer& GetContainer()
    {
        return *iContainer;
    }

    /**
     * Returns a const pointer to contactor service.
     * Use ExecuteServiceL to run contactor service.
     */
    const CCAContactorService* ContactorService();
    
    /**
     * Executes the service using CCAContactorService. This must
     * be used instead of direct call to CCAContactorService to keep
     * the command running/not running state correct.
     */
    void ExecuteServiceL(const CCAContactorService::TCSParameter& aParameter);
    
    /**
     *  Start timer.
     */
    void StartTimerL();
    
    /**
     *  Cancel timer.
     */
    void CancelTimer();

private: // new

    /**
     * Initialises the preferred communication methods array.
     *
     * @since S60 v5.0
     */
    void InitialisePreferredCommMethods();

    /**
     * Loads preferred communication methods array from CenRep.
     *
     * @since S60 v5.0
     */
    void LoadPreferredCommMethodsL();

    /**
     * Creates menuhandler if not created already.
     *
     * @since S60 v5.0
     */
    void EnsureMenuHandlerCreatedL();
    
    /**
     *  Exit CCA application if it is at background when the request timeout.
     * 
     */
    void CloseCCApp();

private: // constructors

    CCCAppCommLauncherPlugin();
    void ConstructL();

public:
    /*
     * Sets the title to the plugin
     * @param aTitle - title to be set
     */
    void SetTitleL( const TDesC& aTitle );

    /**
     * Sets the CBA labels.
     * @param aEditable Boolean that tells if contact has communication
     * methods or not.
     */
    void UpdateMSKinCbaL( TBool aCommMethodsAvailable );
    
    /**
     * Returns the command running state instance. Command state must be
     * to running before executing the command and to not running after
     * the command has completed.
     */
    inline TCCAppCommandState& CommandState() {return iCommandState;}
    
    /**
     * Notify the timeout after sent an aiw service request.
     * 
     */
    static TInt ServiceTimeOutL( TAny* aObject );

private:// data

    /**
     * Pointer to contact data fetcher.
     * Own.
     */
    CCCAppCommLauncherContactHandler* iContactHandler;
    

    /**
     * Pointer to preferred communication methods.
     * In case of deactivation, this is not deleted for making the new opening faster.
     * Own.
     */
    RArray<VPbkFieldTypeSelectorFactory::TVPbkContactActionTypeSelector>
        iPreferredCommMethods;

    /**
     * Pointer to commlauncher's menuhandler
     * Own.
     */
    CCCAppCommLauncherMenuHandler* iMenuHandler;

    /**
     * Flag if contact must be refetched.
     */
    TBool iRefetchContact;

    /**
     * Pointer to contactor service.
     * Own.
     */
    CCAContactorService* iContactorService;
    
    
	/**
	 * The timer notifier an aiw service request timeout. 
	 * Own.
	 */
	CPeriodic* iAiwRequestTimer;
    
    /**
     * Record whether the View foreground flag.
     * Own.
     */
    TBool iIsCcaForeground;
    
    /**
     * Timer start flag.
     * Own.
     */
    TBool iIsTimerStart;
    
    /**
     * 
     */
    TCCAppCommandState iCommandState;
    };

#endif // C_CCAPPCOMMLAUNCHERPLUGIN_H

// End of File