phonebookui/cnthistorymodel/cnthistorymodel_p.cpp
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) 2009 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
*
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#include <QStringList>
hgs
parents:
diff changeset
    19
#include <QtAlgorithms>
hgs
parents:
diff changeset
    20
#include <hbglobal.h>
hgs
parents:
diff changeset
    21
#include <hbicon.h>
hgs
parents:
diff changeset
    22
#include <hbframebackground.h>
hgs
parents:
diff changeset
    23
hgs
parents:
diff changeset
    24
#include "cnthistorymodel_p.h"
hgs
parents:
diff changeset
    25
#include "cntdebug.h"
hgs
parents:
diff changeset
    26
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// Unnamed namespace for helper functions
hgs
parents:
diff changeset
    29
namespace
hgs
parents:
diff changeset
    30
{
hgs
parents:
diff changeset
    31
    bool greaterThan(const HItemPointer& t1, const HItemPointer& t2)
hgs
parents:
diff changeset
    32
    {
hgs
parents:
diff changeset
    33
        return ((*t1).timeStamp > (*t2).timeStamp);
hgs
parents:
diff changeset
    34
    }
hgs
parents:
diff changeset
    35
    
hgs
parents:
diff changeset
    36
    bool lessThan(const HItemPointer& t1, const HItemPointer& t2)
hgs
parents:
diff changeset
    37
    {
hgs
parents:
diff changeset
    38
        return ((*t1).timeStamp < (*t2).timeStamp);
hgs
parents:
diff changeset
    39
    }
hgs
parents:
diff changeset
    40
    
hgs
parents:
diff changeset
    41
#ifdef TRACES
hgs
parents:
diff changeset
    42
#define LOG_ITEM(i) logItem(i)    
hgs
parents:
diff changeset
    43
    void logItem(const HistoryItem& item)
hgs
parents:
diff changeset
    44
    {
hgs
parents:
diff changeset
    45
        QStringList l;
hgs
parents:
diff changeset
    46
        
hgs
parents:
diff changeset
    47
        l << item.message << item.number << item.timeStamp.toString() << item.title;
hgs
parents:
diff changeset
    48
        l << (item.flags & CntIncoming ? "incoming" : "outgoing");
hgs
parents:
diff changeset
    49
        l << (item.flags & CntUnseen ? "unseen" : "seen");
hgs
parents:
diff changeset
    50
        l << (item.flags & CntAttachment ? "attachment" : "");
hgs
parents:
diff changeset
    51
        l << (item.flags & CntCallLog ? "call" : "message");
hgs
parents:
diff changeset
    52
        if (item.flags & CntReceivedCall)
hgs
parents:
diff changeset
    53
            l << "recieved";
hgs
parents:
diff changeset
    54
        else if (item.flags & CntMissedCall)
hgs
parents:
diff changeset
    55
            l << "missed";
hgs
parents:
diff changeset
    56
        else if (item.flags & CntDialledCall)
hgs
parents:
diff changeset
    57
            l << "dialled";
hgs
parents:
diff changeset
    58
        
hgs
parents:
diff changeset
    59
        l.removeAll("");
hgs
parents:
diff changeset
    60
        
hgs
parents:
diff changeset
    61
        qDebug() << l;
hgs
parents:
diff changeset
    62
    }
hgs
parents:
diff changeset
    63
#else
hgs
parents:
diff changeset
    64
#define LOG_ITEM(i)
hgs
parents:
diff changeset
    65
#endif
hgs
parents:
diff changeset
    66
}
hgs
parents:
diff changeset
    67
hgs
parents:
diff changeset
    68
Q_DECLARE_METATYPE(LogsEvent *)
hgs
parents:
diff changeset
    69
hgs
parents:
diff changeset
    70
/*!
hgs
parents:
diff changeset
    71
 * Construct a new CntHistoryModelPrivatePrivate object to communicate 
hgs
parents:
diff changeset
    72
 * with the conversations and logs databases.
hgs
parents:
diff changeset
    73
 *
hgs
parents:
diff changeset
    74
 * \param contactId History specific to this contact is cached. 
hgs
parents:
diff changeset
    75
 * If no contact is specified all the call logs and conversation 
hgs
parents:
diff changeset
    76
 * history from all contacts will be cached.
hgs
parents:
diff changeset
    77
 */
hgs
parents:
diff changeset
    78
CntHistoryModelPrivate::CntHistoryModelPrivate(QContactLocalId contactId, QContactManager* manager)
hgs
parents:
diff changeset
    79
    : QObject(),
hgs
parents:
diff changeset
    80
      m_logsModel(NULL),
hgs
parents:
diff changeset
    81
      m_logsFilter(NULL),
hgs
parents:
diff changeset
    82
      m_AbstractLogsModel(NULL),
hgs
parents:
diff changeset
    83
      m_msgHistory(NULL),
hgs
parents:
diff changeset
    84
      m_contactId(contactId),
hgs
parents:
diff changeset
    85
      m_contactManager(manager),
hgs
parents:
diff changeset
    86
      m_isMyCard(false),
hgs
parents:
diff changeset
    87
      m_isMarkedAsSeen(false),
hgs
parents:
diff changeset
    88
      m_initLogs(false),
hgs
parents:
diff changeset
    89
      m_extendedLocale(HbExtendedLocale::system())
hgs
parents:
diff changeset
    90
{
hgs
parents:
diff changeset
    91
    CNT_ENTRY
hgs
parents:
diff changeset
    92
    
hgs
parents:
diff changeset
    93
    // Create the model structure and cache history data from the databases
hgs
parents:
diff changeset
    94
    initializeModel();
hgs
parents:
diff changeset
    95
    
hgs
parents:
diff changeset
    96
    CNT_EXIT
hgs
parents:
diff changeset
    97
}
hgs
parents:
diff changeset
    98
hgs
parents:
diff changeset
    99
CntHistoryModelPrivate::~CntHistoryModelPrivate()
hgs
parents:
diff changeset
   100
{
hgs
parents:
diff changeset
   101
    CNT_ENTRY
hgs
parents:
diff changeset
   102
    
hgs
parents:
diff changeset
   103
    delete m_logsModel;
hgs
parents:
diff changeset
   104
    delete m_logsFilter;
hgs
parents:
diff changeset
   105
    delete m_msgHistory;
hgs
parents:
diff changeset
   106
    
hgs
parents:
diff changeset
   107
    CNT_EXIT
hgs
parents:
diff changeset
   108
}
hgs
parents:
diff changeset
   109
hgs
parents:
diff changeset
   110
/*!
hgs
parents:
diff changeset
   111
 * Return the data to be used by the view or delegates for a particular
hgs
parents:
diff changeset
   112
 * item and role.
hgs
parents:
diff changeset
   113
 *
hgs
parents:
diff changeset
   114
 * \param index The index of the item to return data about.
hgs
parents:
diff changeset
   115
 * \param role The data should be relevant to this particular purpose.
hgs
parents:
diff changeset
   116
 * \return QVariant The data for the specified index and role.
hgs
parents:
diff changeset
   117
 */
hgs
parents:
diff changeset
   118
