phonebookui/Phonebook2/remotecontactlookup/engine/inc/cpbkxrclresultinfodlg.h
author Dremov Kirill (Nokia-D-MSW/Tampere) <kirill.dremov@nokia.com>
Tue, 14 Sep 2010 20:54:53 +0300
branchRCL_3
changeset 21 9da50d567e3c
parent 0 e686773b3f54
permissions -rw-r--r--
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:  Definition of the class CPbkxRclResultInfoDlg
*
*/


#ifndef CPBKXRCLRESULTINFODLG_H
#define CPBKXRCLRESULTINFODLG_H

#include "cpbkxrclbasedlg.h"
#include "pbkxrclengineconstants.h"
#include <AknUtils.h>

class CAknNavigationControlContainer;
class CAknNavigationDecorator;
class CAknTabGroup;
class CAknTitlePane;
class MPbkxRclContactRetrieval;
class CPbkContactItem;
class CPbkContactEngine;
class CPbkxRclCbRSender;
class CPbkxRclActionServiceWrapper;
class TPbkContactItemField;
class CPbkFieldArray;
class CAknLongTapDetector; 
class CAknStylusPopUpMenu; 
class CVPbkContactManager; 

/**
 *  Result information view implementation.
 *
 *  @lib pbkxrclengine.lib
 *  @since S60 3.1
 */
