From ad66297cfd843199f39e3a231cb8311652ea183c Mon Sep 17 00:00:00 2001 From: Dirk Hohndel Date: Sun, 19 Apr 2020 12:39:59 -0700 Subject: desktop: remove user survey We have never made good use of the results. Let's just remove it. Signed-off-by: Dirk Hohndel --- desktop-widgets/CMakeLists.txt | 3 - desktop-widgets/mainwindow.cpp | 33 ------ desktop-widgets/mainwindow.h | 3 - desktop-widgets/mainwindow.ui | 6 - desktop-widgets/subsurfacewebservices.cpp | 15 --- desktop-widgets/subsurfacewebservices.h | 7 -- desktop-widgets/usersurvey.cpp | 134 --------------------- desktop-widgets/usersurvey.h | 31 ----- desktop-widgets/usersurvey.ui | 191 ------------------------------ 9 files changed, 423 deletions(-) delete mode 100644 desktop-widgets/usersurvey.cpp delete mode 100644 desktop-widgets/usersurvey.h delete mode 100644 desktop-widgets/usersurvey.ui (limited to 'desktop-widgets') diff --git a/desktop-widgets/CMakeLists.txt b/desktop-widgets/CMakeLists.txt index 82a81321e..499dd27b9 100644 --- a/desktop-widgets/CMakeLists.txt +++ b/desktop-widgets/CMakeLists.txt @@ -43,7 +43,6 @@ set (SUBSURFACE_UI tableview.ui templateedit.ui urldialog.ui - usersurvey.ui webservices.ui tab-widgets/maintab.ui tab-widgets/TabDiveStatistics.ui @@ -130,8 +129,6 @@ set(SUBSURFACE_INTERFACE textedit.h updatemanager.cpp updatemanager.h - usersurvey.cpp - usersurvey.h ) if(NOT NO_USERMANUAL) diff --git a/desktop-widgets/mainwindow.cpp b/desktop-widgets/mainwindow.cpp index e7416fe89..d81a2f914 100644 --- a/desktop-widgets/mainwindow.cpp +++ b/desktop-widgets/mainwindow.cpp @@ -51,7 +51,6 @@ #include "desktop-widgets/subsurfacewebservices.h" #include "desktop-widgets/tab-widgets/maintab.h" #include "desktop-widgets/updatemanager.h" -#include "desktop-widgets/usersurvey.h" #include "desktop-widgets/simplewidgets.h" #include "commands/command.h" @@ -125,7 +124,6 @@ MainWindow::MainWindow() : QMainWindow(), helpView(0), #endif state(VIEWALL), - survey(nullptr), findMovedImagesDialog(nullptr) { Q_ASSERT_X(m_Instance == NULL, "MainWindow", "MainWindow recreated!"); @@ -1177,13 +1175,6 @@ void MainWindow::on_actionUserManual_triggered() #endif } -void MainWindow::on_actionUserSurvey_triggered() -{ - if(!survey) - survey = new UserSurvey(this); - survey->show(); -} - void MainWindow::on_actionHash_images_triggered() { if(!findMovedImagesDialog) @@ -1333,40 +1324,16 @@ void MainWindow::initialUiSetup() void MainWindow::readSettings() { - static bool firstRun = true; init_proxy(); // now make sure that the cloud menu items are enabled IFF cloud account is verified enableDisableCloudActions(); loadRecentFiles(); - if (firstRun) { - checkSurvey(); - firstRun = false; - } } #undef TOOLBOX_PREF_BUTTON -void MainWindow::checkSurvey() -{ - QSettings s; - s.beginGroup("UserSurvey"); - if (!s.contains("FirstUse42")) { - QVariant value = QDate().currentDate(); - s.setValue("FirstUse42", value); - } - // wait a week for production versions, but not at all for non-tagged builds - int waitTime = 7; - QDate firstUse42 = s.value("FirstUse42").toDate(); - if (run_survey || (firstUse42.daysTo(QDate().currentDate()) > waitTime && !s.contains("SurveyDone"))) { - if (!survey) - survey = new UserSurvey(this); - survey->show(); - } - s.endGroup(); -} - void MainWindow::writeSettings() { QSettings settings; diff --git a/desktop-widgets/mainwindow.h b/desktop-widgets/mainwindow.h index 1fb20a7ce..ec09e7223 100644 --- a/desktop-widgets/mainwindow.h +++ b/desktop-widgets/mainwindow.h @@ -74,7 +74,6 @@ public: void importFiles(const QStringList importFiles); void setToolButtonsEnabled(bool enabled); void printPlan(); - void checkSurvey(); void setApplicationState(ApplicationState state); bool inPlanner(); NotificationWidget *getNotificationWidget(); @@ -127,7 +126,6 @@ slots: /* other menu actions */ void on_actionAboutSubsurface_triggered(); void on_actionUserManual_triggered(); - void on_actionUserSurvey_triggered(); void on_actionDivePlanner_triggered(); void on_actionReplanDive_triggered(); void on_action_Check_for_Updates_triggered(); @@ -217,7 +215,6 @@ private: void setupForAddAndPlan(const char *model); void configureToolbar(); void setupSocialNetworkMenu(); - QDialog *survey; QDialog *findMovedImagesDialog; struct dive copyPasteDive; struct dive_components what; diff --git a/desktop-widgets/mainwindow.ui b/desktop-widgets/mainwindow.ui index 3e839e51b..5b9e318f5 100644 --- a/desktop-widgets/mainwindow.ui +++ b/desktop-widgets/mainwindow.ui @@ -121,7 +121,6 @@ - @@ -659,11 +658,6 @@ Toggle tissue heat-map - - - User &survey - - &Undo diff --git a/desktop-widgets/subsurfacewebservices.cpp b/desktop-widgets/subsurfacewebservices.cpp index 80a17af2a..d016a9dc6 100644 --- a/desktop-widgets/subsurfacewebservices.cpp +++ b/desktop-widgets/subsurfacewebservices.cpp @@ -4,7 +4,6 @@ #include "core/webservice.h" #include "core/settings/qPrefCloudStorage.h" #include "desktop-widgets/mainwindow.h" -#include "desktop-widgets/usersurvey.h" #include "commands/command.h" #include "core/trip.h" #include "core/errorhelper.h" @@ -478,17 +477,3 @@ void DivelogsDeWebServices::buttonClicked(QAbstractButton *button) break; } } - -UserSurveyServices::UserSurveyServices(QWidget *parent, Qt::WindowFlags f) : QDialog(parent, f) -{ -} - -QNetworkReply *UserSurveyServices::sendSurvey(QString values) -{ - QNetworkRequest request; - request.setUrl(QString("http://subsurface-divelog.org/survey?%1").arg(values)); - request.setRawHeader("Accept", "text/xml"); - request.setRawHeader("User-Agent", getUserAgent().toUtf8()); - QNetworkReply *reply = manager()->get(request); - return reply; -} diff --git a/desktop-widgets/subsurfacewebservices.h b/desktop-widgets/subsurfacewebservices.h index 8f515e27c..e9b593005 100644 --- a/desktop-widgets/subsurfacewebservices.h +++ b/desktop-widgets/subsurfacewebservices.h @@ -76,11 +76,4 @@ private: bool useSelectedDives; }; -class UserSurveyServices : public QDialog { - Q_OBJECT -public: - QNetworkReply* sendSurvey(QString values); - explicit UserSurveyServices(QWidget *parent = 0, Qt::WindowFlags f = 0); -}; - #endif // SUBSURFACEWEBSERVICES_H diff --git a/desktop-widgets/usersurvey.cpp b/desktop-widgets/usersurvey.cpp deleted file mode 100644 index 9f237abea..000000000 --- a/desktop-widgets/usersurvey.cpp +++ /dev/null @@ -1,134 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 -#include -#include -#include - -#include "desktop-widgets/usersurvey.h" -#include "ui_usersurvey.h" -#include "core/version.h" -#include "desktop-widgets/subsurfacewebservices.h" -#include "desktop-widgets/updatemanager.h" - -#include "core/qthelper.h" -#include "core/subsurfacesysinfo.h" - -UserSurvey::UserSurvey(QWidget *parent) : QDialog(parent), - ui(new Ui::UserSurvey) -{ - ui->setupUi(this); - ui->buttonBox->buttons().first()->setText(tr("Send")); - this->adjustSize(); - QShortcut *closeKey = new QShortcut(QKeySequence(Qt::CTRL + Qt::Key_W), this); - connect(closeKey, SIGNAL(activated()), this, SLOT(close())); - QShortcut *quitKey = new QShortcut(QKeySequence(Qt::CTRL + Qt::Key_Q), this); - connect(quitKey, SIGNAL(activated()), parent, SLOT(close())); - - os = QString("ssrfVers=%1").arg(subsurface_canonical_version()); - os.append(QString("&prettyOsName=%1").arg(SubsurfaceSysInfo::prettyOsName())); - QString arch = SubsurfaceSysInfo::buildCpuArchitecture(); - os.append(QString("&appCpuArch=%1").arg(arch)); - if (arch == "i386") { - QString osArch = SubsurfaceSysInfo::currentCpuArchitecture(); - os.append(QString("&osCpuArch=%1").arg(osArch)); - } - os.append(QString("&uiLang=%1").arg(getUiLanguage())); - os.append(QString("&uuid=%1").arg(getUUID())); - ui->system->setPlainText(getVersion()); -} - -QString UserSurvey::getVersion() -{ - QString arch; - // fill in the system data - QString sysInfo = QString("Subsurface %1").arg(subsurface_canonical_version()); - sysInfo.append(tr("\nOperating system: %1").arg(SubsurfaceSysInfo::prettyOsName())); - arch = SubsurfaceSysInfo::buildCpuArchitecture(); - sysInfo.append(tr("\nCPU architecture: %1").arg(arch)); - if (arch == "i386") - sysInfo.append(tr("\nOS CPU architecture: %1").arg(SubsurfaceSysInfo::currentCpuArchitecture())); - sysInfo.append(tr("\nLanguage: %1").arg(getUiLanguage())); - return sysInfo; -} - -UserSurvey::~UserSurvey() -{ - delete ui; -} - -#define ADD_OPTION(_name) values.append(ui->_name->isChecked() ? "&" #_name "=1" : "&" #_name "=0") - -void UserSurvey::on_buttonBox_accepted() -{ - // now we need to collect the data and submit it - QString values = os; - ADD_OPTION(recreational); - ADD_OPTION(tech); - ADD_OPTION(planning); - ADD_OPTION(download); - ADD_OPTION(divecomputer); - ADD_OPTION(manual); - ADD_OPTION(companion); - values.append(QString("&suggestion=%1").arg(ui->suggestions->toPlainText())); - UserSurveyServices uss(this); - connect(uss.sendSurvey(values), SIGNAL(finished()), SLOT(requestReceived())); - hide(); -} - -void UserSurvey::on_buttonBox_rejected() -{ - QMessageBox response(this); - response.setText(tr("Should we ask you later?")); - response.addButton(tr("Don't ask me again"), QMessageBox::RejectRole); - response.addButton(tr("Ask later"), QMessageBox::AcceptRole); - response.setWindowTitle(tr("Ask again?")); // Not displayed on MacOSX as described in Qt API - response.setIcon(QMessageBox::Question); - response.setWindowModality(Qt::WindowModal); - switch (response.exec()) { - case QDialog::Accepted: - // nothing to do here, we'll just ask again the next time they start - break; - case QDialog::Rejected: - QSettings s; - s.beginGroup("UserSurvey"); - s.setValue("SurveyDone", "declined"); - break; - } - hide(); -} - -void UserSurvey::requestReceived() -{ - QMessageBox msgbox; - QString msgTitle = tr("Submit user survey."); - QString msgText = "

