emailservices/nmutilities/src/nmcontacthistorymodel_p.cpp
author hgs
Thu, 14 Oct 2010 17:33:43 +0300
changeset 76 38bf5461e270
parent 74 6c59112cfd31
permissions -rw-r--r--
201041
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
68
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: Private implementation of Contact History Model API
hgs
parents:
diff changeset
    15
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#include "emailmru.h"
74
hgs
parents: 68
diff changeset
    19
#include "emailtrace.h"
68
hgs
parents:
diff changeset
    20
#include "nmcontacthistorymodel_p.h"
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
    23
// Start of implementation (NmContactHistoryModelPrivate)
hgs
parents:
diff changeset
    24
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
    25
/*!
hgs
parents:
diff changeset
    26
    Constructor of NmContactHistoryModelPrivate
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
    \param type The valid values are described by
hgs
parents:
diff changeset
    29
    NmContactHistoryModelPrivate::HistoryModelType enum.
hgs
parents:
diff changeset
    30
*/
hgs
parents:
diff changeset
    31
NmContactHistoryModelPrivate::NmContactHistoryModelPrivate(
hgs
parents:
diff changeset
    32
    const NmContactHistoryModelType modelType) :
hgs
parents:
diff changeset
    33
    mType(modelType),
74
hgs
parents: 68
diff changeset
    34
    mContactManager(NULL),
68
hgs
parents:
diff changeset
    35
    mModelReady(false)
hgs
parents:
diff changeset
    36
{
74
hgs
parents: 68
diff changeset
    37
    NM_FUNCTION;
hgs
parents: 68
diff changeset
    38
68
hgs
parents:
diff changeset
    39
    mContactManager = new QContactManager("symbian");
hgs
parents:
diff changeset
    40
    mNameOrder = EmailMRU::nameOrder();
hgs
parents:
diff changeset
    41
}
hgs
parents:
diff changeset
    42
hgs
parents:
diff changeset
    43
/*!
hgs
parents:
diff changeset
    44
    Destructor of ContactHistoryModel
hgs
parents:
diff changeset
    45
*/
hgs
parents:
diff changeset
    46
NmContactHistoryModelPrivate::~NmContactHistoryModelPrivate()
hgs
parents:
diff changeset
    47
{
74
hgs
parents: 68
diff changeset
    48
    NM_FUNCTION;
hgs
parents: 68
diff changeset
    49
68
hgs
parents:
diff changeset
    50
    delete mContactManager;
hgs
parents:
diff changeset
    51
    mPrivateItemList.clear();
hgs
parents:
diff changeset
    52
    mModelItemList.clear();
hgs
parents:
diff changeset
    53
}
hgs
parents:
diff changeset
    54
hgs
parents:
diff changeset
    55
/*!
hgs
parents:
diff changeset
    56
    Searches contact & MRU  databases according to query parameters.
76
hgs
parents: 74
diff changeset
    57
    Emits queryCompleted() when ready.
68
hgs
parents:
diff changeset
    58
hgs
parents:
diff changeset
    59
    \param query Text to be searched
hgs
parents:
diff changeset
    60
    \return none
hgs
parents:
diff changeset
    61
hgs
parents:
diff changeset
    62
    Note:: QContactManager supports max. ten characters long queries.
hgs
parents:
diff changeset
    63
*/
hgs
parents:
diff changeset
    64
