Jussi Laitinen - jussi.laitinen@ixonos.com
Katri Kaikkonen - katri.kaikkonen@ixonos.com
Henri Lampela - henri.lampela@ixonos.com
+ Ville Tiensuu - ville.tiensuu@ixonos.com
Situare is free software; you can redistribute it and/or
modify it under the terms of the GNU General Public License
USA.
*/
+#include "common.h"
#include "imagebutton.h"
#include "../user/user.h"
#include "userinfo.h"
-const int BACKGROUND_WIDTH = 240; ///< Width for item
-const int BACKGROUND_TOP_HEIGHT = 16; ///< Height for item top
-const int BACKGROUND_BOTTOM_HEIGHT = 15; ///< Height for item bottom
-const QColor COLOR_GRAY = QColor(152, 152, 152); ///< Gray color
-const QFont NOKIA_FONT_NORMAL = QFont("Nokia Sans", 18, QFont::Normal); ///< Normal font
-const QFont NOKIA_FONT_SMALL = QFont("Nokia Sans", 13, QFont::Normal); ///< Small font
-const int ICON_HEIGHT = 24; ///< Icon height
-const int ICON_WIDTH = 24; ///< Icon width
-const int IMAGE_HEIGHT = 60; ///< Profile image height
-const int IMAGE_WIDTH = 60; ///< Profile image width
-const int MARGIN = 5; ///< Icon margin
-const int MOUSE_PRESS_AREA_WIDTH = 20; ///< Area width for item height toggling
-const int MOUSE_PRESS_AREA_HEIGHT = 20; ///< Area height for item height toggling
+const int BACKGROUND_WIDTH = 240; ///< Width for item
+const int BACKGROUND_TOP_HEIGHT = 16; ///< Height for item top
+const int BACKGROUND_BOTTOM_HEIGHT = 15; ///< Height for item bottom
+const int ICON_HEIGHT = 24; ///< Icon height
+const int ICON_WIDTH = 24; ///< Icon width
+const int MARGIN = 5; ///< Icon margin
+const int LINE_LENGTH = 17; ///< Line length
+const int MOUSE_PRESS_AREA_WIDTH = 20; ///< Area width for item height toggling
+const int MOUSE_PRESS_AREA_HEIGHT = 20; ///< Area height for item height toggling
/**
* @var LABEL_MAX_WIDTH
UserInfo::UserInfo(QWidget *parent)
: QWidget(parent),
- m_expanded(false)
+ m_expanded(false),
+ m_messageUpdateVerified(false),
+ m_updateLocation(0)
{
qDebug() << __PRETTY_FUNCTION__;
connect(updateStatusMessageButton,SIGNAL(clicked()),
this,SLOT(messageUpdate()));
+
connect(updateFriendsButton,SIGNAL(clicked()),
this, SIGNAL(refreshUserData()));
+
connect(m_findButton, SIGNAL(clicked()),
- this, SLOT(findButtonClicked()));
+ this, SLOT(findButtonClicked()));
setFixedWidth(BACKGROUND_WIDTH);
m_backgroundTopImage.load(":/res/images/user_info_item_top.png");
m_backgroundMiddleImage.load(":/res/images/user_info_item_middle.png");
m_backgroundBottomImage.load(":/res/images/user_info_item_bottom.png");
+
+ restoreUnsendMessage();
+}
+
+UserInfo::~UserInfo()
+{
+ qDebug() << __PRETTY_FUNCTION__;
+
+ QSettings settings(DIRECTORY_NAME, FILE_NAME);
+
+ if (!m_backupMessage.isEmpty()) {
+ settings.setValue(USER_UNSEND_MESSAGE, m_backupMessage.toAscii());
+ settings.setValue(USER_UNSEND_MESSAGE_PUBLISH, m_backupFacebookPublishPolicity);
+ } else {
+ settings.remove(USER_UNSEND_MESSAGE);
+ settings.remove(USER_UNSEND_MESSAGE_PUBLISH);
+ }
}
void UserInfo::setAddress(const QString &address)
qDebug() << __PRETTY_FUNCTION__;
m_messageText = text;
+ m_expandedMessageText.clear();
+ QString temp = "";
+ for(int i=0;i < text.length();i++) {
+ if(fontMetrics().width(temp.append(text.at(i))) > 170) {
+ temp.append("\n");
+ if(temp.startsWith(QString(" ")))
+ temp.remove(0, 1);
+
+ m_expandedMessageText.append(temp);
+ temp.clear();
+ }
+ }
+ m_expandedMessageText.append(temp);
setText(false);
}
{
qDebug() << __PRETTY_FUNCTION__;
- m_findButton->setIcon(image);
+ m_findButton->setButtonIcon(image);
}
void UserInfo::setTime(const QString &time)
setText(false);
}
-QString UserInfo::shortenText(const QLabel *label, const QString &text, int textMaxWidth)
-{
- qDebug() << __PRETTY_FUNCTION__;
-
- QFontMetrics labelMetrics = label->fontMetrics();
-
- QString textParam = text;
- int index = textParam.indexOf('\n');
-
- if (index > 0) {
- textParam.truncate(index);
- textParam.append("...");
- }
-
- return labelMetrics.elidedText(textParam, Qt::ElideRight, textMaxWidth);
-}
-
void UserInfo::setText(bool expanded)
{
qDebug() << __PRETTY_FUNCTION__;
if (expanded) {
- m_nameLabel->setText(m_userName);
- m_statusTextLabel->setText(m_messageText);
+ m_statusTextLabel->setText(m_expandedMessageText);
}
else {
m_nameLabel->setText(shortenText(m_nameLabel, m_userName, LABEL_MAX_WIDTH));
}
}
+void UserInfo::backupUpdateLocationDialogData(const QString &status, bool publish)
+{
+ qDebug() << __PRETTY_FUNCTION__;
+
+ m_backupMessage = status;
+ m_backupFacebookPublishPolicity = publish;
+
+ m_messageUpdateVerified = false;
+}
+
+void UserInfo::clearUpdateLocationDialogData()
+{
+ qDebug() << __PRETTY_FUNCTION__;
+
+ m_backupMessage.clear();
+ m_backupFacebookPublishPolicity = false;
+}
+
+void UserInfo::findButtonClicked()
+{
+ qDebug() << __PRETTY_FUNCTION__;
+
+ emit findUser(m_coordinates);
+}
+
void UserInfo::mouseReleaseEvent(QMouseEvent *event)
{
qDebug() << __PRETTY_FUNCTION__ << " " << event->pos();
}
}
}
+
+void UserInfo::mousePressEvent(QMouseEvent *event)
+{
+ qDebug() << __PRETTY_FUNCTION__ << " " << event->pos();
+
+ m_mousePosition = event->pos();
+}
+
+void UserInfo::messageUpdate()
+{
+ qDebug() << __PRETTY_FUNCTION__;
+
+ delete m_updateLocation;
+ m_updateLocation = new UpdateLocationDialog(m_backupMessage, m_backupFacebookPublishPolicity,
+ this);
+
+ connect(this, SIGNAL(reverseGeoReady(QString)),
+ m_updateLocation, SLOT(setAddress(QString)));
+
+ connect(m_updateLocation, SIGNAL(statusUpdate(QString,bool)),
+ this, SIGNAL(statusUpdate(QString,bool)));
+
+ connect(m_updateLocation, SIGNAL(statusUpdate(QString,bool)),
+ this, SLOT(backupUpdateLocationDialogData(QString,bool)));
+
+ connect(m_updateLocation, SIGNAL(finished(int)),
+ this, SLOT(updateLocationDialogFinished(int)));
+
+ m_updateLocation->show();
+
+ emit requestReverseGeo();
+}
+
void UserInfo::paintEvent(QPaintEvent *aPaintEvent)
{
qDebug() << __PRETTY_FUNCTION__ << " " << aPaintEvent->rect();
painter.drawPixmap(bottomRect, m_backgroundBottomImage);
}
-void UserInfo::mousePressEvent(QMouseEvent *event)
+void UserInfo::restoreUnsendMessage()
{
- qDebug() << __PRETTY_FUNCTION__ << " " << event->pos();
+ qDebug() << __PRETTY_FUNCTION__;
- m_mousePosition = event->pos();
+ QSettings settings(DIRECTORY_NAME, FILE_NAME);
+ m_backupMessage = settings.value(USER_UNSEND_MESSAGE, EMPTY).toString();
+ m_backupFacebookPublishPolicity =
+ settings.value(USER_UNSEND_MESSAGE_PUBLISH, false).toBool();
}
-void UserInfo::findButtonClicked()
+QString UserInfo::shortenText(const QLabel *label, const QString &text, int textMaxWidth)
{
qDebug() << __PRETTY_FUNCTION__;
- emit findUser(m_coordinates);
+ QFontMetrics labelMetrics = label->fontMetrics();
+ QString textParam = text;
+ int index = textParam.indexOf('\n');
+ int textWidth = fontMetrics().width(textParam);
+
+ if (index > 0) {
+ textParam.truncate(index);
+ textParam.append("...");
+ }
+ if (textWidth > 150)
+ textParam.insert(LINE_LENGTH, QString("\n"));
+
+ return labelMetrics.elidedText(textParam, Qt::ElideRight, textMaxWidth);
}
-void UserInfo::messageUpdate()
+void UserInfo::verifyMessageUpdateFailure(const int error)
{
qDebug() << __PRETTY_FUNCTION__;
- UpdateLocationDialog updateLocationDialog(this);
+ Q_UNUSED(error);
- emit requestReverseGeo();
+ if (!m_messageUpdateVerified) {
- connect(this, SIGNAL(reverseGeoReady(QString)),
- &updateLocationDialog, SLOT(setAddress(QString)));
- connect(&updateLocationDialog, SIGNAL(statusUpdate(QString, bool)),
- this, SIGNAL(statusUpdate(QString, bool)));
+ if (m_messageText != m_backupMessage && !m_backupMessage.isEmpty())
+ emit notificateUpdateFailing(tr("Location update failed, please try again"), false);
+ }
- updateLocationDialog.exec();
+ m_messageUpdateVerified = true;
}
+void UserInfo::updateLocationDialogFinished(int reason)
+{
+ qDebug() << __PRETTY_FUNCTION__;
+
+ Q_UNUSED(reason);
+
+ if (m_updateLocation) {
+ disconnect(this, SIGNAL(reverseGeoReady(QString)),
+ m_updateLocation, SLOT(setAddress(QString)));
+
+ disconnect(m_updateLocation, SIGNAL(statusUpdate(QString,bool)),
+ this, SIGNAL(statusUpdate(QString,bool)));
+
+ disconnect(m_updateLocation, SIGNAL(statusUpdate(QString,bool)),
+ this, SLOT(backupUpdateLocationDialogData(QString,bool)));
+
+ disconnect(m_updateLocation, SIGNAL(finished(int)),
+ this, SLOT(updateLocationDialogFinished(int)));
+
+ m_updateLocation->deleteLater();
+ m_updateLocation = 0;
+ }
+
+}