messagingappbase/mce/inc/MceBitmapResolver.h
author hgs
Thu, 04 Nov 2010 02:02:03 +0530
changeset 81 2043ea884c04
parent 79 2981cb3aa489
permissions -rw-r--r--
201044_03
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
79
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     3
* All rights reserved.
hgs
parents:
diff changeset
     4
* This component and the accompanying materials are made available
hgs
parents:
diff changeset
     5
* under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     6
* which accompanies this distribution, and is available
hgs
parents:
diff changeset
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     8
*
hgs
parents:
diff changeset
     9
* Initial Contributors:
hgs
parents:
diff changeset
    10
* Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    11
*
hgs
parents:
diff changeset
    12
* Contributors:
hgs
parents:
diff changeset
    13
*
hgs
parents:
diff changeset
    14
* Description:  
hgs
parents:
diff changeset
    15
*     Handles different mce bitmaps.
hgs
parents:
diff changeset
    16
*     First collects all the bitmaps from different mtm's and also local
hgs
parents:
diff changeset
    17
*     folder's bitmaps to icon array.
hgs
parents:
diff changeset
    18
*
hgs
parents:
diff changeset
    19
*/
hgs
parents:
diff changeset
    20
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
hgs
parents:
diff changeset
    23
#ifndef MCEBITMAPRESOLVER_H
hgs
parents:
diff changeset
    24
#define MCEBITMAPRESOLVER_H
hgs
parents:
diff changeset
    25
hgs
parents:
diff changeset
    26
//  INCLUDES
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
#include "mcetemplate.h"
hgs
parents:
diff changeset
    29
#include <AknsUtils.h>
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
//cmail update
hgs
parents:
diff changeset
    32
#define KUidMsgTypeFsMtmVal               0x2001F406
hgs
parents:
diff changeset
    33
hgs
parents:
diff changeset
    34
// CONSTANTS
hgs
parents:
diff changeset
    35
const TInt KMceMmsPriority = 1;	// For loading the MMS priority icons
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
// DATA TYPES
hgs
parents:
diff changeset
    38
// these should correspond to the icon array created in CMceBitmapResolver::ConstructL
hgs
parents:
diff changeset
    39
enum TMceBitmapArrayIndexes
hgs
parents:
diff changeset
    40
    {
hgs
parents:
diff changeset
    41
    EMceBitmapIndexMessageSelected = 0,
hgs
parents:
diff changeset
    42
    EMceBitmapIndexWrite,
hgs
parents:
diff changeset
    43
    EMceBitmapIndexRemote,
hgs
parents:
diff changeset
    44
    EMceBitmapIndexRemoteNew,
hgs
parents:
diff changeset
    45
    EMceBitmapIndexDr,
hgs
parents:
diff changeset
    46
    EMceBitmapIndexInbox,
hgs
parents:
diff changeset
    47
    EMceBitmapIndexInboxNew,
hgs
parents:
diff changeset
    48
    EMceBitmapIndexDocuments,
hgs
parents:
diff changeset
    49
    EMceBitmapIndexDocumentsNew,
hgs
parents:
diff changeset
    50
    EMceBitmapIndexDrafts,
hgs
parents:
diff changeset
    51
    EMceBitmapIndexSent,
hgs
parents:
diff changeset
    52
    EMceBitmapIndexOutbox,
hgs
parents:
diff changeset
    53
    EMceBitmapIndexUnknown,
hgs
parents:
diff changeset
    54
    EMceBitmapIndexFolderTemp,
hgs
parents:
diff changeset
    55
    EMceBitmapIndexFolderSmall,
hgs
parents:
diff changeset
    56
    EMceBitmapIndexFolderSmallNew,
hgs
parents:
diff changeset
    57
    EMceBitmapIndexAttachment,
hgs
parents:
diff changeset
    58
    EMceBitmapIndexMailboxConnectionOn,
hgs
parents:
diff changeset
    59
    EMceBitmapIndexAlwaysAdd,
hgs
parents:
diff changeset
    60
    EMceBitmapIndexInactiveAdd,
hgs
parents:
diff changeset
    61
    EMceBitmapIndexAlwaysRoaming,
hgs
parents:
diff changeset
    62
    EMceBitmapIndexPriorityHigh,
hgs
parents:
diff changeset
    63
    EMceBitmapIndexPriorityLow,
hgs
parents:
diff changeset
    64
    EMceBitmapIndexConversation,
hgs
parents:
diff changeset
    65
    EMceBitmapIndexConversationNew,
hgs
parents:
diff changeset
    66
    EMceBitmapIndexReplaceMtmIcon // this MUST be last
hgs
parents:
diff changeset
    67
    };