void NmContactHistoryModelPrivate::queryDatabases(const QString& query)
hgs
parents:
diff changeset
    65
{
74
hgs
parents: 68
diff changeset
    66
    NM_FUNCTION;
hgs
parents: 68
diff changeset
    67
68
hgs
parents:
diff changeset
    68
    mModelReady = false;
hgs
parents:
diff changeset
    69
    // Clear contacts in the list
hgs
parents:
diff changeset
    70
    mPrivateItemList.clear();
hgs
parents:
diff changeset
    71
    mModelItemList.clear();
hgs
parents:
diff changeset
    72
    mMruList.clear();
hgs
parents:
diff changeset
    73
    mMruMatches.clear();
hgs
parents:
diff changeset
    74
74
hgs
parents: 68
diff changeset
    75
    mNameOrder = EmailMRU::nameOrder();
hgs
parents: 68
diff changeset
    76
68
hgs
parents:
diff changeset
    77
    // Modify search to suit our needs
hgs
parents:
diff changeset
    78
    // Space must be removed, because it is understood as logigal AND
hgs
parents:
diff changeset
    79
    // with QContactManager API
hgs
parents:
diff changeset
    80
    QString modifiedQuery = query;
hgs
parents:
diff changeset
    81
hgs
parents:
diff changeset
    82
    int spcPosition = query.indexOf(" ");
hgs
parents:
diff changeset
    83
76
hgs
parents: 74
diff changeset
    84
    if ( spcPosition != -1 ) {
68
hgs
parents:
diff changeset
    85
        modifiedQuery = query.left(spcPosition);
74
hgs
parents: 68
diff changeset
    86
    }
68
hgs
parents:
diff changeset
    87
74
hgs
parents: 68
diff changeset
    88
    // Get matching MRU items
68
hgs
parents:
diff changeset
    89
    queryMruDatabase(modifiedQuery);
74
hgs
parents: 68
diff changeset
    90
    
hgs
parents: 68
diff changeset
    91
    // Populate mPrivateItemList with matching MRU items.
68
hgs
parents:
diff changeset
    92
    populateListWithMruItems(modifiedQuery);
hgs
parents:
diff changeset
    93
74
hgs
parents: 68
diff changeset
    94
    // Get matching IDs from Contacts DB
hgs
parents: 68
diff changeset
    95
    QList<QContactLocalId> cnt_ids = queryContactDatabase(modifiedQuery);
68
hgs
parents:
diff changeset
    96
74
hgs
parents: 68
diff changeset
    97
    // Populate mPrivateItemList with contact items.
hgs
parents: 68
diff changeset
    98
    populateListWithContactItems(cnt_ids, modifiedQuery);
68
hgs
parents:
diff changeset
    99
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
    emit queryCompleted(0);
hgs
parents:
diff changeset
   102
}
hgs
parents:
diff changeset
   103
hgs
parents:
diff changeset
   104
/*!
hgs
parents:
diff changeset
   105
    Internal helper function for queryDatabases()
hgs
parents:
diff changeset
   106
    Not meant to be used alone.
hgs
parents:
diff changeset
   107
hgs
parents:
diff changeset
   108
    \param query Text to be searched
hgs
parents:
diff changeset
   109
    \return list of Contact items.
hgs
parents:
diff changeset
   110
    \sa queryDatabases( )
hgs
parents:
diff changeset
   111
*/
hgs
parents:
diff changeset
   112
QList<QContactLocalId> NmContactHistoryModelPrivate::queryContactDatabase(
hgs
parents:
diff changeset
   113
    const QString &query)
hgs
parents:
diff changeset
   114
{
74
hgs
parents: 68
diff changeset
   115
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   116
68
hgs
parents:
diff changeset
   117
    // Define filter
hgs
parents:
diff changeset
   118
    QContactDetailFilter df;
hgs
parents:
diff changeset
   119
hgs
parents:
diff changeset
   120
    df.setDetailDefinitionName(QContactEmailAddress::DefinitionName,
hgs
parents:
diff changeset
   121
                               QContactEmailAddress::FieldEmailAddress );
hgs
parents:
diff changeset
   122
hgs
parents:
diff changeset
   123
    df.setMatchFlags( QContactFilter::MatchKeypadCollation );
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
    // Construct pattern
hgs
parents:
diff changeset
   126
    QString pattern = query + QChar(30) + QString("vqwerty");
hgs
parents:
diff changeset
   127
    df.setValue( pattern );
hgs
parents:
diff changeset
   128
hgs
parents:
diff changeset
   129
    // Get matching IDs
hgs
parents:
diff changeset
   130
    QList<QContactLocalId> cnt_ids = mContactManager->contactIds( df );
hgs
parents:
diff changeset
   131
hgs
parents:
diff changeset
   132
    return cnt_ids;
hgs
parents:
diff changeset
   133
}
hgs
parents:
diff changeset
   134
hgs
parents:
diff changeset
   135
/*!
hgs
parents:
diff changeset
   136
    Internal helper function for queryDatabases()
hgs
parents:
diff changeset
   137
    Not meant to be used alone.
hgs
parents:
diff changeset
   138
hgs
parents:
diff changeset
   139
    \param query Text to be searched from MRU
hgs
parents:
diff changeset
   140
    \return true on success.
hgs
parents:
diff changeset
   141
    \sa queryDatabases( )
hgs
parents:
diff changeset
   142
*/
hgs
parents:
diff changeset
   143
bool NmContactHistoryModelPrivate::queryMruDatabase(
hgs
parents:
diff changeset
   144
    const QString &query)