class CPbkxRclResultInfoDlg : 
        public CPbkxRclBaseDlg,
        public MEikListBoxObserver
    {
                              
    
public: // constructor and destructor

    /**
    * Two-phase constructor.
    *
    * @param aIndex Selected item index, is updated by dialog after selection
    *               is made.
    * @param aArray Array of list box items.
    * @param aCommand Observer which executes dialog menu commands.
    * @param aContactRetrieval Used to get more information about contacts.
    * @param aContactEngine Used to create pbk contacts.
    * @param aActionService Contact action service.
    * @param aContactSelectorEnabled Flag indicating whether contact
    *                                selection is enabled.
    * @param aActiveItemIndex Initial active item index.
    * @return Created object.
    */
    static CPbkxRclResultInfoDlg* NewL( 
        TInt& aIndex, 
        CDesCArray* aArray,
        MEikCommandObserver* aCommand,
        MPbkxRclContactRetrieval* aContactRetrieval,
        CPbkContactEngine& aContactEngine,
        CPbkxRclActionServiceWrapper& aActionService,
        TBool aContactSelectorEnabled,
        TInt aActiveItemIndex );
    
    /**
    * Destructor.
    */
    virtual ~CPbkxRclResultInfoDlg();

public: // methods from base classes
    
    /**
    * Hides option menu items that are not supposed to be shown.
    *
    * @param aResourceId Menu resource id.
    * @param aMenuPane Menu pane.
    */
    virtual void DynInitMenuPaneL( TInt aResourceId, CEikMenuPane* aMenuPane );

    /**
    * Gets help context for this view.
    *
    * @param aContext On return, contains help context information
    */
    virtual void GetHelpContext( TCoeHelpContext& aContext ) const;
    
   /**
    * From MEikListBoxObserver 
    * Handles listbox pointer events
    */
    void HandleListBoxEventL(
             CEikListBox *aListBox, TListBoxEvent aEventType );
    
public: // new methods

    /**
    * Executes dialog and destroys it after it is closed.
    */
    void ExecuteLD();

    /**
    * Closes dialog.
    */
    void Close();

    /**
    * Sends callback request to selected contact.
    */
    void SendCallbackRequestL();

    /**
    * Sends bussiness card of currently selected contact.
    */ 
    void SendBusinessCardL();

    /**
    * Updates existing contact with currently selected field.
    *
    * If update is successful, a string is constructed which is shown
    * to the user.
    *
    * @return Constructed string to be shown to the user or NULL, if
    *         operation failed.
    */
    HBufC* UpdateExistingContactL();
    
    /**
    * Copies the Selected Details Field to the ClipBorad
    *
    * @param aContactManager - Ref to Virtual Phonebook Contact Manager
    */
    void CopyDetailToClipboardL( CVPbkContactManager& aContactManager );
    
protected: // redefinition of functions in the base class

    /**
    * Handles key events.
    *
    * @param aKeyEvent Key event.
    * @param aType Type of the key event.
    * @return Key response (handled/not handled).
    */
    TKeyResponse OfferKeyEventL( const TKeyEvent& aKeyEvent, TEventCode aType );
    
    TBool OkToExitL( TInt aButtonId );
    
private: // methods used internally

    /**
    * Setup status pane (tab group and title pane text).
    */
    void SetupStatusPaneL();
    
    /**
    * Sets title pane text.
    */
    void SetTitlePaneTextL();

    /**
    * Reverts changes made to status pane.
    */
    void ResetStatusPane();
    
    /**
    * Creates list box entries of the currently selected contact.
    */
    void CreateListBoxEntriesL();

    /**
    * Fetches current contact from contact retrieval interface.
    *
    * @return ETrue if fetching is successful, EFalse otherwise.
    */
    TBool FetchCurrentContactL();

    /**
    * Updates both list box entries and status pane.
    */
    void UpdateDialogL();

    /**
    * Returns ETrue if there are call actions available, EFalse
    * otherwise.
    *
    * @return ETrue if there is call actions available.
    */
    TBool CallActionsAvailable() const;

    /**
    * Returns ETrue if focus is on phone number field.
    *
    * @return ETrue if focus is on phone number field.
    */
    TBool FocusOnPhoneNumberField() const;

    /**
    * Returns ETrue if focus is on email address field.
    *
    * @return ETrue if focus is on email address field.
    */
    TBool FocusOnEmailAddressField() const;
        
    /**
    * Returns ETrue if focus is on voip field.
    *
    * @return ETrue if focus is on voip field.
    */
    TBool FocusOnVoipField() const;

    /**
    * Returns current field focused.
    */
    TPbkContactItemField& CurrentField() const;
    
    /**
     * Set allow exit mode 
     */
    void SetOkToExit(TBool aOkToExit);
    
    /**
     * Returns current status, allow or block exit.
     * Called from OkToExitL which is called by framewor. 
     */
    TBool IsOkToExit();

private: // constructors

    /**
    * Constructor.
    *
    * @param aIndex Selected item index, is updated by dialog after selection
    *               is made.
    * @param aArray Array of list box items.
    * @param aCommand Observer which executes dialog menu commands.
    * @param aContactRetrieval Used to get more information about contacts.
    * @param aContactEngine Used to create pbk contacts.
    * @param aActionService Contact action service.
    * @param aContactSelectorEnabled Flag indicating whether contact
    *                                selection is enabled.
    * @param aActiveItemIndex Initial active item index.
    */
    CPbkxRclResultInfoDlg( 
        TInt& aIndex, 
        CDesCArray* aArray, 
        MEikCommandObserver* aCommand,
        MPbkxRclContactRetrieval* aContactRetrieval,
        CPbkContactEngine& aContactEngine,
        CPbkxRclActionServiceWrapper& aActionService,
        TBool aContactSelectorEnabled,
        TInt aActiveItemIndex );
    
    /**
    * Second-phase constructor.
    */
    void ConstructL();    
    
private:
    
    /**
    * From CCoeControl,HandlePointerEventL.
    */
    void HandlePointerEventL(const TPointerEvent& aPointerEvent);   
   
    
    TInt FindIconIndex(TInt aId) const;
    void LoadIconArrayL();
    
private: // data

    // Array of items. Not owned.
    CDesCArray* iItems;

    // Contacts which information are shown. Owned.
    CPbkContactItem* iCurrentContact;
    
    // Title pane of the application. Not owned.
    CAknTitlePane* iTitlePane;
    
    // Currently active tab.
    TInt iActiveTabIndex;

    // Flag indicating whether contact selector is enabled or not.
    TBool iContactSelectorEnabled;

    // Interface through which contact details are retrieved. Not owned.
    MPbkxRclContactRetrieval* iContactRetrieval;

    // Contact engine to fetch the correct item priorities.
    CPbkContactEngine& iContactEngine;

    // Action service wrapper for handling menu commands.
    CPbkxRclActionServiceWrapper& iContactActionService;

    // Text shown in wait note when details are retrieved. Owned.
    RBuf iWaitNoteText;

    // Original title pane text. Owned.
    HBufC* iTitlePaneText;

    // Class for making callback requests. Owned.
    CPbkxRclCbRSender* iCallbackReqSender;

    // Currently visible fields. Owned.
    CPbkFieldArray* iVisibleFields;

    // Flag indicating that we are exiting dialog. After this is set
    // no key presses are handled.
    TBool iExit;
    
    // Flag indicating wether dialog should allow exit
    TBool iOkToExit;
    
    /// Own: Stylus popup menu
    CAknStylusPopUpMenu* iStylusPopup;
    
    // Owns
    RArray<TAknsItemID>*iSkinIcons;
    
    // Navi pane of the current UI application. Not owned.
    CAknNavigationControlContainer* iNaviPane;
    
    // Navigation label to be shown while result dialog is shown. Owned.
    CAknNavigationDecorator* iNaviDecorator;

    // To keep record is there visible focus in the listbox and was the event invoked
    //by tap or msk. These can be removed if in future there is function get corresponding
    //info reliably from listbox
    TBool iVisibleFocusOnList;
    TBool iMskEvent;
    };

#endif // CPBKXRCLRESULTINFODLG_H