emailservices/nmutilities/src/nmcontacthistorymodel_p.cpp
author hgs
Thu, 30 Sep 2010 11:43:07 +0300
changeset 74 6c59112cfd31
parent 68 83cc6bae1de8
child 76 38bf5461e270
permissions -rw-r--r--
201039
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.
hgs
parents:
diff changeset
    57
    Emits QueryCompleted() when ready.
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
hgs
parents:
diff changeset
    84
    if ( spcPosition != -1 )
74
hgs
parents: 68
diff changeset
    85
    {
68
hgs
parents:
diff changeset
    86
        modifiedQuery = query.left(spcPosition);
74
hgs
parents: 68
diff changeset
    87
    }
68
hgs
parents:
diff changeset
    88
74
hgs
parents: 68
diff changeset
    89
    // Get matching MRU items
68
hgs
parents:
diff changeset
    90
    queryMruDatabase(modifiedQuery);
74
hgs
parents: 68
diff changeset
    91
    
hgs
parents: 68
diff changeset
    92
    // Populate mPrivateItemList with matching MRU items.
68
hgs
parents:
diff changeset
    93
    populateListWithMruItems(modifiedQuery);
hgs
parents:
diff changeset
    94
74
hgs
parents: 68
diff changeset
    95
    // Get matching IDs from Contacts DB
hgs
parents: 68
diff changeset
    96
    QList<QContactLocalId> cnt_ids = queryContactDatabase(modifiedQuery);
68
hgs
parents:
diff changeset
    97
74
hgs
parents: 68
diff changeset
    98
    // Populate mPrivateItemList with contact items.
hgs
parents: 68
diff changeset
    99
    populateListWithContactItems(cnt_ids, modifiedQuery);
68
hgs
parents:
diff changeset
   100
hgs
parents:
diff changeset
   101
74
hgs
parents: 68
diff changeset
   102
    #ifdef _DEBUG
hgs
parents: 68
diff changeset
   103
    
hgs
parents: 68
diff changeset
   104
        for (int i = 0; i < mPrivateItemList.size(); i++)
hgs
parents: 68
diff changeset
   105
        {
hgs
parents: 68
diff changeset
   106
            QSharedPointer<NmContactHistoryModelItemData> itemData = mPrivateItemList[i];
hgs
parents: 68
diff changeset
   107
hgs
parents: 68
diff changeset
   108
            QString dbgString = itemData->mItems[0].mItemText;
hgs
parents: 68
diff changeset
   109
            dbgString.append(" ");
hgs
parents: 68
diff changeset
   110
            dbgString.append(itemData->mItems[1].mItemText);
hgs
parents: 68
diff changeset
   111
hgs
parents: 68
diff changeset
   112
            qDebug(dbgString.toLatin1());
68
hgs
parents:
diff changeset
   113
        }
74
hgs
parents: 68
diff changeset
   114
        
hgs
parents: 68
diff changeset
   115
    #endif
hgs
parents: 68
diff changeset
   116
68
hgs
parents:
diff changeset
   117
hgs
parents:
diff changeset
   118
    emit queryCompleted(0);
hgs
parents:
diff changeset
   119
}
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
/*!
hgs
parents:
diff changeset
   122
    Internal helper function for queryDatabases()
hgs
parents:
diff changeset
   123
    Not meant to be used alone.
hgs
parents:
diff changeset
   124
hgs
parents:
diff changeset
   125
    \param query Text to be searched
hgs
parents:
diff changeset
   126
    \return list of Contact items.
hgs
parents:
diff changeset
   127
    \sa queryDatabases( )
hgs
parents:
diff changeset
   128
*/
hgs
parents:
diff changeset
   129
QList<QContactLocalId> NmContactHistoryModelPrivate::queryContactDatabase(
hgs
parents:
diff changeset
   130
    const QString &query)