hgs
parents:
diff changeset
   145
{
74
hgs
parents: 68
diff changeset
   146
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   147
    bool rVal = false;
hgs
parents: 68
diff changeset
   148
    
76
hgs
parents: 74
diff changeset
   149
    if (mType == EmailAddressModel) {
68
hgs
parents:
diff changeset
   150
        bool mruListFilled = fillMruMatchList();
hgs
parents:
diff changeset
   151
76
hgs
parents: 74
diff changeset
   152
        if (!mruListFilled) {
74
hgs
parents: 68
diff changeset
   153
            return rVal;
68
hgs
parents:
diff changeset
   154
        }
hgs
parents:
diff changeset
   155
hgs
parents:
diff changeset
   156
        QHashIterator<QString, QString> i(mMruList);
hgs
parents:
diff changeset
   157
76
hgs
parents: 74
diff changeset
   158
        while (i.hasNext()) {
68
hgs
parents:
diff changeset
   159
            i.next();
hgs
parents:
diff changeset
   160
hgs
parents:
diff changeset
   161
            QString address = i.key();
hgs
parents:
diff changeset
   162
            QString name = i.value();
hgs
parents:
diff changeset
   163
76
hgs
parents: 74
diff changeset
   164
            if ((name.length() == 0) && (address.contains('@'))) {
68
hgs
parents:
diff changeset
   165
                name = address.left(address.indexOf("@"));
hgs
parents:
diff changeset
   166
            }
hgs
parents:
diff changeset
   167
76
hgs
parents: 74
diff changeset
   168
            if (address.contains(query, Qt::CaseInsensitive)) {
68
hgs
parents:
diff changeset
   169
                mMruMatches.insert(name, address);
hgs
parents:
diff changeset
   170
            }
76
hgs
parents: 74
diff changeset
   171
            else if (name.contains(query, Qt::CaseInsensitive)) {
68
hgs
parents:
diff changeset
   172
                mMruMatches.insert(name, address);
hgs
parents:
diff changeset
   173
            }
74
hgs
parents: 68
diff changeset
   174
        }      
hgs
parents: 68
diff changeset
   175
        rVal = true;
68
hgs
parents:
diff changeset
   176
    }
hgs
parents:
diff changeset
   177
74
hgs
parents: 68
diff changeset
   178
    return rVal;
68
hgs
parents:
diff changeset
   179
}
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
/*!
hgs
parents:
diff changeset
   182
    Internal helper function for queryDatabases()
hgs
parents:
diff changeset
   183
    Not meant to be used alone.
hgs
parents:
diff changeset
   184
hgs
parents:
diff changeset
   185
    \param cnt_ids List of contact IDs
hgs
parents:
diff changeset
   186
    \param modifiedQuery Query
hgs
parents:
diff changeset
   187
    \sa queryDatabases( )
hgs
parents:
diff changeset
   188
*/
hgs
parents:
diff changeset
   189
void NmContactHistoryModelPrivate::populateListWithContactItems(
hgs
parents:
diff changeset
   190
    const QList<QContactLocalId> cnt_ids,
hgs
parents:
diff changeset
   191
    const QString &modifiedQuery)