QVariant CntHistoryModelPrivate::data(const QModelIndex& index, int role) const
hgs
parents:
diff changeset
   119
{
hgs
parents:
diff changeset
   120
    CNT_ENTRY_ARGS(index << role)
hgs
parents:
diff changeset
   121
    // Invalid index
hgs
parents:
diff changeset
   122
    int row = index.row();
hgs
parents:
diff changeset
   123
    
hgs
parents:
diff changeset
   124
    if ( !validateRowIndex(row) )
hgs
parents:
diff changeset
   125
        return QVariant();
hgs
parents:
diff changeset
   126
    
hgs
parents:
diff changeset
   127
    HItemPointer p = m_List.at(row);
hgs
parents:
diff changeset
   128
    if ( p.isNull() )
hgs
parents:
diff changeset
   129
        return QVariant();
hgs
parents:
diff changeset
   130
        
hgs
parents:
diff changeset
   131
    switch( role )
hgs
parents:
diff changeset
   132
    {       
hgs
parents:
diff changeset
   133
        case Qt::DisplayRole:
hgs
parents:
diff changeset
   134
            return displayRoleData(*p);
hgs
parents:
diff changeset
   135
        case Qt::DecorationRole:
hgs
parents:
diff changeset
   136
            return decorationRoleData(*p);
hgs
parents:
diff changeset
   137
        case Qt::BackgroundRole:
hgs
parents:
diff changeset
   138
            return backgroundRoleData(*p);
hgs
parents:
diff changeset
   139
        case CntFlagsRole:
hgs
parents:
diff changeset
   140
            return QVariant((*p).flags);
hgs
parents:
diff changeset
   141
        case CntPhoneNumberRole:
hgs
parents:
diff changeset
   142
            return QVariant((*p).number);
hgs
parents:
diff changeset
   143
        case CntConverstaionIdRole:
hgs
parents:
diff changeset
   144
            return conversationIdRoleData(row);
hgs
parents:
diff changeset
   145
        default:
hgs
parents:
diff changeset
   146
            return QVariant();
hgs
parents:
diff changeset
   147
    }
hgs
parents:
diff changeset
   148
}
hgs
parents:
diff changeset
   149
hgs
parents:
diff changeset
   150
/*!
hgs
parents:
diff changeset
   151
 * Return the data to be used by the view for a display role.
hgs
parents:
diff changeset
   152
 *
hgs
parents:
diff changeset
   153
 * \param item The History item to return data about.
hgs
parents:
diff changeset
   154
 *  return QVariant List of strings to be displayed on the view.
hgs
parents:
diff changeset
   155
 *  The stings can also be NULL
hgs
parents:
diff changeset
   156
 *  index 0 Title of the conversation item.
hgs
parents:
diff changeset
   157
 *  index 1 Body text
hgs
parents:
diff changeset
   158
 *  index 2 Time stamp
hgs
parents:
diff changeset
   159
 */
hgs
parents:
diff changeset
   160
QVariant CntHistoryModelPrivate::displayRoleData(const HistoryItem& item) const
hgs
parents:
diff changeset
   161
{
hgs
parents:
diff changeset
   162
    CNT_ENTRY
hgs
parents:
diff changeset
   163
    
hgs
parents:
diff changeset
   164
    QStringList list;
hgs
parents:
diff changeset
   165
    HbExtendedLocale locale = m_extendedLocale;
hgs
parents:
diff changeset
   166
    
hgs
parents:
diff changeset
   167
    if (item.timeStamp.date() == QDateTime::currentDateTime().date())
hgs
parents:
diff changeset
   168
    {
hgs
parents:
diff changeset
   169
        list << item.title << item.message << locale.format(item.timeStamp.time(), r_qtn_time_usual);
hgs
parents:
diff changeset
   170
    }
hgs
parents:
diff changeset
   171
    else
hgs
parents:
diff changeset
   172
    {
hgs
parents:
diff changeset
   173
        list << item.title << item.message << locale.format(item.timeStamp.date(), r_qtn_date_usual);
hgs
parents:
diff changeset
   174
    }
hgs
parents:
diff changeset
   175
    
hgs
parents:
diff changeset
   176
    CNT_EXIT_ARGS(list)
hgs
parents:
diff changeset
   177
    
hgs
parents:
diff changeset
   178
    return QVariant(list);
hgs
parents:
diff changeset
   179
}
hgs
parents:
diff changeset
   180
hgs
parents:
diff changeset
   181
/*!
hgs
parents:
diff changeset
   182
 * Return the data to be used by the view for a decoration role.
hgs
parents:
diff changeset
   183
 *
hgs
parents:
diff changeset
   184
 * \param item The History item to return data about.
hgs
parents:
diff changeset
   185
 *  return QVariant String of the icon path.
hgs
parents:
diff changeset
   186
 */
hgs
parents:
diff changeset
   187
QVariant CntHistoryModelPrivate::decorationRoleData(const HistoryItem& item) const
hgs
parents:
diff changeset
   188
{
hgs
parents:
diff changeset
   189
    CNT_ENTRY
hgs
parents:
diff changeset
   190
    
hgs
parents:
diff changeset
   191
    // Messages
hgs
parents:
diff changeset
   192
    if (item.flags & CntMessage)
hgs
parents:
diff changeset
   193
        return QVariant(HbIcon(MESSAGE_ICON));
hgs
parents:
diff changeset
   194
    
hgs
parents:
diff changeset
   195
    // Call logs
hgs
parents:
diff changeset
   196
    if (item.flags & CntCallLog) {
hgs
parents:
diff changeset
   197
        if (item.flags & CntMissedCall)
hgs
parents:
diff changeset
   198
            return QVariant(HbIcon(MISSED_CALL_ICON));
hgs
parents:
diff changeset
   199
        if (item.flags & CntDialledCall)
hgs
parents:
diff changeset
   200
            return QVariant(HbIcon(DAILED_CALL_ICON));
hgs
parents:
diff changeset
   201
        if (item.flags & CntReceivedCall)
hgs
parents:
diff changeset
   202
            return QVariant(HbIcon(RECEIVED_CALL_ICON));
hgs
parents:
diff changeset
   203
    }
hgs
parents:
diff changeset
   204
    
hgs
parents:
diff changeset
   205
    return QVariant();
hgs
parents:
diff changeset
   206
}
hgs
parents:
diff changeset
   207
hgs
parents:
diff changeset
   208
/*!
hgs
parents:
diff changeset
   209
 * Return the data to be used to draw the background of list items
hgs
parents:
diff changeset
   210
 *
hgs
parents:
diff changeset
   211
 * \param item The History item to return data about.
hgs
parents:
diff changeset
   212
 *  return QVariant HbFrameBackground of the list item.
hgs
parents:
diff changeset
   213
 */
hgs
parents:
diff changeset
   214
QVariant CntHistoryModelPrivate::backgroundRoleData(const HistoryItem& item) const
hgs
parents:
diff changeset
   215
{
hgs
parents:
diff changeset
   216
    if (item.flags & CntIncoming)
hgs
parents:
diff changeset
   217
        return QVariant(HbFrameBackground("qtg_fr_convlist_received_normal", HbFrameDrawer::NinePieces));
hgs
parents:
diff changeset
   218
    else
hgs
parents:
diff changeset
   219
        return QVariant(HbFrameBackground("qtg_fr_convlist_sent_normal", HbFrameDrawer::NinePieces));
hgs
parents:
diff changeset
   220
}
hgs
parents:
diff changeset
   221
hgs
parents:
diff changeset
   222
