2017-04-27 18:25:32 +00:00
|
|
|
// SPDX-License-Identifier: GPL-2.0
|
2016-04-05 05:02:03 +00:00
|
|
|
#include "qt-models/divecomputermodel.h"
|
|
|
|
#include "core/dive.h"
|
|
|
|
#include "core/divelist.h"
|
2015-05-28 20:51:07 +00:00
|
|
|
|
2016-03-08 05:25:40 +00:00
|
|
|
DiveComputerModel::DiveComputerModel(QMultiMap<QString, DiveComputerNode> &dcMap, QObject *parent) : CleanerTableModel(parent)
|
2015-05-28 20:51:07 +00:00
|
|
|
{
|
|
|
|
setHeaderDataStrings(QStringList() << "" << tr("Model") << tr("Device ID") << tr("Nickname"));
|
|
|
|
dcWorkingMap = dcMap;
|
|
|
|
numRows = 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
QVariant DiveComputerModel::data(const QModelIndex &index, int role) const
|
|
|
|
{
|
|
|
|
QList<DiveComputerNode> values = dcWorkingMap.values();
|
|
|
|
DiveComputerNode node = values.at(index.row());
|
|
|
|
|
|
|
|
QVariant ret;
|
|
|
|
if (role == Qt::DisplayRole || role == Qt::EditRole) {
|
|
|
|
switch (index.column()) {
|
|
|
|
case ID:
|
|
|
|
ret = QString("0x").append(QString::number(node.deviceId, 16));
|
|
|
|
break;
|
|
|
|
case MODEL:
|
|
|
|
ret = node.model;
|
|
|
|
break;
|
|
|
|
case NICKNAME:
|
|
|
|
ret = node.nickName;
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
if (index.column() == REMOVE) {
|
|
|
|
switch (role) {
|
|
|
|
case Qt::DecorationRole:
|
|
|
|
ret = trashIcon();
|
|
|
|
break;
|
|
|
|
case Qt::SizeHintRole:
|
|
|
|
ret = trashIcon().size();
|
|
|
|
break;
|
|
|
|
case Qt::ToolTipRole:
|
|
|
|
ret = tr("Clicking here will remove this dive computer.");
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
return ret;
|
|
|
|
}
|
|
|
|
|
2018-05-21 15:53:42 +00:00
|
|
|
int DiveComputerModel::rowCount(const QModelIndex&) const
|
2015-05-28 20:51:07 +00:00
|
|
|
{
|
|
|
|
return numRows;
|
|
|
|
}
|
|
|
|
|
|
|
|
void DiveComputerModel::update()
|
|
|
|
{
|
|
|
|
QList<DiveComputerNode> values = dcWorkingMap.values();
|
|
|
|
int count = values.count();
|
|
|
|
|
|
|
|
if (numRows) {
|
|
|
|
beginRemoveRows(QModelIndex(), 0, numRows - 1);
|
|
|
|
numRows = 0;
|
|
|
|
endRemoveRows();
|
|
|
|
}
|
|
|
|
|
|
|
|
if (count) {
|
|
|
|
beginInsertRows(QModelIndex(), 0, count - 1);
|
|
|
|
numRows = count;
|
|
|
|
endInsertRows();
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
Qt::ItemFlags DiveComputerModel::flags(const QModelIndex &index) const
|
|
|
|
{
|
|
|
|
Qt::ItemFlags flags = QAbstractItemModel::flags(index);
|
|
|
|
if (index.column() == NICKNAME)
|
|
|
|
flags |= Qt::ItemIsEditable;
|
|
|
|
return flags;
|
|
|
|
}
|
|
|
|
|
2018-05-21 15:53:42 +00:00
|
|
|
bool DiveComputerModel::setData(const QModelIndex &index, const QVariant &value, int)
|
2015-05-28 20:51:07 +00:00
|
|
|
{
|
2016-03-08 05:25:40 +00:00
|
|
|
// We should test if the role == Qt::EditRole
|
|
|
|
|
|
|
|
// WARN: This seems wrong - The values don't are ordered - we need a map from the Key to Index, or something.
|
2015-05-28 20:51:07 +00:00
|
|
|
QList<DiveComputerNode> values = dcWorkingMap.values();
|
|
|
|
DiveComputerNode node = values.at(index.row());
|
|
|
|
dcWorkingMap.remove(node.model, node);
|
|
|
|
node.nickName = value.toString();
|
|
|
|
dcWorkingMap.insert(node.model, node);
|
|
|
|
emit dataChanged(index, index);
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
void DiveComputerModel::remove(const QModelIndex &index)
|
|
|
|
{
|
|
|
|
QList<DiveComputerNode> values = dcWorkingMap.values();
|
|
|
|
DiveComputerNode node = values.at(index.row());
|
|
|
|
dcWorkingMap.remove(node.model, node);
|
|
|
|
update();
|
|
|
|
}
|
|
|
|
|
|
|
|
void DiveComputerModel::dropWorkingList()
|
|
|
|
{
|
|
|
|
// how do I prevent the memory leak ?
|
|
|
|
}
|
|
|
|
|
|
|
|
void DiveComputerModel::keepWorkingList()
|
|
|
|
{
|
|
|
|
if (dcList.dcMap != dcWorkingMap)
|
|
|
|
mark_divelist_changed(true);
|
|
|
|
dcList.dcMap = dcWorkingMap;
|
|
|
|
}
|