hgs
parents:
diff changeset
   192
{
74
hgs
parents: 68
diff changeset
   193
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   194
68
hgs
parents:
diff changeset
   195
    int cntCount = cnt_ids.count();
hgs
parents:
diff changeset
   196
    // Populate mPrivateItemList with contact items.
76
hgs
parents: 74
diff changeset
   197
    for ( int cntIndex = 0; cntIndex < cntCount; cntIndex++) {
68
hgs
parents:
diff changeset
   198
        QContactLocalId cid = cnt_ids.at( cntIndex );
hgs
parents:
diff changeset
   199
        // Fetch extended contact information from DB by ID
hgs
parents:
diff changeset
   200
        QContact contact = mContactManager->contact( cid );
hgs
parents:
diff changeset
   201
hgs
parents:
diff changeset
   202
        // Get number of associated emails for contact
hgs
parents:
diff changeset
   203
        int numberOfEmails =  contact.details(
hgs
parents:
diff changeset
   204
            QContactEmailAddress::DefinitionName).count();
hgs
parents:
diff changeset
   205
76
hgs
parents: 74
diff changeset
   206
        if (numberOfEmails == 0) {
hgs
parents: 74
diff changeset
   207
            continue; 
68
hgs
parents:
diff changeset
   208
        }
hgs
parents:
diff changeset
   209
hgs
parents:
diff changeset
   210
        // Get contact name details
hgs
parents:
diff changeset
   211
        QContactName contactName = contact.detail(
hgs
parents:
diff changeset
   212
            QContactName::DefinitionName);
hgs
parents:
diff changeset
   213
hgs
parents:
diff changeset
   214
        QString firstName = contactName.value(
hgs
parents:
diff changeset
   215
            QContactName::FieldFirstName);
hgs
parents:
diff changeset
   216
        QString lastName = contactName.value(
hgs
parents:
diff changeset
   217
            QContactName::FieldLastName);
hgs
parents:
diff changeset
   218
76
hgs
parents: 74
diff changeset
   219
        for (int emailIndex = 0; emailIndex < numberOfEmails; emailIndex++) {
68
hgs
parents:
diff changeset
   220
            // For Display name (ex. John Doe)
hgs
parents:
diff changeset
   221
            NmContactHistoryModelSubItem itemSubItem1;
hgs
parents:
diff changeset
   222
            // For Email address (ex. john.doe@company.com)
hgs
parents:
diff changeset
   223
            NmContactHistoryModelSubItem itemSubItem2;
hgs
parents:
diff changeset
   224
hgs
parents:
diff changeset
   225
            int queryLength = modifiedQuery.length();
hgs
parents:
diff changeset
   226
hgs
parents:
diff changeset
   227
            // Obey the contacts setting (first name last name order)
hgs
parents:
diff changeset
   228
            itemSubItem1.mItemText = obeyContactOrder(firstName, lastName);
hgs
parents:
diff changeset
   229
76
hgs
parents: 74
diff changeset
   230
            if( firstName.indexOf(modifiedQuery, 0, Qt::CaseInsensitive) == 0) {
68
hgs
parents:
diff changeset
   231
                itemSubItem1.mMatchingRanges.append(0);
hgs
parents:
diff changeset
   232
                itemSubItem1.mMatchingRanges.append(queryLength-1);
hgs
parents:
diff changeset
   233
            }
hgs
parents:
diff changeset
   234
76
hgs
parents: 74
diff changeset
   235
            if( lastName.indexOf(modifiedQuery, 0, Qt::CaseInsensitive) == 0) {
68
hgs
parents:
diff changeset
   236
                int indexLN = itemSubItem1.mItemText.indexOf(lastName,
hgs
parents:
diff changeset
   237
                    firstName.length(),
hgs
parents:
diff changeset
   238
                    Qt::CaseInsensitive );
hgs
parents:
diff changeset
   239
hgs
parents:
diff changeset
   240
                itemSubItem1.mMatchingRanges.append(indexLN);
hgs
parents:
diff changeset
   241
                itemSubItem1.mMatchingRanges.append(indexLN+(queryLength-1));
hgs
parents:
diff changeset
   242
            }
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
            itemSubItem2.mItemText = contact.details (
hgs
parents:
diff changeset
   245
                 QContactEmailAddress::DefinitionName )[emailIndex].value (
hgs
parents:
diff changeset
   246
                 QContactEmailAddress::FieldEmailAddress );
hgs
parents:
diff changeset
   247
hgs
parents:
diff changeset
   248
            if (itemSubItem2.mItemText.indexOf(modifiedQuery, 0,
76
hgs
parents: 74
diff changeset
   249
                Qt::CaseInsensitive) == 0 ) {
68
hgs
parents:
diff changeset
   250
                itemSubItem2.mMatchingRanges.append(0);
hgs
parents:
diff changeset
   251
                itemSubItem2.mMatchingRanges.append(queryLength-1);
hgs
parents:
diff changeset
   252
            }
hgs
parents:
diff changeset
   253
hgs
parents:
diff changeset
   254
            if ((itemSubItem1.mMatchingRanges.count() != 0) ||
76
hgs
parents: 74
diff changeset
   255
                (itemSubItem2.mMatchingRanges.count() != 0) ) {
68
hgs
parents:
diff changeset
   256
                QSharedPointer<NmContactHistoryModelItemData> itemData
hgs
parents:
diff changeset
   257
                    (new NmContactHistoryModelItemData);
hgs
parents:
diff changeset
   258
hgs
parents:
diff changeset
   259
                itemData->mContactId = cid;
hgs
parents:
diff changeset
   260
                itemData->mItems.append(itemSubItem1);
hgs
parents:
diff changeset
   261
                itemData->mItems.append(itemSubItem2);
hgs
parents:
diff changeset
   262
hgs
parents:
diff changeset
   263
                mPrivateItemList.append(itemData);
hgs
parents:
diff changeset
   264
            }
hgs
parents:
diff changeset
   265
        }
hgs
parents:
diff changeset
   266
    }
hgs
parents:
diff changeset
   267
}
hgs
parents:
diff changeset
   268