hgs
parents:
diff changeset
   131
{
74
hgs
parents: 68
diff changeset
   132
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   133
68
hgs
parents:
diff changeset
   134
    // Define filter
hgs
parents:
diff changeset
   135
    QContactDetailFilter df;
hgs
parents:
diff changeset
   136
hgs
parents:
diff changeset
   137
    df.setDetailDefinitionName(QContactEmailAddress::DefinitionName,
hgs
parents:
diff changeset
   138
                               QContactEmailAddress::FieldEmailAddress );
hgs
parents:
diff changeset
   139
hgs
parents:
diff changeset
   140
    df.setMatchFlags( QContactFilter::MatchKeypadCollation );
hgs
parents:
diff changeset
   141
hgs
parents:
diff changeset
   142
    // Construct pattern
hgs
parents:
diff changeset
   143
    QString pattern = query + QChar(30) + QString("vqwerty");
hgs
parents:
diff changeset
   144
    df.setValue( pattern );
hgs
parents:
diff changeset
   145
hgs
parents:
diff changeset
   146
    // Get matching IDs
hgs
parents:
diff changeset
   147
    QList<QContactLocalId> cnt_ids = mContactManager->contactIds( df );
hgs
parents:
diff changeset
   148
hgs
parents:
diff changeset
   149
    return cnt_ids;
hgs
parents:
diff changeset
   150
}
hgs
parents:
diff changeset
   151
hgs
parents:
diff changeset
   152
/*!
hgs
parents:
diff changeset
   153
    Internal helper function for queryDatabases()
hgs
parents:
diff changeset
   154
    Not meant to be used alone.
hgs
parents:
diff changeset
   155
hgs
parents:
diff changeset
   156
    \param query Text to be searched from MRU
hgs
parents:
diff changeset
   157
    \return true on success.
hgs
parents:
diff changeset
   158
    \sa queryDatabases( )
hgs
parents:
diff changeset
   159
*/
hgs
parents:
diff changeset
   160
bool NmContactHistoryModelPrivate::queryMruDatabase(
hgs
parents:
diff changeset
   161
    const QString &query)
hgs
parents:
diff changeset
   162
{
74
hgs
parents: 68
diff changeset
   163
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   164
    bool rVal = false;
hgs
parents: 68
diff changeset
   165
    
68
hgs
parents:
diff changeset
   166
    if (mType == EmailAddressModel)
hgs
parents:
diff changeset
   167
    {
hgs
parents:
diff changeset
   168
        bool mruListFilled = fillMruMatchList();
hgs
parents:
diff changeset
   169
hgs
parents:
diff changeset
   170
        if (!mruListFilled)
hgs
parents:
diff changeset
   171
        {
74
hgs
parents: 68
diff changeset
   172
            return rVal;
68
hgs
parents:
diff changeset
   173
        }
hgs
parents:
diff changeset
   174
hgs
parents:
diff changeset
   175
        QHashIterator<QString, QString> i(mMruList);
hgs
parents:
diff changeset
   176
hgs
parents:
diff changeset
   177
        while (i.hasNext())
hgs
parents:
diff changeset
   178
        {
hgs
parents:
diff changeset
   179
            i.next();
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
            QString address = i.key();
hgs
parents:
diff changeset
   182
            QString name = i.value();
hgs
parents:
diff changeset
   183
hgs
parents:
diff changeset
   184
            if ((name.length() == 0) && (address.contains('@')))
hgs
parents:
diff changeset
   185
            {
hgs
parents:
diff changeset
   186
                name = address.left(address.indexOf("@"));
hgs
parents:
diff changeset
   187
            }
hgs
parents:
diff changeset
   188
hgs
parents:
diff changeset
   189
            if (address.contains(query, Qt::CaseInsensitive))
hgs
parents:
diff changeset
   190
            {
hgs
parents:
diff changeset
   191
                mMruMatches.insert(name, address);
hgs
parents:
diff changeset
   192
            }
hgs
parents:
diff changeset
   193
            else if (name.contains(query, Qt::CaseInsensitive))
hgs
parents:
diff changeset
   194
            {
hgs
parents:
diff changeset
   195
                mMruMatches.insert(name, address);
hgs
parents:
diff changeset
   196
            }
74
hgs
parents: 68
diff changeset
   197
        }      
hgs
parents: 68
diff changeset
   198
        rVal = true;
68
hgs
parents:
diff changeset
   199
    }
hgs
parents:
diff changeset
   200
74
hgs
parents: 68
diff changeset
   201
    return rVal;
68
hgs
parents:
diff changeset
   202
}
hgs
parents:
diff changeset
   203
