messagingapp/msgui/conversationview/src/msgconversationwidget.cpp
changeset 23 238255e8b033
child 25 84d9eb65b26f
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/messagingapp/msgui/conversationview/src/msgconversationwidget.cpp	Fri Apr 16 14:56:15 2010 +0300
@@ -0,0 +1,516 @@
+/*
+ * Copyright (c) 2009 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:
+ *
+ */
+#include "msgconversationwidget.h"
+
+#include <HbTextItem>
+#include <HbFrameItem>
+#include <HbFrameDrawer>
+#include <HbIconItem>
+#include <QPainter>
+#include <QPixmap>
+#include <QImageReader>
+#include <QDir>
+#include "debugtraces.h"
+
+#include "convergedmessage.h"
+
+#define DEBUG_PAINT 0
+
+const int MAX_SIZE(200);
+
+// Icons
+const QString MSG_FORWARD_ICON(":/icons/qtg_mono_forward.svg");
+
+const QString MSG_HIGH_PRIORITY_ICON(":/icons/qtg_small_priority_high.svg");
+const QString MSG_LOW_PRIORITY_ICON(":/icons/qtg_small_priority_low.svg");
+
+const QString MSG_ATTACH_ICON(":/icons/qtg_small_attachment.svg");
+
+const QString MSG_AUDIO_ICON(":/icons/qtg_large_music_player.png");
+const QString MSG_VIDEO_ICON(":/icons/video_icon.png");
+const QString MSG_AUDIO_PLAY_ICON(":/icons/qtg_large_music_player.png");
+
+
+// Frames
+const QString IN_CHAT_FRAME(":/bubble/qtg_fr_convlist_received_normal");
+const QString IN_CHAT_FRAME_PRESSED(":/bubble/qtg_fr_convlist_received_pressed");
+const QString OUT_CHAT_FRAME(":/bubble/qtg_fr_convlist_sent_normal");
+const QString OUT_CHAT_FRAME_PRESSED(":/bubble/qtg_fr_convlist_sent_pressed");
+const QString IN_CHAT_FRAME_UNREAD(":/bubble/qtg_fr_convlist_received_highlight");
+const QString NEW_ITEM_FRAME(":/new_item/qtg_fr_list_new_item");
+const QString SENDING_CHAT_FRAME(":/bubble/qtg_fr_convlist_sent_highlight");
+
+#define PLUGINPATH "conversationviewplugin.dll"
+
+//---------------------------------------------------------------
+// MsgConversationWidget::MsgConversationWidget
+// @see header file
+//---------------------------------------------------------------
+MsgConversationWidget::MsgConversationWidget(QGraphicsItem *parent) :
+        HbWidget(parent),
+        mHasAttachment(false),
+        mHasImage(false),
+        mHasAudio(false),
+        mHasVideo(false),
+        mIsPlayable(false),
+        mIncoming(false),
+        mUnread(false),
+        mIsMMS(false),
+        mPriority(0),
+        mSendingState(0),
+        mNewFrameItem(NULL),
+        mBubbleFrameItem(NULL),
+        mSubjectTextItem(NULL),
+        mBodyTextItem(NULL),
+        mTimeStampTextItem(NULL),
+        mPriorityIconItem(NULL),
+        mAttachmentIconItem(NULL),
+        mAudioIconItem(NULL),
+        mVideoIconItem(NULL),
+        mPlayIconItem(NULL),
+        mPreviewIconItem(NULL)
+
+
+{
+    init();
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::~MsgConversationWidget
+// @see header file
+//---------------------------------------------------------------
+MsgConversationWidget::~MsgConversationWidget()
+{
+
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::init
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::init()
+{
+    // Common to SMS/MMS
+
+    mBubbleFrameItem = new HbFrameItem(this);
+    // ZValue is set to make the bubble to be rendered in behind text items.
+    mBubbleFrameItem->setZValue(-1.0);
+    HbStyle::setItemName(mBubbleFrameItem, "bubble");
+
+    mBodyTextItem = new HbTextItem(this);
+    mBodyTextItem->setTextWrapping(Hb::TextWordWrap);
+    HbStyle::setItemName(mBodyTextItem, "bodyText");
+
+    mTimeStampTextItem = new HbTextItem(this);
+    HbStyle::setItemName(mTimeStampTextItem, "timeStamp");
+
+    mNewFrameItem = new HbFrameItem(this);
+    HbStyle::setItemName(mNewFrameItem, "newItemIcon");
+
+    mAttachmentIconItem = new HbIconItem(this);
+    HbStyle::setItemName(mAttachmentIconItem, "attachment");
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setSubject
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setSubject(const QString &subject)
+{
+    if (!mSubjectTextItem)
+    {
+        mSubjectTextItem = new HbTextItem(this);
+        HbStyle::setItemName(mSubjectTextItem, "subject");
+    }
+    mSubjectTextItem->setText(subject);
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setBodyText
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setBodyText(const QString &body)
+{
+    mBodyTextItem->setText(body);
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setPreviewIconPath
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setPreviewIconPath(const QString &previewPath)
+{
+    if (!mPreviewIconItem)
+    {
+        mPreviewIconItem = new HbIconItem(this);
+        mPreviewIconItem->setAlignment(Qt::AlignHCenter | Qt::AlignTop);
+        HbStyle::setItemName(mPreviewIconItem, "preview");
+    }
+
+    if (previewPath.isEmpty())
+    {
+        mPreviewIconItem->setEnabled(false);
+    }
+    else
+    {
+        QImageReader iReader(previewPath);
+        QSize size(iReader.size());
+        
+        if(size.height() > MAX_SIZE || size.width() > MAX_SIZE)
+        {
+        size.scale(MAX_SIZE,MAX_SIZE,Qt::KeepAspectRatio);
+        iReader.setScaledSize(size);
+
+        QImage icon = iReader.read();
+        QPixmap pixmap = QPixmap::fromImage(icon);
+        
+        mPreviewIconItem->setIcon(HbIcon(pixmap));
+        }
+        else
+        {
+            QPixmap pixmap(previewPath);
+            mPreviewIconItem->setIcon(HbIcon(pixmap));
+        }
+        
+        mPreviewIconItem->setEnabled(true);
+    }
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setPriority
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setPriority(int priority)
+{
+    mPriority = priority;
+
+    if (priority)
+    {
+        if (!mPriorityIconItem)
+        {
+            mPriorityIconItem = new HbIconItem(this);
+            HbStyle::setItemName(mPriorityIconItem, "priority");
+        }
+
+        if (ConvergedMessage::Low == priority)
+        {
+            mPriorityIconItem->setIcon(HbIcon(MSG_LOW_PRIORITY_ICON));
+        }
+        else if (ConvergedMessage::High == priority)
+        {
+            mPriorityIconItem->setIcon(HbIcon(MSG_HIGH_PRIORITY_ICON));
+        }
+    }
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::priority
+// @see header file
+//---------------------------------------------------------------
+int MsgConversationWidget::priority()
+{
+    return mPriority;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setAttachment
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setAttachment(bool attachment)
+{
+    mHasAttachment = attachment;
+
+    if (attachment)
+    {
+        mAttachmentIconItem->setIcon(HbIcon(MSG_ATTACH_ICON));
+    }
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::hasAttachment
+// @see header file
+//---------------------------------------------------------------
+bool MsgConversationWidget::hasAttachment()
+{
+    return mHasAttachment;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setImage
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setImage(bool image)
+{
+    mHasImage = image;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::hasImage
+// @see header file
+//---------------------------------------------------------------
+bool MsgConversationWidget::hasImage()
+{
+    return mHasImage;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setAudio
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setAudio(bool audio)
+{
+    mHasAudio = audio;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::hasAudio
+// @see header file
+//---------------------------------------------------------------
+bool MsgConversationWidget::hasAudio()
+{
+    return mHasAudio;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::displayAudioIcon
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::displayAudioIcon()
+{
+    if (hasAudio())
+    {
+        if (hasImage())
+        {
+            if (!mPlayIconItem)
+            {
+                mPlayIconItem = new HbIconItem(this);
+                HbStyle::setItemName(mPlayIconItem, "playIcon");
+            }
+            mPlayIconItem->setIconName(MSG_AUDIO_PLAY_ICON);
+        }
+        else
+        {
+            if (!mAudioIconItem)
+            {
+                mAudioIconItem = new HbIconItem(this);
+                HbStyle::setItemName(mAudioIconItem, "audioIcon");
+            }
+            mAudioIconItem->setIconName(MSG_AUDIO_ICON);
+        }
+    }
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setVideo
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setVideo(bool video)
+{
+    mHasVideo = video;
+
+    if (video)
+    {
+        if (!mVideoIconItem)
+        {
+            mVideoIconItem = new HbIconItem(this);
+            HbStyle::setItemName(mVideoIconItem, "video");
+        }
+        mVideoIconItem->setIcon(HbIcon(MSG_VIDEO_ICON));
+    }
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::hasVideo
+// @see header file
+//---------------------------------------------------------------
+bool MsgConversationWidget::hasVideo()
+{
+    return mHasVideo;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setPlayable
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setPlayable(bool playable)
+{
+    mIsPlayable = playable;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::isPlayable
+// @see header file
+//---------------------------------------------------------------
+bool MsgConversationWidget::isPlayable()
+{
+    return mIsPlayable;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setIncoming
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setIncoming(bool incoming)
+{
+    mIncoming = incoming;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::isIncoming
+// @see header file
+//---------------------------------------------------------------
+bool MsgConversationWidget::isIncoming()
+{
+    return mIncoming;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setUnread
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setUnread(bool unread)
+{
+    mUnread = unread;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::isUnread
+// @see header file
+//---------------------------------------------------------------
+bool MsgConversationWidget::isUnread()
+{
+    return mUnread;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setMMS
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setMMS(bool isMMS)
+{
+    mIsMMS = isMMS;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::isMMS
+// @see header file
+//---------------------------------------------------------------
+bool MsgConversationWidget::isMMS()
+{
+    return mIsMMS;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setSendingState
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setSendingState(int state)
+{
+    switch (state)
+    {
+        case ConvergedMessage::SentState:
+        {
+            mSendingState = Sent;
+            repolish();
+            break;
+        }
+        case ConvergedMessage::Sending:
+        {
+            mSendingState = Sending;
+            break;
+        }
+        case ConvergedMessage::Suspended:
+        case ConvergedMessage::Resend:
+        {
+            mSendingState = Pending;
+            break;
+        }
+        case ConvergedMessage::Failed:
+        {
+            mSendingState = Failed;
+            break;
+        }
+        default:
+        {
+            mSendingState = Unknown;
+            break;
+        }
+    }
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::sendingState
+// @see header file
+//---------------------------------------------------------------
+int MsgConversationWidget::sendingState()
+{
+    return mSendingState;
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::setTimeStamp
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::setTimeStamp(const QString &timeStamp)
+{
+    mTimeStampTextItem->setText(timeStamp);
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::drawNewItemFrame
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::drawNewItemFrame()
+{
+    if (mUnread)
+    {
+        mNewFrameItem->frameDrawer().setFrameType(HbFrameDrawer::ThreePiecesVertical);
+        mNewFrameItem->frameDrawer().setFrameGraphicsName(NEW_ITEM_FRAME);
+    }
+    else
+    {
+        mNewFrameItem->frameDrawer().setFrameGraphicsName(QString());
+    }
+}
+
+//---------------------------------------------------------------
+// MsgConversationWidget::drawBubbleFrame
+// @see header file
+//---------------------------------------------------------------
+void MsgConversationWidget::drawBubbleFrame()
+{
+    mBubbleFrameItem->frameDrawer().setFrameType(HbFrameDrawer::NinePieces);
+    mBubbleFrameItem->frameDrawer().setFillWholeRect(true);
+
+    if(isIncoming())
+    {
+        mBubbleFrameItem->frameDrawer().setFrameGraphicsName(IN_CHAT_FRAME);
+    }
+    else
+    {
+        if(mSendingState == Sending || mSendingState == Pending || mSendingState == Unknown)
+        {
+            mBubbleFrameItem->frameDrawer().setFrameGraphicsName(SENDING_CHAT_FRAME);
+        }
+        else
+        {
+            mBubbleFrameItem->frameDrawer().setFrameGraphicsName(OUT_CHAT_FRAME);
+        }
+    }
+}
+
+// EOF