hgs
parents:
diff changeset
   269
/*!
hgs
parents:
diff changeset
   270
    Internal helper function for queryDatabases()
hgs
parents:
diff changeset
   271
    Not meant to be used alone.
hgs
parents:
diff changeset
   272
hgs
parents:
diff changeset
   273
    \param modifiedQuery Query
hgs
parents:
diff changeset
   274
    \sa queryDatabases( )
hgs
parents:
diff changeset
   275
*/
hgs
parents:
diff changeset
   276
void NmContactHistoryModelPrivate::populateListWithMruItems(
hgs
parents:
diff changeset
   277
    const QString &query)
hgs
parents:
diff changeset
   278
{
74
hgs
parents: 68
diff changeset
   279
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   280
hgs
parents: 68
diff changeset
   281
    QMapIterator<QString, QString> mruMatch(mMruMatches);
68
hgs
parents:
diff changeset
   282
76
hgs
parents: 74
diff changeset
   283
    while (mruMatch.hasNext()) {
74
hgs
parents: 68
diff changeset
   284
        mruMatch.next();
68
hgs
parents:
diff changeset
   285
        // For Display name (ex. John Doe)
hgs
parents:
diff changeset
   286
        NmContactHistoryModelSubItem itemSubItem1;
hgs
parents:
diff changeset
   287
        // For Email address (ex. john.doe@company.com)
hgs
parents:
diff changeset
   288
        NmContactHistoryModelSubItem itemSubItem2;
hgs
parents:
diff changeset
   289
74
hgs
parents: 68
diff changeset
   290
        QString name = mruMatch.key();
hgs
parents: 68
diff changeset
   291
        QString address = mruMatch.value();
hgs
parents: 68
diff changeset
   292
hgs
parents: 68
diff changeset
   293
        itemSubItem1.mItemText = name;
hgs
parents: 68
diff changeset
   294
        itemSubItem2.mItemText = address;
68
hgs
parents:
diff changeset
   295
hgs
parents:
diff changeset
   296
        // markup for first item.
76
hgs
parents: 74
diff changeset
   297
        if( name.indexOf(query, 0, Qt::CaseInsensitive) == 0) {
68
hgs
parents:
diff changeset
   298
            itemSubItem1.mMatchingRanges.append(0);
hgs
parents:
diff changeset
   299
            itemSubItem1.mMatchingRanges.append(query.length()-1);
hgs
parents:
diff changeset
   300
        }
hgs
parents:
diff changeset
   301
hgs
parents:
diff changeset
   302
        QRegExp rx("[,\\s]", Qt::CaseInsensitive);
74
hgs
parents: 68
diff changeset
   303
        bool separatorExists = name.contains(rx);
68
hgs
parents:
diff changeset
   304
76
hgs
parents: 74
diff changeset
   305
        if (separatorExists) {
74
hgs
parents: 68
diff changeset
   306
            int indexLN = name.indexOf(",", 0, Qt::CaseInsensitive);
68
hgs
parents:
diff changeset
   307
76
hgs
parents: 74
diff changeset
   308
            if (indexLN == -1) {
74
hgs
parents: 68
diff changeset
   309
                indexLN = name.indexOf(" ", 0, Qt::CaseInsensitive);
68
hgs
parents:
diff changeset
   310
            }
hgs
parents:
diff changeset
   311
76
hgs
parents: 74
diff changeset
   312
            if (indexLN > 0) {
74
hgs
parents: 68
diff changeset
   313
                int matchPos = name.indexOf(query, indexLN, Qt::CaseInsensitive);
68
hgs
parents:
diff changeset
   314
76
hgs
parents: 74
diff changeset
   315
                if (matchPos > 0) {
68
hgs
parents:
diff changeset
   316
                    itemSubItem1.mMatchingRanges.append(matchPos);
hgs
parents:
diff changeset
   317
                    itemSubItem1.mMatchingRanges.append((matchPos+query.length())-1);
hgs
parents:
diff changeset
   318
                }
hgs
parents:
diff changeset
   319
            }
hgs
parents:
diff changeset
   320
        }
hgs
parents:
diff changeset
   321
hgs
parents:
diff changeset
   322
        // markup for second item.
76
hgs
parents: 74
diff changeset
   323
        if (address.indexOf(query, 0, Qt::CaseInsensitive) == 0 ) {
68
hgs
parents:
diff changeset
   324
             itemSubItem2.mMatchingRanges.append(0);
hgs
parents:
diff changeset
   325
             itemSubItem2.mMatchingRanges.append(query.length()-1);
76
hgs
parents: 74
diff changeset
   326
        }
68
hgs
parents:
diff changeset
   327
hgs
parents:
diff changeset
   328
        // If match, add to data list.
hgs
parents:
diff changeset
   329
        if ((itemSubItem1.mMatchingRanges.count() != 0) ||
76
hgs
parents: 74
diff changeset
   330
            (itemSubItem2.mMatchingRanges.count() != 0) ) {
68
hgs
parents:
diff changeset
   331
            QSharedPointer<NmContactHistoryModelItemData> itemData
hgs
parents:
diff changeset
   332
                (new NmContactHistoryModelItemData);
hgs
parents:
diff changeset
   333
hgs
parents:
diff changeset
   334
            itemData->mContactId = 0; // No ID available, use 0.
hgs
parents:
diff changeset
   335
            itemData->mItems.append(itemSubItem1);
hgs
parents:
diff changeset
   336
            itemData->mItems.append(itemSubItem2);
hgs
parents:
diff changeset
   337
hgs
parents:
diff changeset
   338
            mPrivateItemList.append(itemData);
hgs
parents:
diff changeset
   339
        }
hgs
parents:
diff changeset
   340
    }
hgs
parents:
diff changeset
   341
}
hgs
parents:
diff changeset
   342