hgs
parents:
diff changeset
    68
hgs
parents:
diff changeset
    69
// FORWARD DECLARATIONS
hgs
parents:
diff changeset
    70
class CMsvSession;
hgs
parents:
diff changeset
    71
class MMtmUiDataRegistryObserver;
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
// CLASS DECLARATION
hgs
parents:
diff changeset
    74
hgs
parents:
diff changeset
    75
/**
hgs
parents:
diff changeset
    76
*  Helper class for bitmap resolver.
hgs
parents:
diff changeset
    77
*/
hgs
parents:
diff changeset
    78
class TMceBitmapListItem
hgs
parents:
diff changeset
    79
    {
hgs
parents:
diff changeset
    80
    public:                     // Data
hgs
parents:
diff changeset
    81
        TBool       iExtraItem;
hgs
parents:
diff changeset
    82
        TUid        iType;  // if extra item, includes application uid to load correct application icon...
hgs
parents:
diff changeset
    83
        TUid        iMtm;
hgs
parents:
diff changeset
    84
        TInt        iIndex; // probably not neccessary
hgs
parents:
diff changeset
    85
        TMsvId      iId;    // needed with inbox, outbox, etc.
hgs
parents:
diff changeset
    86
    };
hgs
parents:
diff changeset
    87
hgs
parents:
diff changeset
    88
/**
hgs
parents:
diff changeset
    89
*  Handles different mce bitmaps.
hgs
parents:
diff changeset
    90
*  First collects all the bitmaps from different mtm's and also local
hgs
parents:
diff changeset
    91
*  folder's bitmaps to icon array.
hgs
parents:
diff changeset
    92
*/
hgs
parents:
diff changeset
    93