/*!
hgs
parents:
diff changeset
   223
 * Return the conversation id of this row if it is a message
hgs
parents:
diff changeset
   224
 *
hgs
parents:
diff changeset
   225
 * \param item The History item to return data about.
hgs
parents:
diff changeset
   226
 *  return QVariant HbFrameBackground of the list item.
hgs
parents:
diff changeset
   227
 */
hgs
parents:
diff changeset
   228
QVariant CntHistoryModelPrivate::conversationIdRoleData(const int row) const
hgs
parents:
diff changeset
   229
{
hgs
parents:
diff changeset
   230
    HItemPointer p = m_List.at(row);
hgs
parents:
diff changeset
   231
    
hgs
parents:
diff changeset
   232
    int id(-1);
hgs
parents:
diff changeset
   233
    if ( p.data()->flags & CntMessage )
hgs
parents:
diff changeset
   234
        id = m_msgMap.key(p, -1);
hgs
parents:
diff changeset
   235
hgs
parents:
diff changeset
   236
    if (id != -1)
hgs
parents:
diff changeset
   237
        return QVariant(id);
hgs
parents:
diff changeset
   238
    else
hgs
parents:
diff changeset
   239
        return QVariant();
hgs
parents:
diff changeset
   240
}
hgs
parents:
diff changeset
   241
hgs
parents:
diff changeset
   242
/*!
hgs
parents:
diff changeset
   243
 * Get the number of rows (conversations) in this model.
hgs
parents:
diff changeset
   244
 *
hgs
parents:
diff changeset
   245
 * \param parent Optional parent index value.
hgs
parents:
diff changeset
   246
 * \return Number of rows in this model.
hgs
parents:
diff changeset
   247
 */
hgs
parents:
diff changeset
   248
int CntHistoryModelPrivate::rowCount(const QModelIndex& /*parent*/) const
hgs
parents:
diff changeset
   249
{
hgs
parents:
diff changeset
   250
    return m_List.size();
hgs
parents:
diff changeset
   251
}
hgs
parents:
diff changeset
   252
hgs
parents:
diff changeset
   253
/*!
hgs
parents:
diff changeset
   254
 * Sort list items on the model.
hgs
parents:
diff changeset
   255
 *
hgs
parents:
diff changeset
   256
 * \param column Column to be sorted. It is not used.
hgs
parents:
diff changeset
   257
 * \param order Order to sort the list items.
hgs
parents:
diff changeset
   258
 */
hgs
parents:
diff changeset
   259
void CntHistoryModelPrivate::sort(int /*column*/, Qt::SortOrder order)
hgs
parents:
diff changeset
   260
{
hgs
parents:
diff changeset
   261
    CNT_ENTRY_ARGS(order)
hgs
parents:
diff changeset
   262
    
hgs
parents:
diff changeset
   263
    if ( order == Qt::AscendingOrder )
hgs
parents:
diff changeset
   264
        qStableSort(m_List.begin(), m_List.end(), lessThan);
hgs
parents:
diff changeset
   265
    else
hgs
parents:
diff changeset
   266
        qStableSort(m_List.begin(), m_List.end(), greaterThan);
hgs
parents:
diff changeset
   267
    
hgs
parents:
diff changeset
   268
    CNT_EXIT
hgs
parents:
diff changeset
   269
}
hgs
parents:
diff changeset
   270
hgs
parents:
diff changeset
   271
/*!
hgs
parents:
diff changeset
   272
 * Clear history from the database. If the history cached
hgs
parents:
diff changeset
   273
 * is specific to one contact, only that history is cleared.
hgs
parents:
diff changeset
   274
 * 
hgs
parents:
diff changeset
   275
 */
hgs
parents:
diff changeset
   276
void CntHistoryModelPrivate::clearHistory()
hgs
parents:
diff changeset
   277
{
hgs
parents:
diff changeset
   278
    CNT_ENTRY
hgs
parents:
diff changeset
   279
    
hgs
parents:
diff changeset
   280
    Q_Q(CntHistoryModel);
hgs
parents:
diff changeset
   281
    
hgs
parents:
diff changeset
   282
    if ( m_List.isEmpty() )
hgs
parents:
diff changeset
   283
        return;
hgs
parents:
diff changeset
   284
    
hgs
parents:
diff changeset
   285
    // Clear all data from the history model.
hgs
parents:
diff changeset
   286
    int count = rowCount();
hgs
parents:
diff changeset
   287
    
hgs
parents:
diff changeset
   288
    q->doBeginRemoveRows( QModelIndex(), 0, count );
hgs
parents:
diff changeset
   289
    
hgs
parents:
diff changeset
   290
    // Call logs
hgs
parents:
diff changeset
   291
    if ( !m_isMyCard && m_logsFilter )
hgs
parents:
diff changeset
   292
        m_logsFilter->clearEvents();
hgs
parents:
diff changeset
   293
    else if ( m_logsModel )
hgs
parents:
diff changeset
   294
        m_logsModel->clearList(LogsModel::TypeLogsClearAll);
hgs
parents:
diff changeset
   295
    
hgs
parents:
diff changeset
   296
    // Messages
hgs
parents:
diff changeset
   297
    if (m_msgHistory)
hgs
parents:
diff changeset
   298
        m_msgHistory->clearMessages( (int)m_contactId );
hgs
parents:
diff changeset
   299
    
hgs
parents:
diff changeset
   300
    m_List.clear();
hgs
parents:
diff changeset
   301
    m_msgMap.clear();
hgs
parents:
diff changeset
   302
    m_logsMap.clear();
hgs
parents:
diff changeset
   303
    
hgs
parents:
diff changeset
   304
    
hgs
parents:
diff changeset
   305
    q->doEndRemoveRows();
hgs
parents:
diff changeset
   306
    
hgs
parents:
diff changeset
   307
    CNT_EXIT
hgs
parents:
diff changeset
   308
}
hgs
parents:
diff changeset
   309
hgs
parents:
diff changeset
   310
/*!
hgs
parents:
diff changeset
   311
 * Mark all the conversations in the view as seen.
hgs
parents:
diff changeset
   312
 * 
hgs
parents:
diff changeset
   313
 */
hgs
parents:
diff changeset
   314
void CntHistoryModelPrivate::markAllAsSeen()
hgs
parents:
diff changeset
   315
{
hgs
parents:
diff changeset
   316
    CNT_ENTRY
hgs
parents:
diff changeset
   317
    
hgs
parents:
diff changeset
   318
    if ( m_isMarkedAsSeen )
hgs
parents:
diff changeset
   319
        return;
hgs
parents:
diff changeset
   320
    
hgs
parents:
diff changeset
   321
    // Messages
hgs
parents:
diff changeset
   322
    if (m_msgHistory->markRead( m_contactId ))
hgs
parents:
diff changeset
   323
        m_isMarkedAsSeen = true;
hgs
parents:
diff changeset
   324
    
hgs
parents:
diff changeset
   325
    CNT_EXIT
hgs
parents:
diff changeset
   326
}
hgs
parents:
diff changeset
   327
hgs
parents:
diff changeset
   328
/*!
hgs
parents:
diff changeset
   329
 * Create the model structure and cache history data from
hgs
parents:
diff changeset
   330
 * conversations and call logs databases.
hgs
parents:
diff changeset
   331
 *
hgs
parents:
diff changeset
   332
 */
hgs
parents:
diff changeset
   333
