feat: toggleable booleans
This commit is contained in:
parent
4ed32e44f0
commit
9932f2ed53
|
@ -1,5 +1,6 @@
|
||||||
#include "propertiesmodel.h"
|
#include "propertiesmodel.h"
|
||||||
#include "datatypes/base.h"
|
#include "datatypes/base.h"
|
||||||
|
#include "objects/base/member.h"
|
||||||
#include "qnamespace.h"
|
#include "qnamespace.h"
|
||||||
|
|
||||||
PropertiesModel::PropertiesModel(InstanceRef selectedItem, QWidget *parent)
|
PropertiesModel::PropertiesModel(InstanceRef selectedItem, QWidget *parent)
|
||||||
|
@ -16,15 +17,22 @@ QVariant PropertiesModel::data(const QModelIndex &index, int role) const {
|
||||||
return {};
|
return {};
|
||||||
|
|
||||||
std::string propertyName = propertiesList[index.row()];
|
std::string propertyName = propertiesList[index.row()];
|
||||||
|
PropertyMeta meta = selectedItem->GetPropertyMeta(propertyName).value();
|
||||||
|
|
||||||
switch (role) {
|
switch (role) {
|
||||||
case Qt::EditRole:
|
case Qt::EditRole:
|
||||||
case Qt::DisplayRole:
|
case Qt::DisplayRole:
|
||||||
if (index.column() == 0)
|
if (index.column() == 0)
|
||||||
return QString::fromStdString(propertyName);
|
return QString::fromStdString(propertyName);
|
||||||
else if (index.column() == 1) {
|
else if (index.column() == 1 && meta.type != &Data::Bool::TYPE) {
|
||||||
return QString::fromStdString(selectedItem->GetPropertyValue(propertyName).value().ToString());
|
return QString::fromStdString(selectedItem->GetPropertyValue(propertyName).value().ToString());
|
||||||
}
|
}
|
||||||
|
return {};
|
||||||
|
case Qt::CheckStateRole:
|
||||||
|
if (index.column() == 0) return {};
|
||||||
|
else if (index.column() == 1 && meta.type == &Data::Bool::TYPE)
|
||||||
|
return selectedItem->GetPropertyValue(propertyName)->get<Data::Bool>().value ? Qt::Checked : Qt::Unchecked;
|
||||||
|
return {};
|
||||||
// case Qt::DecorationRole:
|
// case Qt::DecorationRole:
|
||||||
// return iconOf(item->GetClass());
|
// return iconOf(item->GetClass());
|
||||||
}
|
}
|
||||||
|
@ -33,10 +41,23 @@ QVariant PropertiesModel::data(const QModelIndex &index, int role) const {
|
||||||
}
|
}
|
||||||
|
|
||||||
bool PropertiesModel::setData(const QModelIndex &index, const QVariant &value, int role) {
|
bool PropertiesModel::setData(const QModelIndex &index, const QVariant &value, int role) {
|
||||||
if (index.column() != 1 && role != Qt::EditRole) return false;
|
if (index.column() != 1) return false;
|
||||||
|
|
||||||
if (selectedItem->GetPropertyMeta(propertiesList[index.row()])->type == &Data::String::TYPE) {
|
std::string propertyName = propertiesList[index.row()];
|
||||||
selectedItem->SetPropertyValue(propertiesList[index.row()], value.toString().toStdString());
|
PropertyMeta meta = selectedItem->GetPropertyMeta(propertyName).value();
|
||||||
|
|
||||||
|
switch (role) {
|
||||||
|
case Qt::EditRole:
|
||||||
|
if (meta.type != &Data::String::TYPE)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
selectedItem->SetPropertyValue(propertyName, value.toString().toStdString());
|
||||||
|
return true;
|
||||||
|
case Qt::CheckStateRole:
|
||||||
|
if (meta.type != &Data::Bool::TYPE)
|
||||||
|
return false;
|
||||||
|
|
||||||
|
selectedItem->SetPropertyValue(propertyName, Data::Bool(value.toBool()));
|
||||||
return true;
|
return true;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -50,8 +71,15 @@ Qt::ItemFlags PropertiesModel::flags(const QModelIndex &index) const {
|
||||||
if (index.column() == 0)
|
if (index.column() == 0)
|
||||||
return Qt::ItemIsEnabled;
|
return Qt::ItemIsEnabled;
|
||||||
|
|
||||||
if (index.column() == 1)
|
std::string propertyName = propertiesList[index.row()];
|
||||||
|
PropertyMeta meta = selectedItem->GetPropertyMeta(propertyName).value();
|
||||||
|
|
||||||
|
if (index.column() == 1) {
|
||||||
|
if (meta.type == &Data::Bool::TYPE)
|
||||||
|
return Qt::ItemIsEnabled | Qt::ItemIsUserCheckable;
|
||||||
|
else
|
||||||
return Qt::ItemIsEnabled | Qt::ItemIsEditable;
|
return Qt::ItemIsEnabled | Qt::ItemIsEditable;
|
||||||
|
}
|
||||||
|
|
||||||
return Qt::NoItemFlags;
|
return Qt::NoItemFlags;
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue