videocollection/videocollectionwrapper/src/videocollectionlistener.cpp
author hgs
Mon, 23 Aug 2010 14:27:29 +0300
changeset 55 4bfa887905cf
parent 50 21fe8338c6bf
permissions -rw-r--r--
201033
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
30
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
*
36
hgs
parents: 35
diff changeset
    14
* Description:   VideoCollectionListener class implementation
30
hgs
parents:
diff changeset
    15
* 
hgs
parents:
diff changeset
    16
*/
hgs
parents:
diff changeset
    17
55
hgs
parents: 50
diff changeset
    18
// Version : %version: 35 %
36
hgs
parents: 35
diff changeset
    19
30
hgs
parents:
diff changeset
    20
// INCLUDE FILES
hgs
parents:
diff changeset
    21
#include <mpxmediageneraldefs.h>
hgs
parents:
diff changeset
    22
#include <mpxmessagegeneraldefs.h>
hgs
parents:
diff changeset
    23
#include <mpxmessage2.h>
hgs
parents:
diff changeset
    24
#include <mpxcollectionmessagedefs.h>
hgs
parents:
diff changeset
    25
#include <mpxcollectionmessage.h>
hgs
parents:
diff changeset
    26
#include <mpxmessagecontainerdefs.h>
hgs
parents:
diff changeset
    27
#include <mpxmediacontainerdefs.h>
hgs
parents:
diff changeset
    28
#include <mpxcommandgeneraldefs.h>
hgs
parents:
diff changeset
    29
#include <mpxcollectioncommanddefs.h>
hgs
parents:
diff changeset
    30
#include <vcxmyvideosdefs.h>
hgs
parents:
diff changeset
    31
#include <vcxmyvideosuids.h>
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
#include "videocollectionlistener.h"
hgs
parents:
diff changeset
    34
#include "videocollectionclient.h"
34
hgs
parents: 30
diff changeset
    35
#include "videodatasignalreceiver.h"
30
hgs
parents:
diff changeset
    36
#include "videocollectionutils.h"
34
hgs
parents: 30
diff changeset
    37
#include "videocollectioncommon.h"
36
hgs
parents: 35
diff changeset
    38
#include "videocollectiontrace.h"
30
hgs
parents:
diff changeset
    39
hgs
parents:
diff changeset
    40
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    41
// VideoCollectionListener
hgs
parents:
diff changeset
    42
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    43
//
36
hgs
parents: 35
diff changeset
    44
VideoCollectionListener::VideoCollectionListener( VideoCollectionClient &collectionClient,
hgs
parents: 35
diff changeset
    45
                                                  VideoDataSignalReceiver &signalReceiver)  
hgs
parents: 35
diff changeset
    46
    : mCollectionClient( collectionClient )
hgs
parents: 35
diff changeset
    47
    , mSignalReceiver( signalReceiver )
hgs
parents: 35
diff changeset
    48
    , mVideoUtils( VideoCollectionUtils::instance() )
30
hgs
parents:
diff changeset
    49
{
36
hgs
parents: 35
diff changeset
    50
	FUNC_LOG;
30
hgs
parents:
diff changeset
    51
}
hgs
parents:
diff changeset
    52
hgs
parents:
diff changeset
    53
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    54
// ~VideoCollectionListener
hgs
parents:
diff changeset
    55
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    56
//
hgs
parents:
diff changeset
    57
VideoCollectionListener::~VideoCollectionListener()
hgs
parents:
diff changeset
    58
{
36
hgs
parents: 35
diff changeset
    59
	FUNC_LOG;
30
hgs
parents:
diff changeset
    60
}
hgs
parents:
diff changeset
    61
hgs
parents:
diff changeset
    62
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    63
// HandleCollectionMediaL
hgs
parents:
diff changeset
    64
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    65
//
hgs
parents:
diff changeset
    66
void VideoCollectionListener::HandleCollectionMediaL( 
hgs
parents:
diff changeset
    67
        const CMPXMedia& /*aMedia*/,
hgs
parents:
diff changeset
    68
        TInt /*aError*/)
hgs
parents:
diff changeset
    69
{
36
hgs
parents: 35
diff changeset
    70
	FUNC_LOG;
30
hgs
parents:
diff changeset
    71
}
hgs
parents:
diff changeset
    72
hgs
parents:
diff changeset
    73
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    74
// HandleOpenL
hgs
parents:
diff changeset
    75
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
    76
//
hgs
parents:
diff changeset
    77
void VideoCollectionListener::HandleOpenL( 
hgs
parents:
diff changeset
    78
        const CMPXMedia& aEntries,
hgs
parents:
diff changeset
    79
        TInt /*aIndex*/,
hgs
parents:
diff changeset
    80
        TBool /*aComplete*/,
hgs
parents:
diff changeset
    81
        TInt aError)
