videocollection/mpxmyvideoscollection/inc/vcxmyvideosmdsalbums.h
author hgs
Thu, 01 Apr 2010 23:32:44 +0300
changeset 35 3738fe97f027
parent 34 bbb98528c666
child 36 8aed59de29f9
permissions -rw-r--r--
201011
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
34
hgs
parents:
diff changeset
     1
/*
hgs
parents:
diff changeset
     2
* Copyright (c) 2007 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 the License "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:   Provides albums support from MDS*
hgs
parents:
diff changeset
    15
*/
hgs
parents:
diff changeset
    16
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
hgs
parents:
diff changeset
    19
#ifndef VCXMYVIDEOSMDSALBUMS_H
hgs
parents:
diff changeset
    20
#define VCXMYVIDEOSMDSALBUMS_H
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
// INCLUDES
hgs
parents:
diff changeset
    23
#include <mdequery.h>
hgs
parents:
diff changeset
    24
#include <mpxmedia.h>
hgs
parents:
diff changeset
    25
#include "vcxmyvideosalbum.h"
hgs
parents:
diff changeset
    26
#include "vcxmyvideosmdsdb.h"
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
// FORWARD DECLARATIONS
hgs
parents:
diff changeset
    29
class CMPXMedia;
hgs
parents:
diff changeset
    30
hgs
parents:
diff changeset
    31
// CONSTANTS
hgs
parents:
diff changeset
    32
hgs
parents:
diff changeset
    33
// CLASS DECLARATION
hgs
parents:
diff changeset
    34
hgs
parents:
diff changeset
    35
/**
hgs
parents:
diff changeset
    36
* Provides albums support, uses MDS.
hgs
parents:
diff changeset
    37
*
hgs
parents:
diff changeset
    38
* @lib mpxmyvideoscollectionplugin.lib
hgs
parents:
diff changeset
    39
*/
hgs
parents:
diff changeset
    40
NONSHARABLE_CLASS(CVcxMyVideosMdsAlbums) :
hgs
parents:
diff changeset
    41
        public CActive,
hgs
parents:
diff changeset
    42
        public MMdEQueryObserver,
hgs
parents:
diff changeset
    43
        public MMdERelationItemObserver
hgs
parents:
diff changeset
    44
#if 0 // not used
hgs
parents:
diff changeset
    45
        ,
hgs
parents:
diff changeset
    46
        public MMdERelationObserver
hgs
parents:
diff changeset
    47