hgs
parents:
diff changeset
   343
/*!
hgs
parents:
diff changeset
   344
    After queryDatabases has completed this will be called from public class()
hgs
parents:
diff changeset
   345
    Not meant to be used alone. (NmContactHistoryModel is using this when needed)
hgs
parents:
diff changeset
   346
hgs
parents:
diff changeset
   347
    \sa queryDatabases( )
hgs
parents:
diff changeset
   348
*/
hgs
parents:
diff changeset
   349
void NmContactHistoryModelPrivate::refreshDataModel()
hgs
parents:
diff changeset
   350
{
74
hgs
parents: 68
diff changeset
   351
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   352
68
hgs
parents:
diff changeset
   353
    mModelItemList.clear();
hgs
parents:
diff changeset
   354
hgs
parents:
diff changeset
   355
    for (int cntIndex = 0;
hgs
parents:
diff changeset
   356
             cntIndex < mPrivateItemList.count();
76
hgs
parents: 74
diff changeset
   357
             cntIndex++) {
68
hgs
parents:
diff changeset
   358
        // Construct modelItem to be added to list.
hgs
parents:
diff changeset
   359
        NmContactHistoryModelItem modelItem;
hgs
parents:
diff changeset
   360
hgs
parents:
diff changeset
   361
        QSharedPointer<NmContactHistoryModelItemData> itemData(
hgs
parents:
diff changeset
   362
            mPrivateItemList[cntIndex]);
hgs
parents:
diff changeset
   363
hgs
parents:
diff changeset
   364
        int id = itemData->mContactId;
hgs
parents:
diff changeset
   365
        modelItem.setContactId(itemData->mContactId);
hgs
parents:
diff changeset
   366
hgs
parents:
diff changeset
   367
        for (int itemIndex = 0;
hgs
parents:
diff changeset
   368
                 itemIndex < itemData->mItems.count();
76
hgs
parents: 74
diff changeset
   369
                 itemIndex++) {
68
hgs
parents:
diff changeset
   370
            QString key = itemData->mItems[itemIndex].mItemText;
hgs
parents:
diff changeset
   371
            modelItem.appendSubItem(itemData->mItems[itemIndex]);
hgs
parents:
diff changeset
   372
        }
hgs
parents:
diff changeset
   373
hgs
parents:
diff changeset
   374
        // Append modelItem to list.
hgs
parents:
diff changeset
   375
        mModelItemList.append(modelItem);
hgs
parents:
diff changeset
   376
    }
hgs
parents:
diff changeset
   377
hgs
parents:
diff changeset
   378
    // Notify views that we are done updating model data.
hgs
parents:
diff changeset
   379
    mModelReady = true;
hgs
parents:
diff changeset
   380
hgs
parents:
diff changeset
   381
}
hgs
parents:
diff changeset
   382