hgs
parents:
diff changeset
    82
{
36
hgs
parents: 35
diff changeset
    83
	FUNC_LOG;
30
hgs
parents:
diff changeset
    84
    if(aError != KErrNone)
hgs
parents:
diff changeset
    85
    {
36
hgs
parents: 35
diff changeset
    86
        ERROR(aError, "VideoCollectionListener::HandleOpenL()");
30
hgs
parents:
diff changeset
    87
        return;
hgs
parents:
diff changeset
    88
    }
hgs
parents:
diff changeset
    89
34
hgs
parents: 30
diff changeset
    90
    // Check that current level is valid and entries has collection path. 
36
hgs
parents: 35
diff changeset
    91
    if(mCollectionClient.getCollectionLevel() < VideoCollectionCommon::ELevelCategory )
30
hgs
parents:
diff changeset
    92
    {
36
hgs
parents: 35
diff changeset
    93
        ERROR(-1, "VideoCollectionListener::HandleOpenL() invalid level");
30
hgs
parents:
diff changeset
    94
        return;
hgs
parents:
diff changeset
    95
    }
36
hgs
parents: 35
diff changeset
    96
30
hgs
parents:
diff changeset
    97
    CMPXMediaArray *array =
hgs
parents:
diff changeset
    98
                    mVideoUtils.mediaValuePtr<CMPXMessageArray>(&aEntries, KMPXMediaArrayContents);
hgs
parents:
diff changeset
    99
    if(!array)
hgs
parents:
diff changeset
   100
    {
36
hgs
parents: 35
diff changeset
   101
        ERROR(-1, "VideoCollectionListener::HandleOpenL() array contents is NULL.");
30
hgs
parents:
diff changeset
   102
        return;
hgs
parents:
diff changeset
   103
    }
34
hgs
parents: 30
diff changeset
   104
36
hgs
parents: 35
diff changeset
   105
    CMPXCollectionPath* path = 
hgs
parents: 35
diff changeset
   106
                    mVideoUtils.mediaValuePtr<CMPXCollectionPath>(&aEntries, KMPXMediaGeneralContainerPath);
34
hgs
parents: 30
diff changeset
   107
    if(!path)
hgs
parents: 30
diff changeset
   108
	{
36
hgs
parents: 35
diff changeset
   109
        ERROR(-1, "VideoCollectionListener::HandleOpenL() no container path in message.");
34
hgs
parents: 30
diff changeset
   110
        return;
hgs
parents: 30
diff changeset
   111
	}
hgs
parents: 30
diff changeset
   112
hgs
parents: 30
diff changeset
   113
    TMPXItemId pathId = path->Id();
hgs
parents: 30
diff changeset
   114
    
hgs
parents: 30
diff changeset
   115
    TBool categoryOrAlbumVideoList = false;
35
hgs
parents: 34
diff changeset
   116
    if(path->Levels() == VideoCollectionCommon::PathLevelVideos && pathId.iId2 != KVcxMvcMediaTypeVideo)
34
hgs
parents: 30
diff changeset
   117
	{
hgs
parents: 30
diff changeset
   118
        categoryOrAlbumVideoList = true;
hgs
parents: 30
diff changeset
   119
	}
hgs
parents: 30
diff changeset
   120
hgs
parents: 30
diff changeset
   121
    if(categoryOrAlbumVideoList)
30
hgs
parents:
diff changeset
   122
    {
38
hgs
parents: 36
diff changeset
   123
        // checks if there are new videos in the list that are not yet in our data model.
hgs
parents: 36
diff changeset
   124
        mSignalReceiver.newVideoListSlot(array);
hgs
parents: 36
diff changeset
   125
        
34
hgs
parents: 30
diff changeset
   126
        mSignalReceiver.albumListAvailableSlot(pathId, array);
30
hgs
parents:
diff changeset
   127
    }
hgs
parents:
diff changeset
   128
    else
hgs
parents:
diff changeset
   129
    {
34
hgs
parents: 30
diff changeset
   130
        mSignalReceiver.newVideoListSlot(array);
30
hgs
parents:
diff changeset
   131
    }
38
hgs
parents: 36
diff changeset
   132
    
hgs
parents: 36
diff changeset
   133
    int listCompleted(-1);
50
hgs
parents: 38
diff changeset
   134
    
hgs
parents: 38
diff changeset
   135
    if(path->Levels() == VideoCollectionCommon::PathLevelCategories)
hgs
parents: 38
diff changeset
   136
    {
hgs
parents: 38
diff changeset
   137
        bool listIsPartial(false);
hgs
parents: 38
diff changeset
   138
        if(mVideoUtils.mediaValue<bool>(&aEntries, KVcxMediaMyVideosVideoListIsPartial, listIsPartial))
hgs
parents: 38
diff changeset
   139
        {
hgs
parents: 38
diff changeset
   140
            if(!listIsPartial)
hgs
parents: 38
diff changeset
   141
            {
hgs
parents: 38
diff changeset
   142
                mSignalReceiver.albumListCompleteSlot();
hgs
parents: 38
diff changeset
   143
            }
hgs
parents: 38
diff changeset
   144
        }
hgs
parents: 38
diff changeset
   145
    }
hgs
parents: 38
diff changeset
   146
    else if(mVideoUtils.mediaValue<int>(&aEntries, KVcxMediaMyVideosInt32Value, listCompleted))
38
hgs
parents: 36
diff changeset
   147
    {
hgs
parents: 36
diff changeset
   148
        if(listCompleted == EVcxMyVideosVideoListComplete)
hgs
parents: 36
diff changeset
   149
        {
50
hgs
parents: 38
diff changeset
   150
            mSignalReceiver.videoListCompleteSlot();
38
hgs
parents: 36
diff changeset
   151
        }
hgs
parents: 36
diff changeset
   152
    }
hgs
parents: 36
diff changeset
   153
}
30
hgs
parents:
diff changeset
   154