void CntHistoryModelPrivate::initializeModel()
hgs
parents:
diff changeset
   334
{
hgs
parents:
diff changeset
   335
    CNT_ENTRY
hgs
parents:
diff changeset
   336
    
hgs
parents:
diff changeset
   337
    initializeLogsModel();
hgs
parents:
diff changeset
   338
    initializeMsgModel();
hgs
parents:
diff changeset
   339
    
hgs
parents:
diff changeset
   340
    CNT_EXIT
hgs
parents:
diff changeset
   341
}
hgs
parents:
diff changeset
   342
hgs
parents:
diff changeset
   343
void CntHistoryModelPrivate::initializeMsgModel()
hgs
parents:
diff changeset
   344
{
hgs
parents:
diff changeset
   345
    CNT_ENTRY
hgs
parents:
diff changeset
   346
    
hgs
parents:
diff changeset
   347
    if( m_isMyCard )
hgs
parents:
diff changeset
   348
        return;
hgs
parents:
diff changeset
   349
    
hgs
parents:
diff changeset
   350
    // Contact centric
hgs
parents:
diff changeset
   351
    MsgHistory* m = new MsgHistory();
hgs
parents:
diff changeset
   352
    
hgs
parents:
diff changeset
   353
    m_msgHistory = m;
hgs
parents:
diff changeset
   354
    
hgs
parents:
diff changeset
   355
    // Connect to signals emitted by msg model
hgs
parents:
diff changeset
   356
    connect(m, SIGNAL(messagesReady(QList<MsgItem>& )), this, SLOT(messagesReady(QList<MsgItem>& )));
hgs
parents:
diff changeset
   357
    connect(m, SIGNAL(messageAdded(MsgItem& )), this, SLOT(messageAdded(MsgItem& )));
hgs
parents:
diff changeset
   358
    connect(m, SIGNAL(messageChanged(MsgItem& )), this, SLOT(messageChanged(MsgItem& )));
hgs
parents:
diff changeset
   359
    connect(m, SIGNAL(messageDeleted(MsgItem& )), this, SLOT(messageDeleted(MsgItem& )));
hgs
parents:
diff changeset
   360
    
hgs
parents:
diff changeset
   361
    // Subscribe to get new messages
hgs
parents:
diff changeset
   362
    // received from this contact
hgs
parents:
diff changeset
   363
    m->subscribe(m_contactId);
hgs
parents:
diff changeset
   364
    
hgs
parents:
diff changeset
   365
    // Initial fetch of all messages
hgs
parents:
diff changeset
   366
    m->getMessages(m_contactId);
hgs
parents:
diff changeset
   367
    
hgs
parents:
diff changeset
   368
    CNT_EXIT
hgs
parents:
diff changeset
   369
}
hgs
parents:
diff changeset
   370
hgs
parents:
diff changeset
   371
void CntHistoryModelPrivate::initializeLogsModel()
hgs
parents:
diff changeset
   372
{
hgs
parents:
diff changeset
   373
    CNT_ENTRY
hgs
parents:
diff changeset
   374
    
hgs
parents:
diff changeset
   375
    //populate model with call events
hgs
parents:
diff changeset
   376
    m_logsModel = new LogsModel(LogsModel::LogsFullModel);
hgs
parents:
diff changeset
   377
    if (!m_isMyCard) {
hgs
parents:
diff changeset
   378
        //do the filtering to get call events for the target contact
hgs
parents:
diff changeset
   379
        m_logsFilter = new LogsCustomFilter;
hgs
parents:
diff changeset
   380
        m_logsFilter->setContactId(m_contactId);
hgs
parents:
diff changeset
   381
        m_logsFilter->setSourceModel(m_logsModel);
hgs
parents:
diff changeset
   382
        m_AbstractLogsModel = m_logsFilter;
hgs
parents:
diff changeset
   383
    } else {
hgs
parents:
diff changeset
   384
        //get all call events
hgs
parents:
diff changeset
   385
        m_AbstractLogsModel = m_logsModel;
hgs
parents:
diff changeset
   386
    }
hgs
parents:
diff changeset
   387
    
hgs
parents:
diff changeset
   388
    //read first call events if any and start listening for more 
hgs
parents:
diff changeset
   389
    for ( int i = 0; i < m_AbstractLogsModel->rowCount(); ++i ) {
hgs
parents:
diff changeset
   390
        LogsEvent* event = qVariantValue<LogsEvent*>(
hgs
parents:
diff changeset
   391
                m_AbstractLogsModel->data(m_AbstractLogsModel->index(i, 0), LogsModel::RoleFullEvent) );
hgs
parents:
diff changeset
   392
        
hgs
parents:
diff changeset
   393
        if ( event ) {
hgs
parents:
diff changeset
   394
            HItemPointer item = HItemPointer(new HistoryItem());
hgs
parents:
diff changeset
   395
            readLogEvent(event, *item);
hgs
parents:
diff changeset
   396
            m_logsMap.insert(i, item);
hgs
parents:
diff changeset
   397
            m_List.append( item );
hgs
parents:
diff changeset
   398
        }
hgs
parents:
diff changeset
   399
    }
hgs
parents:
diff changeset
   400
    
hgs
parents:
diff changeset
   401
    connect(m_AbstractLogsModel, SIGNAL(rowsInserted(const QModelIndex &, int, int)), 
hgs
parents:
diff changeset
   402
            this, SLOT(logsRowsInserted(const QModelIndex &, int, int)));
hgs
parents:
diff changeset
   403
    connect(m_AbstractLogsModel, SIGNAL(rowsRemoved(const QModelIndex &, int, int)), 
hgs
parents:
diff changeset
   404
            this, SLOT(logsRowsRemoved(const QModelIndex &, int, int)));
hgs
parents:
diff changeset
   405
    connect(m_AbstractLogsModel, SIGNAL(dataChanged(const QModelIndex &, const QModelIndex &)), 
hgs
parents:
diff changeset
   406
                this, SLOT(logsDataChanged(const QModelIndex &, const QModelIndex &)));
hgs
parents:
diff changeset
   407
    connect(m_AbstractLogsModel, SIGNAL(modelReset()), this, SLOT(handleLogsReset()));
hgs
parents:
diff changeset
   408
hgs
parents:
diff changeset
   409
    CNT_EXIT
hgs
parents:
diff changeset
   410
}
hgs
parents:
diff changeset
   411
hgs
parents:
diff changeset
   412
/*!
hgs
parents:
diff changeset
   413
 * Read call event into a history item
hgs
parents:
diff changeset
   414
 *
hgs
parents:
diff changeset
   415
 * \param event Call log event
hgs
parents:
diff changeset
   416
 * \param item Conversation history item
hgs
parents:
diff changeset
   417
 */
hgs
parents:
diff changeset
   418