hgs
parents:
diff changeset
   383
/*!
74
hgs
parents: 68
diff changeset
   384
    This is called by public class NmContactHistoryModel when model row count is requested
68
hgs
parents:
diff changeset
   385
    Not meant to be used alone.
hgs
parents:
diff changeset
   386
hgs
parents:
diff changeset
   387
*/
74
hgs
parents: 68
diff changeset
   388
int NmContactHistoryModelPrivate::modelRowCount(const QModelIndex &parent) const
68
hgs
parents:
diff changeset
   389
{
74
hgs
parents: 68
diff changeset
   390
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   391
68
hgs
parents:
diff changeset
   392
    Q_UNUSED(parent);
hgs
parents:
diff changeset
   393
    return mModelItemList.count();
hgs
parents:
diff changeset
   394
}
hgs
parents:
diff changeset
   395
hgs
parents:
diff changeset
   396
/*!
74
hgs
parents: 68
diff changeset
   397
    This is called by public class NmContactHistoryModel when private data count is required
hgs
parents: 68
diff changeset
   398
    ie. When model isn't populated yet but data query is complete.
hgs
parents: 68
diff changeset
   399
    Not meant to be used alone.
hgs
parents: 68
diff changeset
   400
hgs
parents: 68
diff changeset
   401
*/
hgs
parents: 68
diff changeset
   402
int NmContactHistoryModelPrivate::privateDataCount() const
hgs
parents: 68
diff changeset
   403
{
hgs
parents: 68
diff changeset
   404
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   405
    return mPrivateItemList.count();
hgs
parents: 68
diff changeset
   406
}
hgs
parents: 68
diff changeset
   407
hgs
parents: 68
diff changeset
   408
/*!
68
hgs
parents:
diff changeset
   409
    This is called by public class NmContactHistoryModel when data() is requested
hgs
parents:
diff changeset
   410
    Not meant to be used alone.
hgs
parents:
diff changeset
   411
hgs
parents:
diff changeset
   412
*/
hgs
parents:
diff changeset
   413
QVariant NmContactHistoryModelPrivate::data(const QModelIndex &index, int role) const
hgs
parents:
diff changeset
   414
{
74
hgs
parents: 68
diff changeset
   415
    NM_FUNCTION;
76
hgs
parents: 74
diff changeset
   416
    QVariant rVariant = QVariant(); 
hgs
parents: 74
diff changeset
   417
    
hgs
parents: 74
diff changeset
   418
    if ( mModelReady ) {
68
hgs
parents:
diff changeset
   419
        if (!index.isValid() ||
hgs
parents:
diff changeset
   420
            index.row() >= mModelItemList.count() ||
76
hgs
parents: 74
diff changeset
   421
            index.row() < 0) {
hgs
parents: 74
diff changeset
   422
            rVariant = QVariant();
68
hgs
parents:
diff changeset
   423
        }
76
hgs
parents: 74
diff changeset
   424
        else if (role == Qt::DisplayRole) {
68
hgs
parents:
diff changeset
   425
            NmContactHistoryModelItem i = mModelItemList.at(index.row());
76
hgs
parents: 74
diff changeset
   426
            rVariant.setValue(i);
68
hgs
parents:
diff changeset
   427
        }
hgs
parents:
diff changeset
   428
    }
hgs
parents:
diff changeset
   429
76
hgs
parents: 74
diff changeset
   430
    return rVariant;
68
hgs
parents:
diff changeset
   431
}
hgs
parents:
diff changeset
   432
hgs
parents:
diff changeset
   433
/*!
hgs
parents:
diff changeset
   434
    Fills MruMatchList, called from queryMruDatabase.
hgs
parents:
diff changeset
   435
    Function uses Email MRU API to fetch information from CenRep
hgs
parents:
diff changeset
   436
hgs
parents:
diff changeset
   437
    \sa queryMruDatabase( )
hgs
parents:
diff changeset
   438
*/
hgs
parents:
diff changeset
   439