hgs
parents:
diff changeset
   155
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   156
// HandleOpenL
hgs
parents:
diff changeset
   157
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   158
//                      
hgs
parents:
diff changeset
   159
void VideoCollectionListener::HandleOpenL( 
hgs
parents:
diff changeset
   160
        const CMPXCollectionPlaylist& /*aPlaylist*/,
hgs
parents:
diff changeset
   161
        TInt /*aError*/)
hgs
parents:
diff changeset
   162
{
36
hgs
parents: 35
diff changeset
   163
	FUNC_LOG;
30
hgs
parents:
diff changeset
   164
}
hgs
parents:
diff changeset
   165
hgs
parents:
diff changeset
   166
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   167
// HandleCommandComplete
hgs
parents:
diff changeset
   168
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   169
//
hgs
parents:
diff changeset
   170
void VideoCollectionListener::HandleCommandComplete( 
hgs
parents:
diff changeset
   171
        CMPXCommand* aCommandResult, 
hgs
parents:
diff changeset
   172
        TInt aError)
hgs
parents:
diff changeset
   173
{
36
hgs
parents: 35
diff changeset
   174
	FUNC_LOG;
30
hgs
parents:
diff changeset
   175
    if(aError != KErrNone || !aCommandResult)
hgs
parents:
diff changeset
   176
    {
36
hgs
parents: 35
diff changeset
   177
        ERROR_1(aError, "VideoCollectionListener::HandleCommandComplete() result: %d", aCommandResult);
30
hgs
parents:
diff changeset
   178
        return;
hgs
parents:
diff changeset
   179
    }
hgs
parents:
diff changeset
   180
    int commandId = -1;
hgs
parents:
diff changeset
   181
    
hgs
parents:
diff changeset
   182
    if(mVideoUtils.mediaValue<int>(aCommandResult, KVcxMediaMyVideosCommandId, commandId))
hgs
parents:
diff changeset
   183
    {
hgs
parents:
diff changeset
   184
        if(commandId == KVcxCommandMyVideosGetMediaFullDetailsByMpxId)
hgs
parents:
diff changeset
   185
        {
hgs
parents:
diff changeset
   186
            handleGetVideoDetailsResp(aCommandResult);
hgs
parents:
diff changeset
   187
        }
34
hgs
parents: 30
diff changeset
   188
        else if(commandId == KVcxCommandMyVideosRemoveAlbums)
hgs
parents: 30
diff changeset
   189
        {
hgs
parents: 30
diff changeset
   190
			CMPXMediaArray *messageArray = 
hgs
parents: 30
diff changeset
   191
				mVideoUtils.mediaValuePtr<CMPXMediaArray>(aCommandResult, KMPXMediaArrayContents);
hgs
parents: 30
diff changeset
   192
			
hgs
parents: 30
diff changeset
   193
			if(!messageArray || messageArray->Count() == 0)
hgs
parents: 30
diff changeset
   194
			{
hgs
parents: 30
diff changeset
   195
				return;
hgs
parents: 30
diff changeset
   196
			}
hgs
parents: 30
diff changeset
   197
			QList<TMPXItemId> failedIds;    
hgs
parents: 30
diff changeset
   198
			TMPXItemId itemId;  
hgs
parents: 30
diff changeset
   199
			int count = messageArray->Count();
hgs
parents: 30
diff changeset
   200
			int failedFlag = 0;
hgs
parents: 30
diff changeset
   201
			CMPXMedia* item = NULL;
hgs
parents: 30
diff changeset
   202
			
hgs
parents: 30
diff changeset
   203
			// go throught all removed albums and see if some has failed
hgs
parents: 30
diff changeset
   204
			for (int i = 0; i < count; ++i)
hgs
parents: 30
diff changeset
   205
			{
hgs
parents: 30
diff changeset
   206
				item = (*messageArray)[i];
hgs
parents: 30
diff changeset
   207
				if(!mVideoUtils.mediaValue<TMPXItemId>(item, KMPXMediaGeneralId, itemId))
hgs
parents: 30
diff changeset
   208
				{
hgs
parents: 30
diff changeset
   209
					// invalid message, return 
hgs
parents: 30
diff changeset
   210
					return;
hgs
parents: 30
diff changeset
   211
				}
hgs
parents: 30
diff changeset
   212
				// if there's error while fetching value, it means that value does not exists,
hgs
parents: 30
diff changeset
   213
				// so we can assume remove was succefull
hgs
parents: 30
diff changeset
   214
				if(mVideoUtils.mediaValue<int>(item, KVcxMediaMyVideosInt32Value, failedFlag))
hgs
parents: 30
diff changeset
   215
				{
hgs
parents: 30
diff changeset
   216
					if (failedFlag)
hgs
parents: 30
diff changeset
   217
					{
hgs
parents: 30
diff changeset
   218
						failedIds.append(itemId);
hgs
parents: 30
diff changeset
   219
					}
hgs
parents: 30
diff changeset
   220
					failedFlag = 0;
hgs
parents: 30
diff changeset
   221
				}       
hgs
parents: 30
diff changeset
   222
			}
hgs
parents: 30
diff changeset
   223
			if (failedIds.count())
hgs
parents: 30
diff changeset
   224
			{
hgs
parents: 30
diff changeset
   225
				mSignalReceiver.albumRemoveFailureSlot(&failedIds);
hgs
parents: 30
diff changeset
   226
			}
hgs
parents: 30
diff changeset
   227
        }
30
hgs
parents:
diff changeset
   228
    }
hgs
parents:
diff changeset
   229
}
hgs
parents:
diff changeset
   230
