aboutsummaryrefslogtreecommitdiffstats
path: root/qt-models
diff options
context:
space:
mode:
Diffstat (limited to 'qt-models')
-rw-r--r--qt-models/divelistmodel.cpp81
-rw-r--r--qt-models/divelistmodel.h27
2 files changed, 21 insertions, 87 deletions
diff --git a/qt-models/divelistmodel.cpp b/qt-models/divelistmodel.cpp
index e812f3df7..e6514064f 100644
--- a/qt-models/divelistmodel.cpp
+++ b/qt-models/divelistmodel.cpp
@@ -12,15 +12,15 @@ DiveListModel::DiveListModel(QObject *parent) : QAbstractListModel(parent)
void DiveListModel::addDive(dive *d)
{
beginInsertRows(QModelIndex(), rowCount(), rowCount());
- m_dives.append(Dive(d));
+ m_dives.append(new DiveObjectHelper(d));
endInsertRows();
}
void DiveListModel::updateDive(dive *d)
{
for (int i = 0; i < m_dives.count(); i++) {
- if (m_dives.at(i).id() == d->id) {
- Dive newDive(d);
+ if (m_dives.at(i)->id() == d->id) {
+ DiveObjectHelper *newDive = new DiveObjectHelper(d);
m_dives.replace(i, newDive);
break;
}
@@ -31,6 +31,7 @@ void DiveListModel::clear()
{
if (m_dives.count()) {
beginRemoveRows(QModelIndex(), 0, m_dives.count() - 1);
+ qDeleteAll(m_dives);
m_dives.clear();
endRemoveRows();
}
@@ -46,76 +47,20 @@ QVariant DiveListModel::data(const QModelIndex &index, int role) const
if(index.row() < 0 || index.row() > m_dives.count())
return QVariant();
- const Dive &dive = m_dives[index.row()];
-
- if (role == DiveNumberRole)
- return dive.number();
- else if (role == DiveTripRole)
- return dive.trip();
- else if (role == DiveDateRole)
- return (qlonglong)dive.timestamp();
- else if (role == DiveDateStringRole)
- return dive.date() + " " + dive.time();
- else if (role == DiveRatingRole)
- return QString::number(dive.rating());
- else if (role == DiveDepthRole)
- return dive.depth();
- else if (role == DiveDurationRole)
- return dive.duration();
- else if (role == DiveAirTemperatureRole)
- return dive.airTemp();
- else if (role == DiveWaterTemperatureRole)
- return dive.waterTemp();
- else if (role == DiveWeightRole)
- return dive.weight(0);
- else if (role == DiveSuitRole)
- return dive.suit();
- else if (role == DiveCylinderRole)
- return dive.cylinder(0);
- else if (role == DiveGasRole)
- return dive.gas();
- else if (role == DiveSacRole)
- return dive.sac();
- else if (role == DiveLocationRole)
- return dive.location();
- else if (role == DiveGPSRole)
- return dive.gps();
- else if (role == DiveNotesRole)
- return dive.notes();
- else if (role == DiveBuddyRole)
- return dive.buddy();
- else if (role == DiveMasterRole)
- return dive.divemaster();
- else if (role == DiveIdRole)
- return QString::number(dive.id());
+ DiveObjectHelper *curr_dive = m_dives[index.row()];
+ switch(role) {
+ case DiveRole: return QVariant::fromValue<QObject*>(curr_dive);
+ case DiveDateRole: return (qlonglong)curr_dive->timestamp();
+ }
return QVariant();
-
}
QHash<int, QByteArray> DiveListModel::roleNames() const
{
QHash<int, QByteArray> roles;
- roles[DiveNumberRole] = "diveNumber";
- roles[DiveTripRole] = "trip";
- roles[DiveDateStringRole] = "date";
- roles[DiveRatingRole] = "rating";
- roles[DiveDepthRole] = "depth";
- roles[DiveDurationRole] = "duration";
- roles[DiveAirTemperatureRole] = "airtemp";
- roles[DiveWaterTemperatureRole] = "watertemp";
- roles[DiveWeightRole] = "weight";
- roles[DiveSuitRole] = "suit";
- roles[DiveCylinderRole] = "cylinder";
- roles[DiveGasRole] = "gas";
- roles[DiveSacRole] = "sac";
- roles[DiveLocationRole] = "location";
- roles[DiveGPSRole] = "gps";
- roles[DiveNotesRole] = "notes";
- roles[DiveBuddyRole] = "buddy";
- roles[DiveMasterRole] = "divemaster";
- roles[DiveIdRole] = "id";
-
+ roles[DiveRole] = "dive";
+ roles[DiveDateRole] = "date";
return roles;
}
@@ -140,3 +85,7 @@ DiveListModel *DiveListModel::instance()
{
return m_instance;
}
+
+DiveObjectHelper* DiveListModel::at(int i){
+ return m_dives.at(i);
+} \ No newline at end of file
diff --git a/qt-models/divelistmodel.h b/qt-models/divelistmodel.h
index f050faab3..5265cd1b0 100644
--- a/qt-models/divelistmodel.h
+++ b/qt-models/divelistmodel.h
@@ -2,8 +2,10 @@
#define DIVELISTMODEL_H
#include <QAbstractListModel>
+
#include "dive.h"
#include "helpers.h"
+#include "subsurface-qt/DiveObjectHelper.h"
class DiveListModel : public QAbstractListModel
{
@@ -11,26 +13,8 @@ class DiveListModel : public QAbstractListModel
public:
enum DiveListRoles {
- DiveNumberRole = Qt::UserRole + 1,
- DiveTripRole,
- DiveDateRole,
- DiveDateStringRole,
- DiveRatingRole,
- DiveDepthRole,
- DiveDurationRole,
- DiveWaterTemperatureRole,
- DiveAirTemperatureRole,
- DiveWeightRole,
- DiveSuitRole,
- DiveCylinderRole,
- DiveGasRole,
- DiveSacRole,
- DiveLocationRole,
- DiveGPSRole,
- DiveNotesRole,
- DiveBuddyRole,
- DiveMasterRole,
- DiveIdRole
+ DiveRole = Qt::UserRole + 1,
+ DiveDateRole
};
static DiveListModel *instance();
@@ -42,8 +26,9 @@ public:
QVariant data(const QModelIndex &index, int role = Qt::DisplayRole) const;
QHash<int, QByteArray> roleNames() const;
QString startAddDive();
+ Q_INVOKABLE DiveObjectHelper* at(int i);
private:
- QList<Dive> m_dives;
+ QList<DiveObjectHelper*> m_dives;
static DiveListModel *m_instance;
};