m_gps = new GPSPosition(this);
// build SituareService
- m_situareService = new SituareService(this);
+ m_situareService = new SituareService(m_networkAccessManager,
+ new ImageFetcher(m_networkAccessManager, this), this);
// build FacebookAuthenticator
m_facebookAuthenticator = new FacebookAuthentication(m_ui, this);
connect(this, SIGNAL(friendsLocationsReady(QList<User*>&)),
m_mapEngine, SIGNAL(friendsLocationsReady(QList<User*>&)));
- connect(this, SIGNAL(friendImageReady(User*)),
- m_ui, SIGNAL(friendImageReady(User*)));
+ connect(this, SIGNAL(userImageReady(QString,QPixmap)),
+ m_ui, SIGNAL(userImageReady(QString,QPixmap)));
- connect(this, SIGNAL(friendImageReady(User*)),
- m_mapEngine, SIGNAL(friendImageReady(User*)));
+ connect(this, SIGNAL(friendImageReady(QString,QPixmap)),
+ m_ui, SIGNAL(friendImageReady(QString,QPixmap)));
+
+ connect(this, SIGNAL(friendImageReady(QString,QPixmap)),
+ m_mapEngine, SIGNAL(friendImageReady(QString,QPixmap)));
m_automaticUpdateIntervalTimer = new QTimer(this);
connect(m_automaticUpdateIntervalTimer, SIGNAL(timeout()),
}
}
-void SituareEngine::imageReady(User *user)
+void SituareEngine::imageReady(const QString &id, const QPixmap &image)
{
qDebug() << __PRETTY_FUNCTION__;
- if(user->type())
- emit userLocationReady(user);
+ if (id.isNull())
+ emit userImageReady(id, image);
else
- emit friendImageReady(user);
+ emit friendImageReady(id, image);
}
void SituareEngine::initializeGpsAndAutocentering()
qDebug() << __PRETTY_FUNCTION__;
if (m_networkAccessManager->isConnected()) {
- m_ui->toggleProgressIndicator(true);
m_situareService->fetchLocations();
}
else {
qDebug() << __PRETTY_FUNCTION__;
if (m_networkAccessManager->isConnected()) {
- m_ui->toggleProgressIndicator(true);
if (m_gps->isRunning())
m_situareService->updateLocation(m_gps->lastPosition(), status, publish);
}
}
+void SituareEngine::requestInterestingPeople()
+{
+ qDebug() << __PRETTY_FUNCTION__;
+
+ QRectF currentSceneRect = m_mapEngine->currentViewSceneRect();
+ SceneCoordinate bottomLeftSceneCoordinate(currentSceneRect.left(), currentSceneRect.bottom());
+ SceneCoordinate topRightSceneCoordinate(currentSceneRect.right(), currentSceneRect.top());
+
+ m_situareService->fetchPeopleWithSimilarInterest(GeoCoordinate(bottomLeftSceneCoordinate),
+ GeoCoordinate(topRightSceneCoordinate));
+}
+
+void SituareEngine::requestSendMessage(const QString &receiverId, const QString &message,
+ bool addCoordinates)
+{
+ qDebug() << __PRETTY_FUNCTION__;
+
+ if (addCoordinates)
+ m_situareService->sendMessage(receiverId, message, m_mapEngine->centerGeoCoordinate());
+ else
+ m_situareService->sendMessage(receiverId, message);
+}
+
void SituareEngine::routeParsed(Route &route)
{
qDebug() << __PRETTY_FUNCTION__;
Q_UNUSED(route);
-
- m_ui->toggleProgressIndicator(false);
}
void SituareEngine::routeTo(const GeoCoordinate &endPointCoordinates)
{
qDebug() << __PRETTY_FUNCTION__;
- m_ui->toggleProgressIndicator(true);
-
if (m_gps->isRunning())
m_routingService->requestRoute(m_gps->lastPosition(), endPointCoordinates);
else
m_mapEngine->setAutoCentering(!enabled);
}
+void SituareEngine::setProgressIndicatorDisabled()
+{
+ m_ui->toggleProgressIndicator(false);
+}
+
+void SituareEngine::setProgressIndicatorEnabled()
+{
+ m_ui->toggleProgressIndicator(true);
+}
+
void SituareEngine::showContactDialog(const QString &facebookId)
{
qDebug() << __PRETTY_FUNCTION__;
"account from Conversations to use this feature."), true);
}
+void SituareEngine::showMessageDialog(const QPair<QString, QString> &receiver)
+{
+ qDebug() << __PRETTY_FUNCTION__;
+
+ m_ui->showMessageDialog(receiver);
+}
+
void SituareEngine::signalsFromFacebookAuthenticator()
{
qDebug() << __PRETTY_FUNCTION__;
this, SLOT(requestAddress()));
connect(m_ui, SIGNAL(locationUpdate(QString,bool)),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(locationUpdate(QString,bool)),
this, SLOT(requestUpdateLocation(QString,bool)));
connect(m_ui, SIGNAL(enableAutomaticLocationUpdate(bool, int)),
this, SLOT(enableAutomaticLocationUpdate(bool, int)));
+ connect(m_ui, SIGNAL(addTags(QStringList)),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(addTags(QStringList)),
+ m_situareService, SLOT(addTags(QStringList)));
+
+ connect(m_ui, SIGNAL(removeTags(QStringList)),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(removeTags(QStringList)),
+ m_situareService, SLOT(removeTags(QStringList)));
+
// signals from user info tab
connect(m_ui, SIGNAL(refreshUserData()),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(refreshUserData()),
this, SLOT(refreshUserData()));
connect(m_ui, SIGNAL(centerToCoordinates(GeoCoordinate)),
m_mapEngine, SLOT(centerToCoordinates(GeoCoordinate)));
+ connect(m_ui, SIGNAL(requestPopularTags()),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(requestPopularTags()),
+ m_situareService, SLOT(fetchPopularTags()));
+
// routing signal from friend list tab & search location tab
+ connect(m_ui, SIGNAL(routeTo(GeoCoordinate)),
+ this, SLOT(setProgressIndicatorEnabled()));
+
connect(m_ui, SIGNAL(routeTo(const GeoCoordinate&)),
this, SLOT(routeTo(const GeoCoordinate&)));
+ connect(m_ui, SIGNAL(requestContactDialog(const QString &)),
+ this, SLOT(showContactDialog(const QString &)));
+
// signals from location search panel
connect(m_ui,
SIGNAL(locationItemClicked(const GeoCoordinate&, const GeoCoordinate&)),
connect(m_ui, SIGNAL(draggingModeTriggered()),
this, SLOT(draggingModeTriggered()));
- // signal from search location dialog
+ // signal from search search dialogs
connect(m_ui, SIGNAL(searchForLocation(QString)),
this, SLOT(locationSearch(QString)));
- // signal from friend list panel
- connect(m_ui, SIGNAL(requestContactDialog(const QString &)),
- this, SLOT(showContactDialog(const QString &)));
+ connect(m_ui, SIGNAL(requestSearchPeopleByTag(QString)),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(requestSearchPeopleByTag(QString)),
+ m_situareService, SLOT(searchPeopleByTag(QString)));
+
+ // signals from meet people panel
+ connect(m_ui, SIGNAL(requestInterestingPeople()),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(requestInterestingPeople()),
+ this, SLOT(requestInterestingPeople()));
+
+ connect(m_ui, SIGNAL(requestMessageDialog(QPair<QString, QString>)),
+ this, SLOT(showMessageDialog(QPair<QString, QString>)));
+
+ connect(m_ui, SIGNAL(sendMessage(QString,QString,bool)),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(sendMessage(QString,QString,bool)),
+ this, SLOT(requestSendMessage(QString,QString,bool)));
+
+ // signals from message panel
+ connect(m_ui, SIGNAL(requestMessages()),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(requestMessages()),
+ m_situareService, SLOT(fetchMessages()));
+
+ connect(m_ui, SIGNAL(requestRemoveMessage(QString)),
+ this, SLOT(setProgressIndicatorEnabled()));
+
+ connect(m_ui, SIGNAL(requestRemoveMessage(QString)),
+ m_situareService, SLOT(removeMessage(QString)));
}
void SituareEngine::signalsFromMapEngine()
qDebug() << __PRETTY_FUNCTION__;
connect(m_routingService, SIGNAL(routeParsed(Route&)),
- this, SLOT(routeParsed(Route&)));
+ this, SLOT(setProgressIndicatorDisabled()));
connect(m_routingService, SIGNAL(routeParsed(Route&)),
m_mapEngine, SLOT(setRoute(Route&)));
connect(m_situareService, SIGNAL(error(int, int)),
this, SLOT(error(int, int)));
- connect(m_situareService, SIGNAL(imageReady(User*)),
- this, SLOT(imageReady(User*)));
+ connect(m_situareService, SIGNAL(imageReady(QString,QPixmap)),
+ this, SLOT(imageReady(QString,QPixmap)));
connect(m_situareService, SIGNAL(reverseGeoReady(QString)),
m_ui, SIGNAL(reverseGeoReady(QString)));
+ connect(m_situareService, SIGNAL(userDataChanged(User*,QList<User*>&)),
+ this, SLOT(setProgressIndicatorDisabled()));
+
connect(m_situareService, SIGNAL(userDataChanged(User*, QList<User*>&)),
this, SLOT(userDataChanged(User*, QList<User*>&)));
- connect(m_situareService, SIGNAL(updateWasSuccessful()),
- this, SLOT(updateWasSuccessful()));
+ connect(m_situareService, SIGNAL(updateWasSuccessful(SituareService::SuccessfulMethod)),
+ m_ui, SIGNAL(clearUpdateLocationDialogData()));
+
+ connect(m_situareService, SIGNAL(updateWasSuccessful(SituareService::SuccessfulMethod)),
+ this, SLOT(updateWasSuccessful(SituareService::SuccessfulMethod)));
+
+ connect(m_situareService, SIGNAL(interestingPeopleReceived(QList<User>&,QList<User>&)),
+ m_ui, SIGNAL(interestingPeopleReceived(QList<User>&,QList<User>&)));
+
+ connect(m_situareService, SIGNAL(interestingPeopleReceived(QList<User>&,QList<User>&)),
+ this, SLOT(setProgressIndicatorDisabled()));
+
+ connect(m_situareService, SIGNAL(messagesReceived(QList<Message>&, QList<Message> &)),
+ this, SLOT(setProgressIndicatorDisabled()));
+
+
+ connect(m_situareService, SIGNAL(messagesReceived(QList<Message>&, QList<Message> &)),
+ m_ui, SIGNAL(messagesReceived(QList<Message>&, QList<Message>&)));
- connect(m_situareService, SIGNAL(updateWasSuccessful()),
- m_ui, SIGNAL(updateWasSuccessful()));
+ connect(m_situareService, SIGNAL(popularTagsReceived(QHash<QString,QString>&)),
+ this, SLOT(setProgressIndicatorDisabled()));
+
+ connect(m_situareService, SIGNAL(popularTagsReceived(QHash<QString,QString>&)),
+ m_ui, SIGNAL(popularTagsReceived(QHash<QString,QString>&)));
}
void SituareEngine::startAutomaticUpdate()
setPowerSaving(!isMainWindow);
}
-void SituareEngine::updateWasSuccessful()
+void SituareEngine::updateWasSuccessful(SituareService::SuccessfulMethod successfulMethod)
{
qDebug() << __PRETTY_FUNCTION__;
- if (m_networkAccessManager->isConnected())
- m_situareService->fetchLocations();
- else
+ if (m_networkAccessManager->isConnected()) {
+ if (successfulMethod == SituareService::SuccessfulUpdateLocation)
+ m_situareService->fetchLocations();
+ else if ((successfulMethod == SituareService::SuccessfulRemoveMessage) ||
+ (successfulMethod == SituareService::SuccessfulSendMessage))
+ m_situareService->fetchMessages();
+ else if ((successfulMethod == SituareService::SuccessfulAddTags) ||
+ (successfulMethod == SituareService::SuccessfulRemoveTags))
+ m_situareService->fetchLocations();
+ } else {
error(ErrorContext::NETWORK, QNetworkReply::UnknownNetworkError);
+ }
}
void SituareEngine::userDataChanged(User *user, QList<User *> &friendsList)
{
qDebug() << __PRETTY_FUNCTION__;
- m_ui->toggleProgressIndicator(false);
-
emit userLocationReady(user);
emit friendsLocationsReady(friendsList);
}