hgs
parents:
diff changeset
   231
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   232
// HandleCollectionMessage
hgs
parents:
diff changeset
   233
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   234
//
hgs
parents:
diff changeset
   235
void VideoCollectionListener::HandleCollectionMessage( 
hgs
parents:
diff changeset
   236
        CMPXMessage* aMessage,
hgs
parents:
diff changeset
   237
        TInt aError )
hgs
parents:
diff changeset
   238
{
36
hgs
parents: 35
diff changeset
   239
	FUNC_LOG;
30
hgs
parents:
diff changeset
   240
    if(aError)
hgs
parents:
diff changeset
   241
    {
36
hgs
parents: 35
diff changeset
   242
        ERROR(aError, "VideoCollectionListener::HandleCollectionMessage()");
30
hgs
parents:
diff changeset
   243
        return;
hgs
parents:
diff changeset
   244
    }  
hgs
parents:
diff changeset
   245
hgs
parents:
diff changeset
   246
    TMPXMessageId mainMessageId;
hgs
parents:
diff changeset
   247
    if(!mVideoUtils.mediaValue<TMPXMessageId>(aMessage, KMPXMessageGeneralId, mainMessageId))
hgs
parents:
diff changeset
   248
    {
hgs
parents:
diff changeset
   249
        return;
hgs
parents:
diff changeset
   250
    }  
hgs
parents:
diff changeset
   251
    
hgs
parents:
diff changeset
   252
    if(mCollectionClient.getOpenStatus() == VideoCollectionClient::ECollectionOpened )
hgs
parents:
diff changeset
   253
    {
hgs
parents:
diff changeset
   254
        // after colletion has been opened we handle messages from our collection plugin only
34
hgs
parents: 30
diff changeset
   255
        TUid collectionUid = {0};
30
hgs
parents:
diff changeset
   256
        bool status = mVideoUtils.mediaValue<TUid>(aMessage, KMPXMessageCollectionId, collectionUid);
hgs
parents:
diff changeset
   257
        if(!status || collectionUid.iUid != KVcxUidMyVideosMpxCollection)
hgs
parents:
diff changeset
   258
        {
hgs
parents:
diff changeset
   259
            return;
hgs
parents:
diff changeset
   260
        }
hgs
parents:
diff changeset
   261
    }
hgs
parents:
diff changeset
   262
    else
hgs
parents:
diff changeset
   263
    {
hgs
parents:
diff changeset
   264
        // before opening we're just excepting general messages
hgs
parents:
diff changeset
   265
        if(mainMessageId == KMPXMessageGeneral)
hgs
parents:
diff changeset
   266
        {
hgs
parents:
diff changeset
   267
            handleGeneralMPXMessage(aMessage);
hgs
parents:
diff changeset
   268
        }
hgs
parents:
diff changeset
   269
        return;
hgs
parents:
diff changeset
   270
    }
36
hgs
parents: 35
diff changeset
   271
30
hgs
parents:
diff changeset
   272
    if( mainMessageId == KVcxCommandIdMyVideos)
hgs
parents:
diff changeset
   273
    {        
hgs
parents:
diff changeset
   274
        int myVideosMainMsgId = -1; 
hgs
parents:
diff changeset
   275
36
hgs
parents: 35
diff changeset
   276
        if(!mVideoUtils.mediaValue<int>(aMessage, KVcxMediaMyVideosCommandId, myVideosMainMsgId))
30
hgs
parents:
diff changeset
   277
        {
hgs
parents:
diff changeset
   278
            return;
hgs
parents:
diff changeset
   279
        }
hgs
parents:
diff changeset
   280
36
hgs
parents: 35
diff changeset
   281
        if (myVideosMainMsgId == KVcxMessageMyVideosMessageArray)
30
hgs
parents:
diff changeset
   282
        {
hgs
parents:
diff changeset
   283
            handleMyVideosMessageArray(aMessage); 
hgs
parents:
diff changeset
   284
        }
hgs
parents:
diff changeset
   285
        else
hgs
parents:
diff changeset
   286
        {
hgs
parents:
diff changeset
   287
            handleMyVideosMPXMessage(myVideosMainMsgId, aMessage);
hgs
parents:
diff changeset
   288
        }
hgs
parents:
diff changeset
   289
    }
hgs
parents:
diff changeset
   290
    else
hgs
parents:
diff changeset
   291
    {
hgs
parents:
diff changeset
   292
        handleMPXMessage(mainMessageId, aMessage);
hgs
parents:
diff changeset
   293
    }
hgs
parents:
diff changeset
   294
}
hgs
parents:
diff changeset
   295