hgs
parents:
diff changeset
   204
/*!
hgs
parents:
diff changeset
   205
    Internal helper function for queryDatabases()
hgs
parents:
diff changeset
   206
    Not meant to be used alone.
hgs
parents:
diff changeset
   207
hgs
parents:
diff changeset
   208
    \param cnt_ids List of contact IDs
hgs
parents:
diff changeset
   209
    \param modifiedQuery Query
hgs
parents:
diff changeset
   210
    \sa queryDatabases( )
hgs
parents:
diff changeset
   211
*/
hgs
parents:
diff changeset
   212
void NmContactHistoryModelPrivate::populateListWithContactItems(
hgs
parents:
diff changeset
   213
    const QList<QContactLocalId> cnt_ids,
hgs
parents:
diff changeset
   214
    const QString &modifiedQuery)
hgs
parents:
diff changeset
   215
{
74
hgs
parents: 68
diff changeset
   216
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   217
68
hgs
parents:
diff changeset
   218
    int cntCount = cnt_ids.count();
hgs
parents:
diff changeset
   219
    // Populate mPrivateItemList with contact items.
hgs
parents:
diff changeset
   220
    for ( int cntIndex = 0; cntIndex < cntCount; cntIndex++)
hgs
parents:
diff changeset
   221
    {
hgs
parents:
diff changeset
   222
        QContactLocalId cid = cnt_ids.at( cntIndex );
hgs
parents:
diff changeset
   223
        // Fetch extended contact information from DB by ID
hgs
parents:
diff changeset
   224
        QContact contact = mContactManager->contact( cid );
hgs
parents:
diff changeset
   225
hgs
parents:
diff changeset
   226
        // Get number of associated emails for contact
hgs
parents:
diff changeset
   227
        int numberOfEmails =  contact.details(
hgs
parents:
diff changeset
   228
            QContactEmailAddress::DefinitionName).count();
hgs
parents:
diff changeset
   229
hgs
parents:
diff changeset
   230
        if (numberOfEmails == 0)
hgs
parents:
diff changeset
   231
        {
hgs
parents:
diff changeset
   232
            continue; // Scotty, I need warp speed.
hgs
parents:
diff changeset
   233
        }
hgs
parents:
diff changeset
   234
hgs
parents:
diff changeset
   235
        // Get contact name details
hgs
parents:
diff changeset
   236
        QContactName contactName = contact.detail(
hgs
parents:
diff changeset
   237
            QContactName::DefinitionName);
hgs
parents:
diff changeset
   238
hgs
parents:
diff changeset
   239
        QString firstName = contactName.value(
hgs
parents:
diff changeset
   240
            QContactName::FieldFirstName);
hgs
parents:
diff changeset
   241
        QString lastName = contactName.value(
hgs
parents:
diff changeset
   242
            QContactName::FieldLastName);
hgs
parents:
diff changeset
   243
hgs
parents:
diff changeset
   244
        for (int emailIndex = 0; emailIndex < numberOfEmails; emailIndex++)
hgs
parents:
diff changeset
   245
        {
hgs
parents:
diff changeset
   246
            // For Display name (ex. John Doe)
hgs
parents:
diff changeset
   247
            NmContactHistoryModelSubItem itemSubItem1;
hgs
parents:
diff changeset
   248
            // For Email address (ex. john.doe@company.com)
hgs
parents:
diff changeset
   249
            NmContactHistoryModelSubItem itemSubItem2;
hgs
parents:
diff changeset
   250
hgs
parents:
diff changeset
   251
            int queryLength = modifiedQuery.length();
hgs
parents:
diff changeset
   252
hgs
parents:
diff changeset
   253
            // Obey the contacts setting (first name last name order)
hgs
parents:
diff changeset
   254
            itemSubItem1.mItemText = obeyContactOrder(firstName, lastName);
hgs
parents:
diff changeset
   255
hgs
parents:
diff changeset
   256
            if( firstName.indexOf(modifiedQuery, 0, Qt::CaseInsensitive) == 0)
hgs
parents:
diff changeset
   257
            {
hgs
parents:
diff changeset
   258
                itemSubItem1.mMatchingRanges.append(0);
hgs
parents:
diff changeset
   259
                itemSubItem1.mMatchingRanges.append(queryLength-1);
hgs
parents:
diff changeset
   260
            }
hgs
parents:
diff changeset
   261
hgs
parents:
diff changeset
   262
            if( lastName.indexOf(modifiedQuery, 0, Qt::CaseInsensitive) == 0)
hgs
parents:
diff changeset
   263
            {
hgs
parents:
diff changeset
   264
                int indexLN = itemSubItem1.mItemText.indexOf(lastName,
hgs
parents:
diff changeset
   265
                    firstName.length(),
hgs
parents:
diff changeset
   266
                    Qt::CaseInsensitive );
hgs
parents:
diff changeset
   267
hgs
parents:
diff changeset
   268
                itemSubItem1.mMatchingRanges.append(indexLN);
hgs
parents:
diff changeset
   269
                itemSubItem1.mMatchingRanges.append(indexLN+(queryLength-1));
hgs
parents:
diff changeset
   270
            }
hgs
parents:
diff changeset
   271
hgs
parents:
diff changeset
   272
            itemSubItem2.mItemText = contact.details (
hgs
parents:
diff changeset
   273
                 QContactEmailAddress::DefinitionName )[emailIndex].value (
hgs
parents:
diff changeset
   274
                 QContactEmailAddress::FieldEmailAddress );
hgs
parents:
diff changeset
   275
hgs
parents:
diff changeset
   276
            if (itemSubItem2.mItemText.indexOf(modifiedQuery, 0,
hgs
parents:
diff changeset
   277
                Qt::CaseInsensitive) == 0 )
hgs
parents:
diff changeset
   278
            {
hgs
parents:
diff changeset
   279
                itemSubItem2.mMatchingRanges.append(0);
hgs
parents:
diff changeset
   280
                itemSubItem2.mMatchingRanges.append(queryLength-1);
hgs
parents:
diff changeset
   281
            }
hgs
parents:
diff changeset
   282
hgs
parents:
diff changeset
   283
            if ((itemSubItem1.mMatchingRanges.count() != 0) ||
hgs
parents:
diff changeset
   284
                (itemSubItem2.mMatchingRanges.count() != 0) )
hgs
parents:
diff changeset
   285
            {
hgs
parents:
diff changeset
   286
                QSharedPointer<NmContactHistoryModelItemData> itemData
hgs
parents:
diff changeset
   287
                    (new NmContactHistoryModelItemData);
hgs
parents:
diff changeset
   288
hgs
parents:
diff changeset
   289
                itemData->mContactId = cid;
hgs
parents:
diff changeset
   290
                itemData->mItems.append(itemSubItem1);
hgs
parents:
diff changeset
   291
                itemData->mItems.append(itemSubItem2);
hgs
parents:
diff changeset
   292
hgs
parents:
diff changeset
   293
                mPrivateItemList.append(itemData);
hgs
parents:
diff changeset
   294
            }
hgs
parents:
diff changeset
   295
        }
hgs
parents:
diff changeset
   296
    }
hgs
parents:
diff changeset
   297
}
hgs
parents:
diff changeset
   298
