phonebookui/cntlistmodel/cntcache.h
author hgs
Fri, 15 Oct 2010 12:24:46 +0300
changeset 81 640d30f4fb64
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
81
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2010 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: Asynchronously fetches and caches visual contact info for
hgs
parents:
diff changeset
    15
*              e.g. list views.
hgs
parents:
diff changeset
    16
*
hgs
parents:
diff changeset
    17
*/
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef CNTCACHE_H
hgs
parents:
diff changeset
    20
#define CNTCACHE_H
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <QObject>
hgs
parents:
diff changeset
    23
#include <QTimer>
hgs
parents:
diff changeset
    24
#include <QSet>
hgs
parents:
diff changeset
    25
#include <HbIcon>
hgs
parents:
diff changeset
    26
#include <cntuids.h>
hgs
parents:
diff changeset
    27
#include <qcontactmanager.h>
hgs
parents:
diff changeset
    28
#include <cntinfoprovider.h>
hgs
parents:
diff changeset
    29
hgs
parents:
diff changeset
    30
class CntNameFetcher;
hgs
parents:
diff changeset
    31
class CntInfoFetcher;
hgs
parents:
diff changeset
    32
class CntIconFetcher;
hgs
parents:
diff changeset
    33
class CntNameCacheItem;
hgs
parents:
diff changeset
    34
class CntInfoCacheItem;
hgs
parents:
diff changeset
    35
class CntIconCacheItem;
hgs
parents:
diff changeset
    36
hgs
parents:
diff changeset
    37
QTM_USE_NAMESPACE
hgs
parents:
diff changeset
    38
hgs
parents:
diff changeset
    39
class CntContactInfo : public QObject
hgs
parents:
diff changeset
    40
{
hgs
parents:
diff changeset
    41
    Q_OBJECT
hgs
parents:
diff changeset
    42
public:
hgs
parents:
diff changeset
    43
    CntContactInfo(QContactLocalId id,
hgs
parents:
diff changeset
    44
                   const QString& name,
hgs
parents:
diff changeset
    45
                   const QString& text,
hgs
parents:
diff changeset
    46
                   const HbIcon& icon1,
hgs
parents:
diff changeset
    47
                   const HbIcon& icon2)
hgs
parents:
diff changeset
    48
    {
hgs
parents:
diff changeset
    49
        mId = id;
hgs
parents:
diff changeset
    50
        mName = name;
hgs
parents:
diff changeset
    51
        mText = text;
hgs
parents:
diff changeset
    52
        mIcon1 = icon1;
hgs
parents:
diff changeset
    53
        mIcon2 = icon2;
hgs
parents:
diff changeset
    54
    }
hgs
parents:
diff changeset
    55
    ~CntContactInfo() {}
hgs
parents:
diff changeset
    56
hgs
parents:
diff changeset
    57
    int id() const { return mId; }
hgs
parents:
diff changeset
    58
    QString name() const { return mName; }
hgs
parents:
diff changeset
    59
    QString text() const { return mText; }
hgs
parents:
diff changeset
    60
    HbIcon icon1() const { return mIcon1; }
hgs
parents:
diff changeset
    61
    HbIcon icon2() const { return mIcon2; }
hgs
parents:
diff changeset
    62
hgs
parents:
diff changeset
    63
private:
hgs
parents:
diff changeset
    64
    QContactLocalId mId;
hgs
parents:
diff changeset
    65
    QString mName;
hgs
parents:
diff changeset
    66
    QString mText;
hgs
parents:
diff changeset
    67
    HbIcon mIcon1;
hgs
parents:
diff changeset
    68
    HbIcon mIcon2;
hgs
parents:
diff changeset
    69
};
hgs
parents:
diff changeset
    70
hgs
parents:
diff changeset
    71