class CMceBitmapResolver : public CBase
hgs
parents:
diff changeset
    94
    {
hgs
parents:
diff changeset
    95
    public:  // Constructors and destructor
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
        /**
hgs
parents:
diff changeset
    98
        * Two-phased constructor.
hgs
parents:
diff changeset
    99
        */
hgs
parents:
diff changeset
   100
        static CMceBitmapResolver* NewL(
hgs
parents:
diff changeset
   101
            CMsvSessionPtr aSession,
hgs
parents:
diff changeset
   102
            MMtmUiDataRegistryObserver& aRegObserver,
hgs
parents:
diff changeset
   103
            TBool aLargeIcons );
hgs
parents:
diff changeset
   104
hgs
parents:
diff changeset
   105
        /**
hgs
parents:
diff changeset
   106
        * Destructor.
hgs
parents:
diff changeset
   107
        */
hgs
parents:
diff changeset
   108
        ~CMceBitmapResolver();
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
        /**
hgs
parents:
diff changeset
   111
        * Returns pointer to icon array.
hgs
parents:
diff changeset
   112
        * @return Pointer to icon array.
hgs
parents:
diff changeset
   113
        */
hgs
parents:
diff changeset
   114
        CArrayPtrFlat<CGulIcon>* IconArray();
hgs
parents:
diff changeset
   115
hgs
parents:
diff changeset
   116
        /**
hgs
parents:
diff changeset
   117
        * Can be used to get index of the bitmap of the message.
hgs
parents:
diff changeset
   118
        * @param aItem: Fill TMceBitmapListItem fields before calling this.
hgs
parents:
diff changeset
   119
        * @return Index of the bitmap requested.
hgs
parents:
diff changeset
   120
        */
hgs
parents:
diff changeset
   121
        TInt BitmapIndex( const TMceBitmapListItem& aItem ) const;
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
        /**
hgs
parents:
diff changeset
   124
        * Can be used to get index of the bitmap of the message.
hgs
parents:
diff changeset
   125
        * Loads bitmap from the mtm ui data and changes it to be last icon in icon array
hgs
parents:
diff changeset
   126
        * @param aEntry: Fill TMsvEntry fields before calling this.
hgs
parents:
diff changeset
   127
        * @return Index of the bitmap requested.
hgs
parents:
diff changeset
   128
        */
hgs
parents:
diff changeset
   129
        TInt BitmapIndex( const TMsvEntry& aEntry );
hgs
parents:
diff changeset
   130
hgs
parents:
diff changeset
   131
#ifdef RD_MSG_NAVIPANE_IMPROVEMENT
hgs
parents:
diff changeset
   132
        /**
hgs
parents:
diff changeset
   133
        * Can be used to get index of the bitmap of the message.
hgs
parents:
diff changeset
   134
        * Loads bitmap from the mtm ui data and changes it to be last icon in icon array
hgs
parents:
diff changeset
   135
        * Since 5.0
hgs
parents:
diff changeset
   136
        * @param aEntry: Fill TMsvEntry fields before calling this.
hgs
parents:
diff changeset
   137
        * @param aMessageCount: number of messages under the entry (0 if entry is not folder)
hgs
parents:
diff changeset
   138
        * @return Index of the bitmap requested.
hgs
parents:
diff changeset
   139
        */
hgs
parents:
diff changeset
   140
        TInt BitmapIndex( const TMsvEntry& aEntry, TInt& aMessageCount );
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
        /**
hgs
parents:
diff changeset
   143
        * Checks if entry aId has unread children.
hgs
parents:
diff changeset
   144
        * Since 5.0
hgs
parents:
diff changeset
   145
        * @param aId: folder or service to be checked.
hgs
parents:
diff changeset
   146
        * @param aMessages:number of messages under the folder or service.
hgs
parents:
diff changeset
   147
        * @param aUnreadMessages: number of unread messages under the folder or service.
hgs
parents:
diff changeset
   148
        * @return ETrue if unread children found.
hgs
parents:
diff changeset
   149
        */
hgs
parents:
diff changeset
   150
        TBool HasUnreadMessagesL( const TMsvId aId, TInt& aMessages, TInt& aUnreadMessages );
hgs
parents:
diff changeset
   151
		
hgs
parents:
diff changeset
   152
        /**
hgs
parents:
diff changeset
   153
         * Find Visible Count for local service Draft\sent\outbox folder
hgs
parents:
diff changeset
   154
         * Unread message check is not required.
hgs
parents:
diff changeset
   155
         * @param aId: folder ID of local service.
hgs
parents:
diff changeset
   156
         * @return TInt Return Message Count visble in messaging main view
hgs
parents:
diff changeset
   157
         */
hgs
parents:
diff changeset
   158
        TInt FindVisibleCountL(TMsvId aFolderId ) const;
hgs
parents:
diff changeset
   159
         
hgs
parents:
diff changeset
   160
        /**
hgs
parents:
diff changeset
   161
         * Find Visible Count for local service Inbox folder
hgs
parents:
diff changeset
   162
         * Unread message check is  required here to show Inbox icon with u
hgs
parents:
diff changeset
   163
         * @param aId: folder ID of local service.
hgs
parents:
diff changeset
   164
         * @param aUnreadMessages: It will be True if Inbox has atleast
hgs
parents:
diff changeset
   165
         *        one unread message.
hgs
parents:
diff changeset
   166
         * @return TInt Return Message Count visble in messaging main view
hgs
parents:
diff changeset
   167
         */
hgs
parents:
diff changeset
   168
        TInt FindVisibleCountWithUnreadMessageL(TMsvId aFolderId , TBool& aUnreadMessages) const;
hgs
parents:
diff changeset
   169
         
hgs
parents:
diff changeset
   170
        
hgs
parents:
diff changeset
   171
#else
hgs
parents:
diff changeset
   172
hgs
parents:
diff changeset
   173
        /**
hgs
parents:
diff changeset
   174
        * Checks if entry aId has unread children.
hgs
parents:
diff changeset
   175
        * @param aId: folder or service to be checked.
hgs
parents:
diff changeset
   176
        * @return ETrue if unread children found.
hgs
parents:
diff changeset
   177
        */
hgs
parents:
diff changeset
   178
        TBool HasUnreadMessagesL( const TMsvId aId );
hgs
parents:
diff changeset
   179
#endif // RD_MSG_NAVIPANE_IMPROVEMENT
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
        /**
hgs
parents:
diff changeset
   182
        * Changes the bitmaps in icon array, if skin is changed
hgs
parents:
diff changeset
   183
        */
hgs
parents:
diff changeset
   184
        void ChangeBitmapInIconArrayL(  );
hgs
parents:
diff changeset
   185
 
hgs
parents:
diff changeset
   186
        /**
hgs
parents:
diff changeset
   187
        * Loads correct bitmap of the message from the mtm ui data and changes
hgs
parents:
diff changeset
   188
        * it to the last of the iIcons array. In ConstructL dummy icon is added to the
hgs
parents:
diff changeset
   189
        * last so that it can be changed.
hgs
parents:
diff changeset
   190
        * @param aEntry: entry to be loaded.
hgs
parents:
diff changeset
   191
        *        aPriority ETrue if the method is called to retrieve the icon of
hgs
parents:
diff changeset
   192
        *                  high or low priority of a MMS
hgs
parents:
diff changeset
   193
        * @param aHasUnreadMessages ETrue if current service/folder has unread messages, othervise EFalse.
hgs
parents:
diff changeset
   194
        *        this is needed because BitmapIndex is already doing this calculation so prevent duplicate calculation.
hgs
parents:
diff changeset
   195
        * @return Index of the bitmap requested.
hgs
parents:
diff changeset
   196
        */
hgs
parents:
diff changeset
   197
#ifndef RD_MSG_NAVIPANE_IMPROVEMENT
hgs
parents:
diff changeset
   198
        TInt LoadBitmapL( const TMsvEntry& aEntry, TBool aPriority = EFalse );
hgs
parents:
diff changeset
   199
#else
hgs
parents:
diff changeset
   200
        TInt LoadBitmapL( const TMsvEntry& aEntry, TBool aHasUnreadMessages );
hgs
parents:
diff changeset
   201
#endif
hgs
parents:
diff changeset
   202
        /**
hgs
parents:
diff changeset
   203
        * Loads and adds local bitmap to icon array.
hgs
parents:
diff changeset
   204
        * @param aId
hgs
parents:
diff changeset
   205
        * @param aFileName
hgs
parents:
diff changeset
   206
        * @param aBitmapIndex
hgs
parents:
diff changeset
   207
        * @param aListItem
hgs
parents:
diff changeset
   208
        */
hgs
parents:
diff changeset
   209
        void CreateAndAppendIconL(
hgs
parents:
diff changeset
   210
            TAknsItemID aId,
hgs
parents:
diff changeset
   211
            const TDesC& aFileName,
hgs
parents:
diff changeset
   212
            TInt aBitmapIndex,
hgs
parents:
diff changeset
   213
            const TMceBitmapListItem* aListItem = NULL,
hgs
parents:
diff changeset
   214
            TBool aColorSkinnedIcon = EFalse );
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
                    
hgs
parents:
diff changeset
   217
        /**
hgs
parents:
diff changeset
   218
        * Returns bitmap index which is used as placeholder for
hgs
parents:
diff changeset
   219
        * mtm icons
hgs
parents:
diff changeset
   220
        * @since 3.0
hgs
parents:
diff changeset
   221
        * @return index in the icon array
hgs
parents:
diff changeset
   222
        */
hgs
parents:
diff changeset
   223
        TInt MtmIconIndex();
hgs
parents:
diff changeset
   224
        
hgs
parents:
diff changeset
   225
        /**
hgs
parents:
diff changeset
   226
        * description length defined in muiu cenrep file.
hgs
parents:
diff changeset
   227
        * KCRUidMuiuSettings / KMuiuDescriptionLength
hgs
parents:
diff changeset
   228
        */
hgs
parents:
diff changeset
   229
        TInt DescriptionLength();
hgs
parents:
diff changeset
   230
        
hgs
parents:
diff changeset
   231
        
hgs
parents:
diff changeset
   232
    private:
hgs
parents:
diff changeset
   233
hgs
parents:
diff changeset
   234
        /**
hgs
parents:
diff changeset
   235
        * Constructor.
hgs
parents:
diff changeset
   236
        */
hgs
parents:
diff changeset
   237
        CMceBitmapResolver(
hgs
parents:
diff changeset
   238
            CMsvSessionPtr aSession,
hgs
parents:
diff changeset
   239
            MMtmUiDataRegistryObserver& aRegObserver,
hgs
parents:
diff changeset
   240
            TBool aLargeIcons );
hgs
parents:
diff changeset
   241
hgs
parents:
diff changeset
   242
        /**
hgs
parents:
diff changeset
   243
        * By default Symbian OS constructor is private.
hgs
parents:
diff changeset
   244
        */
hgs
parents:
diff changeset
   245
        void ConstructL();
hgs
parents:
diff changeset
   246
hgs
parents:
diff changeset
   247
        /**
hgs
parents:
diff changeset
   248
        * Loads and adds local bitmap to icon array. Uses \system\data\muiu.mbm
hgs
parents:
diff changeset
   249
        * @param aId
hgs
parents:
diff changeset
   250
        * @param aBitmapIndex
hgs
parents:
diff changeset
   251
        * @param aListItem
hgs
parents:
diff changeset
   252
        */
hgs
parents:
diff changeset
   253
        void CreateAndAppendIconL(
hgs
parents:
diff changeset
   254
            TAknsItemID aId,
hgs
parents:
diff changeset
   255
            TInt aBitmapIndex,
hgs
parents:
diff changeset
   256
            const TMceBitmapListItem* aListItem = NULL );
hgs
parents:
diff changeset
   257
hgs
parents:
diff changeset
   258
        /**
hgs
parents:
diff changeset
   259
        * Returns bitmap index of the entry
hgs
parents:
diff changeset
   260
        * @param aEntryId: id of the entry to be returned
hgs
parents:
diff changeset
   261
        * @return index of the bitmap
hgs
parents:
diff changeset
   262
        */
hgs
parents:
diff changeset
   263
        TInt LocalEntryBitmapIndex( TMsvId aEntryId ) const;
hgs
parents:
diff changeset
   264
hgs
parents:
diff changeset
   265
    private:    // Data
hgs
parents:
diff changeset
   266
        MMtmUiDataRegistryObserver& iRegObserver;
hgs
parents:
diff changeset
   267
        CMsvSessionPtr              iSession;
hgs
parents:
diff changeset
   268
        TBool                       iLargeIcons; // ETrue if large icons == main view
hgs
parents:
diff changeset
   269
hgs
parents:
diff changeset
   270
        CArrayPtrFlat<CGulIcon>*    iIcons;
hgs
parents:
diff changeset
   271
        CArrayFixFlat<TMceBitmapListItem>* iIconIndexes;
hgs
parents:
diff changeset
   272
hgs
parents:
diff changeset
   273
        // security data caging
hgs
parents:
diff changeset
   274
        TFileName                   iFilenameMuiu;
hgs
parents:
diff changeset
   275
        TFileName                   iFilenameAvkon;
hgs
parents:
diff changeset
   276
        TInt                        iBitmapsLoaded;
hgs
parents:
diff changeset
   277
        
hgs
parents:
diff changeset
   278
        TInt                        iDescriptionLength;
hgs
parents:
diff changeset
   279
        
hgs
parents:
diff changeset
   280
        /**
hgs
parents:
diff changeset
   281
         * Email Framework Feature flag.
hgs
parents:
diff changeset
   282
         * ETure if Feature in ON
hgs
parents:
diff changeset
   283
         * otherwsie EFalse. 
hgs
parents:
diff changeset
   284
         */
hgs
parents:
diff changeset
   285
        TBool                       iEmailFramework;
hgs
parents:
diff changeset
   286
    };
hgs
parents:
diff changeset
   287
hgs
parents:
diff changeset
   288
hgs
parents:
diff changeset
   289
#endif
hgs
parents:
diff changeset
   290
hgs
parents:
diff changeset
   291
hgs
parents:
diff changeset
   292
// End of file