hgs
parents:
diff changeset
   299
/*!
hgs
parents:
diff changeset
   300
    Internal helper function for queryDatabases()
hgs
parents:
diff changeset
   301
    Not meant to be used alone.
hgs
parents:
diff changeset
   302
hgs
parents:
diff changeset
   303
    \param modifiedQuery Query
hgs
parents:
diff changeset
   304
    \sa queryDatabases( )
hgs
parents:
diff changeset
   305
*/
hgs
parents:
diff changeset
   306
void NmContactHistoryModelPrivate::populateListWithMruItems(
hgs
parents:
diff changeset
   307
    const QString &query)
hgs
parents:
diff changeset
   308
{
74
hgs
parents: 68
diff changeset
   309
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   310
hgs
parents: 68
diff changeset
   311
    QMapIterator<QString, QString> mruMatch(mMruMatches);
68
hgs
parents:
diff changeset
   312
74
hgs
parents: 68
diff changeset
   313
    while (mruMatch.hasNext())
68
hgs
parents:
diff changeset
   314
    {
74
hgs
parents: 68
diff changeset
   315
        mruMatch.next();
68
hgs
parents:
diff changeset
   316
        // For Display name (ex. John Doe)
hgs
parents:
diff changeset
   317
        NmContactHistoryModelSubItem itemSubItem1;
hgs
parents:
diff changeset
   318
        // For Email address (ex. john.doe@company.com)
hgs
parents:
diff changeset
   319
        NmContactHistoryModelSubItem itemSubItem2;
hgs
parents:
diff changeset
   320
74
hgs
parents: 68
diff changeset
   321
        QString name = mruMatch.key();
hgs
parents: 68
diff changeset
   322
        QString address = mruMatch.value();
hgs
parents: 68
diff changeset
   323
hgs
parents: 68
diff changeset
   324
        itemSubItem1.mItemText = name;
hgs
parents: 68
diff changeset
   325
        itemSubItem2.mItemText = address;
68
hgs
parents:
diff changeset
   326
hgs
parents:
diff changeset
   327
        // markup for first item.
74
hgs
parents: 68
diff changeset
   328
        if( name.indexOf(query, 0, Qt::CaseInsensitive) == 0)
68
hgs
parents:
diff changeset
   329
        {
hgs
parents:
diff changeset
   330
            itemSubItem1.mMatchingRanges.append(0);
hgs
parents:
diff changeset
   331
            itemSubItem1.mMatchingRanges.append(query.length()-1);
hgs
parents:
diff changeset
   332
        }
hgs
parents:
diff changeset
   333
hgs
parents:
diff changeset
   334
        QRegExp rx("[,\\s]", Qt::CaseInsensitive);
74
hgs
parents: 68
diff changeset
   335
        bool separatorExists = name.contains(rx);
68
hgs
parents:
diff changeset
   336
hgs
parents:
diff changeset
   337
        if (separatorExists)
hgs
parents:
diff changeset
   338
        {
74
hgs
parents: 68
diff changeset
   339
            int indexLN = name.indexOf(",", 0, Qt::CaseInsensitive);
68
hgs
parents:
diff changeset
   340
hgs
parents:
diff changeset
   341
            if (indexLN == -1)
hgs
parents:
diff changeset
   342
            {
74
hgs
parents: 68
diff changeset
   343
                indexLN = name.indexOf(" ", 0, Qt::CaseInsensitive);
68
hgs
parents:
diff changeset
   344
            }
hgs
parents:
diff changeset
   345
hgs
parents:
diff changeset
   346
            if (indexLN > 0)
hgs
parents:
diff changeset
   347
            {
74
hgs
parents: 68
diff changeset
   348
                int matchPos = name.indexOf(query, indexLN, Qt::CaseInsensitive);
68
hgs
parents:
diff changeset
   349
hgs
parents:
diff changeset
   350
                if (matchPos > 0)
hgs
parents:
diff changeset
   351
                {
hgs
parents:
diff changeset
   352
                    itemSubItem1.mMatchingRanges.append(matchPos);
hgs
parents:
diff changeset
   353
                    itemSubItem1.mMatchingRanges.append((matchPos+query.length())-1);
hgs
parents:
diff changeset
   354
                }
hgs
parents:
diff changeset
   355
            }
hgs
parents:
diff changeset
   356
        }
hgs
parents:
diff changeset
   357
hgs
parents:
diff changeset
   358
        // markup for second item.
74
hgs
parents: 68
diff changeset
   359
        if (address.indexOf(query, 0, Qt::CaseInsensitive) == 0 )
68
hgs
parents:
diff changeset
   360
         {
hgs
parents:
diff changeset
   361
             itemSubItem2.mMatchingRanges.append(0);
hgs
parents:
diff changeset
   362
             itemSubItem2.mMatchingRanges.append(query.length()-1);
hgs
parents:
diff changeset
   363
         }
hgs
parents:
diff changeset
   364
hgs
parents:
diff changeset
   365
        // If match, add to data list.
hgs
parents:
diff changeset
   366
        if ((itemSubItem1.mMatchingRanges.count() != 0) ||
hgs
parents:
diff changeset
   367
            (itemSubItem2.mMatchingRanges.count() != 0) )
hgs
parents:
diff changeset
   368
        {
hgs
parents:
diff changeset
   369
            QSharedPointer<NmContactHistoryModelItemData> itemData
hgs
parents:
diff changeset
   370
                (new NmContactHistoryModelItemData);
hgs
parents:
diff changeset
   371
hgs
parents:
diff changeset
   372
            itemData->mContactId = 0; // No ID available, use 0.
hgs
parents:
diff changeset
   373
            itemData->mItems.append(itemSubItem1);
hgs
parents:
diff changeset
   374
            itemData->mItems.append(itemSubItem2);
hgs
parents:
diff changeset
   375
hgs
parents:
diff changeset
   376
            mPrivateItemList.append(itemData);
hgs
parents:
diff changeset
   377
        }
hgs
parents:
diff changeset
   378
    }
hgs
parents:
diff changeset
   379
}
hgs
parents:
diff changeset
   380
