#include <ModelAPI_Feature.h>
#include <ModelAPI_CompositeFeature.h>
#include <ModelAPI_ResultCompSolid.h>
+#include <ModelAPI_ResultField.h>
#include <ModelAPI_Tools.h>
#include <Config_FeatureMessage.h>
#include <QIcon>
#include <QBrush>
-#define ACTIVE_COLOR Qt::black
+#define ACTIVE_COLOR QColor(Qt::black)
//#define ACTIVE_COLOR QColor(0,72,140)
//#define PASSIVE_COLOR Qt::black
#define SELECTABLE_COLOR QColor(80, 80, 80)
#define DISABLED_COLOR QColor(200, 200, 200)
+
ResultPartPtr getPartResult(ModelAPI_Object* theObj)
{
ModelAPI_Feature* aFeature = dynamic_cast<ModelAPI_Feature*>(theObj);
XGUI_DataModel::~XGUI_DataModel()
{
+ clear();
}
//******************************************************
} else {
int aFolderId = myXMLReader->rootFolderId(aObjType);
if (aFolderId != -1) {
- insertRow(aRow, createIndex(aFolderId, 0, -1));
+ insertRow(aRow, createIndex(aFolderId, 0, (void*)Q_NULLPTR));
}
}
}
}
}
}
+ } else {
+ rebuildDataTree();
+ break;
}
} else {
rebuildDataTree();
// Process root sub-folder
int aFolderId = myXMLReader->rootFolderId(aGroup);
if (aFolderId != -1) {
- QModelIndex aFolderIndex = createIndex(aFolderId, 0, -1);
+ QModelIndex aFolderIndex = createIndex(aFolderId, 0, (void*)Q_NULLPTR);
removeRow(aRow, aFolderIndex);
//rebuildBranch(0, aRow);
}
for (aIt = aObjects.begin(); aIt != aObjects.end(); ++aIt) {
ObjectPtr aObject = (*aIt);
if (aObject->data()->isValid()) {
- QModelIndex aIndex = objectIndex(aObject);
- if (aIndex.isValid()) {
- emit dataChanged(aIndex, aIndex);
+ FeaturePtr aFeature = std::dynamic_pointer_cast<ModelAPI_Feature>(aObject);
+ if (aFeature.get() && aFeature->firstResult().get()
+ && (aFeature->firstResult()->groupName() == ModelAPI_ResultField::group())) {
+ ResultFieldPtr aResult =
+ std::dynamic_pointer_cast<ModelAPI_ResultField>(aFeature->firstResult());
+ QModelIndex aIndex = objectIndex(aResult);
+ removeRows(0, aResult->stepsSize(), aIndex);
+ } else {
+ QModelIndex aIndex = objectIndex(aObject);
+ if (aIndex.isValid()) {
+ emit dataChanged(aIndex, aIndex);
+ }
}
} else {
rebuildDataTree();
if (aGroup == myXMLReader->rootType()) // Update objects under root
aStartId = foldersCount();
else // Update objects in folder under root
- aParent = createIndex(folderId(aGroup), 0, -1);
+ aParent = createIndex(folderId(aGroup), 0, (void*)Q_NULLPTR);
} else {
// Update a sub-document
if (aGroup == myXMLReader->subType()) {
//******************************************************
void XGUI_DataModel::clear()
{
-
+ beginResetModel();
+ endResetModel();
}
//******************************************************
//******************************************************
ObjectPtr XGUI_DataModel::object(const QModelIndex& theIndex) const
{
- if (theIndex.internalId() < 0) // this is a folder
+ if (theIndex.internalId() == 0) // this is a folder
+ return ObjectPtr();
+ ModelAPI_Object* aObj =
+ dynamic_cast<ModelAPI_Object*>((ModelAPI_Entity*)theIndex.internalPointer());
+ if (!aObj)
return ObjectPtr();
- ModelAPI_Object* aObj = (ModelAPI_Object*)theIndex.internalPointer();
if (getSubDocument(aObj)) // the selected index is a folder of sub-document
return ObjectPtr();
if (theIndex.column() == 1)
return QVariant();
- int aParentId = theIndex.internalId();
- if (aParentId == -1) { // root folders
+ quintptr aParentId = theIndex.internalId();
+ if (aParentId == 0) { // root folders
switch (theRole) {
case Qt::DisplayRole:
return QString(myXMLReader->rootFolderName(theIndexRow).c_str()) +
}
}
} else {
- ModelAPI_Object* aObj = (ModelAPI_Object*)theIndex.internalPointer();
- switch (theRole) {
- case Qt::DisplayRole:
- {
- if (aObj->groupName() == ModelAPI_ResultParameter::group()) {
- ModelAPI_ResultParameter* aParam = dynamic_cast<ModelAPI_ResultParameter*>(aObj);
- AttributeDoublePtr aValueAttribute =
- aParam->data()->real(ModelAPI_ResultParameter::VALUE());
- QString aVal = QString::number(aValueAttribute->value());
- QString aTitle = QString(aObj->data()->name().c_str());
- return aTitle + " = " + aVal;
+ ModelAPI_Object* aObj =
+ dynamic_cast<ModelAPI_Object*>((ModelAPI_Entity*)theIndex.internalPointer());
+ if (aObj) {
+ switch (theRole) {
+ case Qt::DisplayRole:
+ {
+ if (aObj->groupName() == ModelAPI_ResultParameter::group()) {
+ ModelAPI_ResultParameter* aParam = dynamic_cast<ModelAPI_ResultParameter*>(aObj);
+ AttributeDoublePtr aValueAttribute =
+ aParam->data()->real(ModelAPI_ResultParameter::VALUE());
+ QString aVal = QString::number(aValueAttribute->value());
+ QString aTitle = QString(aObj->data()->name().c_str());
+ return aTitle + " = " + aVal;
+ }
+ QString aSuffix;
+ if (aObj->groupName() == myXMLReader->subType()) {
+ ResultPartPtr aPartRes = getPartResult(aObj);
+ if (aPartRes.get()) {
+ if (aPartRes->partDoc().get() == NULL)
+ aSuffix = " (Not loaded)";
+ }
+ }
+ return aObj->data()->name().c_str() + aSuffix;
}
- QString aSuffix;
- if (aObj->groupName() == myXMLReader->subType()) {
- ResultPartPtr aPartRes = getPartResult(aObj);
- if (aPartRes.get()) {
- if (aPartRes->partDoc().get() == NULL)
- aSuffix = " (Not loaded)";
+ case Qt::DecorationRole:
+ return ModuleBase_IconFactory::get()->getIcon(object(theIndex));
+ }
+ } else {
+ switch (theRole) {
+ case Qt::DisplayRole:
+ {
+ ModelAPI_ResultField::ModelAPI_FieldStep* aStep =
+ dynamic_cast<ModelAPI_ResultField::ModelAPI_FieldStep*>
+ ((ModelAPI_Entity*)theIndex.internalPointer());
+ if (aStep) {
+ return "Step " + QString::number(aStep->id() + 1) + " " +
+ aStep->field()->textLine(aStep->id()).c_str();
}
}
- return aObj->data()->name().c_str() + aSuffix;
+ break;
}
- case Qt::DecorationRole:
- return ModuleBase_IconFactory::get()->getIcon(object(theIndex));
}
}
}
return aNbFolders + aNbItems;
}
- int aId = theParent.internalId();
- if (aId == -1) {
+ quintptr aId = theParent.internalId();
+ if (aId == 0) {
// this is a folder under root
int aParentPos = theParent.row();
std::string aType = myXMLReader->rootFolderType(aParentPos);
return aDoc->size(aType);
}
} else {
- ModelAPI_Object* aObj = (ModelAPI_Object*)theParent.internalPointer();
+ ModelAPI_Object* aObj =
+ dynamic_cast<ModelAPI_Object*>((ModelAPI_Entity*)theParent.internalPointer());
// Check for Part feature
ResultPartPtr aPartRes = getPartResult(aObj);
if (aPartRes.get()) {
ModelAPI_ResultCompSolid* aCompRes = dynamic_cast<ModelAPI_ResultCompSolid*>(aObj);
if (aCompRes)
return aCompRes->numberOfSubs(true);
+ ModelAPI_ResultField* aFieldRes = dynamic_cast<ModelAPI_ResultField*>(aObj);
+ if (aFieldRes)
+ return aFieldRes->stepsSize();
}
}
}
if (!theParent.isValid()) {
if (theRow < aNbFolders) // Return first level folder index
- return createIndex(theRow, theColumn, -1);
+ return createIndex(theRow, theColumn, (void*)Q_NULLPTR);
else { // return object under root index
std::string aType = myXMLReader->rootType();
int aObjId = theRow - aNbFolders;
}
}
} else {
- int aId = theParent.internalId();
+ quintptr aId = theParent.internalId();
int aParentPos = theParent.row();
- if (aId == -1) { // return object index inside of first level of folders
+ if (aId == 0) { // return object index inside of first level of folders
std::string aType = myXMLReader->rootFolderType(aParentPos);
if (theRow < aRootDoc->size(aType)) {
ObjectPtr aObj = aRootDoc->object(aType, theRow);
}
}
} else {
- ModelAPI_Object* aParentObj = (ModelAPI_Object*)theParent.internalPointer();
+ ModelAPI_Object* aParentObj =
+ dynamic_cast<ModelAPI_Object*>((ModelAPI_Entity*)theParent.internalPointer());
// Check for Part feature
ResultPartPtr aPartRes = getPartResult(aParentObj);
dynamic_cast<ModelAPI_ResultCompSolid*>(aParentObj);
if (aCompRes)
aIndex = objectIndex(aCompRes->subResult(theRow));
+ else {
+ ModelAPI_ResultField* aFieldRes =
+ dynamic_cast<ModelAPI_ResultField*>(aParentObj);
+ if (aFieldRes) {
+ aIndex = createIndex(theRow, 0, aFieldRes->step(theRow));
+ }
+ }
}
}
}
if (theIndex == MYLastDeleted)
return QModelIndex();
- int aId = theIndex.internalId();
- if (aId != -1) { // The object is not a root folder
+ SessionPtr aSession = ModelAPI_Session::get();
+ quintptr aId = theIndex.internalId();
+ if (aId != 0) { // The object is not a root folder
ModelAPI_Document* aDoc = getSubDocument(theIndex.internalPointer());
if (aDoc) {
// It is a folder of sub-document
}
ObjectPtr aObj = object(theIndex);
if (!aObj.get()) {
+ // It can b e a step of a field
+ ModelAPI_ResultField::ModelAPI_FieldStep* aStep =
+ dynamic_cast<ModelAPI_ResultField::ModelAPI_FieldStep*>
+ ((ModelAPI_Entity*)theIndex.internalPointer());
+ if (aStep) {
+ ModelAPI_ResultField* aField = aStep->field();
+ DocumentPtr aDoc = aSession->activeDocument();
+ ObjectPtr aFld;
+ for(int i = 0; i < aDoc->size(ModelAPI_ResultField::group()); i++) {
+ aFld = aDoc->object(ModelAPI_ResultField::group(), i);
+ if (aFld.get() == aField)
+ return objectIndex(aFld);
+ }
+ }
// To avoid additional request about index which was already deleted
// If deleted it causes a crash on delete object from Part
MYLastDeleted = theIndex;
}
// Use as ordinary object
std::string aType = aObj->groupName();
- SessionPtr aSession = ModelAPI_Session::get();
DocumentPtr aRootDoc = aSession->moduleDocument();
DocumentPtr aSubDoc = aObj->document();
if (aSubDoc == aRootDoc) {
// return first level of folder index
int aFolderId = myXMLReader->rootFolderId(aType);
// Items in a one row must have the same parent
- return createIndex(aFolderId, 0, -1);
+ return createIndex(aFolderId, 0, (void*)Q_NULLPTR);
}
} else {
if (aType == myXMLReader->subType())
//******************************************************
Qt::ItemFlags XGUI_DataModel::flags(const QModelIndex& theIndex) const
{
- qint64 aIt = theIndex.internalId();
+ quintptr aIt = theIndex.internalId();
ModelAPI_Object* aObj = 0;
ModelAPI_Document* aDoc = 0;
SessionPtr aSession = ModelAPI_Session::get();
Qt::ItemFlags aEditingFlag = Qt::ItemIsSelectable | Qt::ItemIsEnabled | Qt::ItemIsEditable;
- if (aIt == -1) {
+ if (aIt == 0) {
// Folders under root
DocumentPtr aRootDoc = aSession->moduleDocument();
if (aRootDoc != aActiveDoc)
} else {
aDoc = getSubDocument(theIndex.internalPointer());
if (!aDoc)
- aObj = (ModelAPI_Object*) theIndex.internalPointer();
+ aObj = dynamic_cast<ModelAPI_Object*>((ModelAPI_Entity*)theIndex.internalPointer());
}
if (aObj) {