void CntHistoryModelPrivate::readLogEvent(LogsEvent* event, HistoryItem& item)
hgs
parents:
diff changeset
   419
{
hgs
parents:
diff changeset
   420
    QString bodyText;
hgs
parents:
diff changeset
   421
    QString title;
hgs
parents:
diff changeset
   422
    
hgs
parents:
diff changeset
   423
    if ( m_isMyCard ) {
hgs
parents:
diff changeset
   424
        if ( event->remoteParty().length() > 0 ) {
hgs
parents:
diff changeset
   425
            title = QString(event->remoteParty());
hgs
parents:
diff changeset
   426
        }
hgs
parents:
diff changeset
   427
        else {
hgs
parents:
diff changeset
   428
            title = QString(event->number());
hgs
parents:
diff changeset
   429
        }
hgs
parents:
diff changeset
   430
    } else {
hgs
parents:
diff changeset
   431
        if ( event->direction() == LogsEvent::DirIn ) {
hgs
parents:
diff changeset
   432
            bodyText = hbTrId("txt_phob_list_received");
hgs
parents:
diff changeset
   433
            item.flags |= CntReceivedCall;
hgs
parents:
diff changeset
   434
        } else if ( event->direction() == LogsEvent::DirOut ) {
hgs
parents:
diff changeset
   435
            bodyText = hbTrId("txt_phob_list_dialled_call");
hgs
parents:
diff changeset
   436
            item.flags |= CntDialledCall;
hgs
parents:
diff changeset
   437
        } else if ( event->direction() == LogsEvent::DirMissed ) {
hgs
parents:
diff changeset
   438
            bodyText = hbTrId("txt_phob_list_missed_call");
hgs
parents:
diff changeset
   439
            item.flags |= CntMissedCall;
hgs
parents:
diff changeset
   440
        }
hgs
parents:
diff changeset
   441
    }
hgs
parents:
diff changeset
   442
hgs
parents:
diff changeset
   443
    if ( event->direction() == LogsEvent::DirOut ) {
hgs
parents:
diff changeset
   444
        item.flags &= ~CntIncoming;
hgs
parents:
diff changeset
   445
    } else {
hgs
parents:
diff changeset
   446
        item.flags |= CntIncoming;
hgs
parents:
diff changeset
   447
    }
hgs
parents:
diff changeset
   448
    
hgs
parents:
diff changeset
   449
    item.message = bodyText;
hgs
parents:
diff changeset
   450
    item.title = title;
hgs
parents:
diff changeset
   451
    item.timeStamp = event->time().toLocalTime();
hgs
parents:
diff changeset
   452
    item.flags |= CntCallLog;
hgs
parents:
diff changeset
   453
    item.number = QString(event->number());
hgs
parents:
diff changeset
   454
    
hgs
parents:
diff changeset
   455
    LOG_ITEM(item);
hgs
parents:
diff changeset
   456
}
hgs
parents:
diff changeset
   457
hgs
parents:
diff changeset
   458
/*!
hgs
parents:
diff changeset
   459
 * Slot used for receiving new rows from the LogsModel.
hgs
parents:
diff changeset
   460
 *
hgs
parents:
diff changeset
   461
 * \param parent Optional parent index value.
hgs
parents:
diff changeset
   462
 * \param first The first row item to be received from the model.
hgs
parents:
diff changeset
   463
 * \param last The last row item to be received from the model.
hgs
parents:
diff changeset
   464
 */
hgs
parents:
diff changeset
   465
void CntHistoryModelPrivate::logsRowsInserted(const QModelIndex& /*parent*/, int first, int last)
hgs
parents:
diff changeset
   466
{
hgs
parents:
diff changeset
   467
    CNT_ENTRY_ARGS(first << last)
hgs
parents:
diff changeset
   468
    
hgs
parents:
diff changeset
   469
    Q_Q(CntHistoryModel);
hgs
parents:
diff changeset
   470
    
hgs
parents:
diff changeset
   471
    // Check if this is the first time to receive events
hgs
parents:
diff changeset
   472
    if ( !m_initLogs ) {
hgs
parents:
diff changeset
   473
        q->doBeginResetModel();
hgs
parents:
diff changeset
   474
    }
hgs
parents:
diff changeset
   475
    else {
hgs
parents:
diff changeset
   476
        q->doBeginInsertRows( QModelIndex(), rowCount(), rowCount() + (last - first) );
hgs
parents:
diff changeset
   477
    }
hgs
parents:
diff changeset
   478
    
hgs
parents:
diff changeset
   479
    QList<HItemPointer> l;
hgs
parents:
diff changeset
   480
    
hgs
parents:
diff changeset
   481
    for ( int i = first; i < m_AbstractLogsModel->rowCount() && i <= last; ++i ) {
hgs
parents:
diff changeset
   482
        LogsEvent* event = qVariantValue<LogsEvent*>(
hgs
parents:
diff changeset
   483
                m_AbstractLogsModel->data(m_AbstractLogsModel->index(i, 0), LogsModel::RoleFullEvent) );
hgs
parents:
diff changeset
   484
        
hgs
parents:
diff changeset
   485
        if ( event ) {
hgs
parents:
diff changeset
   486
            HItemPointer item(new HistoryItem());
hgs
parents:
diff changeset
   487
            readLogEvent(event, *item);
hgs
parents:
diff changeset
   488
            m_logsMap.insert(i, item);
hgs
parents:
diff changeset
   489
            m_List.append( item );
hgs
parents:
diff changeset
   490
        }
hgs
parents:
diff changeset
   491
    }
hgs
parents:
diff changeset
   492
    
hgs
parents:
diff changeset
   493
    // Check if this is the first time to receive events
hgs
parents:
diff changeset
   494
    // and sort the entire list.
hgs
parents:
diff changeset
   495
    if ( !m_initLogs ) {
hgs
parents:
diff changeset
   496
        sort();
hgs
parents:
diff changeset
   497
        m_initLogs = true;
hgs
parents:
diff changeset
   498
        q->doEndResetModel();
hgs
parents:
diff changeset
   499
    }
hgs
parents:
diff changeset
   500
    else {
hgs
parents:
diff changeset
   501
        q->doEndInsertRows();
hgs
parents:
diff changeset
   502
    }
hgs
parents:
diff changeset
   503
    
hgs
parents:
diff changeset
   504
    CNT_EXIT
hgs
parents:
diff changeset
   505
}
hgs
parents:
diff changeset
   506
hgs
parents:
diff changeset
   507
/*!
hgs
parents:
diff changeset
   508
 * Slot used for receiving new rows from the LogsModel.
hgs
parents:
diff changeset
   509
 *
hgs
parents:
diff changeset
   510
 * \param parent Optional parent index value.
hgs
parents:
diff changeset
   511
 * \param first The first row item to be received from the model.
hgs
parents:
diff changeset
   512
 * \param last The last row item to be received from the model.
hgs
parents:
diff changeset
   513
 */
hgs
parents:
diff changeset
   514