hgs
parents:
diff changeset
   381
/*!
hgs
parents:
diff changeset
   382
    After queryDatabases has completed this will be called from public class()
hgs
parents:
diff changeset
   383
    Not meant to be used alone. (NmContactHistoryModel is using this when needed)
hgs
parents:
diff changeset
   384
hgs
parents:
diff changeset
   385
    \sa queryDatabases( )
hgs
parents:
diff changeset
   386
*/
hgs
parents:
diff changeset
   387
void NmContactHistoryModelPrivate::refreshDataModel()
hgs
parents:
diff changeset
   388
{
74
hgs
parents: 68
diff changeset
   389
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   390
68
hgs
parents:
diff changeset
   391
    mModelItemList.clear();
hgs
parents:
diff changeset
   392
hgs
parents:
diff changeset
   393
    for (int cntIndex = 0;
hgs
parents:
diff changeset
   394
             cntIndex < mPrivateItemList.count();
hgs
parents:
diff changeset
   395
             cntIndex++)
hgs
parents:
diff changeset
   396
    {
hgs
parents:
diff changeset
   397
        // Construct modelItem to be added to list.
hgs
parents:
diff changeset
   398
        NmContactHistoryModelItem modelItem;
hgs
parents:
diff changeset
   399
hgs
parents:
diff changeset
   400
        QSharedPointer<NmContactHistoryModelItemData> itemData(
hgs
parents:
diff changeset
   401
            mPrivateItemList[cntIndex]);
hgs
parents:
diff changeset
   402
hgs
parents:
diff changeset
   403
        int id = itemData->mContactId;
hgs
parents:
diff changeset
   404
        modelItem.setContactId(itemData->mContactId);
hgs
parents:
diff changeset
   405
hgs
parents:
diff changeset
   406
        for (int itemIndex = 0;
hgs
parents:
diff changeset
   407
                 itemIndex < itemData->mItems.count();
hgs
parents:
diff changeset
   408
                 itemIndex++)
hgs
parents:
diff changeset
   409
        {
hgs
parents:
diff changeset
   410
            QString key = itemData->mItems[itemIndex].mItemText;
hgs
parents:
diff changeset
   411
            modelItem.appendSubItem(itemData->mItems[itemIndex]);
hgs
parents:
diff changeset
   412
        }
hgs
parents:
diff changeset
   413
hgs
parents:
diff changeset
   414
        // Append modelItem to list.
hgs
parents:
diff changeset
   415
        mModelItemList.append(modelItem);
hgs
parents:
diff changeset
   416
    }
hgs
parents:
diff changeset
   417
hgs
parents:
diff changeset
   418
    // Notify views that we are done updating model data.
hgs
parents:
diff changeset
   419
    mModelReady = true;
hgs
parents:
diff changeset
   420
hgs
parents:
diff changeset
   421
}
hgs
parents:
diff changeset
   422
