From 857d9547a9fc4a00c6e621fb54720d047ba90864 Mon Sep 17 00:00:00 2001 From: Philipp Andreas Date: Wed, 14 Jan 2015 02:10:36 +0100 Subject: First prototype of pebble app store integration --- app/app.pro | 11 ++++++---- app/pebble.cpp | 3 +++ app/pebblestoreview.cpp | 50 ++++++++++++++++++++++++++++++++++++++++++ app/pebblestoreview.h | 23 +++++++++++++++++++ app/qml/pages/AppStorePage.qml | 24 ++++++++++++++++++++ app/qml/pages/ManagerPage.qml | 4 ++++ 6 files changed, 111 insertions(+), 4 deletions(-) create mode 100644 app/pebblestoreview.cpp create mode 100644 app/pebblestoreview.h create mode 100644 app/qml/pages/AppStorePage.qml diff --git a/app/app.pro b/app/app.pro index 97c6232..9600919 100644 --- a/app/app.pro +++ b/app/app.pro @@ -2,7 +2,7 @@ TARGET = pebble CONFIG += sailfishapp -QT += dbus +QT += dbus webkit quick-private webkit-private CONFIG += c++11 DEFINES += APP_VERSION=\\\"$$VERSION\\\" @@ -10,11 +10,13 @@ DEFINES += APP_VERSION=\\\"$$VERSION\\\" SOURCES += \ pebble.cpp \ pebbledinterface.cpp \ - pebbleappiconprovider.cpp + pebbleappiconprovider.cpp \ + pebblestoreview.cpp HEADERS += \ pebbledinterface.h \ - pebbleappiconprovider.h + pebbleappiconprovider.h \ + pebblestoreview.h DBUS_INTERFACES += ../org.pebbled.Watch.xml @@ -30,7 +32,8 @@ OTHER_FILES += \ qml/images/* \ translations/*.ts \ pebble.desktop \ - pebble.png + pebble.png \ + qml/pages/AppStorePage.qml CONFIG += sailfishapp_i18n TRANSLATIONS += translations/pebble-es.ts diff --git a/app/pebble.cpp b/app/pebble.cpp index 22f6ac1..dd3c915 100644 --- a/app/pebble.cpp +++ b/app/pebble.cpp @@ -34,6 +34,7 @@ #include #include "pebbledinterface.h" #include "pebbleappiconprovider.h" +#include "pebblestoreview.h" int main(int argc, char *argv[]) { @@ -48,6 +49,8 @@ int main(int argc, char *argv[]) qmlRegisterUncreatableType("org.pebbled", 0, 1, "PebbledInterface", "Please use pebbled context property"); + qmlRegisterType("org.pebbled", 0, 1, "PebbleStoreView"); + QScopedPointer view(SailfishApp::createView()); QScopedPointer pebbled(new PebbledInterface); QScopedPointer appicons(new PebbleAppIconProvider(pebbled.data())); diff --git a/app/pebblestoreview.cpp b/app/pebblestoreview.cpp new file mode 100644 index 0000000..011d056 --- /dev/null +++ b/app/pebblestoreview.cpp @@ -0,0 +1,50 @@ +#include "pebblestoreview.h" +#include +#include +#include + +PebbleStoreView::PebbleStoreView() + : QQuickWebView() +{ + connect(this, SIGNAL(navigationRequested(QWebNavigationRequest*)), this, SLOT(onNavigationRequested(QWebNavigationRequest*))); +} + + +void PebbleStoreView::onNavigationRequested(QWebNavigationRequest* request) +{ + if (request->url().scheme() == "pebble") { + if (request->url().host() == "login") { + QUrlQuery *accessTokenFragment = new QUrlQuery(request->url().fragment()); + qDebug()<<"login"<queryItemValue("access_token"); + emit loginSuccess(accessTokenFragment->queryItemValue("access_token")); + } + } + if (request->url().scheme() == "pebble-method-call-js-frame") { + QString urlStr = ""; + + //Basic parse error string + QRegExp reg(".*; source was \"(.*)\";.*"); + reg.setMinimal(true); + if (reg.indexIn(request->url().errorString()) > -1) { + urlStr = reg.cap(1); + reg.setPattern("method=(.*)&args=(.*)$"); + reg.setMinimal(true); + if (reg.indexIn(urlStr) > -1) { + QString methodStr = reg.cap(1); + QString argsStr = QUrl::fromPercentEncoding(reg.cap(2).toUtf8()); + emit call(methodStr, argsStr); + if (methodStr == "loadAppToDeviceAndLocker") { + QJsonDocument jsonResponse = QJsonDocument::fromJson(argsStr.toUtf8()); + QJsonObject jsonObject = jsonResponse.object(); + QJsonObject data = jsonObject.value("data").toObject(); + qDebug()<<"download"< +#include +#include + +class PebbleStoreView : public QQuickWebView +{ + Q_OBJECT +public: + PebbleStoreView(); + +public slots: + void onNavigationRequested(QWebNavigationRequest* request); + +signals: + void loginSuccess(const QString & accessToken); + void downloadPebbleApp(const QString & title, const QString & downloadUrl); + void call(const QString &, const QString &); +}; + +#endif // PEBBLESTOREVIEW_H diff --git a/app/qml/pages/AppStorePage.qml b/app/qml/pages/AppStorePage.qml new file mode 100644 index 0000000..95bb2db --- /dev/null +++ b/app/qml/pages/AppStorePage.qml @@ -0,0 +1,24 @@ +import QtQuick 2.0 +import QtQml 2.1 +import Sailfish.Silica 1.0 +import org.pebbled 0.1 + +Page { + id: page + + PebbleStoreView { + id: webview + anchors.fill: parent + url: "https://auth.getpebble.com/oauth/authorize?client_id=f88739e8e7a696c411236c41afc81cbef16dc54c3ff633d92dd4ceb0e5a25e5f&response_type=token&mid=xxx&pid=xxx&platform=android&mobile=sign_in&redirect_uri=pebble%3A%2F%2Flogin" + + onLoginSuccess: { + console.log("ON Login " + accessToken); + webview.url = "https://apps-prod.getpebble.com/en_US/?access_token=" + accessToken + "#/watchfaces" + } + + onDownloadPebbleApp: { + console.log("ON DOWNLOAD " + title); + console.log(downloadUrl); + } + } +} diff --git a/app/qml/pages/ManagerPage.qml b/app/qml/pages/ManagerPage.qml index 814c9d8..c0dd411 100644 --- a/app/qml/pages/ManagerPage.qml +++ b/app/qml/pages/ManagerPage.qml @@ -65,6 +65,10 @@ Page { text: qsTr("About") onClicked: pageStack.push(Qt.resolvedUrl("AboutPage.qml")) } + MenuItem { + text: qsTr("Pebble Appstore") + onClicked: pageStack.push(Qt.resolvedUrl("AppStorePage.qml")) + } } Column { -- cgit v1.2.3