void CntHistoryModelPrivate::logsRowsRemoved(const QModelIndex& /*parent*/, int first, int last)
hgs
parents:
diff changeset
   515
{
hgs
parents:
diff changeset
   516
    CNT_ENTRY_ARGS(first << last)
hgs
parents:
diff changeset
   517
    
hgs
parents:
diff changeset
   518
    Q_Q(CntHistoryModel);
hgs
parents:
diff changeset
   519
    
hgs
parents:
diff changeset
   520
    QList< int > indices;
hgs
parents:
diff changeset
   521
    
hgs
parents:
diff changeset
   522
    for ( int i = first; i <= last; ++i ) {
hgs
parents:
diff changeset
   523
        HItemPointer item = m_logsMap.value( i );
hgs
parents:
diff changeset
   524
        int index = m_List.indexOf( item );
hgs
parents:
diff changeset
   525
        if ( index > -1 ) {
hgs
parents:
diff changeset
   526
            m_logsMap.remove( i );        
hgs
parents:
diff changeset
   527
            indices.append( index );
hgs
parents:
diff changeset
   528
        }
hgs
parents:
diff changeset
   529
    }
hgs
parents:
diff changeset
   530
    
hgs
parents:
diff changeset
   531
    foreach(int i, indices) {
hgs
parents:
diff changeset
   532
        m_List.removeAt( i );
hgs
parents:
diff changeset
   533
    }
hgs
parents:
diff changeset
   534
    
hgs
parents:
diff changeset
   535
    // Remove list items in batches
hgs
parents:
diff changeset
   536
    if ( !indices.isEmpty() ) {
hgs
parents:
diff changeset
   537
        QList< QList<int> > batches = findIndices(indices);
hgs
parents:
diff changeset
   538
        foreach( QList<int> l, batches ) {
hgs
parents:
diff changeset
   539
            q->doBeginRemoveRows(QModelIndex(), l.first(), l.last());
hgs
parents:
diff changeset
   540
            q->doEndRemoveRows();
hgs
parents:
diff changeset
   541
        }
hgs
parents:
diff changeset
   542
    }
hgs
parents:
diff changeset
   543
    
hgs
parents:
diff changeset
   544
    CNT_EXIT
hgs
parents:
diff changeset
   545
}
hgs
parents:
diff changeset
   546
hgs
parents:
diff changeset
   547
/*!
hgs
parents:
diff changeset
   548
 * Update events from logs model. Events are
hgs
parents:
diff changeset
   549
 * received as a batch
hgs
parents:
diff changeset
   550
 *
hgs
parents:
diff changeset
   551
 * \param first First updated model index
hgs
parents:
diff changeset
   552
 * \param last Last updated model index
hgs
parents:
diff changeset
   553
 */
hgs
parents:
diff changeset
   554
void CntHistoryModelPrivate::logsDataChanged(const QModelIndex& first, const QModelIndex& last)
hgs
parents:
diff changeset
   555
{
hgs
parents:
diff changeset
   556
    CNT_ENTRY_ARGS(first << last)
hgs
parents:
diff changeset
   557
    
hgs
parents:
diff changeset
   558
    Q_Q(CntHistoryModel);
hgs
parents:
diff changeset
   559
    
hgs
parents:
diff changeset
   560
    int f = first.row();
hgs
parents:
diff changeset
   561
    int l = last.row();
hgs
parents:
diff changeset
   562
    QList< int > indices;
hgs
parents:
diff changeset
   563
    
hgs
parents:
diff changeset
   564
    for ( int i = f; i < m_AbstractLogsModel->rowCount() && i <= l; ++i ) {
hgs
parents:
diff changeset
   565
        
hgs
parents:
diff changeset
   566
        LogsEvent* event = qVariantValue<LogsEvent*>(
hgs
parents:
diff changeset
   567
                m_AbstractLogsModel->data(m_AbstractLogsModel->index(i, 0), LogsModel::RoleFullEvent) );
hgs
parents:
diff changeset
   568
        
hgs
parents:
diff changeset
   569
        // Fetch item from the mapped logs model items
hgs
parents:
diff changeset
   570
        HItemPointer item = m_logsMap.value( i );
hgs
parents:
diff changeset
   571
        
hgs
parents:
diff changeset
   572
        // Found item in the logs map
hgs
parents:
diff changeset
   573
        if ( !item.isNull() && event ) {
hgs
parents:
diff changeset
   574
            int index = m_List.indexOf( item );
hgs
parents:
diff changeset
   575
            readLogEvent( event, *item );
hgs
parents:
diff changeset
   576
            indices.append( index );
hgs
parents:
diff changeset
   577
        }
hgs
parents:
diff changeset
   578
    }
hgs
parents:
diff changeset
   579
    
hgs
parents:
diff changeset
   580
    // Emit dataChanged signal only if there were updates
hgs
parents:
diff changeset
   581
    if ( !indices.isEmpty() ) {
hgs
parents:
diff changeset
   582
        QList< QList<int> > batches = findIndices( indices );
hgs
parents:
diff changeset
   583
        foreach( QList<int> l, batches )
hgs
parents:
diff changeset
   584
            q->doDataChanged( q->index(l.first(), 0), q->index(l.last(), 0) );
hgs
parents:
diff changeset
   585
    }
hgs
parents:
diff changeset
   586
    
hgs
parents:
diff changeset
   587
    CNT_EXIT
hgs
parents:
diff changeset
   588
}
hgs
parents:
diff changeset
   589
hgs
parents:
diff changeset
   590
/*
hgs
parents:
diff changeset
   591
 * Clear all call logs and refetches new call events after 
hgs
parents:
diff changeset
   592
 * receiving a reset model signal from logs model
hgs
parents:
diff changeset
   593
 */
hgs
parents:
diff changeset
   594
void CntHistoryModelPrivate::handleLogsReset()
hgs
parents:
diff changeset
   595
{
hgs
parents:
diff changeset
   596
    CNT_ENTRY
hgs
parents:
diff changeset
   597
    
hgs
parents:
diff changeset
   598
    Q_Q(CntHistoryModel);
hgs
parents:
diff changeset
   599
    
hgs
parents:
diff changeset
   600
    q->doBeginResetModel();
hgs
parents:
diff changeset
   601
    
hgs
parents:
diff changeset
   602
    // Remove all call logs
hgs
parents:
diff changeset
   603
    QList<HItemPointer> values = m_logsMap.values();
hgs
parents:
diff changeset
   604
    foreach(HItemPointer p, values) {
hgs
parents:
diff changeset
   605
        m_List.removeOne( p );
hgs
parents:
diff changeset
   606
    }
hgs
parents:
diff changeset
   607
    
hgs
parents:
diff changeset
   608
    m_logsMap.clear();
hgs
parents:
diff changeset
   609
    
hgs
parents:
diff changeset
   610
    //read first call events if any and start listening for more 
hgs
parents:
diff changeset
   611
    for ( int i = 0; i < m_AbstractLogsModel->rowCount(); ++i ) {
hgs
parents:
diff changeset
   612
        LogsEvent* event = qVariantValue<LogsEvent*>(
hgs
parents:
diff changeset
   613
                m_AbstractLogsModel->data(m_AbstractLogsModel->index(i, 0), LogsModel::RoleFullEvent) );
hgs
parents:
diff changeset
   614
        
hgs
parents:
diff changeset
   615
        if ( event ) {
hgs
parents:
diff changeset
   616
            HItemPointer item = HItemPointer(new HistoryItem());
hgs
parents:
diff changeset
   617
            readLogEvent(event, *item);
hgs
parents:
diff changeset
   618
            m_logsMap.insert(i, item);
hgs
parents:
diff changeset
   619
            m_List.append( item );
hgs
parents:
diff changeset
   620
        }
hgs
parents:
diff changeset
   621
    }
hgs
parents:
diff changeset
   622
    
hgs
parents:
diff changeset
   623
    sort();
hgs
parents:
diff changeset
   624
hgs
parents:
diff changeset
   625
    q->doEndResetModel();
hgs
parents:
diff changeset
   626
    
hgs
parents:
diff changeset
   627
    CNT_EXIT
hgs
parents:
diff changeset
   628
}
hgs
parents:
diff changeset
   629
hgs
parents:
diff changeset
   630