hgs
parents:
diff changeset
   423
/*!
74
hgs
parents: 68
diff changeset
   424
    This is called by public class NmContactHistoryModel when model row count is requested
68
hgs
parents:
diff changeset
   425
    Not meant to be used alone.
hgs
parents:
diff changeset
   426
hgs
parents:
diff changeset
   427
*/
74
hgs
parents: 68
diff changeset
   428
int NmContactHistoryModelPrivate::modelRowCount(const QModelIndex &parent) const
68
hgs
parents:
diff changeset
   429
{
74
hgs
parents: 68
diff changeset
   430
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   431
68
hgs
parents:
diff changeset
   432
    Q_UNUSED(parent);
hgs
parents:
diff changeset
   433
    return mModelItemList.count();
hgs
parents:
diff changeset
   434
}
hgs
parents:
diff changeset
   435
hgs
parents:
diff changeset
   436
/*!
74
hgs
parents: 68
diff changeset
   437
    This is called by public class NmContactHistoryModel when private data count is required
hgs
parents: 68
diff changeset
   438
    ie. When model isn't populated yet but data query is complete.
hgs
parents: 68
diff changeset
   439
    Not meant to be used alone.
hgs
parents: 68
diff changeset
   440
hgs
parents: 68
diff changeset
   441
*/
hgs
parents: 68
diff changeset
   442
