summaryrefslogtreecommitdiff
path: root/tagproptablemodel.cpp
diff options
context:
space:
mode:
Diffstat (limited to 'tagproptablemodel.cpp')
-rw-r--r--tagproptablemodel.cpp52
1 files changed, 28 insertions, 24 deletions
diff --git a/tagproptablemodel.cpp b/tagproptablemodel.cpp
index 711494d..4dc5e6b 100644
--- a/tagproptablemodel.cpp
+++ b/tagproptablemodel.cpp
@@ -1,26 +1,24 @@
#include "tagproptablemodel.h"
TagPropTableModel::TagPropTableModel(SQLiteSaveFile &backend, const Tag tag)
- : backend(backend)
- , tag_cached(tag)
- , tagIsValid(true)
+ : TagPropTableModel(backend, true)
{
+ tag_cached = tag;
tag_keys = tag_cached.metadata.keys();
tag_keys.sort();
- connect(&backend, &SQLiteSaveFile::tagChange,
- this, &TagPropTableModel::tagChange);
- connect(&backend, &SQLiteSaveFile::fileReload,
- [=]() {
- beginResetModel();
- tagIsValid = false;
- endResetModel();
- });
+ qDebug() << "connecting TagPropTableModel" << &backend;
}
-TagPropTableModel::TagPropTableModel(SQLiteSaveFile &backend)
+TagPropTableModel::TagPropTableModel(SQLiteSaveFile &backend, bool tagIsValid)
: backend(backend)
- , tagIsValid(false)
+ , tagIsValid(tagIsValid)
{
+ connect(&backend, &SQLiteSaveFile::tagChange, this, &TagPropTableModel::tagChange);
+ connect(&backend, &SQLiteSaveFile::fileReload, [=]() {
+ beginResetModel();
+ this->tagIsValid = false;
+ endResetModel();
+ });
}
int TagPropTableModel::rowCount(const QModelIndex &parent) const
@@ -42,7 +40,7 @@ QVariant TagPropTableModel::data(const QModelIndex &index, int role) const
if (!index.isValid())
return QVariant();
- if (role != Qt::DisplayRole)
+ if (role != Qt::DisplayRole && role != Qt::EditRole)
return QVariant();
bool label = index.column() == 0;
@@ -50,7 +48,7 @@ QVariant TagPropTableModel::data(const QModelIndex &index, int role) const
switch (index.row()) {
case 0: return label ? QVariant("Database ID") : tag_cached.id; break;
case 1: return label ? QVariant("Label") : tag_cached.name; break;
- case 2: return label ? QVariant("Anchor") : tag_cached.anchor; break;
+ case 2: return label ? QVariant("Anchor") : QString("%1, %2").arg(tag_cached.anchor.x()).arg(tag_cached.anchor.y()); break;
}
int idx = index.row() - 3;
@@ -100,18 +98,19 @@ bool TagPropTableModel::setData(const QModelIndex &index, const QVariant &value,
if (role != Qt::EditRole)
return false;
- if (index.row() == 1)
+ if (index.row() == 1) {
tag_cached.name = value.toString();
- else if (index.row() < 3)
+ } else if (index.row() < 3) {
return false;
-
- int idx = index.row() - 3;
- if (index.column() == 0) { /* key changed */
- /* move value to new key and delete old key */
- tag_cached.metadata[value.toString()] = tag_cached.metadata[tag_keys[idx]];
- tag_cached.metadata.remove(tag_keys[idx]);
} else {
- tag_cached.metadata[tag_keys[idx]] = value.toString();
+ int idx = index.row() - 3;
+ if (index.column() == 0) { /* key changed */
+ /* move value to new key and delete old key */
+ tag_cached.metadata[value.toString()] = tag_cached.metadata[tag_keys[idx]];
+ tag_cached.metadata.remove(tag_keys[idx]);
+ } else {
+ tag_cached.metadata[tag_keys[idx]] = value.toString();
+ }
}
backend.updateTag(tag_cached);
@@ -120,13 +119,17 @@ bool TagPropTableModel::setData(const QModelIndex &index, const QVariant &value,
void TagPropTableModel::tagChange(TagChange change, const Tag &tag)
{
+ auto dbg = qDebug() << QString("TagPropTableModel::tagChange(%1, %2 \"%3\")").arg(change).arg(tag.id).arg(tag.name);
if (tag.id != tag_cached.id)
return;
assert(change != TagChange::CREATED);
if (change == TagChange::CHANGED) {
+ dbg << "changed";
showTag(tag);
+
} else if (change == TagChange::DELETED) {
+ dbg << "deleted";
beginResetModel();
tagIsValid = false;
endResetModel();
@@ -140,5 +143,6 @@ void TagPropTableModel::showTag(const Tag &tag)
tag_cached = tag;
tag_keys = tag_cached.metadata.keys();
tag_keys.sort();
+ tagIsValid = true;
endResetModel();
}