summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tomaz.canabrava@intel.com>2014-12-28 21:06:07 -0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2014-12-29 09:05:53 -0800
commited903c42b9aac5a87cdbef0c888782b4985724b0 (patch)
tree939c9bff15f65d34d387ac7fd3187454eba570bb
parent571f86485d6063f86901487bca62e79b6383db45 (diff)
downloadsubsurface-ed903c42b9aac5a87cdbef0c888782b4985724b0.tar.gz
Facebook integration: Always ask for a folder before sending the photo
This way we are sure that the upload was made in the correct folder. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-ui/maintab.cpp1
-rw-r--r--qt-ui/socialnetworks.cpp29
-rw-r--r--qt-ui/socialnetworks.h2
3 files changed, 25 insertions, 7 deletions
diff --git a/qt-ui/maintab.cpp b/qt-ui/maintab.cpp
index 6edc5fa8e..302c0b210 100644
--- a/qt-ui/maintab.cpp
+++ b/qt-ui/maintab.cpp
@@ -190,6 +190,7 @@ MainTab::MainTab(QWidget *parent) : QTabWidget(parent),
FacebookManager *fb = FacebookManager::instance();
connect(fb, &FacebookManager::justLoggedIn, ui.facebookPublish, &QPushButton::show);
connect(fb, &FacebookManager::justLoggedOut, ui.facebookPublish, &QPushButton::hide);
+ connect(ui.facebookPublish, &QPushButton::clicked, fb, &FacebookManager::sendDive);
ui.facebookPublish->setVisible(fb->loggedIn());
}
diff --git a/qt-ui/socialnetworks.cpp b/qt-ui/socialnetworks.cpp
index 75d292ba6..b722c34c5 100644
--- a/qt-ui/socialnetworks.cpp
+++ b/qt-ui/socialnetworks.cpp
@@ -13,6 +13,8 @@
#include <QFile>
#include <QBuffer>
#include <QDebug>
+#include <QMessageBox>
+#include <QInputDialog>
#include "mainwindow.h"
#include "profile/profilewidget2.h"
#include "pref.h"
@@ -85,8 +87,6 @@ void FacebookManager::tryLogin(const QUrl& loginResponse)
sync();
requestUserId();
sync();
- requestAlbumId();
- sync();
emit justLoggedIn();
qDebug() << "End try login";
}
@@ -150,6 +150,7 @@ void FacebookManager::requestAlbumId()
if (album.contains("id")) {
s.setValue("AlbumId", album.value("id").toString());
qDebug() << "Got album ID";
+ sync();
return;
}
@@ -188,18 +189,28 @@ void FacebookManager::setDesiredAlbumName(const QString& a)
/* to be changed to export the currently selected dive as shown on the profile.
* Much much easier, and its also good to people do not select all the dives
* and send erroniously *all* of them to facebook. */
-void FacebookManager::sendDive(int divenr)
+void FacebookManager::sendDive()
{
+ bool ok;
+ albumName = QInputDialog::getText(qApp->activeWindow(), tr("Enter Facebook Album"),
+ tr("Facebook Album:"), QLineEdit::Normal,
+ "Subsurface", &ok);
+ if (!ok)
+ return;
+
+ requestAlbumId();
+
ProfileWidget2 *profile = MainWindow::instance()->graphics();
QPixmap pix = QPixmap::grabWidget(profile);
-
+ struct dive* d = current_dive;
QByteArray bytes;
QBuffer buffer(&bytes);
buffer.open(QIODevice::WriteOnly);
pix.save(&buffer, "PNG");
QUrl url("https://graph.facebook.com/v2.2/" + QString(prefs.facebook.album_id) + "/photos?" +
"&access_token=" + QString(prefs.facebook.access_token) +
- "&source=image");
+ "&source=image" +
+ "&message=" + QString(d->notes).toHtmlEscaped());
QNetworkAccessManager *am = new QNetworkAccessManager(this);
@@ -226,5 +237,11 @@ void FacebookManager::sendDive(int divenr)
connect(reply, SIGNAL(finished()), &loop, SLOT(quit()));
loop.exec();
- qDebug() << reply->readAll();
+ QJsonDocument jsonDoc = QJsonDocument::fromJson(reply->readAll());
+ QJsonObject obj = jsonDoc.object();
+ if (obj.keys().contains("id")){
+ QMessageBox::
+ } else {
+
+ }
}
diff --git a/qt-ui/socialnetworks.h b/qt-ui/socialnetworks.h
index 8c474c906..66a95f22a 100644
--- a/qt-ui/socialnetworks.h
+++ b/qt-ui/socialnetworks.h
@@ -22,7 +22,7 @@ public slots:
void tryLogin(const QUrl& loginResponse);
void logout();
void setDesiredAlbumName(const QString& albumName);
- void sendDive(int divenr);
+ void sendDive();
private:
explicit FacebookManager(QObject *parent = 0);