hgs
parents:
diff changeset
   296
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   297
// handleMyVideosMessageArray
hgs
parents:
diff changeset
   298
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   299
//
hgs
parents:
diff changeset
   300
void VideoCollectionListener::handleMyVideosMessageArray(CMPXMessage *aMessage)
hgs
parents:
diff changeset
   301
{   
36
hgs
parents: 35
diff changeset
   302
	FUNC_LOG;
30
hgs
parents:
diff changeset
   303
    CMPXMessageArray* messageArray = NULL;
hgs
parents:
diff changeset
   304
    
hgs
parents:
diff changeset
   305
    messageArray = mVideoUtils.mediaValuePtr<CMPXMessageArray>(aMessage, KMPXMessageArrayContents);
hgs
parents:
diff changeset
   306
    if(!messageArray)
hgs
parents:
diff changeset
   307
    {
hgs
parents:
diff changeset
   308
        return;
hgs
parents:
diff changeset
   309
    }
hgs
parents:
diff changeset
   310
    
36
hgs
parents: 35
diff changeset
   311
    int count = messageArray->Count();
30
hgs
parents:
diff changeset
   312
    int myVideosMsgId;
hgs
parents:
diff changeset
   313
    TMPXMessageId mpxMessageId;
hgs
parents:
diff changeset
   314
    
hgs
parents:
diff changeset
   315
    CMPXMessage *singleMessage;
hgs
parents:
diff changeset
   316
    for ( int i = 0; i < count; ++i )
hgs
parents:
diff changeset
   317
    {
hgs
parents:
diff changeset
   318
        singleMessage = (*messageArray)[i];
hgs
parents:
diff changeset
   319
        if(mVideoUtils.mediaValue<int>(singleMessage, KVcxMediaMyVideosCommandId, myVideosMsgId))
hgs
parents:
diff changeset
   320
        {
hgs
parents:
diff changeset
   321
            handleMyVideosMPXMessage(myVideosMsgId, singleMessage);
hgs
parents:
diff changeset
   322
        }
hgs
parents:
diff changeset
   323
        else if(mVideoUtils.mediaValue<TMPXMessageId>(
hgs
parents:
diff changeset
   324
                                        singleMessage, KMPXMessageGeneralId, mpxMessageId))
hgs
parents:
diff changeset
   325
        {
hgs
parents:
diff changeset
   326
            handleMPXMessage(mpxMessageId, singleMessage);
hgs
parents:
diff changeset
   327
        }
hgs
parents:
diff changeset
   328
    }    
hgs
parents:
diff changeset
   329
}
hgs
parents:
diff changeset
   330
hgs
parents:
diff changeset
   331
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   332
// handleMyVideosMPXMessage
hgs
parents:
diff changeset
   333
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   334
//
hgs
parents:
diff changeset
   335
void VideoCollectionListener::handleMyVideosMPXMessage(int &myVideosMsgId, CMPXMessage *aMessage)
hgs
parents:
diff changeset
   336
{
36
hgs
parents: 35
diff changeset
   337
	FUNC_LOG;
30
hgs
parents:
diff changeset
   338
    switch (myVideosMsgId)
hgs
parents:
diff changeset
   339
    {
hgs
parents:
diff changeset
   340
        case KVcxMessageMyVideosGetMediasByMpxIdResp:
hgs
parents:
diff changeset
   341
            handleGetMediasByMpxIdResp(aMessage);
hgs
parents:
diff changeset
   342
            break;
hgs
parents:
diff changeset
   343
        case KVcxMessageMyVideosDeleteResp:
hgs
parents:
diff changeset
   344
            handleMyVideosDeleteMessage(aMessage);
hgs
parents:
diff changeset
   345
            break;
hgs
parents:
diff changeset
   346
        case KVcxMessageMyVideosDeleteStarted:
hgs
parents:
diff changeset
   347
            break;
hgs
parents:
diff changeset
   348
        case KVcxMessageMyVideosListComplete:
hgs
parents:
diff changeset
   349
            mCollectionClient.startOpenCurrentState();
hgs
parents:
diff changeset
   350
            break;
hgs
parents:
diff changeset
   351
        case KVcxMessageMyVideosItemsAppended:
hgs
parents:
diff changeset
   352
            mCollectionClient.startOpenCurrentState();
hgs
parents:
diff changeset
   353
            break;
hgs
parents:
diff changeset
   354
        case KVcxMessageMyVideosMoveOrCopyStarted:
hgs
parents:
diff changeset
   355
            break;
hgs
parents:
diff changeset
   356
        case KVcxMessageMyVideosMoveResp:
hgs
parents:
diff changeset
   357
            break;
hgs
parents:
diff changeset
   358
        case KVcxMessageMyVideosCopyResp:
hgs
parents:
diff changeset
   359
            break;
hgs
parents:
diff changeset
   360
        default:
hgs
parents:
diff changeset
   361
            break;
hgs
parents:
diff changeset
   362
    }
hgs
parents:
diff changeset
   363
}
hgs
parents:
diff changeset
   364
