#include <ModelAPI_Tools.h>
#include <Config_FeatureMessage.h>
+#include <Config_DataModelReader.h>
#include <Events_Loop.h>
-#include <Events_Error.h>
#include <QIcon>
#include <QBrush>
-#define ACTIVE_COLOR QColor(0,72,140)
+#define ACTIVE_COLOR Qt::black
+//#define ACTIVE_COLOR QColor(0,72,140)
//#define PASSIVE_COLOR Qt::black
/// Returns ResultPart object if the given object is a Part feature
/// Otherwise returns NULL
+
+#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);
// Constructor *************************************************
-XGUI_DataModel::XGUI_DataModel(QObject* theParent) : ModuleBase_IDocumentDataModel(theParent)
+XGUI_DataModel::XGUI_DataModel(QObject* theParent) : QAbstractItemModel(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_OBJECT_UPDATED));
+ aLoop->registerListener(this, Events_Loop::eventByName(EVENT_ORDER_UPDATED));
aLoop->registerListener(this, Events_Loop::eventByName(EVENT_DOCUMENT_CHANGED));
}
+XGUI_DataModel::~XGUI_DataModel()
+{
+}
+
//******************************************************
void XGUI_DataModel::processEvent(const std::shared_ptr<Events_Message>& theMessage)
{
DocumentPtr aRootDoc = ModelAPI_Session::get()->moduleDocument();
- std::string aRootType = myXMLReader.rootType();
- std::string aSubType = myXMLReader.subType();
+ std::string aRootType = myXMLReader->rootType();
+ std::string aSubType = myXMLReader->subType();
int aNbFolders = foldersCount();
// Created object event *******************
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
+ // We do not show objects which does not need to be shown in object browser
if (!aObject->isInHistory())
continue;
foreach (QString aNotEmptyFolder, aNotEmptyFolders) {
if ((aNotEmptyFolder.toStdString() == aObjType) && (aRootDoc->size(aObjType) == 1))
// Appears first object in folder which can not be shown empty
- insertRow(myXMLReader.rootFolderId(aObjType));
+ insertRow(myXMLReader->rootFolderId(aObjType));
}
// Insert new object
int aRow = aRootDoc->size(aObjType) - 1;
- if (aObjType == aRootType) {
- insertRow(aRow + aNbFolders + 1);
- } else {
- int aFolderId = myXMLReader.rootFolderId(aObjType);
- if (aFolderId != -1) {
- insertRow(aRow, createIndex(aFolderId, 0, -1));
- }
- }
+ if (aRow != -1) {
+ if (aObjType == aRootType) {
+ insertRow(aRow + aNbFolders + 1);
+ } else {
+ int aFolderId = myXMLReader->rootFolderId(aObjType);
+ if (aFolderId != -1) {
+ insertRow(aRow, createIndex(aFolderId, 0, -1));
+ }
+ }
+ }
} else {
// Object created in sub-document
QModelIndex aDocRoot = findDocumentRootIndex(aDoc.get());
foreach (QString aNotEmptyFolder, aNotEmptyFolders) {
if ((aNotEmptyFolder.toStdString() == aObjType) && (aDoc->size(aObjType) == 1))
// Appears first object in folder which can not be shown empty
- insertRow(myXMLReader.subFolderId(aObjType), aDocRoot);
+ insertRow(myXMLReader->subFolderId(aObjType), aDocRoot);
}
- int aRow = aDoc->size(aObjType) - 1;
- int aNbSubFolders = foldersCount(aDoc.get());
- if (aObjType == aSubType) {
- // List of objects under document root
- insertRow(aRow + aNbSubFolders, aDocRoot);
- } else {
- // List of objects under a folder
- if (aRow != -1) {
- int aFolderId = myXMLReader.subFolderId(aObjType);
- if (aFolderId != -1) {
- insertRow(aRow, createIndex(aFolderId, 0, aDoc.get()));
+ int aRow = aDoc->index(aObject);
+ if (aRow != -1) {
+ int aNbSubFolders = foldersCount(aDoc.get());
+ if (aObjType == aSubType) {
+ // List of objects under document root
+ insertRow(aRow + aNbSubFolders, aDocRoot);
+ } else {
+ // List of objects under a folder
+ if (aRow != -1) {
+ int aFolderId = folderId(aObjType, aDoc.get());
+ if (aFolderId != -1) {
+ QModelIndex aParentFolder = createIndex(aFolderId, 0, aDoc.get());
+ insertRow(aRow, aParentFolder);
+ emit dataChanged(aParentFolder, aParentFolder);
+ }
}
}
}
- }
-#ifdef _DEBUG
- else
- Events_Error::send("Problem with Data Model definition of sub-document");
-#endif
+ } else {
+ rebuildDataTree();
+ break;
+ }
}
}
// Deleted object event ***********************
std::shared_ptr<ModelAPI_ObjectDeletedMessage> aUpdMsg =
std::dynamic_pointer_cast<ModelAPI_ObjectDeletedMessage>(theMessage);
DocumentPtr aDoc = aUpdMsg->document();
- std::set<std::string> aGroups = aUpdMsg->groups();
- std::set<std::string>::const_iterator aIt;
+ std::set<std::string> aMsgGroups = aUpdMsg->groups();
+
+ /// Sort groups because RootType deletion has to be done after others
+ std::string aType = (aDoc == aRootDoc)? aRootType : aSubType;
+ std::list<std::string> aGroups;
+ std::set<std::string>::const_iterator aSetIt;
+ for (aSetIt = aMsgGroups.begin(); aSetIt != aMsgGroups.end(); ++aSetIt) {
+ std::string aGroup = (*aSetIt);
+ if (aGroup == aType)
+ aGroups.push_back(aGroup);
+ else
+ aGroups.push_front(aGroup);
+ }
+
+ std::list<std::string>::const_iterator aIt;
for (aIt = aGroups.begin(); aIt != aGroups.end(); ++aIt) {
std::string aGroup = (*aIt);
if (aDoc == aRootDoc) { // If root objects
int aRow = aRootDoc->size(aGroup);
if (aGroup == aRootType) {
+ // Process root folder
removeRow(aRow + aNbFolders);
+ rebuildBranch(aNbFolders, aRow);
} else {
- int aFolderId = myXMLReader.rootFolderId(aGroup);
+ // Process root sub-folder
+ int aFolderId = myXMLReader->rootFolderId(aGroup);
if (aFolderId != -1) {
QModelIndex aFolderIndex = createIndex(aFolderId, 0, -1);
removeRow(aRow, aFolderIndex);
+ //rebuildBranch(0, aRow);
}
}
// Check that some folders could erased
QStringList aNotEmptyFolders = listOfShowNotEmptyFolders();
foreach (QString aNotEmptyFolder, aNotEmptyFolders) {
- if ((aNotEmptyFolder.toStdString() == aGroup) && (aRootDoc->size(aGroup) == 0))
+ if ((aNotEmptyFolder.toStdString() == aGroup) && (aRootDoc->size(aGroup) == 0)) {
// Appears first object in folder which can not be shown empty
- removeRow(myXMLReader.rootFolderId(aGroup));
+ removeRow(myXMLReader->rootFolderId(aGroup));
+ //rebuildBranch(0, aNbFolders + aDoc->size(myXMLReader->rootType()));
+ break;
+ }
}
} else {
// Remove row for sub-document
if (aGroup == aSubType) {
// List of objects under document root
removeRow(aRow + aNbSubFolders, aDocRoot);
+ rebuildBranch(aNbSubFolders, aRow, aDocRoot);
} else {
// List of objects under a folder
- int aFolderId = myXMLReader.subFolderId(aGroup);
+ int aFolderId = folderId(aGroup, aDoc.get());
if (aFolderId != -1) {
- removeRow(aRow, createIndex(aFolderId, 0, aDoc.get()));
+ QModelIndex aFolderRoot = createIndex(aFolderId, 0, aDoc.get());
+ removeRow(aRow, aFolderRoot);
+ //rebuildBranch(0, aRow, aFolderRoot);
}
}
// Check that some folders could disappear
QStringList aNotEmptyFolders = listOfShowNotEmptyFolders(false);
+ int aSize = aDoc->size(aGroup);
foreach (QString aNotEmptyFolder, aNotEmptyFolders) {
- if ((aNotEmptyFolder.toStdString() == aGroup) && (aDoc->size(aGroup) == 1))
+ if ((aNotEmptyFolder.toStdString() == aGroup) && (aSize == 0)) {
// Appears first object in folder which can not be shown empty
- removeRow(myXMLReader.subFolderId(aGroup), aDocRoot);
+ removeRow(myXMLReader->subFolderId(aGroup), aDocRoot);
+ //rebuildBranch(0, aNbSubFolders + aDoc->size(myXMLReader->subType()), aDocRoot);
+ break;
+ }
}
- }
-#ifdef _DEBUG
- else
- Events_Error::send("Problem with Data Model definition of sub-document");
-#endif
+ } else {
+ rebuildDataTree();
+ break;
+ }
+ }
+ }
+ } else if (theMessage->eventID() == Events_Loop::loop()->eventByName(EVENT_OBJECT_UPDATED)) {
+ std::shared_ptr<ModelAPI_ObjectUpdatedMessage> aUpdMsg =
+ std::dynamic_pointer_cast<ModelAPI_ObjectUpdatedMessage>(theMessage);
+ std::set<ObjectPtr> aObjects = aUpdMsg->objects();
+
+ std::set<ObjectPtr>::const_iterator aIt;
+ std::string aObjType;
+ 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);
+ }
+ } else {
+ rebuildDataTree();
+ break;
}
}
+ } else if (theMessage->eventID() == Events_Loop::loop()->eventByName(EVENT_ORDER_UPDATED)) {
+ std::shared_ptr<ModelAPI_OrderUpdatedMessage> aUpdMsg =
+ std::dynamic_pointer_cast<ModelAPI_OrderUpdatedMessage>(theMessage);
+ if (aUpdMsg->reordered().get()) {
+ DocumentPtr aDoc = aUpdMsg->reordered()->document();
+ std::string aGroup = aUpdMsg->reordered()->group();
+
+ QModelIndex aParent;
+ int aStartId = 0;
+ if (aDoc == aRootDoc) {
+ // Update a group under root
+ if (aGroup == myXMLReader->rootType()) // Update objects under root
+ aStartId = foldersCount();
+ else // Update objects in folder under root
+ aParent = createIndex(folderId(aGroup), 0, -1);
+ } else {
+ // Update a sub-document
+ if (aGroup == myXMLReader->subType()) {
+ // Update sub-document root
+ aParent = findDocumentRootIndex(aDoc.get());
+ aStartId = foldersCount(aDoc.get());
+ } else
+ // update folder in sub-document
+ aParent = createIndex(folderId(aGroup, aDoc.get()), 0, aDoc.get());
+ }
+ int aChildNb = rowCount(aParent);
+ rebuildBranch(aStartId, aChildNb - aStartId, aParent);
+ } else {
+ rebuildDataTree();
+ }
} 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
+ else
+ // We have got a new document
+ rebuildDataTree();
}
}
}
//******************************************************
void XGUI_DataModel::rebuildDataTree()
{
-
+ beginResetModel();
+ endResetModel();
+ emit treeRebuilt();
}
//******************************************************
}
SessionPtr aSession = ModelAPI_Session::get();
DocumentPtr aRootDoc = aSession->moduleDocument();
- if (aDoc == aRootDoc && myXMLReader.rootType() == aType) {
+ if (aDoc == aRootDoc && myXMLReader->rootType() == aType) {
// The object from root document
aRow += foldersCount();
- } else if (myXMLReader.subType() == aType) {
+ } else if (myXMLReader->subType() == aType) {
// The object from sub document
aRow += foldersCount(aDoc.get());
}
if (aParentId == -1) { // root folders
switch (theRole) {
case Qt::DisplayRole:
- return QString(myXMLReader.rootFolderName(theIndexRow).c_str()) +
+ return QString(myXMLReader->rootFolderName(theIndexRow).c_str()) +
QString(" (%1)").arg(rowCount(theIndex));
case Qt::DecorationRole:
- return QIcon(myXMLReader.rootFolderIcon(theIndexRow).c_str());
+ return QIcon(myXMLReader->rootFolderIcon(theIndexRow).c_str());
case Qt::ForegroundRole:
- if ((flags(theIndex) & Qt::ItemIsEditable) == 0)
- return QBrush(Qt::lightGray);
+ {
+ Qt::ItemFlags aFlags = theIndex.flags();
+ if (aFlags == Qt::ItemFlags())
+ return QBrush(DISABLED_COLOR);
+ if (!aFlags.testFlag(Qt::ItemIsEditable))
+ return QBrush(SELECTABLE_COLOR);
+ }
return ACTIVE_COLOR;
}
} else { // an object or sub-document
if (theRole == Qt::ForegroundRole) {
- if ((flags(theIndex) & Qt::ItemIsEditable) == 0)
- return QBrush(Qt::lightGray);
+ Qt::ItemFlags aFlags = theIndex.flags();
+ if (aFlags == Qt::ItemFlags())
+ return QBrush(DISABLED_COLOR);
+ if (!aFlags.testFlag(Qt::ItemIsEditable))
+ return QBrush(SELECTABLE_COLOR);
return ACTIVE_COLOR;
}
switch (theRole) {
case Qt::DisplayRole:
- return QString(myXMLReader.subFolderName(aRow).c_str()) +
+ return QString(myXMLReader->subFolderName(aRow).c_str()) +
QString(" (%1)").arg(rowCount(theIndex));
case Qt::DecorationRole:
- return QIcon(myXMLReader.subFolderIcon(aRow).c_str());
+ return QIcon(myXMLReader->subFolderIcon(aRow).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;
+ {
+ 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;
}
- return aObj->data()->name().c_str();
case Qt::DecorationRole:
return ModuleBase_IconFactory::get()->getIcon(object(theIndex));
}
// Return number of items in root
int aNbFolders = foldersCount();
int aNbItems = 0;
- std::string aType = myXMLReader.rootType();
+ std::string aType = myXMLReader->rootType();
if (!aType.empty())
aNbItems = aRootDoc->size(aType);
return aNbFolders + aNbItems;
if (aId == -1) {
// this is a folder under root
int aParentPos = theParent.row();
- std::string aType = myXMLReader.rootFolderType(aParentPos);
+ std::string aType = myXMLReader->rootFolderType(aParentPos);
return aRootDoc->size(aType);
} else {
// It is an object which could have children
int aRow = theParent.row();
while (aMissedIdx.contains(aRow))
aRow++;
- std::string aType = myXMLReader.subFolderType(aRow);
+ std::string aType = myXMLReader->subFolderType(aRow);
return aDoc->size(aType);
} else {
ModelAPI_Object* aObj = (ModelAPI_Object*)theParent.internalPointer();
ResultPartPtr aPartRes = getPartResult(aObj);
if (aPartRes.get()) {
DocumentPtr aSubDoc = aPartRes->partDoc();
+ if (!aSubDoc.get())
+ return 0;
+
int aNbSubFolders = foldersCount(aSubDoc.get());
int aNbSubItems = 0;
- std::string aSubType = myXMLReader.subType();
+ std::string aSubType = myXMLReader->subType();
if (!aSubType.empty())
aNbSubItems = aSubDoc->size(aSubType);
return aNbSubItems + aNbSubFolders;
if (theRow < aNbFolders) // Return first level folder index
return createIndex(theRow, theColumn, -1);
else { // return object under root index
- std::string aType = myXMLReader.rootType();
+ std::string aType = myXMLReader->rootType();
int aObjId = theRow - aNbFolders;
if (aObjId < aRootDoc->size(aType)) {
ObjectPtr aObj = aRootDoc->object(aType, aObjId);
int aId = theParent.internalId();
int aParentPos = theParent.row();
if (aId == -1) { // return object index inside of first level of folders
- std::string aType = myXMLReader.rootFolderType(aParentPos);
+ std::string aType = myXMLReader->rootFolderType(aParentPos);
if (theRow < aRootDoc->size(aType)) {
ObjectPtr aObj = aRootDoc->object(aType, theRow);
aIndex = objectIndex(aObj);
ModelAPI_Document* aDoc = getSubDocument(theParent.internalPointer());
if (aDoc) {
// It is a folder of sub-document
- std::string aType = myXMLReader.subFolderType(aParentPos);
+ int aParentRow = aParentPos;
+ QIntList aMissedIdx = missedFolderIndexes(aDoc);
+ while (aMissedIdx.contains(aParentRow))
+ aParentRow++;
+ std::string aType = myXMLReader->subFolderType(aParentRow);
if (theRow < aDoc->size(aType)) {
ObjectPtr aObj = aDoc->object(aType, theRow);
aIndex = objectIndex(aObj);
aIndex = createIndex(theRow, theColumn, aSubDoc.get());
} else {
// this is an object under sub document root
- std::string aType = myXMLReader.subType();
+ std::string aType = myXMLReader->subType();
ObjectPtr aObj = aSubDoc->object(aType, theRow - aNbSubFolders);
aIndex = objectIndex(aObj);
}
} else {
// Check for composite object
- ModelAPI_CompositeFeature* aCompFeature = dynamic_cast<ModelAPI_CompositeFeature*>(aParentObj);
+ ModelAPI_CompositeFeature* aCompFeature =
+ dynamic_cast<ModelAPI_CompositeFeature*>(aParentObj);
if (aCompFeature) {
aIndex = objectIndex(aCompFeature->subFeature(theRow));
} else {
- ModelAPI_ResultCompSolid* aCompRes = dynamic_cast<ModelAPI_ResultCompSolid*>(aParentObj);
+ ModelAPI_ResultCompSolid* aCompRes =
+ dynamic_cast<ModelAPI_ResultCompSolid*>(aParentObj);
if (aCompRes)
aIndex = objectIndex(aCompRes->subResult(theRow));
}
static QModelIndex MYLastDeleted;
QModelIndex XGUI_DataModel::parent(const QModelIndex& theIndex) const
{
+ if (!theIndex.isValid())
+ return QModelIndex();
// To avoid additional request about index which was already deleted
if (theIndex == MYLastDeleted)
return QModelIndex();
DocumentPtr aRootDoc = aSession->moduleDocument();
DocumentPtr aSubDoc = aObj->document();
if (aSubDoc == aRootDoc) {
- if (aType == myXMLReader.rootType())
+ if (aType == myXMLReader->rootType())
return QModelIndex();
else {
// return first level of folder index
- int aFolderId = myXMLReader.rootFolderId(aType);
+ int aFolderId = myXMLReader->rootFolderId(aType);
// Items in a one row must have the same parent
return createIndex(aFolderId, 0, -1);
}
} else {
- if (aType == myXMLReader.subType())
+ if (aType == myXMLReader->subType())
return findDocumentRootIndex(aSubDoc.get());
else {
// return first level of folder index
- int aFolderId = myXMLReader.subFolderId(aType);
+ int aFolderId = myXMLReader->subFolderId(aType);
// Items in a one row must have the same parent
return createIndex(aFolderId, 0, aSubDoc.get());
}
// An object
if (aObj->isDisabled())
return theIndex.column() == 1? Qt::ItemIsSelectable : aNullFlag;
+
+ if (aSession->moduleDocument() != aObj->document())
+ if (aActiveDoc != aObj->document())
+ return theIndex.column() == 1? Qt::ItemIsSelectable : aNullFlag;
bool isCompositeSub = false;
// An object which is sub-object of a composite object can not be accessible in column 1
} else if (aDoc) {
// A folder under sub-document
if (aActiveDoc.get() != aDoc)
- return aDefaultFlag;
+ return aNullFlag;
}
return aEditingFlag;
}
{
SessionPtr aSession = ModelAPI_Session::get();
DocumentPtr aRootDoc = aSession->moduleDocument();
- if (myXMLReader.isAttachToResult()) { // If document is attached to result
+ if (myXMLReader->isAttachToResult()) { // If document is attached to result
int aNb = aRootDoc->size(ModelAPI_ResultPart::group());
ObjectPtr aObj;
ResultPartPtr aPartRes;
aPartRes = std::dynamic_pointer_cast<ModelAPI_ResultPart>(aObj);
if (aPartRes.get() && (aPartRes->partDoc().get() == theDoc)) {
int aRow = i;
- if (myXMLReader.rootType() == ModelAPI_Feature::group()) {
+ if (myXMLReader->rootType() == ModelAPI_Feature::group()) {
aRow += foldersCount();
}
return createIndex(aRow, 0, aObj.get());
aPartRes = getPartResult(aObj.get());
if (aPartRes.get() && (aPartRes->partDoc().get() == theDoc)) {
int aRow = i;
- if (myXMLReader.rootType() == ModelAPI_Feature::group())
+ if (myXMLReader->rootType() == ModelAPI_Feature::group())
aRow += foldersCount();
return createIndex(aRow, 0, aObj.get());
}
SessionPtr aSession = ModelAPI_Session::get();
DocumentPtr aRootDoc = aSession->moduleDocument();
if ((theDoc == 0) || (theDoc == aRootDoc.get())) {
- for (int i = 0; i < myXMLReader.rootFoldersNumber(); i++) {
- if (myXMLReader.rootShowEmpty(i))
+ for (int i = 0; i < myXMLReader->rootFoldersNumber(); i++) {
+ if (myXMLReader->rootShowEmpty(i))
aNb++;
else {
- if (aRootDoc->size(myXMLReader.rootFolderType(i)) > 0)
+ if (aRootDoc->size(myXMLReader->rootFolderType(i)) > 0)
aNb++;
}
}
} else {
- for (int i = 0; i < myXMLReader.subFoldersNumber(); i++) {
- if (myXMLReader.subShowEmpty(i))
+ for (int i = 0; i < myXMLReader->subFoldersNumber(); i++) {
+ if (myXMLReader->subShowEmpty(i))
aNb++;
else {
- if (theDoc->size(myXMLReader.subFolderType(i)) > 0)
+ if (theDoc->size(myXMLReader->subFolderType(i)) > 0)
aNb++;
}
}
SessionPtr aSession = ModelAPI_Session::get();
DocumentPtr aRootDoc = aSession->moduleDocument();
if ((theDoc == 0) || (theDoc == aRootDoc.get())) {
- for (int i = 0; i < myXMLReader.rootFoldersNumber(); i++) {
- if (!myXMLReader.rootShowEmpty(i)) {
- if (aRootDoc->size(myXMLReader.rootFolderType(i)) == 0)
+ for (int i = 0; i < myXMLReader->rootFoldersNumber(); i++) {
+ if (!myXMLReader->rootShowEmpty(i)) {
+ if (aRootDoc->size(myXMLReader->rootFolderType(i)) == 0)
aList.append(i);
}
}
} else {
- for (int i = 0; i < myXMLReader.subFoldersNumber(); i++) {
- if (!myXMLReader.subShowEmpty(i)) {
- if (theDoc->size(myXMLReader.subFolderType(i)) == 0)
+ for (int i = 0; i < myXMLReader->subFoldersNumber(); i++) {
+ if (!myXMLReader->subShowEmpty(i)) {
+ if (theDoc->size(myXMLReader->subFolderType(i)) == 0)
aList.append(i);
}
}
{
QStringList aResult;
if (fromRoot) {
- for (int i = 0; i < myXMLReader.rootFoldersNumber(); i++) {
- if (!myXMLReader.rootShowEmpty(i))
- aResult << myXMLReader.rootFolderType(i).c_str();
+ for (int i = 0; i < myXMLReader->rootFoldersNumber(); i++) {
+ if (!myXMLReader->rootShowEmpty(i))
+ aResult << myXMLReader->rootFolderType(i).c_str();
}
} else {
- for (int i = 0; i < myXMLReader.subFoldersNumber(); i++) {
- if (!myXMLReader.subShowEmpty(i))
- aResult << myXMLReader.subFolderType(i).c_str();
+ for (int i = 0; i < myXMLReader->subFoldersNumber(); i++) {
+ if (!myXMLReader->subShowEmpty(i))
+ aResult << myXMLReader->subFolderType(i).c_str();
}
}
return aResult;
else
return createIndex(foldersCount(aCurDoc.get()) - 1, 1, aCurDoc.get());
}
-}
\ No newline at end of file
+}
+
+//******************************************************
+int XGUI_DataModel::folderId(std::string theType, ModelAPI_Document* theDoc)
+{
+ SessionPtr aSession = ModelAPI_Session::get();
+ ModelAPI_Document* aDoc = theDoc;
+ if (aDoc == 0)
+ aDoc = aSession->moduleDocument().get();
+
+ bool aUseSubDoc = (aDoc != aSession->moduleDocument().get());
+
+ int aRes = -1;
+ if (aUseSubDoc) {
+ int aId = myXMLReader->subFolderId(theType);
+ aRes = aId;
+ for (int i = 0; i < aId; i++) {
+ if (!myXMLReader->subShowEmpty(i)) {
+ if (aDoc->size(myXMLReader->subFolderType(i)) == 0)
+ aRes--;
+ }
+ }
+ } else {
+ int aId = myXMLReader->rootFolderId(theType);
+ aRes = aId;
+ for (int i = 0; i < aId; i++) {
+ if (!myXMLReader->rootShowEmpty(i)) {
+ if (aDoc->size(myXMLReader->rootFolderType(i)) == 0)
+ aRes--;
+ }
+ }
+ }
+ return aRes;
+}
+
+//******************************************************
+void XGUI_DataModel::rebuildBranch(int theRow, int theCount, const QModelIndex& theParent)
+{
+ if (theCount > 0) {
+ removeRows(theRow, theCount, theParent);
+ insertRows(theRow, theCount, theParent);
+ }
+}