2017-04-27 20:25:32 +02:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
2016-04-04 22:02:03 -07:00
|
|
|
#include "qt-models/divelistmodel.h"
|
2018-06-03 22:15:19 +02:00
|
|
|
#include "core/qthelper.h"
|
2015-12-26 21:34:45 -08:00
|
|
|
#include <QDateTime>
|
2015-06-09 22:20:44 +03:00
|
|
|
|
2016-01-28 18:23:14 -08:00
|
|
|
DiveListSortModel::DiveListSortModel(QObject *parent) : QSortFilterProxyModel(parent)
|
|
|
|
{
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
int DiveListSortModel::getDiveId(int idx)
|
|
|
|
{
|
|
|
|
DiveListModel *mySourceModel = qobject_cast<DiveListModel *>(sourceModel());
|
|
|
|
return mySourceModel->getDiveId(mapToSource(index(idx,0)).row());
|
|
|
|
}
|
|
|
|
|
|
|
|
int DiveListSortModel::getIdxForId(int id)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < rowCount(); i++) {
|
|
|
|
QVariant v = data(index(i, 0), DiveListModel::DiveRole);
|
|
|
|
DiveObjectHelper *d = v.value<DiveObjectHelper *>();
|
|
|
|
if (d->id() == id)
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2017-05-28 11:48:30 -07:00
|
|
|
void DiveListSortModel::clear()
|
|
|
|
{
|
|
|
|
DiveListModel *mySourceModel = qobject_cast<DiveListModel *>(sourceModel());
|
|
|
|
mySourceModel->clear();
|
|
|
|
}
|
|
|
|
|
|
|
|
void DiveListSortModel::addAllDives()
|
|
|
|
{
|
|
|
|
DiveListModel *mySourceModel = qobject_cast<DiveListModel *>(sourceModel());
|
|
|
|
mySourceModel->addAllDives();
|
|
|
|
}
|
|
|
|
|
2015-06-09 22:20:44 +03:00
|
|
|
DiveListModel *DiveListModel::m_instance = NULL;
|
|
|
|
|
|
|
|
DiveListModel::DiveListModel(QObject *parent) : QAbstractListModel(parent)
|
|
|
|
{
|
|
|
|
m_instance = this;
|
|
|
|
}
|
|
|
|
|
2016-04-05 21:17:37 -07:00
|
|
|
void DiveListModel::addDive(QList<dive *>listOfDives)
|
2015-06-09 22:20:44 +03:00
|
|
|
{
|
2016-04-05 21:17:37 -07:00
|
|
|
if (listOfDives.isEmpty())
|
|
|
|
return;
|
|
|
|
beginInsertRows(QModelIndex(), rowCount(), rowCount() + listOfDives.count() - 1);
|
|
|
|
foreach (dive *d, listOfDives) {
|
|
|
|
m_dives.append(new DiveObjectHelper(d));
|
|
|
|
}
|
2015-06-09 22:20:44 +03:00
|
|
|
endInsertRows();
|
|
|
|
}
|
|
|
|
|
2016-04-05 21:17:37 -07:00
|
|
|
void DiveListModel::addAllDives()
|
|
|
|
{
|
|
|
|
QList<dive *>listOfDives;
|
|
|
|
int i;
|
|
|
|
struct dive *d;
|
|
|
|
for_each_dive (i, d)
|
|
|
|
listOfDives.append(d);
|
|
|
|
addDive(listOfDives);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
2016-01-27 11:27:41 -08:00
|
|
|
void DiveListModel::insertDive(int i, DiveObjectHelper *newDive)
|
|
|
|
{
|
|
|
|
beginInsertRows(QModelIndex(), i, i);
|
|
|
|
m_dives.insert(i, newDive);
|
|
|
|
endInsertRows();
|
|
|
|
}
|
|
|
|
|
|
|
|
void DiveListModel::removeDive(int i)
|
|
|
|
{
|
|
|
|
beginRemoveRows(QModelIndex(), i, i);
|
2018-01-07 10:53:13 +01:00
|
|
|
delete m_dives.at(i);
|
2016-01-27 11:27:41 -08:00
|
|
|
m_dives.removeAt(i);
|
|
|
|
endRemoveRows();
|
|
|
|
}
|
|
|
|
|
2016-01-29 06:25:13 -08:00
|
|
|
void DiveListModel::removeDiveById(int id)
|
|
|
|
{
|
|
|
|
for (int i = 0; i < rowCount(); i++) {
|
|
|
|
if (m_dives.at(i)->id() == id) {
|
|
|
|
removeDive(i);
|
|
|
|
return;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2016-01-27 11:50:04 -08:00
|
|
|
void DiveListModel::updateDive(int i, dive *d)
|
|
|
|
{
|
|
|
|
DiveObjectHelper *newDive = new DiveObjectHelper(d);
|
2018-06-25 16:39:56 +08:00
|
|
|
// we need to make sure that QML knows that this dive has changed -
|
|
|
|
// the only reliable way I've found is to remove and re-insert it
|
|
|
|
removeDive(i);
|
|
|
|
insertDive(i, newDive);
|
2015-12-07 22:23:09 -08:00
|
|
|
}
|
|
|
|
|
2015-11-30 10:09:46 -08:00
|
|
|
void DiveListModel::clear()
|
|
|
|
{
|
2015-12-03 21:22:18 +01:00
|
|
|
if (m_dives.count()) {
|
|
|
|
beginRemoveRows(QModelIndex(), 0, m_dives.count() - 1);
|
2016-01-07 16:01:24 -02:00
|
|
|
qDeleteAll(m_dives);
|
2015-12-03 21:22:18 +01:00
|
|
|
m_dives.clear();
|
|
|
|
endRemoveRows();
|
|
|
|
}
|
2015-11-30 10:09:46 -08:00
|
|
|
}
|
|
|
|
|
2018-01-07 16:08:25 +01:00
|
|
|
void DiveListModel::resetInternalData()
|
|
|
|
{
|
|
|
|
// this is a hack. There is a long standing issue, that seems related to a
|
|
|
|
// sync problem between QML engine and underlying model data. It causes delete
|
|
|
|
// from divelist (on mobile) to crash. But not always. This function is part of
|
|
|
|
// an attempt to fix this. See commit.
|
|
|
|
beginResetModel();
|
|
|
|
endResetModel();
|
|
|
|
}
|
|
|
|
|
2015-06-09 22:20:44 +03:00
|
|
|
int DiveListModel::rowCount(const QModelIndex &) const
|
|
|
|
{
|
|
|
|
return m_dives.count();
|
|
|
|
}
|
|
|
|
|
2016-01-28 18:23:14 -08:00
|
|
|
int DiveListModel::getDiveId(int idx) const
|
|
|
|
{
|
|
|
|
if (idx < 0 || idx >= m_dives.count())
|
|
|
|
return -1;
|
|
|
|
return m_dives[idx]->id();
|
|
|
|
}
|
|
|
|
|
2016-03-02 04:41:36 -08:00
|
|
|
int DiveListModel::getDiveIdx(int id) const
|
|
|
|
{
|
|
|
|
int i;
|
|
|
|
for (i = 0; i < m_dives.count(); i++) {
|
|
|
|
if (m_dives.at(i)->id() == id)
|
|
|
|
return i;
|
|
|
|
}
|
|
|
|
return -1;
|
|
|
|
}
|
|
|
|
|
2015-06-09 22:20:44 +03:00
|
|
|
QVariant DiveListModel::data(const QModelIndex &index, int role) const
|
|
|
|
{
|
|
|
|
if(index.row() < 0 || index.row() > m_dives.count())
|
|
|
|
return QVariant();
|
|
|
|
|
2016-01-07 16:01:24 -02:00
|
|
|
DiveObjectHelper *curr_dive = m_dives[index.row()];
|
|
|
|
switch(role) {
|
|
|
|
case DiveRole: return QVariant::fromValue<QObject*>(curr_dive);
|
|
|
|
case DiveDateRole: return (qlonglong)curr_dive->timestamp();
|
|
|
|
}
|
2015-06-09 22:20:44 +03:00
|
|
|
return QVariant();
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
QHash<int, QByteArray> DiveListModel::roleNames() const
|
|
|
|
{
|
|
|
|
QHash<int, QByteArray> roles;
|
2016-01-07 16:01:24 -02:00
|
|
|
roles[DiveRole] = "dive";
|
|
|
|
roles[DiveDateRole] = "date";
|
2015-06-09 22:20:44 +03:00
|
|
|
return roles;
|
|
|
|
}
|
|
|
|
|
2015-12-26 21:34:45 -08:00
|
|
|
// create a new dive. set the current time and add it to the end of the dive list
|
2015-12-26 21:37:18 -08:00
|
|
|
QString DiveListModel::startAddDive()
|
2015-08-12 15:01:39 +03:00
|
|
|
{
|
2015-08-16 11:57:18 +03:00
|
|
|
struct dive *d;
|
|
|
|
d = alloc_dive();
|
2015-12-26 21:34:45 -08:00
|
|
|
d->when = QDateTime::currentMSecsSinceEpoch() / 1000L + gettimezoneoffset();
|
2016-01-29 11:53:22 -08:00
|
|
|
|
|
|
|
// find the highest dive nr we have and pick the next one
|
|
|
|
struct dive *pd;
|
|
|
|
int i, nr = 0;
|
|
|
|
for_each_dive(i, pd) {
|
|
|
|
if (pd->number > nr)
|
|
|
|
nr = pd->number;
|
|
|
|
}
|
|
|
|
nr++;
|
2015-12-26 21:34:45 -08:00
|
|
|
d->number = nr;
|
2016-01-01 00:32:30 -08:00
|
|
|
d->dc.model = strdup("manually added dive");
|
2015-12-26 21:34:45 -08:00
|
|
|
add_single_dive(-1, d);
|
2016-03-02 09:02:00 -08:00
|
|
|
insertDive(get_idx_by_uniq_id(d->id), new DiveObjectHelper(d));
|
2015-12-26 21:37:18 -08:00
|
|
|
return QString::number(d->id);
|
2015-08-12 15:01:39 +03:00
|
|
|
}
|
|
|
|
|
2015-06-09 22:20:44 +03:00
|
|
|
DiveListModel *DiveListModel::instance()
|
|
|
|
{
|
|
|
|
return m_instance;
|
|
|
|
}
|
2016-01-07 16:01:24 -02:00
|
|
|
|
2016-01-29 06:25:13 -08:00
|
|
|
DiveObjectHelper* DiveListModel::at(int i)
|
|
|
|
{
|
2016-01-07 16:01:24 -02:00
|
|
|
return m_dives.at(i);
|
2016-01-27 11:27:41 -08:00
|
|
|
}
|