/*!
hgs
parents:
diff changeset
   631
 * Check whether an idex is out of bound of our list
hgs
parents:
diff changeset
   632
 *
hgs
parents:
diff changeset
   633
 * \param index Index to be validated
hgs
parents:
diff changeset
   634
 */
hgs
parents:
diff changeset
   635
hgs
parents:
diff changeset
   636
bool CntHistoryModelPrivate::validateRowIndex( const int index) const
hgs
parents:
diff changeset
   637
{
hgs
parents:
diff changeset
   638
    return( index < rowCount() && index >= 0 );
hgs
parents:
diff changeset
   639
}
hgs
parents:
diff changeset
   640
hgs
parents:
diff changeset
   641
/*!
hgs
parents:
diff changeset
   642
 * Find the sequences of indices for the given indices from the private list
hgs
parents:
diff changeset
   643
 * 
hgs
parents:
diff changeset
   644
 * \param indices List of indices
hgs
parents:
diff changeset
   645
 * \return sequences of indices
hgs
parents:
diff changeset
   646
 */
hgs
parents:
diff changeset
   647
QList< QList<int> > CntHistoryModelPrivate::findIndices( const QList< int >& indices )
hgs
parents:
diff changeset
   648
{
hgs
parents:
diff changeset
   649
    CNT_ENTRY_ARGS(indices)
hgs
parents:
diff changeset
   650
    
hgs
parents:
diff changeset
   651
    QList< QList<int> > sequences;
hgs
parents:
diff changeset
   652
    QList<int> currSequence;
hgs
parents:
diff changeset
   653
    int prevIndex = indices.at(0) - 1;
hgs
parents:
diff changeset
   654
    
hgs
parents:
diff changeset
   655
    foreach( int currIndex, indices )
hgs
parents:
diff changeset
   656
    {
hgs
parents:
diff changeset
   657
        if ( currIndex >= 0 )
hgs
parents:
diff changeset
   658
        {
hgs
parents:
diff changeset
   659
            if ( prevIndex+1 != currIndex && !currSequence.isEmpty() )
hgs
parents:
diff changeset
   660
            {
hgs
parents:
diff changeset
   661
                sequences.append( currSequence );
hgs
parents:
diff changeset
   662
                currSequence.clear();
hgs
parents:
diff changeset
   663
            } 
hgs
parents:
diff changeset
   664
            currSequence.append( currIndex );
hgs
parents:
diff changeset
   665
            prevIndex = currIndex;
hgs
parents:
diff changeset
   666
        }
hgs
parents:
diff changeset
   667
    }
hgs
parents:
diff changeset
   668
    
hgs
parents:
diff changeset
   669
    if ( !currSequence.isEmpty() )
hgs
parents:
diff changeset
   670
    {
hgs
parents:
diff changeset
   671
        // Add last sequence if such exist
hgs
parents:
diff changeset
   672
        sequences.append( currSequence );
hgs
parents:
diff changeset
   673
    }
hgs
parents:
diff changeset
   674
    
hgs
parents:
diff changeset
   675
    CNT_EXIT_ARGS(sequences)
hgs
parents:
diff changeset
   676
    
hgs
parents:
diff changeset
   677
    return sequences;
hgs
parents:
diff changeset
   678
}
hgs
parents:
diff changeset
   679
hgs
parents:
diff changeset
   680
/*!
hgs
parents:
diff changeset
   681
 * Read message event into a history item
hgs
parents:
diff changeset
   682
 *
hgs
parents:
diff changeset
   683
 * \param event Message event
hgs
parents:
diff changeset
   684
 * \param item Conversation history item
hgs
parents:
diff changeset
   685
 */
hgs
parents:
diff changeset
   686
void CntHistoryModelPrivate::readMsgEvent(MsgItem& event, HistoryItem& item)
hgs
parents:
diff changeset
   687
{
hgs
parents:
diff changeset
   688
    CNT_ENTRY
hgs
parents:
diff changeset
   689
    
hgs
parents:
diff changeset
   690
    // Msg direction
hgs
parents:
diff changeset
   691
    if ( event.direction() == MsgItem::MsgDirectionIncoming ) {
hgs
parents:
diff changeset
   692
        item.flags |= CntIncoming;
hgs
parents:
diff changeset
   693
        // Read status
hgs
parents:
diff changeset
   694
        if ( event.isAttributeSet(MsgItem::MsgAttributeUnread) )
hgs
parents:
diff changeset
   695
            item.flags |= CntUnseen;
hgs
parents:
diff changeset
   696
        else
hgs
parents:
diff changeset
   697
            item.flags &= ~CntUnseen;
hgs
parents:
diff changeset
   698
    } else if ( event.direction() == MsgItem::MsgDirectionOutgoing )
hgs
parents:
diff changeset
   699
        item.flags &= ~CntIncoming;
hgs
parents:
diff changeset
   700
    
hgs
parents:
diff changeset
   701
    // Attachment
hgs
parents:
diff changeset
   702
    if (event.isAttributeSet(MsgItem::MsgAttributeAttachment))
hgs
parents:
diff changeset
   703
        item.flags |= CntAttachment;
hgs
parents:
diff changeset
   704
    
hgs
parents:
diff changeset
   705
    item.flags |= CntMessage;
hgs
parents:
diff changeset
   706
    item.number = event.phoneNumber();
hgs
parents:
diff changeset
   707
    
hgs
parents:
diff changeset
   708
    if (event.body().isEmpty())
hgs
parents:
diff changeset
   709
    {
hgs
parents:
diff changeset
   710
        item.message = " ";
hgs
parents:
diff changeset
   711
    }
hgs
parents:
diff changeset
   712
    else
hgs
parents:
diff changeset
   713
    {
hgs
parents:
diff changeset
   714
        item.message = event.body();
hgs
parents:
diff changeset
   715
    }
hgs
parents:
diff changeset
   716
    
hgs
parents:
diff changeset
   717
    item.timeStamp = event.timeStamp().toLocalTime();
hgs
parents:
diff changeset
   718
    
hgs
parents:
diff changeset
   719
    LOG_ITEM(item);
hgs
parents:
diff changeset
   720
    
hgs
parents:
diff changeset
   721
    CNT_EXIT
hgs
parents:
diff changeset
   722
}
hgs
parents:
diff changeset
   723
hgs
parents:
diff changeset
   724
/*!
hgs
parents:
diff changeset
   725
 * Slot to receive new messages for the first time
hgs
parents:
diff changeset
   726
 * from the messages model
hgs
parents:
diff changeset
   727
 *
hgs
parents:
diff changeset
   728
 * \param event Message event
hgs
parents:
diff changeset
   729
 * \param item Conversation history item
hgs
parents:
diff changeset
   730
 */
hgs
parents:
diff changeset
   731
