From d0e9f626245e7833847ad25ae3b97c5ab87caccb Mon Sep 17 00:00:00 2001 From: jan Iversen Date: Tue, 12 Jun 2018 10:29:40 +0200 Subject: mobile: add qmlprefs class add class to cmake and pro register class Signed-off-by: Jan Iversen --- CMakeLists.txt | 1 + mobile-widgets/qml/main.qml | 4 ++++ mobile-widgets/qmlprefs.cpp | 21 +++++++++++++++++++++ mobile-widgets/qmlprefs.h | 25 +++++++++++++++++++++++++ packaging/ios/Subsurface-mobile.pro | 2 ++ subsurface-mobile-helper.cpp | 2 ++ 6 files changed, 55 insertions(+) create mode 100644 mobile-widgets/qmlprefs.cpp create mode 100644 mobile-widgets/qmlprefs.h diff --git a/CMakeLists.txt b/CMakeLists.txt index 7b90f8318..75e2b0b9f 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -285,6 +285,7 @@ endif() if(${SUBSURFACE_TARGET_EXECUTABLE} MATCHES "MobileExecutable") set(MOBILE_SRC mobile-widgets/qmlmanager.cpp + mobile-widgets/qmlprefs.cpp mobile-widgets/qml/kirigami/src/kirigamiplugin.cpp mobile-widgets/qml/kirigami/src/settings.cpp mobile-widgets/qml/kirigami/src/enums.cpp diff --git a/mobile-widgets/qml/main.qml b/mobile-widgets/qml/main.qml index bd567894e..28f16a9b8 100644 --- a/mobile-widgets/qml/main.qml +++ b/mobile-widgets/qml/main.qml @@ -492,6 +492,10 @@ if you have network connectivity and want to sync your data to cloud storage."), } } + QMLPrefs { + id: prefs + } + QMLManager { id: manager } diff --git a/mobile-widgets/qmlprefs.cpp b/mobile-widgets/qmlprefs.cpp new file mode 100644 index 000000000..49a788708 --- /dev/null +++ b/mobile-widgets/qmlprefs.cpp @@ -0,0 +1,21 @@ +// SPDX-License-Identifier: GPL-2.0 +#include "qmlprefs.h" + +QMLPrefs *QMLPrefs::m_instance = NULL; + + +QMLPrefs::QMLPrefs() +{ + if (!m_instance) + m_instance = this; +} + +QMLPrefs::~QMLPrefs() +{ + m_instance = NULL; +} + +QMLPrefs *QMLPrefs::instance() +{ + return m_instance; +} diff --git a/mobile-widgets/qmlprefs.h b/mobile-widgets/qmlprefs.h new file mode 100644 index 000000000..2755014e8 --- /dev/null +++ b/mobile-widgets/qmlprefs.h @@ -0,0 +1,25 @@ +// SPDX-License-Identifier: GPL-2.0 +#ifndef QMLPREFS_H +#define QMLPREFS_H + +#include + + +class QMLPrefs : public QObject { + Q_OBJECT + +public: + QMLPrefs(); + ~QMLPrefs(); + + static QMLPrefs *instance(); + +public slots: + +private: + static QMLPrefs *m_instance; + +signals: +}; + +#endif diff --git a/packaging/ios/Subsurface-mobile.pro b/packaging/ios/Subsurface-mobile.pro index 911557399..45f1501e4 100644 --- a/packaging/ios/Subsurface-mobile.pro +++ b/packaging/ios/Subsurface-mobile.pro @@ -81,6 +81,7 @@ SOURCES += ../../subsurface-mobile-main.cpp \ ../../core/subsurface-qt/DiveObjectHelper.cpp \ ../../core/subsurface-qt/SettingsObjectWrapper.cpp \ ../../mobile-widgets/qmlmanager.cpp \ + ../../mobile-widgets/qmlprefs.cpp \ ../../qt-models/divelistmodel.cpp \ ../../qt-models/diveplotdatamodel.cpp \ ../../qt-models/gpslistmodel.cpp \ @@ -183,6 +184,7 @@ HEADERS += \ ../../core/subsurface-qt/DiveObjectHelper.h \ ../../core/subsurface-qt/SettingsObjectWrapper.h \ ../../mobile-widgets/qmlmanager.h \ + ../../mobile-widgets/qmlprefs.h \ ../../map-widget/qmlmapwidgethelper.h \ ../../qt-models/divelistmodel.h \ ../../qt-models/diveplotdatamodel.h \ diff --git a/subsurface-mobile-helper.cpp b/subsurface-mobile-helper.cpp index a36b75c60..6fcdb1191 100644 --- a/subsurface-mobile-helper.cpp +++ b/subsurface-mobile-helper.cpp @@ -17,6 +17,7 @@ #include #include #include "mobile-widgets/qmlmanager.h" +#include "mobile-widgets/qmlprefs.h" #include "qt-models/divelistmodel.h" #include "qt-models/gpslistmodel.h" #include "profile-widget/qmlprofile.h" @@ -55,6 +56,7 @@ void run_ui() { LOG_STP("run_ui starting"); qmlRegisterType("org.subsurfacedivelog.mobile", 1, 0, "QMLManager"); + qmlRegisterType("org.subsurfacedivelog.mobile", 1, 0, "QMLPrefs"); qmlRegisterType("org.subsurfacedivelog.mobile", 1, 0, "QMLProfile"); qmlRegisterType("org.subsurfacedivelog.mobile", 1, 0, "DCDownloadThread"); -- cgit v1.2.3-70-g09d2