hgs
parents:
diff changeset
   365
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   366
// handleCommonMPXMessage
hgs
parents:
diff changeset
   367
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   368
//
hgs
parents:
diff changeset
   369
void VideoCollectionListener::handleMPXMessage(TMPXMessageId &mpxMessageId, CMPXMessage *aMessage)
hgs
parents:
diff changeset
   370
{
36
hgs
parents: 35
diff changeset
   371
	FUNC_LOG;
30
hgs
parents:
diff changeset
   372
    switch(mpxMessageId)
hgs
parents:
diff changeset
   373
    {
hgs
parents:
diff changeset
   374
        case KMPXMessageGeneral:
hgs
parents:
diff changeset
   375
            handleGeneralMPXMessage(aMessage);
hgs
parents:
diff changeset
   376
        break;
hgs
parents:
diff changeset
   377
        case KMPXMessageIdItemChanged:
hgs
parents:
diff changeset
   378
            handleMyVideosItemsChanged(aMessage);
hgs
parents:
diff changeset
   379
        break;
hgs
parents:
diff changeset
   380
        default:
hgs
parents:
diff changeset
   381
        break;
hgs
parents:
diff changeset
   382
    }
hgs
parents:
diff changeset
   383
}
hgs
parents:
diff changeset
   384
hgs
parents:
diff changeset
   385
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   386
// handleGeneralMPXMessage
hgs
parents:
diff changeset
   387
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   388
//
hgs
parents:
diff changeset
   389
void VideoCollectionListener::handleGeneralMPXMessage(CMPXMessage* aMessage)
hgs
parents:
diff changeset
   390
{
36
hgs
parents: 35
diff changeset
   391
	FUNC_LOG;
30
hgs
parents:
diff changeset
   392
    if(mCollectionClient.getOpenStatus() != VideoCollectionClient::ECollectionOpening)
hgs
parents:
diff changeset
   393
    {
hgs
parents:
diff changeset
   394
        return;
hgs
parents:
diff changeset
   395
    }
hgs
parents:
diff changeset
   396
    int event = 0;
hgs
parents:
diff changeset
   397
    if(!mVideoUtils.mediaValue<int>(aMessage, KMPXMessageGeneralEvent, event))
hgs
parents:
diff changeset
   398
    {
hgs
parents:
diff changeset
   399
        return;
hgs
parents:
diff changeset
   400
    }
hgs
parents:
diff changeset
   401
hgs
parents:
diff changeset
   402
    int data = 0;
hgs
parents:
diff changeset
   403
    if(!mVideoUtils.mediaValue<int>(aMessage, KMPXMessageGeneralData, data))
hgs
parents:
diff changeset
   404
    {
hgs
parents:
diff changeset
   405
        return;
hgs
parents:
diff changeset
   406
    }
hgs
parents:
diff changeset
   407
hgs
parents:
diff changeset
   408
    if( event == TMPXCollectionMessage::EPathChanged &&    
hgs
parents:
diff changeset
   409
        data == EMcContainerOpened )
hgs
parents:
diff changeset
   410
    {
hgs
parents:
diff changeset
   411
        mCollectionClient.setOpenStatus(VideoCollectionClient::ECollectionOpened);
hgs
parents:
diff changeset
   412
    }
hgs
parents:
diff changeset
   413
}
hgs
parents:
diff changeset
   414
hgs
parents:
diff changeset
   415
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   416
// handleMyVideosItemsChanged
hgs
parents:
diff changeset
   417
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   418
//
hgs
parents:
diff changeset
   419
