videocollection/videocollectionview/src/videohintwidget.cpp
branchRCL_3
changeset 56 839377eedc2b
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/videocollection/videocollectionview/src/videohintwidget.cpp	Tue Aug 31 15:15:55 2010 +0300
@@ -0,0 +1,186 @@
+/*
+* 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 "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:   Videolist content widget implementation
+*
+*/
+
+// Version : %version: 15 %
+
+// INCLUDE FILES
+#include <hbpushbutton.h>
+#include <hblabel.h>
+#include <qgraphicsitem.h>
+#include <hbinstance.h>
+
+#include "videohintwidget.h"
+#include "videocollectionuiloader.h"
+#include "videocollectionviewutils.h"
+#include "videocollectioncenrepdefs.h"
+#include "videocollectiontrace.h"
+
+// ---------------------------------------------------------------------------
+// Constructor
+// ---------------------------------------------------------------------------
+//
+VideoHintWidget::VideoHintWidget( VideoCollectionUiLoader *uiLoader, QGraphicsItem *parent ) 
+    : HbWidget( parent )
+    , mUiLoader( uiLoader )
+    , mCurrentLevel( AllVideos )
+    , mButtonShown( false )
+    , mActivated( false )
+{
+    FUNC_LOG;
+    // NOP
+}
+
+// ---------------------------------------------------------------------------
+// Destructor
+// ---------------------------------------------------------------------------
+//
+VideoHintWidget::~VideoHintWidget()
+{
+    FUNC_LOG;
+}
+
+// ---------------------------------------------------------------------------
+// initialize
+// ---------------------------------------------------------------------------
+//
+void VideoHintWidget::initialize()
+{
+    FUNC_LOG;
+    VideoCollectionViewUtils& utils = VideoCollectionViewUtils::instance();
+    
+    QString textId = utils.getCenRepStringValue(KVideoCollectionViewCenrepServiceItem1Text);
+    if(!textId.isEmpty())
+    {
+        mHintText = hbTrId(textId.toLatin1().constData());
+    }
+}
+
+// ---------------------------------------------------------------------------
+// setLevel
+// ---------------------------------------------------------------------------
+//
+void VideoHintWidget::setLevel(HintLevel level)
+{
+    FUNC_LOG;
+    INFO_1("VideoHintWidget::setLevel() level: %d", level);
+    mCurrentLevel = level;
+    if(mActivated) {
+        updateUiComponents();
+    }
+}
+
+// ---------------------------------------------------------------------------
+// setButtonShown
+// ---------------------------------------------------------------------------
+//
+void VideoHintWidget::setButtonShown(bool shown)
+{
+    FUNC_LOG;
+    INFO_1("VideoHintWidget::setButtonShown() shown: %d", shown);
+	mButtonShown = shown;
+    if(mActivated) {
+        updateUiComponents();
+    }
+}
+
+// ---------------------------------------------------------------------------
+// orientationChanged
+// ---------------------------------------------------------------------------
+//
+void VideoHintWidget::orientationChangedSlot(Qt::Orientation targetOrientation)
+{
+    FUNC_LOG;
+    Q_UNUSED(targetOrientation);
+    updateUiComponents();
+}
+
+// ---------------------------------------------------------------------------
+// activate
+// ---------------------------------------------------------------------------
+//
+void VideoHintWidget::activate()
+{
+    FUNC_LOG;
+    if (!mActivated)
+    {
+        HbMainWindow *mainWnd = hbInstance->allMainWindows().value(0);
+        connect(
+            mainWnd, SIGNAL(orientationChanged(Qt::Orientation)),
+            this, SLOT(orientationChangedSlot(Qt::Orientation)));
+        
+        updateUiComponents();
+        
+        setVisible(true);
+        
+        mActivated = true;
+    }
+}
+
+// ---------------------------------------------------------------------------
+// deactivate
+// ---------------------------------------------------------------------------
+//
+void VideoHintWidget::deactivate()
+{
+    FUNC_LOG;
+    if (mActivated)
+    {
+        mActivated = false;
+        
+        setVisible(false);
+        
+        HbMainWindow *mainWnd = hbInstance->allMainWindows().value(0);
+        disconnect(
+            mainWnd, SIGNAL(orientationChanged(Qt::Orientation)),
+            this, SLOT(orientationChangedSlot(Qt::Orientation)));
+    }
+}
+
+// ---------------------------------------------------------------------------
+// updateUiComponents
+// ---------------------------------------------------------------------------
+//
+void VideoHintWidget::updateUiComponents()
+{
+    FUNC_LOG;
+    HbMainWindow *mainWnd = hbInstance->allMainWindows().value(0);
+    if (mainWnd)
+    {
+        HbPushButton *hintButton =
+            mUiLoader->findWidget<HbPushButton>(
+                DOCML_NAME_HINT_BUTTON);
+        HbLabel *noVideosLabel =
+            mUiLoader->findWidget<HbLabel>(
+                DOCML_NAME_NO_VIDEOS_LABEL);
+        if (hintButton && noVideosLabel)
+        {
+            noVideosLabel->setVisible(true);
+
+            if (mCurrentLevel == AllVideos && !mHintText.isEmpty())
+            {
+                hintButton->setText(mHintText);
+                hintButton->setVisible(mButtonShown);
+            }
+            else
+            {
+                hintButton->setVisible(false);
+            }
+        }
+    }
+}
+
+// end of file