browserui/browser/FavouritesSrc/BrowserFavouritesIncrementalMove.cpp
branchRCL_3
changeset 48 8e6fa1719340
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/browserui/browser/FavouritesSrc/BrowserFavouritesIncrementalMove.cpp	Wed Sep 01 12:31:04 2010 +0100
@@ -0,0 +1,153 @@
+/*
+* Copyright (c) 2002 Nokia Corporation and/or its subsidiary(-ies).
+* All rights reserved.
+* This component and the accompanying materials are made available
+* under the terms of the License "Eclipse Public License v1.0"
+* which accompanies this distribution, and is available
+* at the URL "http://www.eclipse.org/legal/epl-v10.html".
+*
+* Initial Contributors:
+* Nokia Corporation - initial contribution.
+*
+* Contributors:
+*
+* Description: 
+*      Implementation of CWmlBrowserFavouritesIncrementalMove.
+*      
+*
+*/
+
+
+// INCLUDE FILES
+
+#include <AknWaitDialog.h>
+#include <favouritesdb.h>
+#include <favouritesitem.h>
+#include <BrowserNG.rsg>
+#include "BrowserFavouritesIncrementalMove.h"
+#include "BrowserFavouritesModel.h"
+
+// ================= MEMBER FUNCTIONS =======================
+
+// ---------------------------------------------------------
+// CBrowserFavouritesIncrementalMove::NewL
+// ---------------------------------------------------------
+//
+CBrowserFavouritesIncrementalMove*
+CBrowserFavouritesIncrementalMove::NewL
+        (
+        CBrowserFavouritesModel& aModel,
+        CArrayFix<TInt>& aUids,
+        CArrayFix<TInt>& aUnmovableUids,
+        CArrayFix<TInt>& aConflictingNameUids,
+        TInt aTargetFolder,
+        TInt aPriority /*=CActive::EPriorityStandard*/
+        )
+    {
+    CBrowserFavouritesIncrementalMove* incMove =
+        new (ELeave) CBrowserFavouritesIncrementalMove
+        (
+        aModel,
+        aUids,
+        aUnmovableUids,
+        aConflictingNameUids,
+        aTargetFolder,
+        aPriority
+        );
+    CleanupStack::PushL( incMove );
+    incMove->ConstructL();
+    CleanupStack::Pop();    // incMove
+    return incMove;
+    }
+
+// ---------------------------------------------------------
+// CBrowserFavouritesIncrementalMove::~CBrowserFavouritesIncrementalMove
+// ---------------------------------------------------------
+//
+CBrowserFavouritesIncrementalMove::~CBrowserFavouritesIncrementalMove()
+    {
+    delete iItem;
+    }
+
+// ---------------------------------------------------------
+// CBrowserFavouritesIncrementalMove::CBrowserFavouritesIncrementalMove
+// ---------------------------------------------------------
+//
+CBrowserFavouritesIncrementalMove::CBrowserFavouritesIncrementalMove
+    (
+    CBrowserFavouritesModel& aModel,
+    CArrayFix<TInt>& aUids,
+    CArrayFix<TInt>& aUnmovableUids,
+    CArrayFix<TInt>& aConflictingNameUids,
+    TInt aTargetFolder,
+    TInt aPriority
+    )
+: CBrowserFavouritesIncrementalOp( aModel, aPriority ),
+  iUids( &aUids ),
+  iUnmovableUids( &aUnmovableUids ),
+  iConflictingNameUids( &aConflictingNameUids ),
+  iTargetFolder( aTargetFolder ),
+  iIndex( 0 )
+    {
+    }
+
+// CBrowserFavouritesIncrementalMove::ConstructL
+// ---------------------------------------------------------
+//
+void CBrowserFavouritesIncrementalMove::ConstructL()
+    {
+    CBrowserFavouritesIncrementalOp::ConstructL();
+    iItem = CFavouritesItem::NewL();
+    }
+
+// ---------------------------------------------------------
+// CBrowserFavouritesIncrementalMove::StepL
+// ---------------------------------------------------------
+//
+TInt CBrowserFavouritesIncrementalMove::StepL()
+    {
+    if ( iIndex < iUids->Count() )
+        {
+        TInt uid = iUids->At( iIndex );
+        TInt err = iModel->Database().Get( uid, *iItem );
+        if ( !err )
+            {
+            iItem->SetParentFolder( iTargetFolder );
+            err = iModel->Database().Update
+                            ( *iItem, uid, /*aAutoRename=*/EFalse );
+            }
+        switch ( err )
+            {
+            case KErrNone:
+                {
+                // All is well.
+                break;
+                }
+            case KErrAlreadyExists:
+                {
+                iConflictingNameUids->AppendL( uid );
+                break;
+                }
+            default:
+                {
+                iUnmovableUids->AppendL( uid );
+                break;
+                }
+            }
+        iIndex++;
+        }
+    return iUids->Count() - iIndex;
+    }
+
+// ---------------------------------------------------------
+// CBrowserFavouritesIncrementalMove::CreateWaitNoteLC
+// ---------------------------------------------------------
+//
+void CBrowserFavouritesIncrementalMove::CreateWaitNoteLC()
+    {
+    iWaitNote = new (ELeave) CAknWaitDialog
+        ( REINTERPRET_CAST( CEikDialog**, &iWaitNote ) );
+    iWaitNote->PrepareLC( R_WMLBROWSER_FAVOURITES_NOTE_MOVING );
+    }
+
+// End of File