void VideoCollectionListener::handleMyVideosItemsChanged(CMPXMessage* aMessage)
hgs
parents:
diff changeset
   420
{
36
hgs
parents: 35
diff changeset
   421
	FUNC_LOG;
34
hgs
parents: 30
diff changeset
   422
    TMPXChangeEventType eventType = EMPXItemModified; 
hgs
parents: 30
diff changeset
   423
    if(!mVideoUtils.mediaValue<TMPXChangeEventType>(
hgs
parents: 30
diff changeset
   424
        aMessage,KMPXMessageChangeEventType, eventType))
30
hgs
parents:
diff changeset
   425
    {
hgs
parents:
diff changeset
   426
        return;
hgs
parents:
diff changeset
   427
    }
34
hgs
parents: 30
diff changeset
   428
    TMPXItemId itemId = TMPXItemId::InvalidId(); 
hgs
parents: 30
diff changeset
   429
    if(!mVideoUtils.mediaValue<TMPXItemId>(
hgs
parents: 30
diff changeset
   430
        aMessage,KMPXMessageMediaGeneralId, itemId))
30
hgs
parents:
diff changeset
   431
    {       
hgs
parents:
diff changeset
   432
        return;
hgs
parents:
diff changeset
   433
    }
36
hgs
parents: 35
diff changeset
   434
    INFO_3("VideoCollectionListener::handleMyVideosItemsChanged event: %d - item id1: %d id2: %d", eventType, itemId.iId1, itemId.iId2);
30
hgs
parents:
diff changeset
   435
    switch(eventType)
hgs
parents:
diff changeset
   436
    {
hgs
parents:
diff changeset
   437
        case EMPXItemDeleted:
34
hgs
parents: 30
diff changeset
   438
        {
hgs
parents: 30
diff changeset
   439
            mSignalReceiver.itemDeletedSlot(itemId);
hgs
parents: 30
diff changeset
   440
            break;
hgs
parents: 30
diff changeset
   441
        }
hgs
parents: 30
diff changeset
   442
        case EMPXItemInserted:
hgs
parents: 30
diff changeset
   443
        {
hgs
parents: 30
diff changeset
   444
            CMPXMedia *media = mVideoUtils.mediaValuePtr<CMPXMedia>(
hgs
parents: 30
diff changeset
   445
                aMessage, KMPXCommandColAddMedia);
36
hgs
parents: 35
diff changeset
   446
            if(media)
34
hgs
parents: 30
diff changeset
   447
            {
hgs
parents: 30
diff changeset
   448
                mSignalReceiver.newVideoAvailableSlot(media); 
hgs
parents: 30
diff changeset
   449
            }
hgs
parents: 30
diff changeset
   450
            else
30
hgs
parents:
diff changeset
   451
            {
34
hgs
parents: 30
diff changeset
   452
                mCollectionClient.fetchMpxMediaByMpxId(itemId);
30
hgs
parents:
diff changeset
   453
            }
34
hgs
parents: 30
diff changeset
   454
            break;
hgs
parents: 30
diff changeset
   455
        }
hgs
parents: 30
diff changeset
   456
        case EMPXItemModified:
hgs
parents: 30
diff changeset
   457
        {
36
hgs
parents: 35
diff changeset
   458
            INFO("VideoCollectionListener::handleMyVideosItemsChanged EMPXItemModified");
hgs
parents: 35
diff changeset
   459
            // Inform that item data has changed.
hgs
parents: 35
diff changeset
   460
            mSignalReceiver.itemModifiedSlot(itemId);
55
hgs
parents: 50
diff changeset
   461
            // Update contents for albums and captured and downloads categories.
hgs
parents: 50
diff changeset
   462
            if( itemId.iId2 == KVcxMvcMediaTypeAlbum ||
hgs
parents: 50
diff changeset
   463
               (itemId.iId2 == KVcxMvcMediaTypeCategory &&
hgs
parents: 50
diff changeset
   464
               (itemId.iId1 == KVcxMvcCategoryIdCaptured ||
hgs
parents: 50
diff changeset
   465
                itemId.iId1 == KVcxMvcCategoryIdDownloads)) )
34
hgs
parents: 30
diff changeset
   466
            {
36
hgs
parents: 35
diff changeset
   467
                INFO("VideoCollectionListener::handleMyVideosItemsChanged album or category modified, opening.");
34
hgs
parents: 30
diff changeset
   468
                mCollectionClient.openItem(itemId);
36
hgs
parents: 35
diff changeset
   469
                // collection is already opened at this stage, so we can safely set value here
hgs
parents: 35
diff changeset
   470
                // to make sure we do not let any other messages unhandled 
hgs
parents: 35
diff changeset
   471
                mCollectionClient.setOpenStatus(VideoCollectionClient::ECollectionOpened, false);
34
hgs
parents: 30
diff changeset
   472
            }
hgs
parents: 30
diff changeset
   473
            break;
hgs
parents: 30
diff changeset
   474
        }
hgs
parents: 30
diff changeset
   475
        default:
hgs
parents: 30
diff changeset
   476
        {
hgs
parents: 30
diff changeset
   477
            // invalid event type
hgs
parents: 30
diff changeset
   478
            break;
hgs
parents: 30
diff changeset
   479
        }
30
hgs
parents:
diff changeset
   480
    }
hgs
parents:
diff changeset
   481
}
hgs
parents:
diff changeset
   482
hgs
parents:
diff changeset
   483
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   484
// handleMyVideosDeleteMessage
hgs
parents:
diff changeset
   485
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   486
//
hgs
parents:
diff changeset
   487
