summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorGravatar Tomaz Canabrava <tomaz.canabrava@intel.com>2015-01-08 10:12:11 -0200
committerGravatar Dirk Hohndel <dirk@hohndel.org>2015-01-08 07:40:33 -0800
commitdb367ae0a28088be9438e1479c97da14e4b5737c (patch)
treefa785c6d0b7985f6b413f63aecb7ddf660eef253
parent5f4770a5bd361b2bf0675f3e0de869242861f8e3 (diff)
downloadsubsurface-db367ae0a28088be9438e1479c97da14e4b5737c.tar.gz
Dive d/l selection UI:: Add skeleton for the dialog
So the user can remove the ones they don't like. Signed-off-by: Tomaz Canabrava <tomaz.canabrava@intel.com> Signed-off-by: Dirk Hohndel <dirk@hohndel.org>
-rw-r--r--qt-ui/downloadfromdivecomputer.cpp65
-rw-r--r--qt-ui/downloadfromdivecomputer.h16
2 files changed, 64 insertions, 17 deletions
diff --git a/qt-ui/downloadfromdivecomputer.cpp b/qt-ui/downloadfromdivecomputer.cpp
index 7f5fd4a46..b359aa5dc 100644
--- a/qt-ui/downloadfromdivecomputer.cpp
+++ b/qt-ui/downloadfromdivecomputer.cpp
@@ -53,6 +53,7 @@ DownloadFromDCWidget::DownloadFromDCWidget(QWidget *parent, Qt::WindowFlags f) :
ui.progressBar->hide();
ui.progressBar->setMinimum(0);
ui.progressBar->setMaximum(100);
+ diveImportedModel = new DiveImportedModel(this);
progress_bar_text = "";
@@ -388,23 +389,7 @@ void DownloadFromDCWidget::onDownloadThreadFinished()
for (int i = dive_table.nr - 1; i >= previousLast; i--)
delete_single_dive(i);
} else if (dive_table.nr) {
- int uniqId, idx;
- // remember the last downloaded dive (on most dive computers this will be the chronologically
- // first new dive) and select it again after processing all the dives
- MainWindow::instance()->dive_list()->unselectDives();
- uniqId = get_dive(dive_table.nr - 1)->id;
- process_dives(true, preferDownloaded());
- // after process_dives does any merging or resorting needed, we need
- // to recreate the model for the dive list so we can select the newest dive
- MainWindow::instance()->recreateDiveList();
- idx = get_idx_by_uniq_id(uniqId);
- // this shouldn't be necessary - but there are reports that somehow existing dives stay selected
- // (but not visible as selected)
- MainWindow::instance()->dive_list()->unselectDives();
- MainWindow::instance()->dive_list()->selectDive(idx, true);
- QString dcName = data.devname;
- if (ostcFirmwareCheck && currentState == DONE)
- ostcFirmwareCheck->checkLatest(this, &data);
+ diveImportedModel->setImportedDivesIndexes(previousLast, dive_table.nr-1);
}
} else if (currentState == CANCELLING || currentState == CANCELLED) {
if (import_thread_cancelled) {
@@ -416,6 +401,27 @@ void DownloadFromDCWidget::onDownloadThreadFinished()
updateState(CANCELLED);
}
}
+/*
+ * This needs to get moved somewhere else.
+ int uniqId, idx;
+ // remember the last downloaded dive (on most dive computers this will be the chronologically
+ // first new dive) and select it again after processing all the dives
+ MainWindow::instance()->dive_list()->unselectDives();
+ uniqId = get_dive(dive_table.nr - 1)->id;
+ process_dives(true, preferDownloaded());
+ // after process_dives does any merging or resorting needed, we need
+ // to recreate the model for the dive list so we can select the newest dive
+ MainWindow::instance()->recreateDiveList();
+ idx = get_idx_by_uniq_id(uniqId);
+ // this shouldn't be necessary - but there are reports that somehow existing dives stay selected
+ // (but not visible as selected)
+ MainWindow::instance()->dive_list()->unselectDives();
+ MainWindow::instance()->dive_list()->selectDive(idx, true);
+ QString dcName = data.devname;
+ if (ostcFirmwareCheck && currentState == DONE)
+ ostcFirmwareCheck->checkLatest(this, &data);
+
+*/
void DownloadFromDCWidget::markChildrenAsDisabled()
{
@@ -491,3 +497,28 @@ void DownloadThread::run()
if (errorText)
error = str_error(errorText, data->devname, data->vendor, data->product);
}
+
+DiveImportedModel::DiveImportedModel(QObject *o)
+{
+
+}
+
+int DiveImportedModel::columnCount(const QModelIndex& model ) const
+{
+
+}
+
+int DiveImportedModel::rowCount(const QModelIndex& model) const
+{
+
+}
+
+QVariant DiveImportedModel::data(const QModelIndex& model, int role) const
+{
+
+}
+
+void DiveImportedModel::setImportedDivesIndexes(int first, int last)
+{
+
+}
diff --git a/qt-ui/downloadfromdivecomputer.h b/qt-ui/downloadfromdivecomputer.h
index dcb568c9e..799b0c991 100644
--- a/qt-ui/downloadfromdivecomputer.h
+++ b/qt-ui/downloadfromdivecomputer.h
@@ -5,6 +5,7 @@
#include <QThread>
#include <QHash>
#include <QMap>
+#include <QAbstractTableModel>
#include "libdivecomputer.h"
#include "configuredivecomputerdialog.h"
@@ -24,6 +25,20 @@ private:
device_data_t *data;
};
+class DiveImportedModel : public QAbstractTableModel
+{
+ Q_OBJECT
+public:
+ DiveImportedModel(QObject *o);
+ int columnCount(const QModelIndex& index = QModelIndex()) const;
+ int rowCount(const QModelIndex& index = QModelIndex()) const;
+ QVariant data(const QModelIndex& index, int role) const;
+ void setImportedDivesIndexes(int first, int last);
+private:
+ int firstIndex;
+ int lastIndex;
+};
+
class DownloadFromDCWidget : public QDialog {
Q_OBJECT
public:
@@ -77,6 +92,7 @@ private:
QTimer *timer;
bool dumpWarningShown;
OstcFirmwareCheck *ostcFirmwareCheck;
+ DiveImportedModel *diveImportedModel;
public:
bool preferDownloaded();