void CntHistoryModelPrivate::messagesReady(QList<MsgItem>& msgs)
hgs
parents:
diff changeset
   732
{
hgs
parents:
diff changeset
   733
    CNT_ENTRY
hgs
parents:
diff changeset
   734
    
hgs
parents:
diff changeset
   735
    Q_Q(CntHistoryModel);
hgs
parents:
diff changeset
   736
    
hgs
parents:
diff changeset
   737
    q->doBeginResetModel();
hgs
parents:
diff changeset
   738
    
hgs
parents:
diff changeset
   739
    foreach( MsgItem m, msgs ) {
hgs
parents:
diff changeset
   740
        // Create a new hst item
hgs
parents:
diff changeset
   741
        HItemPointer item(new HistoryItem());
hgs
parents:
diff changeset
   742
        
hgs
parents:
diff changeset
   743
        // Parse the MsgItem and add data into hst item
hgs
parents:
diff changeset
   744
        readMsgEvent( m, *item );
hgs
parents:
diff changeset
   745
        
hgs
parents:
diff changeset
   746
        // Map the hist item to a MsgItem in the msgModel
hgs
parents:
diff changeset
   747
        m_msgMap.insert( m.id(), item );
hgs
parents:
diff changeset
   748
        
hgs
parents:
diff changeset
   749
        // Append the hst item to our list
hgs
parents:
diff changeset
   750
        m_List.append( item );
hgs
parents:
diff changeset
   751
    }
hgs
parents:
diff changeset
   752
    
hgs
parents:
diff changeset
   753
    sort();
hgs
parents:
diff changeset
   754
    
hgs
parents:
diff changeset
   755
    q->doEndResetModel();
hgs
parents:
diff changeset
   756
    
hgs
parents:
diff changeset
   757
    CNT_EXIT
hgs
parents:
diff changeset
   758
}
hgs
parents:
diff changeset
   759
hgs
parents:
diff changeset
   760
/*!
hgs
parents:
diff changeset
   761
 * Slot to receive new messages from the messages model
hgs
parents:
diff changeset
   762
 *
hgs
parents:
diff changeset
   763
 * \param event Message event
hgs
parents:
diff changeset
   764
 * \param item Conversation history item
hgs
parents:
diff changeset
   765
 */
hgs
parents:
diff changeset
   766
void CntHistoryModelPrivate::messageAdded(MsgItem& msg)
hgs
parents:
diff changeset
   767
{
hgs
parents:
diff changeset
   768
    CNT_ENTRY
hgs
parents:
diff changeset
   769
    
hgs
parents:
diff changeset
   770
    Q_Q(CntHistoryModel);
hgs
parents:
diff changeset
   771
    
hgs
parents:
diff changeset
   772
    q->doBeginInsertRows( QModelIndex(), rowCount(), rowCount() );
hgs
parents:
diff changeset
   773
    
hgs
parents:
diff changeset
   774
    // Create a new hst item
hgs
parents:
diff changeset
   775
    HItemPointer item(new HistoryItem());
hgs
parents:
diff changeset
   776
    
hgs
parents:
diff changeset
   777
    // Parse the MsgItem and add data into hst item
hgs
parents:
diff changeset
   778
    readMsgEvent( msg, *item );
hgs
parents:
diff changeset
   779
    
hgs
parents:
diff changeset
   780
    // Map the hist item to a MsgItem in the msgModel
hgs
parents:
diff changeset
   781
    m_msgMap.insert( msg.id(), item );
hgs
parents:
diff changeset
   782
    
hgs
parents:
diff changeset
   783
    // Append the hst item to our list
hgs
parents:
diff changeset
   784
    m_List.append( item );
hgs
parents:
diff changeset
   785
    
hgs
parents:
diff changeset
   786
    q->doEndInsertRows();
hgs
parents:
diff changeset
   787
    
hgs
parents:
diff changeset
   788
    CNT_EXIT
hgs
parents:
diff changeset
   789
}
hgs
parents:
diff changeset
   790
hgs
parents:
diff changeset
   791
/*!
hgs
parents:
diff changeset
   792
 * Slot to update a message from the messages model
hgs
parents:
diff changeset
   793
 *
hgs
parents:
diff changeset
   794
 * \param event Message event
hgs
parents:
diff changeset
   795
 * \param item Conversation history item
hgs
parents:
diff changeset
   796
 */
hgs
parents:
diff changeset
   797
void CntHistoryModelPrivate::messageChanged(MsgItem& msg)
hgs
parents:
diff changeset
   798
{
hgs
parents:
diff changeset
   799
    CNT_ENTRY
hgs
parents:
diff changeset
   800
    
hgs
parents:
diff changeset
   801
    Q_Q(CntHistoryModel);
hgs
parents:
diff changeset
   802
    
hgs
parents:
diff changeset
   803
    // Fetch the hst item that maps to this MsgItem
hgs
parents:
diff changeset
   804
    HItemPointer p = m_msgMap.value( msg.id() );
hgs
parents:
diff changeset
   805
    
hgs
parents:
diff changeset
   806
    // No item was found.
hgs
parents:
diff changeset
   807
    if ( p.isNull() )
hgs
parents:
diff changeset
   808
        return;
hgs
parents:
diff changeset
   809
hgs
parents:
diff changeset
   810
    // Parse the MsgItem and add data into hst item
hgs
parents:
diff changeset
   811
    readMsgEvent(msg, *p);
hgs
parents:
diff changeset
   812
    
hgs
parents:
diff changeset
   813
    // Get the index of the the hst item in the list
hgs
parents:
diff changeset
   814
    int pIndex = m_List.indexOf( p );
hgs
parents:
diff changeset
   815
    
hgs
parents:
diff changeset
   816
    q->doDataChanged(q->index(pIndex, 0), q->index(pIndex, 0));
hgs
parents:
diff changeset
   817
    
hgs
parents:
diff changeset
   818
    CNT_EXIT
hgs
parents:
diff changeset
   819
}
hgs
parents:
diff changeset
   820
hgs
parents:
diff changeset
   821
/*!
hgs
parents:
diff changeset
   822
 * Slot to delete a message from the messages model
hgs
parents:
diff changeset
   823
 *
hgs
parents:
diff changeset
   824
 * \param event Message event
hgs
parents:
diff changeset
   825
 * \param item Conversation history item
hgs
parents:
diff changeset
   826
 */
hgs
parents:
diff changeset
   827
void CntHistoryModelPrivate::messageDeleted(MsgItem& msg)
hgs
parents:
diff changeset
   828
{
hgs
parents:
diff changeset
   829
    CNT_ENTRY
hgs
parents:
diff changeset
   830
    
hgs
parents:
diff changeset
   831
    Q_Q(CntHistoryModel);
hgs
parents:
diff changeset
   832
    
hgs
parents:
diff changeset
   833
    // Fetch the hst item that maps to this MsgItem
hgs
parents:
diff changeset
   834
    HItemPointer p = m_msgMap.value( msg.id() );
hgs
parents:
diff changeset
   835
    
hgs
parents:
diff changeset
   836
    // No item was found.
hgs
parents:
diff changeset
   837
    if ( p.isNull() )
hgs
parents:
diff changeset
   838
        return;
hgs
parents:
diff changeset
   839
    
hgs
parents:
diff changeset
   840
    // Remove the item in stored containers
hgs
parents:
diff changeset
   841
    m_msgMap.remove( msg.id() );
hgs
parents:
diff changeset
   842
    int index = m_List.indexOf( p );
hgs
parents:
diff changeset
   843
    if ( index > -1 ) {
hgs
parents:
diff changeset
   844
        q->doBeginRemoveRows(QModelIndex(), index, index);
hgs
parents:
diff changeset
   845
        m_List.removeAt( index );
hgs
parents:
diff changeset
   846
        q->doEndRemoveRows();
hgs
parents:
diff changeset
   847
    }
hgs
parents:
diff changeset
   848
    
hgs
parents:
diff changeset
   849
    CNT_EXIT
hgs
parents:
diff changeset
   850
}