diff options
author | Grace Karanja <gracie.karanja89@gmail.com> | 2015-07-21 11:57:10 +0300 |
---|---|---|
committer | Grace Karanja <gracie.karanja89@gmail.com> | 2015-07-22 09:53:19 +0300 |
commit | ea11eff27900b0929068c2fd18728db6412484cf (patch) | |
tree | f6a115c7fa9f20548a022b94e6aec79e19f27aed /qt-mobile | |
parent | b28517b9b002bbdaac867d0b720c17ae865cf17d (diff) | |
download | subsurface-ea11eff27900b0929068c2fd18728db6412484cf.tar.gz |
QML UI: Implement saving of cloud password
If the user ticks the 'Save Password' box, then we save the password
for future use.
Signed-off-by: Grace Karanja <gracie.karanja89@gmail.com>
Diffstat (limited to 'qt-mobile')
-rw-r--r-- | qt-mobile/Preferences.qml | 2 | ||||
-rw-r--r-- | qt-mobile/qmlmanager.cpp | 26 | ||||
-rw-r--r-- | qt-mobile/qmlmanager.h | 6 |
3 files changed, 30 insertions, 4 deletions
diff --git a/qt-mobile/Preferences.qml b/qt-mobile/Preferences.qml index f03ab8a02..8f4a15328 100644 --- a/qt-mobile/Preferences.qml +++ b/qt-mobile/Preferences.qml @@ -50,6 +50,7 @@ Item { } CheckBox { + checked: manager.saveCloudPassword id: savePassword } @@ -63,6 +64,7 @@ Item { onClicked: { manager.cloudUserName = login.text manager.cloudPassword = password.text + manager.saveCloudPassword = savePassword.checked manager.savePreferences() stackView.pop() } diff --git a/qt-mobile/qmlmanager.cpp b/qt-mobile/qmlmanager.cpp index a1c64191b..8cefbe95f 100644 --- a/qt-mobile/qmlmanager.cpp +++ b/qt-mobile/qmlmanager.cpp @@ -20,6 +20,7 @@ QMLManager::QMLManager() //Initialize cloud credentials. setCloudUserName(prefs.cloud_storage_email); setCloudPassword(prefs.cloud_storage_password); + setSaveCloudPassword(prefs.save_password_local); } QMLManager::~QMLManager() @@ -31,15 +32,22 @@ void QMLManager::savePreferences() QSettings s; s.beginGroup("CloudStorage"); s.setValue("email", cloudUserName()); - s.setValue("password", cloudPassword()); + s.setValue("save_password_local", saveCloudPassword()); + if (saveCloudPassword()) + s.setValue("password", cloudPassword()); s.sync(); if (!same_string(prefs.cloud_storage_email, qPrintable(cloudUserName()))) { free(prefs.cloud_storage_email); prefs.cloud_storage_email = strdup(qPrintable(cloudUserName())); } - if (!same_string(prefs.cloud_storage_password, qPrintable(cloudPassword()))) { - free(prefs.cloud_storage_password); - prefs.cloud_storage_password = strdup(qPrintable(cloudPassword())); + if (saveCloudPassword() != prefs.save_password_local) { + prefs.save_password_local = saveCloudPassword(); + } + if (saveCloudPassword()) { + if (!same_string(prefs.cloud_storage_password, qPrintable(cloudPassword()))) { + free(prefs.cloud_storage_password); + prefs.cloud_storage_password = strdup(qPrintable(cloudPassword())); + } } } @@ -114,6 +122,16 @@ void QMLManager::saveChanges() set_filename(fileName.toUtf8().data(), true); mark_divelist_changed(false); } +bool QMLManager::saveCloudPassword() const +{ + return m_saveCloudPassword; +} + +void QMLManager::setSaveCloudPassword(bool saveCloudPassword) +{ + m_saveCloudPassword = saveCloudPassword; +} + QString QMLManager::cloudPassword() const { diff --git a/qt-mobile/qmlmanager.h b/qt-mobile/qmlmanager.h index 2f5ac2894..0f1df2b59 100644 --- a/qt-mobile/qmlmanager.h +++ b/qt-mobile/qmlmanager.h @@ -9,6 +9,7 @@ class QMLManager : public QObject Q_OBJECT Q_PROPERTY(QString cloudUserName READ cloudUserName WRITE setCloudUserName NOTIFY cloudUserNameChanged) Q_PROPERTY(QString cloudPassword READ cloudPassword WRITE setCloudPassword NOTIFY cloudPasswordChanged) + Q_PROPERTY(bool saveCloudPassword READ saveCloudPassword WRITE setSaveCloudPassword NOTIFY saveCloudPasswordChanged) public: QMLManager(); ~QMLManager(); @@ -19,6 +20,9 @@ public: QString cloudPassword() const; void setCloudPassword(const QString &cloudPassword); + bool saveCloudPassword() const; + void setSaveCloudPassword(bool saveCloudPassword); + public slots: void savePreferences(); void loadDives(); @@ -27,10 +31,12 @@ public slots: private: QString m_cloudUserName; QString m_cloudPassword; + bool m_saveCloudPassword; signals: void cloudUserNameChanged(); void cloudPasswordChanged(); + void saveCloudPasswordChanged(); }; #endif |