videofeeds/hgvodui/inc/vcxhgvodcontentlistimpl.h
changeset 0 96612d01cf9f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/videofeeds/hgvodui/inc/vcxhgvodcontentlistimpl.h	Mon Jan 18 20:21:12 2010 +0200
@@ -0,0 +1,225 @@
+/*
+* Copyright (c) 2008 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:    HG VOD content view functionality implementation*
+*/
+
+
+
+
+#ifndef VCXHGVODCONTENTLISTIMPL_H
+#define VCXHGVODCONTENTLISTIMPL_H
+
+
+#include <remconcoreapi.h>
+#include "vcxhgvodmainviewcontainer.h"
+#include "vcxhgvodlistimplbase.h"
+#include "vcxnscontent.h"
+
+class CHgScroller;
+class CVcxHgVodMainViewContainer;
+class CVcxHgVodContentListModelHandler;
+
+// CLASS DECLARATION
+/**
+ *  Content list implementation
+ *  This class handles service view list functionality.
+ *
+ *  @code
+ *   
+ *  @endcode
+ *
+ *  @lib vcxhgvodui.lib
+ *  @since S60 v5.0
+ */
+class CVcxHgVodContentListImpl : public CVcxHgVodListImplBase
+    {
+
+public:
+
+    /**
+     * Two-phased constructor.
+     * @param aScroller UI component responsible of drawing the information
+     * @param aDataProviderIf Reference to UI engine
+     * @param aView Reference to main view
+     * @return Pointer to newly created instance
+     */
+    static CVcxHgVodContentListImpl* NewL(
+            CHgScroller& aScroller,
+            CVcxNsUiEngine& aDataProviderIf,
+            CVcxHgVodMainView& aView );
+    
+    /**
+     * Two-phased constructor.
+     * @param aScroller UI component responsible of drawing the information
+     * @param aDataProviderIf Reference to UI engine
+     * @param aView Reference to main view
+     * @return Pointer to newly created instance
+     */
+    static CVcxHgVodContentListImpl* NewLC( 
+            CHgScroller& aScroller, 
+            CVcxNsUiEngine& aDataProviderIf,
+            CVcxHgVodMainView& aView );
+
+    /**
+    * Destructor.
+    */
+    virtual ~CVcxHgVodContentListImpl();
+    
+    /**
+     * Activate service model
+     */
+    void DoActivateL( );
+
+    /**
+     * Deactivate service model
+     *
+     */
+    void DoDeactivate();
+
+    /**
+     * Handle user command
+     */
+    void HandleCommandL( TInt aCommand );
+    
+    /**
+     * Activate menu pane items before displaying menu
+     * 
+     * @param aMenuPane Pointer to menu pane
+     *
+     */
+    void ActivateMenuPaneItemsL( CEikMenuPane* aMenuPane, TInt aResourceId );
+
+    /**
+     * Update title pane text for content view.
+     */
+    void UpdateTitlePaneL();
+    
+    /**
+     * Get content download status and content type data.
+     * @param aDlStatus On return, download status data
+     * @param aContentTypes On return, content types
+     * 
+     */
+    void ContentStatusDataL( 
+        CVcxNsContent::TVcxContentDlStatus &aDlStatus,
+        TUint32 &aContentTypes );
+    
+    /**
+     * Check msk
+     * 
+     */
+    void CheckMskL();
+
+    /**
+    * Get help context.
+    *
+    * @param aContext context
+    */
+    void GetHelpContext( TCoeHelpContext& aContext ) const;
+    
+    /**
+     * Selection (highlight) changes.
+     * @param aIndex Index of selected item.
+     */
+    void HandleSelectL( TInt /*aIndex*/ );
+    
+    /**
+     * Handles item opening.
+     * @param aIndex Index of item to be opened.
+     */
+    void HandleOpenL( TInt /*aIndex*/ );
+
+public: //from MViaPlayerMediaKeyListner
+
+    /**
+     * Called when media key event happens.
+     *
+     * @since S60 v3.0
+     * @param aOperationId The media key operation (ie. play, rewind, etc)
+     * @param aButtonAct The activity of the button (ie. pressed, released, etc)
+     */
+    void MediaKeyEventL( TRemConCoreApiOperationId aOperationId, 
+        TRemConCoreApiButtonAction aButtonAct );
+    
+private:    
+    
+    /**
+     * Default constructor
+     * @param aListWidget List widget
+     * @param aDataProviderIf Reference to ui engine interface
+     * @param aView Main view
+     */
+    CVcxHgVodContentListImpl( CHgScroller& aScroller,
+                              CVcxNsUiEngine& aDataProviderIf,
+                              CVcxHgVodMainView& aView );
+
+    /**
+     * 
+     * @param aDataProviderIf
+     * @param aView Main view
+     */
+    void ConstructL( 
+            CVcxNsUiEngine& aDataProviderIf, 
+            CVcxHgVodMainView& aView  );
+    
+    /**
+     * Start playback of given video item.
+     */
+    void StartPlaybackL();
+    
+    /**
+     * Open selected list items browser link. 
+     * @param aSelected Focused list item index
+     */
+    void OpenBrowserLinkL( TInt aSelected );
+    
+    /**
+     * Send video content link via SMS or Email
+     *
+     * @param aMessageTypeModule MTM service Uid
+     * @param aSelected Selected item index from the list
+     */
+    void ShareLinkL( const TUid aMessageTypeModule, TInt aSelected );
+    
+    /**
+     * Check MSK.
+     * @param aShowDownload
+     * @param aShowPlay
+     * @param aShowResume
+     * 
+     */
+    void CheckMskL( TBool aShowDownload, 
+                    TBool aShowPlay,
+                    TBool aShowResume );   
+    
+    /**
+     * Handle selected item in content list (touch).
+     */
+    void HandleSelectionL();
+
+private: // data
+
+    /**
+     * Flag for email accoun availability.
+     */
+    TBool iEmailAccountEnabled;
+        
+    /**
+     * List widget model handler
+     * Own.
+     */
+    CVcxHgVodContentListModelHandler* iModelHandler;
+    };
+
+#endif // VCXHGVODCONTENTLISTIMPL_H