void VideoCollectionListener::handleMyVideosDeleteMessage(CMPXMessage* aMessage)
hgs
parents:
diff changeset
   488
    {
36
hgs
parents: 35
diff changeset
   489
	FUNC_LOG;
30
hgs
parents:
diff changeset
   490
    CMPXMediaArray *messageArray = 
hgs
parents:
diff changeset
   491
        mVideoUtils.mediaValuePtr<CMPXMediaArray>(aMessage, KMPXMediaArrayContents);
hgs
parents:
diff changeset
   492
    if(!messageArray || messageArray->Count() == 0)
hgs
parents:
diff changeset
   493
    {
hgs
parents:
diff changeset
   494
        return;
hgs
parents:
diff changeset
   495
    }
hgs
parents:
diff changeset
   496
    
hgs
parents:
diff changeset
   497
    QList<TMPXItemId> failedIds;    
hgs
parents:
diff changeset
   498
    TMPXItemId itemId;  
hgs
parents:
diff changeset
   499
    int count = messageArray->Count();
hgs
parents:
diff changeset
   500
    int failedFlag = 0;
hgs
parents:
diff changeset
   501
    CMPXMedia* item = NULL;
hgs
parents:
diff changeset
   502
    
hgs
parents:
diff changeset
   503
    // go throught all removed videos and see if some has failed
hgs
parents:
diff changeset
   504
    for (int i = 0; i < count; ++i)
hgs
parents:
diff changeset
   505
    {
hgs
parents:
diff changeset
   506
        item = (*messageArray)[i];
hgs
parents:
diff changeset
   507
        if(!mVideoUtils.mediaValue<TMPXItemId>(item, KMPXMediaGeneralId, itemId))
hgs
parents:
diff changeset
   508
        {
hgs
parents:
diff changeset
   509
            // invalid message, return 
hgs
parents:
diff changeset
   510
            return;
hgs
parents:
diff changeset
   511
        }
hgs
parents:
diff changeset
   512
        // if there's error while fetching value, it means that value does not exists,
hgs
parents:
diff changeset
   513
        // so we can assume deletion was succefull
hgs
parents:
diff changeset
   514
        if(mVideoUtils.mediaValue<int>(item, KVcxMediaMyVideosInt32Value, failedFlag))
hgs
parents:
diff changeset
   515
        {
hgs
parents:
diff changeset
   516
            if (failedFlag)
hgs
parents:
diff changeset
   517
            {
hgs
parents:
diff changeset
   518
                failedIds.append(itemId);
hgs
parents:
diff changeset
   519
            }
hgs
parents:
diff changeset
   520
            failedFlag = 0;
hgs
parents:
diff changeset
   521
        }       
hgs
parents:
diff changeset
   522
    }
34
hgs
parents: 30
diff changeset
   523
    mSignalReceiver.videoDeleteCompletedSlot(count, &failedIds);
30
hgs
parents:
diff changeset
   524
}
hgs
parents:
diff changeset
   525
hgs
parents:
diff changeset
   526
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   527
// handleGetMediasByMpxIdResp
hgs
parents:
diff changeset
   528
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   529
//
hgs
parents:
diff changeset
   530
void VideoCollectionListener::handleGetMediasByMpxIdResp(CMPXMessage* aMessage)
hgs
parents:
diff changeset
   531
{
36
hgs
parents: 35
diff changeset
   532
	FUNC_LOG;
30
hgs
parents:
diff changeset
   533
    CMPXMediaArray* array = 
hgs
parents:
diff changeset
   534
        mVideoUtils.mediaValuePtr<CMPXMediaArray>(aMessage, KMPXMediaArrayContents);
hgs
parents:
diff changeset
   535
    if(!array || array->Count() < 1)
hgs
parents:
diff changeset
   536
    {
hgs
parents:
diff changeset
   537
        return;
hgs
parents:
diff changeset
   538
    }
36
hgs
parents: 35
diff changeset
   539
    mSignalReceiver.newVideoAvailableSlot((*array)[0]);
30
hgs
parents:
diff changeset
   540
}
hgs
parents:
diff changeset
   541
hgs
parents:
diff changeset
   542
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   543
// handleGetVideoDetailsResp
hgs
parents:
diff changeset
   544
// -----------------------------------------------------------------------------
hgs
parents:
diff changeset
   545
//
hgs
parents:
diff changeset
   546
void VideoCollectionListener::handleGetVideoDetailsResp(CMPXMessage* aMessage)
hgs
parents:
diff changeset
   547
{
36
hgs
parents: 35
diff changeset
   548
	FUNC_LOG;
30
hgs
parents:
diff changeset
   549
    CMPXMedia *item = mVideoUtils.mediaValuePtr<CMPXMedia>(aMessage,KMPXCommandColAddMedia); 
hgs
parents:
diff changeset
   550
    if(!item)
hgs
parents:
diff changeset
   551
    {
hgs
parents:
diff changeset
   552
        return;
hgs
parents:
diff changeset
   553
    }
36
hgs
parents: 35
diff changeset
   554
    mSignalReceiver.videoDetailsCompletedSlot(item);
30
hgs
parents:
diff changeset
   555
}
hgs
parents:
diff changeset
   556
36
hgs
parents: 35
diff changeset
   557
// End of file.