bool NmContactHistoryModelPrivate::fillMruMatchList()
hgs
parents:
diff changeset
   440
{
74
hgs
parents: 68
diff changeset
   441
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   442
68
hgs
parents:
diff changeset
   443
    EmailMRU *mru = new EmailMRU();
74
hgs
parents: 68
diff changeset
   444
    bool rVal = false;
76
hgs
parents: 74
diff changeset
   445
    int updateCount = 0;
68
hgs
parents:
diff changeset
   446
76
hgs
parents: 74
diff changeset
   447
    int addressCount = mru->entryCount();
68
hgs
parents:
diff changeset
   448
76
hgs
parents: 74
diff changeset
   449
    for (int i = addressCount; i > 0; i--) {
hgs
parents: 74
diff changeset
   450
        QString key, value; // "Email or Number" & "Display Name"
hgs
parents: 74
diff changeset
   451
        bool success;
68
hgs
parents:
diff changeset
   452
76
hgs
parents: 74
diff changeset
   453
        success = mru->getEntry(i, value, key);
68
hgs
parents:
diff changeset
   454
76
hgs
parents: 74
diff changeset
   455
        if (success) {
hgs
parents: 74
diff changeset
   456
            mMruList.insertMulti(key, value);
hgs
parents: 74
diff changeset
   457
            updateCount++;
68
hgs
parents:
diff changeset
   458
        }
76
hgs
parents: 74
diff changeset
   459
    }
68
hgs
parents:
diff changeset
   460
76
hgs
parents: 74
diff changeset
   461
    delete mru;
hgs
parents: 74
diff changeset
   462
    
hgs
parents: 74
diff changeset
   463
    if (updateCount == addressCount) {
74
hgs
parents: 68
diff changeset
   464
        rVal = true;
76
hgs
parents: 74
diff changeset
   465
    } 
74
hgs
parents: 68
diff changeset
   466
hgs
parents: 68
diff changeset
   467
    return rVal;
68
hgs
parents:
diff changeset
   468
}
hgs
parents:
diff changeset
   469
hgs
parents:
diff changeset
   470
/*!
hgs
parents:
diff changeset
   471
    This is called from populateListWithContactItems() when correct order of
hgs
parents:
diff changeset
   472
    first name, last name setting is required
hgs
parents:
diff changeset
   473
hgs
parents:
diff changeset
   474
    \param firstName First name
hgs
parents:
diff changeset
   475
    \param lastName Last name
hgs
parents:
diff changeset
   476
hgs
parents:
diff changeset
   477
    \sa populateListWithContactItems( )
hgs
parents:
diff changeset
   478
hgs
parents:
diff changeset
   479
    \return concennated string formatted as contact setting specifies.
hgs
parents:
diff changeset
   480
*/
hgs
parents:
diff changeset
   481
QString NmContactHistoryModelPrivate::obeyContactOrder(const QString &firstName,
74
hgs
parents: 68
diff changeset
   482
                                                       const QString &lastName) const
68
hgs
parents:
diff changeset
   483
{
74
hgs
parents: 68
diff changeset
   484
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   485
68
hgs
parents:
diff changeset
   486
    QString result;
hgs
parents:
diff changeset
   487
76
hgs
parents: 74
diff changeset
   488
    switch (mNameOrder) {
hgs
parents: 74
diff changeset
   489
    case LastNameFirstName:
hgs
parents: 74
diff changeset
   490
        result = lastName + " " + firstName;
68
hgs
parents:
diff changeset
   491
        break;
hgs
parents:
diff changeset
   492
76
hgs
parents: 74
diff changeset
   493
    case LastNameCommaFirstName:
hgs
parents: 74
diff changeset
   494
        result = lastName + ", " + firstName;
68
hgs
parents:
diff changeset
   495
        break;
hgs
parents:
diff changeset
   496
76
hgs
parents: 74
diff changeset
   497
    case FirstNameLastName:
hgs
parents: 74
diff changeset
   498
        result = firstName + " " + lastName;
68
hgs
parents:
diff changeset
   499
        break;
hgs
parents:
diff changeset
   500
76
hgs
parents: 74
diff changeset
   501
    default:
hgs
parents: 74
diff changeset
   502
        result = firstName + " " + lastName;
68
hgs
parents:
diff changeset
   503
        break;
hgs
parents:
diff changeset
   504
    }
hgs
parents:
diff changeset
   505
hgs
parents:
diff changeset
   506
    return result;
hgs
parents:
diff changeset
   507
}
hgs
parents:
diff changeset
   508
hgs
parents:
diff changeset
   509
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   510
// End of implementation (NmContactHistoryModelPrivate)
hgs
parents:
diff changeset
   511
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   512