phonebookui/Phonebook2/remotecontactlookup/contactactionservice/inc/CFscContactNameFormatterBase.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 0 e686773b3f54
permissions -rw-r--r--
Revision: 201039 Kit: 201041

/*
* 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:  A base class for contact name formatters
 *
*/


#ifndef CFSCCONTACTNAMEFORMATTERBASE_H
#define CFSCCONTACTNAMEFORMATTERBASE_H

//  INCLUDES
#include <e32base.h>
#include <MPbk2ContactNameFormatter.h>
#include "TFscSortOrderFieldMapper.h"

// FORWARD DECLARATIONS
class CPbk2SortOrderManager;
class MVPbkFieldTypeList;
class CVPbkFieldTypeRefsList;
class CVPbkFieldTypeSelector;
class TResourceReader;

// CLASS DECLARATION

/**
 *  A base class for contact name formatters
 *
 */
NONSHARABLE_CLASS( CFscContactNameFormatterBase )
: public CBase,
public MPbk2ContactNameFormatter
    {
public: // Constructors and destructor

    /**
     * Destructor.
     */
    virtual ~CFscContactNameFormatterBase();

public: // Functions from MPbk2ContactNameFormatter

    HBufC* GetContactTitleOrNullL(
            const MVPbkBaseContactFieldCollection& aContactFields,
            TUint32 aFormattingFlags);
    HBufC* GetContactTitleL(
            const MVPbkBaseContactFieldCollection& aContactFields,
            TUint32 aFormattingFlags);
    virtual void GetContactTitle(
            const MVPbkBaseContactFieldCollection& aContactFields,
            TDes& aTitle,
            TUint32 aFormattingFlags) = 0;
    virtual void GetContactTitleForFind(
            const MVPbkBaseContactFieldCollection& aContactFields,
            TDes& aTitle,
            TUint32 aFormattingFlags) = 0;

    const TDesC& UnnamedText() const;
    TBool IsTitleField(
            const MVPbkBaseContactField& aContactField) const;
    TBool IsTitleFieldType(
            const MVPbkFieldType& aFieldType) const;
    virtual CVPbkBaseContactFieldTypeListIterator* ActualTitleFieldsLC(
            CVPbkFieldTypeRefsList& aFieldTypeList,
            const MVPbkBaseContactFieldCollection& aContactFields ) = 0;
    virtual TInt MaxTitleLength(
            const MVPbkBaseContactFieldCollection& aContactFields,
            const TUint32 aFormattingFlags) = 0;
    virtual TInt MaxTitleLengthForFind(
            const MVPbkBaseContactFieldCollection& aContactFields,
            const TUint32 aFormattingFlags) = 0;
    virtual TBool IsFindSeparatorChar( TChar aCh ) = 0;

protected: // New functions

    /**
     * Field mapper returns fields from the given contact fields
     * in the order defined by iSortOrderManager. Must be called
     * from sub class functions
     * @param aContactFields current fields
     */
    void SetFieldMapper(
            const MVPbkBaseContactFieldCollection& aContactFields );

    /**
     * Get contact title according to given sort order positions
     *
     * @param aTitle a descriptor for adding data
     * @param aFormattingFlags flags from the client
     * @param aStartingPosition the index of the first type
     *           in the sort order that is used for title
     * @param aEndingPosition the index of the last type
     *           in the sort order that is used for title
     */
    void DoGetContactTitle(
            TDes& aTitle,
            TUint32 aFormattingFlags,
            const TInt aStartingPosition,
            const TInt aEndingPosition);

    /**
     * Returns the maximum length of the title
     *
     * @param aFormattingFlags flags from the client
     * @param aStartingPosition the index of the first type
     *           in the sort order that is used for title
     * @param aEndingPosition the index of the last type
     *           in the sort order that is used for title
     */
    TInt DoCalculateMaxTitleLength(
            const TUint32 aFormattingFlags,
            const TInt aStartingPosition,
            const TInt aEndingPosition);

    /**
     * Return non empty title field types
     *
     * @param aFieldTypeList target list where field types are appended
     * @param aStartingPosition the index of the first type
     *           in the sort order that is used for title
     * @param aEndingPosition the index of the last type
     *           in the sort order that is used for title
     */
    void DoAppendNonEmptyTitleFieldTypesL(
            CVPbkFieldTypeRefsList& aFieldTypeList,
            const TInt aStartingPosition,
            const TInt aEndingPosition);

    /**
     * Check if title fields are empty
     *
     * @param aStartingPosition the index of the first type
     *           in the sort order that is used for title
     * @param aEndingPosition the index of the last type
     *           in the sort order that is used for title
     * @return ETrue if title fields are empty else EFalse
     */
    TBool AreTitleFieldsEmpty(
            const TInt aStartingPosition,
            const TInt aEndingPosition ) const;

protected:

    /**
     * C++ default constructor.
     */
    CFscContactNameFormatterBase(
            const MVPbkFieldTypeList& aMasterFieldTypeList,
            const CPbk2SortOrderManager& aSortOrderManager);

    /**
     * By default Symbian 2nd phase constructor is protected.
     */
    void BaseConstructL( const TDesC& aUnnamedText,
            CVPbkFieldTypeSelector* aTitleFieldSelector );

private: // Implementation
    TBool RequiresSeparatorBetweenNames(
            const TDesC& aLhs,
            const TDesC& aRhs) const;
    void TakePartOfName(
            const MVPbkBaseContactField* aField,
            TDes& aTitle,
            const TUint32 aFormattingFlags,
            const TBool aUseSeparator) const;
    void CalculatePartOfName(
            const MVPbkBaseContactField* aField,
            TInt& aLength,
            const TUint32 aFormattingFlags,
            const TBool aUseSeparator) const;

protected: // Data
    /// Own: Field mapper
    TFscSortOrderFieldMapper iFieldMapper;

private: // Data
    const MVPbkFieldTypeList& iMasterFieldTypeList;
    /// Ref: Sort order manager
    const CPbk2SortOrderManager& iSortOrderManager;
    /// Own: Text for unnamed contacts
    HBufC* iUnnamedText;
    /// Own: Title field selector
    CVPbkFieldTypeSelector* iTitleFieldSelector;
    };

#endif      // CFSCCONTACTNAMEFORMATTERBASE_H
// End of File