int NmContactHistoryModelPrivate::privateDataCount() const
hgs
parents: 68
diff changeset
   443
{
hgs
parents: 68
diff changeset
   444
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   445
    return mPrivateItemList.count();
hgs
parents: 68
diff changeset
   446
}
hgs
parents: 68
diff changeset
   447
hgs
parents: 68
diff changeset
   448
/*!
68
hgs
parents:
diff changeset
   449
    This is called by public class NmContactHistoryModel when data() is requested
hgs
parents:
diff changeset
   450
    Not meant to be used alone.
hgs
parents:
diff changeset
   451
hgs
parents:
diff changeset
   452
*/
hgs
parents:
diff changeset
   453
QVariant NmContactHistoryModelPrivate::data(const QModelIndex &index, int role) const
hgs
parents:
diff changeset
   454
{
74
hgs
parents: 68
diff changeset
   455
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   456
68
hgs
parents:
diff changeset
   457
    if ( mModelReady )
hgs
parents:
diff changeset
   458
    {
hgs
parents:
diff changeset
   459
        if (!index.isValid() ||
hgs
parents:
diff changeset
   460
            index.row() >= mModelItemList.count() ||
hgs
parents:
diff changeset
   461
            index.row() < 0)
hgs
parents:
diff changeset
   462
        {
hgs
parents:
diff changeset
   463
            return QVariant();
hgs
parents:
diff changeset
   464
        }
74
hgs
parents: 68
diff changeset
   465
        else if (role == Qt::DisplayRole)
68
hgs
parents:
diff changeset
   466
        {
hgs
parents:
diff changeset
   467
            QVariant v;
hgs
parents:
diff changeset
   468
            NmContactHistoryModelItem i = mModelItemList.at(index.row());
hgs
parents:
diff changeset
   469
            v.setValue(i);
hgs
parents:
diff changeset
   470
            return v;
hgs
parents:
diff changeset
   471
        }
hgs
parents:
diff changeset
   472
    }
hgs
parents:
diff changeset
   473
hgs
parents:
diff changeset
   474
    return QVariant();
hgs
parents:
diff changeset
   475
}
hgs
parents:
diff changeset
   476
hgs
parents:
diff changeset
   477
/*!
hgs
parents:
diff changeset
   478
    Fills MruMatchList, called from queryMruDatabase.
hgs
parents:
diff changeset
   479
    Function uses Email MRU API to fetch information from CenRep
hgs
parents:
diff changeset
   480
hgs
parents:
diff changeset
   481
    \sa queryMruDatabase( )
hgs
parents:
diff changeset
   482
*/
hgs
parents:
diff changeset
   483
