diff options
author | Tomaz Canabrava <tomaz.canabrava@intel.com> | 2015-01-08 10:12:11 -0200 |
---|---|---|
committer | Dirk Hohndel <dirk@hohndel.org> | 2015-01-08 07:40:33 -0800 |
commit | db367ae0a28088be9438e1479c97da14e4b5737c (patch) | |
tree | fa785c6d0b7985f6b413f63aecb7ddf660eef253 /qt-ui | |
parent | 5f4770a5bd361b2bf0675f3e0de869242861f8e3 (diff) | |
download | subsurface-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>
Diffstat (limited to 'qt-ui')
-rw-r--r-- | qt-ui/downloadfromdivecomputer.cpp | 65 | ||||
-rw-r--r-- | qt-ui/downloadfromdivecomputer.h | 16 |
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(); |