" + tr("Subsurface was unable to submit the user survey.") + "

"; - - QNetworkReply *reply = qobject_cast(sender()); - if (reply->error() != QNetworkReply::NoError) { - //Network Error - msgText = msgText + "
" + tr("The following error occurred:") + "
" + reply->errorString() - + "

" + tr("Please check your internet connection.") + ""; - } else { - //No network error - QString response(reply->readAll()); - QString responseBody = response.split("\"").at(1); - - msgbox.setIcon(QMessageBox::Information); - - if (responseBody == "OK") { - msgText = tr("Survey successfully submitted."); - QSettings s; - s.beginGroup("UserSurvey"); - s.setValue("SurveyDone", "submitted"); - } else { - msgText = tr("There was an error while trying to check for updates.

%1").arg(responseBody); - msgbox.setIcon(QMessageBox::Warning); - } - } - - msgbox.setWindowTitle(msgTitle); - msgbox.setWindowIcon(QIcon(":subsurface-icon")); - msgbox.setText(msgText); - msgbox.setTextFormat(Qt::RichText); - msgbox.exec(); - reply->deleteLater(); -} diff --git a/desktop-widgets/usersurvey.h b/desktop-widgets/usersurvey.h deleted file mode 100644 index 32acfa87b..000000000 --- a/desktop-widgets/usersurvey.h +++ /dev/null @@ -1,31 +0,0 @@ -// SPDX-License-Identifier: GPL-2.0 -#ifndef USERSURVEY_H -#define USERSURVEY_H - -#include -class QNetworkAccessManager; -class QNetworkReply; - -namespace Ui { - class UserSurvey; -} - -class UserSurvey : public QDialog { - Q_OBJECT - -public: - explicit UserSurvey(QWidget *parent = 0); - ~UserSurvey(); - static QString getVersion(); - -private -slots: - void on_buttonBox_accepted(); - void on_buttonBox_rejected(); - void requestReceived(); - -private: - Ui::UserSurvey *ui; - QString os; -}; -#endif // USERSURVEY_H diff --git a/desktop-widgets/usersurvey.ui b/desktop-widgets/usersurvey.ui deleted file mode 100644 index c509fd2a7..000000000 --- a/desktop-widgets/usersurvey.ui +++ /dev/null @@ -1,191 +0,0 @@ - - - UserSurvey - - - - 0 - 0 - 538 - 714 - - - - User survey - - - - - - <html><head/><body><p>We would love to learn more about our users, their preferences and their usage habits. Please spare a minute to fill out this form and submit it to the Subsurface team.</p></body></html> - - - Qt::AlignLeading|Qt::AlignLeft|Qt::AlignVCenter - - - true - - - - - - - Qt::Horizontal - - - - - - - What kind of diver are you? - - - - - - - Technical diver - - - - - - - Recreational diver - - - - - - - Dive planner - - - - - - - Qt::Horizontal - - - - - - - Where are you importing data from? - - - - - - - Supported dive computer - - - - - - - Other software/sources - - - - - - - Manually entering dives - - - - - - - Android/iPhone companion app - - - - - - - Qt::Horizontal - - - - - - - Any suggestions? (in English) - - - - - - - - - - The following information about your system will also be submitted. - - - true - - - - - - - - 0 - 0 - - - - true - - - - - - - Qt::TabFocus - - - Qt::Horizontal - - - QDialogButtonBox::Cancel|QDialogButtonBox::Save - - - - - - - - 11 - - - - Subsurface user survey - - - Qt::AlignCenter - - - - - - - tech - recreational - planning - download - divecomputer - manual - companion - suggestions - system - buttonBox - - - - -- cgit v1.2.3-70-g09d2