bool NmContactHistoryModelPrivate::fillMruMatchList()
hgs
parents:
diff changeset
   484
{
74
hgs
parents: 68
diff changeset
   485
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   486
68
hgs
parents:
diff changeset
   487
    EmailMRU *mru = new EmailMRU();
74
hgs
parents: 68
diff changeset
   488
    bool rVal = false;
68
hgs
parents:
diff changeset
   489
hgs
parents:
diff changeset
   490
    if (mru)
hgs
parents:
diff changeset
   491
    {
hgs
parents:
diff changeset
   492
        int addressCount = mru->entryCount();
hgs
parents:
diff changeset
   493
hgs
parents:
diff changeset
   494
        for (int i = addressCount; i > 0; i--)
hgs
parents:
diff changeset
   495
        {
hgs
parents:
diff changeset
   496
            QString key, value; // "Email or Number" & "Display Name"
hgs
parents:
diff changeset
   497
            bool success;
hgs
parents:
diff changeset
   498
hgs
parents:
diff changeset
   499
            success = mru->getEntry(i, value, key);
hgs
parents:
diff changeset
   500
hgs
parents:
diff changeset
   501
            if (success)
hgs
parents:
diff changeset
   502
            {
hgs
parents:
diff changeset
   503
                mMruList.insertMulti(key, value);
hgs
parents:
diff changeset
   504
            }
hgs
parents:
diff changeset
   505
        }
hgs
parents:
diff changeset
   506
hgs
parents:
diff changeset
   507
        delete mru;
74
hgs
parents: 68
diff changeset
   508
        rVal = true;
68
hgs
parents:
diff changeset
   509
    }
hgs
parents:
diff changeset
   510
    else
hgs
parents:
diff changeset
   511
    {
74
hgs
parents: 68
diff changeset
   512
        rVal = false;
68
hgs
parents:
diff changeset
   513
    }
74
hgs
parents: 68
diff changeset
   514
hgs
parents: 68
diff changeset
   515
    return rVal;
68
hgs
parents:
diff changeset
   516
}
hgs
parents:
diff changeset
   517
hgs
parents:
diff changeset
   518
/*!
hgs
parents:
diff changeset
   519
    This is called from populateListWithContactItems() when correct order of
hgs
parents:
diff changeset
   520
    first name, last name setting is required
hgs
parents:
diff changeset
   521
hgs
parents:
diff changeset
   522
    \param firstName First name
hgs
parents:
diff changeset
   523
    \param lastName Last name
hgs
parents:
diff changeset
   524
hgs
parents:
diff changeset
   525
    \sa populateListWithContactItems( )
hgs
parents:
diff changeset
   526
hgs
parents:
diff changeset
   527
    \return concennated string formatted as contact setting specifies.
hgs
parents:
diff changeset
   528
*/
hgs
parents:
diff changeset
   529
QString NmContactHistoryModelPrivate::obeyContactOrder(const QString &firstName,
74
hgs
parents: 68
diff changeset
   530
                                                       const QString &lastName) const
68
hgs
parents:
diff changeset
   531
{
74
hgs
parents: 68
diff changeset
   532
    NM_FUNCTION;
hgs
parents: 68
diff changeset
   533
68
hgs
parents:
diff changeset
   534
    QString result;
hgs
parents:
diff changeset
   535
hgs
parents:
diff changeset
   536
    switch (mNameOrder)
hgs
parents:
diff changeset
   537
    {
hgs
parents:
diff changeset
   538
        case LastNameFirstName:
hgs
parents:
diff changeset
   539
            result = lastName + " " + firstName;
hgs
parents:
diff changeset
   540
        break;
hgs
parents:
diff changeset
   541
hgs
parents:
diff changeset
   542
        case LastNameCommaFirstName:
hgs
parents:
diff changeset
   543
            result = lastName + ", " + firstName;
hgs
parents:
diff changeset
   544
        break;
hgs
parents:
diff changeset
   545
hgs
parents:
diff changeset
   546
        case FirstNameLastName:
hgs
parents:
diff changeset
   547
            result = firstName + " " + lastName;
hgs
parents:
diff changeset
   548
        break;
hgs
parents:
diff changeset
   549
hgs
parents:
diff changeset
   550
        default:
hgs
parents:
diff changeset
   551
            result = firstName + " " + lastName;
hgs
parents:
diff changeset
   552
        break;
hgs
parents:
diff changeset
   553
    }
hgs
parents:
diff changeset
   554
hgs
parents:
diff changeset
   555
    return result;
hgs
parents:
diff changeset
   556
}
hgs
parents:
diff changeset
   557
hgs
parents:
diff changeset
   558
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   559
// End of implementation (NmContactHistoryModelPrivate)
hgs
parents:
diff changeset
   560
// --------------------------------------------------------------------------
hgs
parents:
diff changeset
   561