#endif
hgs
parents:
diff changeset
    48
    {    
hgs
parents:
diff changeset
    49
    public: // Constructors and destructor
hgs
parents:
diff changeset
    50
        
hgs
parents:
diff changeset
    51
        friend class CVcxMyVideosMdsCmdQueue;
35
hgs
parents: 34
diff changeset
    52
        friend class CVcxMyVideosMdsDb;
hgs
parents: 34
diff changeset
    53
        
34
hgs
parents:
diff changeset
    54
        enum TVcxAsyncOperation
hgs
parents:
diff changeset
    55
            {
hgs
parents:
diff changeset
    56
            EVcxNone,
hgs
parents:
diff changeset
    57
            EVcxAddVideosToAlbum,
hgs
parents:
diff changeset
    58
            EVcxRemoveRelations,
hgs
parents:
diff changeset
    59
            EVcxRemoveAlbums
hgs
parents:
diff changeset
    60
            };
hgs
parents:
diff changeset
    61
        
hgs
parents:
diff changeset
    62
        /**
hgs
parents:
diff changeset
    63
        * Constructor.
hgs
parents:
diff changeset
    64
        * 
hgs
parents:
diff changeset
    65
        * @param aMdsDb    Owner of this object.
hgs
parents:
diff changeset
    66
        * @param aObserver Object which is listening album related events. If NULL, then
hgs
parents:
diff changeset
    67
        *                  no observer is set.
hgs
parents:
diff changeset
    68
        */
hgs
parents:
diff changeset
    69
        static CVcxMyVideosMdsAlbums* NewL( CVcxMyVideosMdsDb& aMdsDb,
hgs
parents:
diff changeset
    70
                MVcxMyVideosMdsAlbumsObserver* aObserver );
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
        /**
hgs
parents:
diff changeset
    73
        * Destructor
hgs
parents:
diff changeset
    74
        */
hgs
parents:
diff changeset
    75
        virtual ~CVcxMyVideosMdsAlbums();
hgs
parents:
diff changeset
    76
hgs
parents:
diff changeset
    77
    public: // new methods
hgs
parents:
diff changeset
    78
hgs
parents:
diff changeset
    79
        /**
hgs
parents:
diff changeset
    80
         * Cancels possible ongoing asynchronous request.
hgs
parents:
diff changeset
    81
         * 
hgs
parents:
diff changeset
    82
         * @param aType Defines what kind of request is cancelled.
hgs
parents:
diff changeset
    83
         */
hgs
parents:
diff changeset
    84
        void Cancel( CVcxMyVideosMdsDb::TRequestType aType = CVcxMyVideosMdsDb::EAll );
hgs
parents:
diff changeset
    85
hgs
parents:
diff changeset
    86
        /**
hgs
parents:
diff changeset
    87
        * Gets My Videos albums from MDS asynchronously.
hgs
parents:
diff changeset
    88
        * HandleGetAlbumsResp() callback function is called when ready.
hgs
parents:
diff changeset
    89
        * Utilizes CVcxMyVideosMdsCmdQueue.
hgs
parents:
diff changeset
    90
        *
hgs
parents:
diff changeset
    91
        * @param aAlbumList  Album list is written here. Caller owns this, ownership
hgs
parents:
diff changeset
    92
        *                    does not move.
hgs
parents:
diff changeset
    93
        * @param aClient     Response call is done to this object.
hgs
parents:
diff changeset
    94
        */
hgs
parents:
diff changeset
    95
        void GetAlbumsL( CMPXMedia* aAlbumList, MVcxMyVideosMdsAlbumsObserver& aClient );
35
hgs
parents: 34
diff changeset
    96
hgs
parents: 34
diff changeset
    97
        /**
hgs
parents: 34
diff changeset
    98
         * Gets album from MDS synchronously.
hgs
parents: 34
diff changeset
    99
         * 
hgs
parents: 34
diff changeset
   100
         * @param aId  MDS ID of the album to be fetched.
hgs
parents: 34
diff changeset
   101
         * @returm     MPX media containing album data. Ownership
hgs
parents: 34
diff changeset
   102
         *             moves to caller. NULL if not found.
hgs
parents: 34
diff changeset
   103
         */
hgs
parents: 34
diff changeset
   104
        CMPXMedia* GetAlbumL( TUint32 aId );
hgs
parents: 34
diff changeset
   105
34
hgs
parents:
diff changeset
   106
        /**
hgs
parents:
diff changeset
   107
         * Gets album content IDs asynchronously.
hgs
parents:
diff changeset
   108
         * HandleGetAlbumContentIdsResp() callback function is called when ready.
hgs
parents:
diff changeset
   109
         * Utilizes CVcxMyVideosMdsCmdQueue.
hgs
parents:
diff changeset
   110
         *
hgs
parents:
diff changeset
   111
         * @param aAlbumId      Album ID.
hgs
parents:
diff changeset
   112
         * @param aContentArray Item IDs which belog to aAlbum are written here. Caller must
hgs
parents:
diff changeset
   113
         *                      keep aContentArray available until HandleGetAlbumContentIdsResp
hgs
parents:
diff changeset
   114
         *                      has been called.
hgs
parents:
diff changeset
   115
        * @param aClient        Response call is done to this object.
hgs
parents:
diff changeset
   116
         */
hgs
parents:
diff changeset
   117
        void GetAlbumContentIdsL( TUint32 aAlbumId, RArray<TVcxMyVideosAlbumVideo>& aContentArray,
hgs
parents:
diff changeset
   118
                MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   119
        
hgs
parents:
diff changeset
   120
        /**
hgs
parents:
diff changeset
   121
         * Gets album content videos asynchronously.
hgs
parents:
diff changeset
   122
         * HandleGetAlbumContentVideosResp() callback function is called when ready.
hgs
parents:
diff changeset
   123
         * Utilizes CVcxMyVideosMdsCmdQueue.
hgs
parents:
diff changeset
   124
         * 
hgs
parents:
diff changeset
   125
         * @param aAlbumId    Album ID.
hgs
parents:
diff changeset
   126
         * @param aVideoList  Media containing media array. Video media objects are added to media array.
hgs
parents:
diff changeset
   127
         *                    Caller must keep aVideoList available until callback has been called.
hgs
parents:
diff changeset
   128
         * @param aClient     Response call is done to this object.
hgs
parents:
diff changeset
   129
         */
hgs
parents:
diff changeset
   130
        void GetAlbumContentVideosL( TUint32 aAlbumId, CMPXMedia& aVideoList,
hgs
parents:
diff changeset
   131
                MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   132
        
hgs
parents:
diff changeset
   133
        /**
hgs
parents:
diff changeset
   134
         * Adds videos to album asynchronously. HandleAddVideosToAlbumResp() callback function
hgs
parents:
diff changeset
   135
         * is called when operation finishes.
hgs
parents:
diff changeset
   136
         * Utilizes CVcxMyVideosMdsCmdQueue.
hgs
parents:
diff changeset
   137
         *
hgs
parents:
diff changeset
   138
         * @param aMpxCmd    Media containing command parameters: album ID and video ID list.
hgs
parents:
diff changeset
   139
         *                   Results are also written to this object. See media structure and
hgs
parents:
diff changeset
   140
         *                   used attributes from vcxmyvideosdef.c file,
hgs
parents:
diff changeset
   141
         *                   KVcxCommandMyVideosAddToAlbum command. Ownership does not move.
hgs
parents:
diff changeset
   142
         *                   
hgs
parents:
diff changeset
   143
         * @param aClient    Response call is done to this object.
hgs
parents:
diff changeset
   144
         */
hgs
parents:
diff changeset
   145
        void AddVideosToAlbumL( CMPXMedia* aMpxCmd, MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   146
        
hgs
parents:
diff changeset
   147
        /**
hgs
parents:
diff changeset
   148
         * Removes relations asynchronously.
hgs
parents:
diff changeset
   149
         * Utilizes CVcxMyVideosMdsCmdQueue.
hgs
parents:
diff changeset
   150
         * 
hgs
parents:
diff changeset
   151
         * @param aRelationIds  Relations which are removed.
hgs
parents:
diff changeset
   152
         * @param aResults      In sync with aRelationIds. Result codes, KErrNone if successful,
hgs
parents:
diff changeset
   153
         *                      KErrGeneral if failed.
hgs
parents:
diff changeset
   154
         * @param aClient       Response call is done to this object.
hgs
parents:
diff changeset
   155
         */
hgs
parents:
diff changeset
   156
        void RemoveRelationsL( RArray<TUint32>& aRelationIds,
hgs
parents:
diff changeset
   157
                RArray<TUint32>& aResults, MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   158
 
hgs
parents:
diff changeset
   159
        /**
hgs
parents:
diff changeset
   160
         * Adds album to MDS. aAlbum should have KMPXMediaGeneralTitle attribute
hgs
parents:
diff changeset
   161
         * set. The MDS item ID of the created album is written to KMPXMediaGeneralId
hgs
parents:
diff changeset
   162
         * attribute.
hgs
parents:
diff changeset
   163
         * 
hgs
parents:
diff changeset
   164
         * @param aAlbum  Album which is added to database. 
hgs
parents:
diff changeset
   165
         */
hgs
parents:
diff changeset
   166
        void AddAlbumL( CMPXMedia& aAlbum );
hgs
parents:
diff changeset
   167
        
hgs
parents:
diff changeset
   168
        /**
hgs
parents:
diff changeset
   169
         * Removes albums asynchronously. HandleRemoveAlbumsResp() callback function
hgs
parents:
diff changeset
   170
         * is called when operation finishes.
hgs
parents:
diff changeset
   171
         * Utilizes CVcxMyVideosMdsCmdQueue.
hgs
parents:
diff changeset
   172
         *
hgs
parents:
diff changeset
   173
         * @param aMpxCmd    Media containing command parameters: media array containing album IDs.
hgs
parents:
diff changeset
   174
         *                   Results are also written to this object. See media structure and
hgs
parents:
diff changeset
   175
         *                   used attributes from vcxmyvideosdef.c file,
hgs
parents:
diff changeset
   176
         *                   KVcxCommandMyVideosRemoveAlbums command. Ownership does not move.
hgs
parents:
diff changeset
   177
         *                   
hgs
parents:
diff changeset
   178
         * @param aClient    Response call is done to this object.
hgs
parents:
diff changeset
   179
         */        
hgs
parents:
diff changeset
   180
        void RemoveAlbumsL( CMPXMedia* aMpxCmd, MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   181
        
35
hgs
parents: 34
diff changeset
   182
        /**
hgs
parents: 34
diff changeset
   183
         * Sets album attributes.
hgs
parents: 34
diff changeset
   184
         * 
hgs
parents: 34
diff changeset
   185
         * @param aVideo  Values from aVideo are written to MDS.
hgs
parents: 34
diff changeset
   186
         */
hgs
parents: 34
diff changeset
   187
        void SetAlbumL( CMPXMedia& aVideo );
hgs
parents: 34
diff changeset
   188
        
34
hgs
parents:
diff changeset
   189
    protected:
hgs
parents:
diff changeset
   190
        
hgs
parents:
diff changeset
   191
        /**
hgs
parents:
diff changeset
   192
        * From CActive.
hgs
parents:
diff changeset
   193
        * Called when operation completes.
hgs
parents:
diff changeset
   194
        */
hgs
parents:
diff changeset
   195
        void RunL();
hgs
parents:
diff changeset
   196
hgs
parents:
diff changeset
   197
        /**
hgs
parents:
diff changeset
   198
        * From CActive.
hgs
parents:
diff changeset
   199
        * Actual implementation for cancelling.
hgs
parents:
diff changeset
   200
        */
hgs
parents:
diff changeset
   201
        void DoCancel();
hgs
parents:
diff changeset
   202
        
hgs
parents:
diff changeset
   203
    private:
hgs
parents:
diff changeset
   204
hgs
parents:
diff changeset
   205
        /**
hgs
parents:
diff changeset
   206
        * Constructor
hgs
parents:
diff changeset
   207
        */
hgs
parents:
diff changeset
   208
        CVcxMyVideosMdsAlbums( CVcxMyVideosMdsDb& aMdsDb,
hgs
parents:
diff changeset
   209
                MVcxMyVideosMdsAlbumsObserver* aObserver );
hgs
parents:
diff changeset
   210
hgs
parents:
diff changeset
   211
        /**
hgs
parents:
diff changeset
   212
        * Symbian 2nd phase constructor.
hgs
parents:
diff changeset
   213
        */
hgs
parents:
diff changeset
   214
        void ConstructL();
hgs
parents:
diff changeset
   215
hgs
parents:
diff changeset
   216
        /**
hgs
parents:
diff changeset
   217
        * Copies album data from aObject to aAlbum.
hgs
parents:
diff changeset
   218
        *
hgs
parents:
diff changeset
   219
        * @param aObject  MDS object to copy data from.
hgs
parents:
diff changeset
   220
        * @param aAlbum   MPX media to copy data to.
hgs
parents:
diff changeset
   221
        */
hgs
parents:
diff changeset
   222
        void Object2MediaL( CMdEObject& aObject, CMPXMedia& aAlbum );
hgs
parents:
diff changeset
   223
        
hgs
parents:
diff changeset
   224
        /**
hgs
parents:
diff changeset
   225
         * Copies album data from aAlbum to aObject.
hgs
parents:
diff changeset
   226
         * 
hgs
parents:
diff changeset
   227
         * @param aAlbum MPX media to copy data from.
hgs
parents:
diff changeset
   228
         * @param aObject MDS object to copy data to.
hgs
parents:
diff changeset
   229
         */
hgs
parents:
diff changeset
   230
        void Media2ObjectL( CMPXMedia& aAlbum, CMdEObject& aObject);
hgs
parents:
diff changeset
   231
hgs
parents:
diff changeset
   232
        /**
hgs
parents:
diff changeset
   233
        * Gets various defintions from MDS and stores them to member variables.
hgs
parents:
diff changeset
   234
        */
hgs
parents:
diff changeset
   235
        void GetSchemaDefinitionsL();
hgs
parents:
diff changeset
   236
hgs
parents:
diff changeset
   237
        /**
hgs
parents:
diff changeset
   238
        * Gets My Videos albums from MDS asynchronously.
hgs
parents:
diff changeset
   239
        * HandleGetAlbumsResp() callback function is called when ready.
hgs
parents:
diff changeset
   240
        *
hgs
parents:
diff changeset
   241
        * @param aAlbumList  Album list is written here. Caller owns this, ownership
hgs
parents:
diff changeset
   242
        *                    does not move.
hgs
parents:
diff changeset
   243
        * @param aClient     Callback is done to this object.
hgs
parents:
diff changeset
   244
        */
hgs
parents:
diff changeset
   245
        void DoGetAlbumsL( CMPXMedia* aAlbumList, MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   246
hgs
parents:
diff changeset
   247
        /**
hgs
parents:
diff changeset
   248
         * Gets album content IDs from MDS asynchronously.
hgs
parents:
diff changeset
   249
         * HandleGetAlbumContentIdsResp() callback function is called when ready.
hgs
parents:
diff changeset
   250
         *
hgs
parents:
diff changeset
   251
         * @param aAlbumId      Album ID.
hgs
parents:
diff changeset
   252
         * @param aContentArray Array containing MDS IDs which belong to aAlbum.
hgs
parents:
diff changeset
   253
         *                      Caller is responsible to keep array available
hgs
parents:
diff changeset
   254
         *                      until HandleGetAlbumContentResp has been called. 
hgs
parents:
diff changeset
   255
        * @param aClient        Callback is done to this object.
hgs
parents:
diff changeset
   256
         */
hgs
parents:
diff changeset
   257
        void DoGetAlbumContentIdsL( TUint32 aAlbumId,
hgs
parents:
diff changeset
   258
                RArray<TVcxMyVideosAlbumVideo>& aContentArray,
hgs
parents:
diff changeset
   259
                MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   260
hgs
parents:
diff changeset
   261
        /**
hgs
parents:
diff changeset
   262
         * Gets album content videos from MDS asynchronously.
hgs
parents:
diff changeset
   263
         * HandleGetAlbumContentVideosResp() callback function is called when ready.
hgs
parents:
diff changeset
   264
         * 
hgs
parents:
diff changeset
   265
         * @param aAlbumId   Album ID.
hgs
parents:
diff changeset
   266
         * @param aVideoList Media containing empty media array. Videos are added to array. Caller
hgs
parents:
diff changeset
   267
         *                   must keep aVideoList available until HandleGetAlbumContentVideosResp
hgs
parents:
diff changeset
   268
         *                   is called.
hgs
parents:
diff changeset
   269
         * @param aClient    Callback is done to this object.
hgs
parents:
diff changeset
   270
         */
hgs
parents:
diff changeset
   271
        void DoGetAlbumContentVideosL( TUint32 aAlbumId, CMPXMedia& aVideoList,
hgs
parents:
diff changeset
   272
                MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   273
hgs
parents:
diff changeset
   274
        /**
hgs
parents:
diff changeset
   275
         * Adds videos to album asynchronously. HandleAddVideosToAlbumResp() callback function
hgs
parents:
diff changeset
   276
         * is called when operation finishes.
hgs
parents:
diff changeset
   277
         * 
hgs
parents:
diff changeset
   278
         * @param aMpxCmd    Media containing command parameters: album ID and video ID list.
hgs
parents:
diff changeset
   279
         *                   Results are also written to this object. See media structure and
hgs
parents:
diff changeset
   280
         *                   used attributes from vcxmyvideosdef.c file,
hgs
parents:
diff changeset
   281
         *                   KVcxCommandMyVideosAddToAlbum command. Ownership does not move.
hgs
parents:
diff changeset
   282
         * @param aClient    Response call is done to this object.
hgs
parents:
diff changeset
   283
         */
hgs
parents:
diff changeset
   284
        void DoAddVideosToAlbumL( CMPXMedia* aMpxCmd, MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   285
        
hgs
parents:
diff changeset
   286
        /**
hgs
parents:
diff changeset
   287
         * Removes relations asynchronously.
hgs
parents:
diff changeset
   288
         * 
hgs
parents:
diff changeset
   289
         * @param aRelationIds  Relations which are removed.
hgs
parents:
diff changeset
   290
         * @param aResults      In sync with aRelationIds. Result codes, KErrNone if successful,
hgs
parents:
diff changeset
   291
         *                      KErrGeneral if failed.
hgs
parents:
diff changeset
   292
         * @param aClient       Response call is done to this object.
hgs
parents:
diff changeset
   293
         */
hgs
parents:
diff changeset
   294
        void DoRemoveRelationsL( RArray<TUint32>& aRelationIds,
hgs
parents:
diff changeset
   295
                RArray<TUint32>& aResults, MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   296
        
hgs
parents:
diff changeset
   297
        /**
hgs
parents:
diff changeset
   298
         * Removes albums asynchronously.
hgs
parents:
diff changeset
   299
         * 
hgs
parents:
diff changeset
   300
         * @param aMpxCmd  Media containing command parameters: array with albums IDs.
hgs
parents:
diff changeset
   301
         * @param aClient  Response call is done to this object.
hgs
parents:
diff changeset
   302
         */
hgs
parents:
diff changeset
   303
        void CVcxMyVideosMdsAlbums::DoRemoveAlbumsL( CMPXMedia* aMpxCmd,
hgs
parents:
diff changeset
   304
                MVcxMyVideosMdsAlbumsObserver& aClient );
hgs
parents:
diff changeset
   305
hgs
parents:
diff changeset
   306
        /**
hgs
parents:
diff changeset
   307
        * Handles album query responses.
hgs
parents:
diff changeset
   308
        * 
hgs
parents:
diff changeset
   309
        * @param aQuery  Query instance.
hgs
parents:
diff changeset
   310
        * @param aError  <code>KErrNone</code>, if the query was completed
hgs
parents:
diff changeset
   311
        *                successfully. Otherwise one of the system-wide error 
hgs
parents:
diff changeset
   312
        *                codes.
hgs
parents:
diff changeset
   313
        */
hgs
parents:
diff changeset
   314
        void HandleAlbumQueryCompletedL(CMdEQuery& aQuery, TInt aError);
hgs
parents:
diff changeset
   315
hgs
parents:
diff changeset
   316
        /**
hgs
parents:
diff changeset
   317
        * Handles video query responses.
hgs
parents:
diff changeset
   318
        * 
hgs
parents:
diff changeset
   319
        * @param aQuery  Query instance.
hgs
parents:
diff changeset
   320
        * @param aError  <code>KErrNone</code>, if the query was completed
hgs
parents:
diff changeset
   321
        *                successfully. Otherwise one of the system-wide error 
hgs
parents:
diff changeset
   322
        *                codes.
hgs
parents:
diff changeset
   323
        * @param aFirstNewItemIndex Index of the first new item in the query.
hgs
parents:
diff changeset
   324
        * @param aNewItemCount      How many new items were added.
hgs
parents:
diff changeset
   325
        * @param aComplete          ETrue if query is complete, EFalse if new to come.
hgs
parents:
diff changeset
   326
        */
hgs
parents:
diff changeset
   327
        void HandleVideoQueryResultsL( CMdEQuery& aQuery, TInt aError,
hgs
parents:
diff changeset
   328
                TInt aFirstNewItemIndex, TInt aNewItemCount, TBool aComplete );
hgs
parents:
diff changeset
   329
hgs
parents:
diff changeset
   330
        /**
hgs
parents:
diff changeset
   331
         * Handles relation query responses.
hgs
parents:
diff changeset
   332
         * 
hgs
parents:
diff changeset
   333
         * @param aQuery Query instance.
hgs
parents:
diff changeset
   334
         * @param aError  <code>KErrNone</code>, if the query was completed
hgs
parents:
diff changeset
   335
         *                successfully. Otherwise one of the system-wide error 
hgs
parents:
diff changeset
   336
         *                codes.
hgs
parents:
diff changeset
   337
         */
hgs
parents:
diff changeset
   338
        void HandleRelationQueryCompletedL( CMdEQuery& aQuery, TInt aError );
hgs
parents:
diff changeset
   339
hgs
parents:
diff changeset
   340
        /**
hgs
parents:
diff changeset
   341
         * Called from RunL when video adding to album completes.
hgs
parents:
diff changeset
   342
         */
hgs
parents:
diff changeset
   343
        void HandleAddVideosToAlbumCompletedL();
hgs
parents:
diff changeset
   344
hgs
parents:
diff changeset
   345
        /**
hgs
parents:
diff changeset
   346
         * Called from RunL when relations remove completes.
hgs
parents:
diff changeset
   347
         */
hgs
parents:
diff changeset
   348
        void HandleRemoveRelationsCompletedL();
hgs
parents:
diff changeset
   349
hgs
parents:
diff changeset
   350
        /**
hgs
parents:
diff changeset
   351
         * Called from RunL when albums remove completes.
hgs
parents:
diff changeset
   352
         */
hgs
parents:
diff changeset
   353
        void HandleRemoveAlbumsCompletedL();
hgs
parents:
diff changeset
   354
        
hgs
parents:
diff changeset
   355
    public:
hgs
parents:
diff changeset
   356
hgs
parents:
diff changeset
   357
        /**
hgs
parents:
diff changeset
   358
        * From MMdEQueryObserver.
hgs
parents:
diff changeset
   359
        * Called to notify the observer that new results have been received 
hgs
parents:
diff changeset
   360
        * in the query.
hgs
parents:
diff changeset
   361
        *
hgs
parents:
diff changeset
   362
        * @param aQuery              Query instance that received new results.
hgs
parents:
diff changeset
   363
        * @param aFirstNewItemIndex  Index of the first new item that was added
hgs
parents:
diff changeset
   364
        *                            to the result item array.
hgs
parents:
diff changeset
   365
        * @param aNewItemCount       Number of items added to the result item 
hgs
parents:
diff changeset
   366
        *                            array.
hgs
parents:
diff changeset
   367
        */
hgs
parents:
diff changeset
   368
        void HandleQueryNewResults(CMdEQuery& aQuery,
hgs
parents:
diff changeset
   369
                TInt aFirstNewItemIndex,
hgs
parents:
diff changeset
   370
                TInt aNewItemCount);
hgs
parents:
diff changeset
   371
hgs
parents:
diff changeset
   372
        /**
hgs
parents:
diff changeset
   373
        * From MMdEQueryObserver.
hgs
parents:
diff changeset
   374
        * Called to notify the observer that the query has been completed,
hgs
parents:
diff changeset
   375
        * or that an error has occured.
hgs
parents:
diff changeset
   376
        *
hgs
parents:
diff changeset
   377
        * @param aQuery  Query instance.
hgs
parents:
diff changeset
   378
        * @param aError  <code>KErrNone</code>, if the query was completed
hgs
parents:
diff changeset
   379
        *                successfully. Otherwise one of the system-wide error 
hgs
parents:
diff changeset
   380
        *                codes.
hgs
parents:
diff changeset
   381
        */
hgs
parents:
diff changeset
   382
        void HandleQueryCompleted(CMdEQuery& aQuery, TInt aError);
hgs
parents:
diff changeset
   383
hgs
parents:
diff changeset
   384
        /**
hgs
parents:
diff changeset
   385
         * From MMdERelationItemObserver
hgs
parents:
diff changeset
   386
         */
hgs
parents:
diff changeset
   387
        void HandleRelationItemNotification(CMdESession& aSession, 
hgs
parents:
diff changeset
   388
                    TObserverNotificationType aType,
hgs
parents:
diff changeset
   389
                    const RArray<TMdERelation>& aRelationArray);
hgs
parents:
diff changeset
   390
hgs
parents:
diff changeset
   391
#if 0 //not used
hgs
parents:
diff changeset
   392
        /**
hgs
parents:
diff changeset
   393
         * From MMdERelationObserver
hgs
parents:
diff changeset
   394
         */
hgs
parents:
diff changeset
   395
        void HandleRelationNotification(CMdESession& aSession, 
hgs
parents:
diff changeset
   396
                TObserverNotificationType aType,
hgs
parents:
diff changeset
   397
                const RArray<TItemId>& aRelationIdArray);
hgs
parents:
diff changeset
   398
#endif
hgs
parents:
diff changeset
   399
        
hgs
parents:
diff changeset
   400
    private:
hgs
parents:
diff changeset
   401
        
hgs
parents:
diff changeset
   402
        /**
hgs
parents:
diff changeset
   403
         * Main class for Mds operations. Owns session to MDS.
hgs
parents:
diff changeset
   404
         */
hgs
parents:
diff changeset
   405
        CVcxMyVideosMdsDb& iMdsDb;
hgs
parents:
diff changeset
   406
        
hgs
parents:
diff changeset
   407
        /**
hgs
parents:
diff changeset
   408
         * Observer of albums related events. May be NULL.
hgs
parents:
diff changeset
   409
         * not own.
hgs
parents:
diff changeset
   410
         */
hgs
parents:
diff changeset
   411
        MVcxMyVideosMdsAlbumsObserver* iObserver;
hgs
parents:
diff changeset
   412
        
hgs
parents:
diff changeset
   413
        /**
hgs
parents:
diff changeset
   414
        * Asynchronous album object fetching query is stored here. Own.
hgs
parents:
diff changeset
   415
        */
hgs
parents:
diff changeset
   416
        CMdEObjectQuery* iAlbumQuery;
hgs
parents:
diff changeset
   417
hgs
parents:
diff changeset
   418
        /**
hgs
parents:
diff changeset
   419
        * Asynchronous video object fetching query is stored here. Own.
hgs
parents:
diff changeset
   420
        */
hgs
parents:
diff changeset
   421
        CMdEObjectQuery* iVideoQuery;
hgs
parents:
diff changeset
   422
hgs
parents:
diff changeset
   423
        /**
hgs
parents:
diff changeset
   424
        * Asynchronous relation fetching query is stored here. Own.
hgs
parents:
diff changeset
   425
        */
hgs
parents:
diff changeset
   426
        CMdERelationQuery* iRelationQuery;
hgs
parents:
diff changeset
   427
                
hgs
parents:
diff changeset
   428
        /**
hgs
parents:
diff changeset
   429
        * The default namespace definition, not own.
hgs
parents:
diff changeset
   430
        */
hgs
parents:
diff changeset
   431
        CMdENamespaceDef* iNamespaceDef;
hgs
parents:
diff changeset
   432
        
hgs
parents:
diff changeset
   433
        /**
hgs
parents:
diff changeset
   434
        * Album object definition, not own.
hgs
parents:
diff changeset
   435
        */
hgs
parents:
diff changeset
   436
        CMdEObjectDef* iAlbumObjectDef;
hgs
parents:
diff changeset
   437
        
hgs
parents:
diff changeset
   438
        /**
hgs
parents:
diff changeset
   439
        * Album type property definition, not own.
hgs
parents:
diff changeset
   440
        */
hgs
parents:
diff changeset
   441
        CMdEPropertyDef* iTypePropertyDef;
hgs
parents:
diff changeset
   442
        
hgs
parents:
diff changeset
   443
        /**
hgs
parents:
diff changeset
   444
         * "Contains" relation definition, not own.
hgs
parents:
diff changeset
   445
         */
hgs
parents:
diff changeset
   446
        CMdERelationDef* iContainsRelationDef;
hgs
parents:
diff changeset
   447
        
hgs
parents:
diff changeset
   448
        /**
hgs
parents:
diff changeset
   449
        * Pointer to album list which is being fetched from MDS. Not own.
hgs
parents:
diff changeset
   450
        */
hgs
parents:
diff changeset
   451
        CMPXMedia* iAlbumList;
hgs
parents:
diff changeset
   452
hgs
parents:
diff changeset
   453
        /**
hgs
parents:
diff changeset
   454
        * Pointer to video list which is being fetched from MDS. Not own.
hgs
parents:
diff changeset
   455
        */
hgs
parents:
diff changeset
   456
        CMPXMedia* iVideoList;
hgs
parents:
diff changeset
   457
hgs
parents:
diff changeset
   458
        /**
hgs
parents:
diff changeset
   459
         * When doing some async operation to MDS, the album ID is stored here.
hgs
parents:
diff changeset
   460
         */
hgs
parents:
diff changeset
   461
        TUint32 iAlbumId;
hgs
parents:
diff changeset
   462
        
hgs
parents:
diff changeset
   463
        /**
hgs
parents:
diff changeset
   464
         * When fetching album content from MDS, the pointer to content array is stored here.
hgs
parents:
diff changeset
   465
         * Only MDS ID is filled to TVideo.
hgs
parents:
diff changeset
   466
         * Not own.
hgs
parents:
diff changeset
   467
         */
hgs
parents:
diff changeset
   468
        RArray<TVcxMyVideosAlbumVideo>* iAlbumContent;
hgs
parents:
diff changeset
   469
hgs
parents:
diff changeset
   470
        /**
hgs
parents:
diff changeset
   471
         * The pending async operation ID is stored here.
hgs
parents:
diff changeset
   472
         */
hgs
parents:
diff changeset
   473
        TVcxAsyncOperation iAsyncOperation;
hgs
parents:
diff changeset
   474
hgs
parents:
diff changeset
   475
        /**
hgs
parents:
diff changeset
   476
         * Used for storing items during async mds operations.
hgs
parents:
diff changeset
   477
         */
hgs
parents:
diff changeset
   478
        RPointerArray<CMdEInstanceItem> iItemArray;
hgs
parents:
diff changeset
   479
        
hgs
parents:
diff changeset
   480
        /**
hgs
parents:
diff changeset
   481
         * Used for storing result buffer during async mds operations.
hgs
parents:
diff changeset
   482
         */
hgs
parents:
diff changeset
   483
        RMdEDataBuffer iResultBuffer;
hgs
parents:
diff changeset
   484
hgs
parents:
diff changeset
   485
        /**
hgs
parents:
diff changeset
   486
         * Used in async operations to store
hgs
parents:
diff changeset
   487
         * pointer to result array (which is owned by the user). 
hgs
parents:
diff changeset
   488
         */
hgs
parents:
diff changeset
   489
        RArray<TInt>* iResultArray;
hgs
parents:
diff changeset
   490
hgs
parents:
diff changeset
   491
        /**
hgs
parents:
diff changeset
   492
         * Used in async operations to store
hgs
parents:
diff changeset
   493
         * pointer to result array (which is owned by the user). 
hgs
parents:
diff changeset
   494
         */
hgs
parents:
diff changeset
   495
        RArray<TUint32>* iResultArrayUint32;
hgs
parents:
diff changeset
   496
        
hgs
parents:
diff changeset
   497
        /**
hgs
parents:
diff changeset
   498
         * Used in async oprations (EVcxAddVideosToAlbum and EVcxRemoveVideosFromAlbum) to store
hgs
parents:
diff changeset
   499
         * pointer to item ID array (which is owned by the user). 
hgs
parents:
diff changeset
   500
         */
hgs
parents:
diff changeset
   501
        RArray<TUint32>* iIdArray;
hgs
parents:
diff changeset
   502
                
hgs
parents:
diff changeset
   503
        /**
hgs
parents:
diff changeset
   504
         * Used to store command parameters during async MDS operations. Not owned.
hgs
parents:
diff changeset
   505
         */
hgs
parents:
diff changeset
   506
        CMPXMedia* iMpxCmd;
hgs
parents:
diff changeset
   507
        
hgs
parents:
diff changeset
   508
        /**
hgs
parents:
diff changeset
   509
         * Used to store pointer to client who initiated the async operation.
hgs
parents:
diff changeset
   510
         */
hgs
parents:
diff changeset
   511
        MVcxMyVideosMdsAlbumsObserver* iClient;
hgs
parents:
diff changeset
   512
hgs
parents:
diff changeset
   513
    };
hgs
parents:
diff changeset
   514
hgs
parents:
diff changeset
   515
#endif   // VCXMYVIDEOSMDSALBUMS_H
hgs
parents:
diff changeset
   516
hgs
parents:
diff changeset
   517