if (aFeature) {
ResultPtr aRes = aFeature->firstResult();
if (aRes.get() && (aRes->groupName() == ModelAPI_ResultPart::group())) {
- return std::dynamic_pointer_cast<ModelAPI_ResultPart>(aRes);
+ ResultPartPtr aPartRes = std::dynamic_pointer_cast<ModelAPI_ResultPart>(aRes);
+ // Use only original parts, not a placement results
+ if (aPartRes == aPartRes->original())
+ return aPartRes;
}
}
return ResultPartPtr();
// Constructor *************************************************
-XGUI_DataModel::XGUI_DataModel(QObject* theParent) : QAbstractItemModel(theParent)
+XGUI_DataModel::XGUI_DataModel(QObject* theParent) : ModuleBase_IDocumentDataModel(theParent)
{
myXMLReader.readAll();
Events_Loop* aLoop = Events_Loop::loop();
aLoop->registerListener(this, Events_Loop::eventByName(EVENT_OBJECT_CREATED));
aLoop->registerListener(this, Events_Loop::eventByName(EVENT_OBJECT_DELETED));
+ aLoop->registerListener(this, Events_Loop::eventByName(EVENT_DOCUMENT_CHANGED));
}
//******************************************************
std::string aObjType;
for (aIt = aObjects.begin(); aIt != aObjects.end(); ++aIt) {
ObjectPtr aObject = (*aIt);
+ // We do not show objects which not has to be shown in object browser
+ if (!aObject->isInHistory())
+ continue;
+
aObjType = aObject->groupName();
DocumentPtr aDoc = aObject->document();
if (aDoc == aRootDoc) {
}
}
#ifdef _DEBUG
- else {
+ else
Events_Error::send("Problem with Data Model definition of sub-document");
- }
#endif
}
}
}
}
#ifdef _DEBUG
- else {
+ else
Events_Error::send("Problem with Data Model definition of sub-document");
- }
#endif
}
}
+ } else if (theMessage->eventID() == Events_Loop::loop()->eventByName(EVENT_DOCUMENT_CHANGED)) {
+ DocumentPtr aDoc = ModelAPI_Session::get()->activeDocument();
+ if (aDoc != aRootDoc) {
+ QModelIndex aDocRoot = findDocumentRootIndex(aDoc.get());
+ if (aDocRoot.isValid())
+ emit dataChanged(aDocRoot, aDocRoot);
+#ifdef _DEBUG
+ else
+ Events_Error::send("Problem with Data Model definition of sub-document");
+#endif
+ }
}
}
ObjectPtr aObj = object(theIndex);
if (!aObj.get()) {
// To avoid additional request about index which was already deleted
+ // If deleted it causes a crash on delete object from Part
MYLastDeleted = theIndex;
return QModelIndex();
}
// Check for Part feature
ResultPartPtr aPartRes = getPartResult(aObj);
if (aPartRes.get())
- return true;
+ return aPartRes->partDoc().get() != NULL;
else {
// Check for composite object
ModelAPI_CompositeFeature* aCompFeature = dynamic_cast<ModelAPI_CompositeFeature*>(aObj);
aObj = (ModelAPI_Object*) theIndex.internalPointer();
}
if (aObj) {
- aFlags |= Qt::ItemIsEditable;
-
- if (!aObj->isDisabled())
- aFlags |= Qt::ItemIsEnabled;
- } else
- aFlags |= Qt::ItemIsEnabled;
+ if (aObj->isDisabled())
+ return Qt::ItemFlags();
+
+ bool isCompositeSub = false;
+ if (theIndex.column() == 1) {
+ ObjectPtr aObjPtr = aObj->data()->owner();
+ FeaturePtr aFeature = std::dynamic_pointer_cast<ModelAPI_Feature>(aObjPtr);
+ if (aFeature.get()) {
+ CompositeFeaturePtr aCompFea = ModelAPI_Tools::compositeOwner(aFeature);
+ if (aCompFea.get())
+ isCompositeSub = true;
+ } else {
+ ResultPtr aResult = std::dynamic_pointer_cast<ModelAPI_Result>(aObjPtr);
+ if (aResult.get()) {
+ ResultCompSolidPtr aCompRes = ModelAPI_Tools::compSolidOwner(aResult);
+ if (aCompRes.get())
+ isCompositeSub = true;
+ }
+ }
+ }
+ // An object which is sub-object of a composite object can not be accessible in column 1
+ if (isCompositeSub)
+ return Qt::ItemFlags();
+ }
+
+ aFlags |= Qt::ItemIsEnabled;
return aFlags;
}