class CntCache : public QObject
hgs
parents:
diff changeset
    72
{
hgs
parents:
diff changeset
    73
    Q_OBJECT
hgs
parents:
diff changeset
    74
public:
hgs
parents:
diff changeset
    75
    static CntCache* createSession(void *client, QContactManager *manager);
hgs
parents:
diff changeset
    76
    void closeSession(void *client);
hgs
parents:
diff changeset
    77
hgs
parents:
diff changeset
    78
    CntContactInfo* fetchContactInfo(int row, const QList<QContactLocalId>& idList);
hgs
parents:
diff changeset
    79
    QList<QContactLocalId> sortIdsByName(const QSet<QContactLocalId>* idFilter = NULL) const;
hgs
parents:
diff changeset
    80
    QList<QContactLocalId> sortIdsByName(const QStringList &searchList) const;
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
    bool event(QEvent *event);
hgs
parents:
diff changeset
    83
hgs
parents:
diff changeset
    84
signals:
hgs
parents:
diff changeset
    85
    void contactInfoUpdated(QContactLocalId contactId);
hgs
parents:
diff changeset
    86
    void contactsChanged(const QList<QContactLocalId> &changedContacts);
hgs
parents:
diff changeset
    87
    void contactsRemoved(const QList<QContactLocalId> &removedContacts);
hgs
parents:
diff changeset
    88
    void contactsAdded(const QList<QContactLocalId> &addedContacts);
hgs
parents:
diff changeset
    89
    void dataChanged();
hgs
parents:
diff changeset
    90
hgs
parents:
diff changeset
    91
private slots:
hgs
parents:
diff changeset
    92
    void startUrgencyMode();
hgs
parents:
diff changeset
    93
    void stopUrgencyMode();
hgs
parents:
diff changeset
    94
    void processJobs();
hgs
parents:
diff changeset
    95
    void postponeJobs(int postponementType, int duration = 0);
hgs
parents:
diff changeset
    96
    void resumeJobs();
hgs
parents:
diff changeset
    97
hgs
parents:
diff changeset
    98
    void updateCachedInfo(QContactLocalId contactId, const ContactInfoField &infoField, const QString &infoValue);
hgs
parents:
diff changeset
    99
    void cancelInfoFetch(QContactLocalId contactId);
hgs
parents:
diff changeset
   100
    void updateCachedIcon(const QString &iconName, const HbIcon &icon);
hgs
parents:
diff changeset
   101
    void cancelIconFetch(const QString &iconName);
hgs
parents:
diff changeset
   102
hgs
parents:
diff changeset
   103
    void updateContacts(const QList<QContactLocalId> &changedContacts);
hgs
parents:
diff changeset
   104
    void removeContacts(const QList<QContactLocalId> &removedContacts);
hgs
parents:
diff changeset
   105
    void addContacts(const QList<QContactLocalId> &addedContacts);
hgs
parents:
diff changeset
   106
hgs
parents:
diff changeset
   107
    void reformatNames(CntNameOrder newFormat);
hgs
parents:
diff changeset
   108
    void setNameList(QList<CntNameCacheItem *> newSortedNames);
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
private:
hgs
parents:
diff changeset
   111
    CntCache(QContactManager *manager);
hgs
parents:
diff changeset
   112
    ~CntCache();
hgs
parents:
diff changeset
   113
    void loadNames();
hgs
parents:
diff changeset
   114
    bool contactExists(QContactLocalId contactId) const;
hgs
parents:
diff changeset
   115
    QString contactName(QContactLocalId contactId) const;
hgs
parents:
diff changeset
   116
    CntInfoCacheItem* createInfoCacheItem(QContactLocalId contactId);
hgs
parents:
diff changeset
   117
    CntIconCacheItem* createIconCacheItem(const QString &iconName);
hgs
parents:
diff changeset
   118
    void updateReadAheadCache(int mostRecentRow, const QList<QContactLocalId> &idList);
hgs
parents:
diff changeset
   119
    void emitContactInfoUpdated(QContactLocalId contactId);
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
private:
hgs
parents:
diff changeset
   122
    static CntCache *mInstance;                 // the one and only instance of CntCache
hgs
parents:
diff changeset
   123
    QSet<void*> mClients;                       // the current clients of cache
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
    QContactManager *mContactManager;           // for getting notifications about changes to contacts
hgs
parents:
diff changeset
   126
    CntNameFetcher *mNameFetcher;               // fetches contact names
hgs
parents:
diff changeset
   127
    CntInfoFetcher *mInfoFetcher;               // fetches secondary text and icon paths
hgs
parents:
diff changeset
   128
    CntIconFetcher *mIconFetcher;               // fetches icons
hgs
parents:
diff changeset
   129
hgs
parents:
diff changeset
   130
    QList<CntNameCacheItem *> mSortedNames;                                 // list of all contact names, in sorted order
hgs
parents:
diff changeset
   131
    QHash<QContactLocalId, CntNameCacheItem *> mNameCache;                  // cache with all contact names, indexed by contact id
hgs
parents:
diff changeset
   132
    QHash<QContactLocalId, CntInfoCacheItem *> mInfoCache;                  // cache with recent contact info, indexed by contact id
hgs
parents:
diff changeset
   133
    QHash<QString, CntIconCacheItem *> mIconCache;                          // cache with recent icons, indexed by contact id and icon name
hgs
parents:
diff changeset
   134
    QList<QPair<QContactLocalId, int> > mReadAheadCache;                    // cache with contacts to prefetch (they are likely to be needed soon)
hgs
parents:
diff changeset
   135
hgs
parents:
diff changeset
   136
    QTimer mResumeJobsTimer;                    // timer used to resume postponed jobs
hgs
parents:
diff changeset
   137
    bool mProcessingJobs;                       // true from when job loop event has been posted until job loop exits
hgs
parents:
diff changeset
   138
    int mJobsPostponed;                         // are jobs postponed (no / for some time / until further notice)
hgs
parents:
diff changeset
   139
    bool mIsInUrgencyMode;                      // true if cache is in urgency mode; secondary info is fetched immediately
hgs
parents:
diff changeset
   140
    int mLastEmittedContactId;                  // id of the last contact emitted to UI
hgs
parents:
diff changeset
   141
    bool mHasModifiedNames;                     // monitors whether any names have changed since file cache was last updated
hgs
parents:
diff changeset
   142
    bool mAllNamesFetchStarted;                 // false until the asynch fetching of all names from the DB has started;
hgs
parents:
diff changeset
   143
                                                // this operation is done only once
hgs
parents:
diff changeset
   144
    friend class TestCntCache;
hgs
parents:
diff changeset
   145
};
hgs
parents:
diff changeset
   146
hgs
parents:
diff changeset
   147
#endif