+// Copyright (C) 2014-20xx CEA/DEN, EDF R&D -->
+
#include "XGUI_ObjectsBrowser.h"
#include "XGUI_DocumentDataModel.h"
#include "XGUI_Tools.h"
#include <ModelAPI_Data.h>
-#include <ModelAPI_PluginManager.h>
+#include <ModelAPI_Session.h>
#include <ModelAPI_Document.h>
#include <ModelAPI_Object.h>
#include <QMouseEvent>
#include <QAction>
-
-
XGUI_DataTree::XGUI_DataTree(QWidget* theParent)
- : QTreeView(theParent)
+ : QTreeView(theParent)
{
setHeaderHidden(true);
setModel(new XGUI_DocumentDataModel(this));
setSelectionBehavior(QAbstractItemView::SelectRows);
setSelectionMode(QAbstractItemView::ExtendedSelection);
- connect(selectionModel(), SIGNAL(selectionChanged(const QItemSelection&, const QItemSelection&)),
+ connect(selectionModel(), SIGNAL(selectionChanged(const QItemSelection&, const QItemSelection&)),
this, SLOT(onSelectionChanged(const QItemSelection&, const QItemSelection&)));
}
{
}
-XGUI_DocumentDataModel* XGUI_DataTree::dataModel() const
-{
- return static_cast<XGUI_DocumentDataModel*>(model());
+XGUI_DocumentDataModel* XGUI_DataTree::dataModel() const
+{
+ return static_cast<XGUI_DocumentDataModel*>(model());
}
-
-void XGUI_DataTree::onSelectionChanged(const QItemSelection& theSelected,
- const QItemSelection& theDeselected)
+void XGUI_DataTree::onSelectionChanged(const QItemSelection& theSelected,
+ const QItemSelection& theDeselected)
{
mySelectedData.clear();
QModelIndexList aIndexes = selectionModel()->selectedIndexes();
if (theEvent->button() == Qt::LeftButton) {
QModelIndex aIndex = currentIndex();
XGUI_DocumentDataModel* aModel = dataModel();
-
- if ((aModel->activePartIndex() != aIndex) && aModel->activePartIndex().isValid()) {
- setExpanded(aModel->activePartIndex(), false);
- }
- bool isChanged = aModel->activatedIndex(aIndex);
- QTreeView::mouseDoubleClickEvent(theEvent);
- if (isChanged) {
- if (aModel->activePartIndex().isValid())
- setExpanded(aIndex, true);
- emit activePartChanged(aModel->activePart());
+ ObjectPtr aObject = aModel->object(aIndex);
+ ResultPartPtr aPart = std::dynamic_pointer_cast<ModelAPI_ResultPart>(aObject);
+ if (aPart) {
+ aPart->activate();
}
- } else
+ } else
QTreeView::mouseDoubleClickEvent(theEvent);
}
if (aEditor) {
QString aRes = aEditor->text();
ObjectPtr aFeature = mySelectedData.first();
- PluginManagerPtr aMgr = ModelAPI_PluginManager::get();
- aMgr->rootDocument()->startOperation();
+ SessionPtr aMgr = ModelAPI_Session::get();
+ aMgr->startOperation("RenameFeature");
aFeature->data()->setName(qPrintable(aRes));
- aMgr->rootDocument()->finishOperation();
+ aMgr->finishOperation();
}
}
+void XGUI_DataTree::clear()
+{
+ mySelectedData.clear();
+ XGUI_DocumentDataModel* aModel = dataModel();
+ aModel->clear();
+ reset();
+}
+
//********************************************************************
//********************************************************************
//********************************************************************
XGUI_ObjectsBrowser::XGUI_ObjectsBrowser(QWidget* theParent)
- : QWidget(theParent)
+ : QWidget(theParent)
{
QVBoxLayout* aLayout = new QVBoxLayout(this);
aLayout->setContentsMargins(0, 0, 0, 0);
aLabelLay->addWidget(aLbl);
- PluginManagerPtr aMgr = ModelAPI_PluginManager::get();
- DocumentPtr aDoc = aMgr->rootDocument();
+ SessionPtr aMgr = ModelAPI_Session::get();
+ DocumentPtr aDoc = aMgr->moduleDocument();
// TODO: Find a name of the root document
myActiveDocLbl = new QLineEdit(tr("Part set"), aLabelWgt);
myActiveDocLbl->installEventFilter(this);
aLabelLay->addWidget(myActiveDocLbl);
- aLabelLay->setStretch(1,1);
+ aLabelLay->setStretch(1, 1);
myTreeView = new XGUI_DataTree(this);
aLayout->addWidget(myTreeView);
aLabelWgt->setFrameShadow(myTreeView->frameShadow());
connect(myTreeView, SIGNAL(selectionChanged()), this, SLOT(onSelectionChanged()));
- connect(myTreeView, SIGNAL(activePartChanged(ObjectPtr)), this, SLOT(onActivePartChanged(ObjectPtr)));
- connect(myTreeView, SIGNAL(activePartChanged(ObjectPtr)), this, SIGNAL(activePartChanged(ObjectPtr)));
-
- connect(myActiveDocLbl, SIGNAL(customContextMenuRequested(const QPoint&)),
- this, SLOT(onLabelContextMenuRequested(const QPoint&)));
- connect(myTreeView, SIGNAL(contextMenuRequested(QContextMenuEvent*)),
- this, SLOT(onContextMenuRequested(QContextMenuEvent*)));
-
+ connect(myTreeView, SIGNAL(activePartChanged(ObjectPtr)), this,
+ SLOT(onActivePartChanged(ObjectPtr)));
+ connect(myTreeView, SIGNAL(activePartChanged(ObjectPtr)), this,
+ SIGNAL(activePartChanged(ObjectPtr)));
+
+ connect(myActiveDocLbl, SIGNAL(customContextMenuRequested(const QPoint&)), this,
+ SLOT(onLabelContextMenuRequested(const QPoint&)));
+ connect(myTreeView, SIGNAL(contextMenuRequested(QContextMenuEvent*)), this,
+ SLOT(onContextMenuRequested(QContextMenuEvent*)));
+
onActivePartChanged(ObjectPtr());
// Create internal actions
QPalette aPalet = myActiveDocLbl->palette();
if (thePart) {
aPalet.setColor(QPalette::Text, Qt::black);
- } else {
+ } else {
aPalet.setColor(QPalette::Text, QColor(0, 72, 140));
}
myActiveDocLbl->setPalette(aPalet);
} else if (theEvent->type() == QEvent::KeyRelease) {
QKeyEvent* aEvent = (QKeyEvent*) theEvent;
switch (aEvent->key()) {
- case Qt::Key_Return: // Accept current input
- closeDocNameEditing(true);
- break;
- case Qt::Key_Escape: // Cancel the input
- closeDocNameEditing(false);
- break;
- }
+ case Qt::Key_Return:
+ case Qt::Key_Enter: // Accept current input
+ closeDocNameEditing(true);
+ break;
+ case Qt::Key_Escape: // Cancel the input
+ closeDocNameEditing(false);
+ break;
+ }
}
}
}
myActiveDocLbl->setReadOnly(true);
if (toSave) {
// TODO: Save the name of root document
- PluginManagerPtr aMgr = ModelAPI_PluginManager::get();
- DocumentPtr aDoc = aMgr->rootDocument();
+ SessionPtr aMgr = ModelAPI_Session::get();
+ DocumentPtr aDoc = aMgr->moduleDocument();
} else {
myActiveDocLbl->setText(myActiveDocLbl->property("OldText").toString());
}
}
//***************************************************
-void XGUI_ObjectsBrowser::onContextMenuRequested(QContextMenuEvent* theEvent)
+void XGUI_ObjectsBrowser::onContextMenuRequested(QContextMenuEvent* theEvent)
{
myObjectsList = myTreeView->selectedObjects();
- bool toEnable = myObjectsList.size() > 0;
- foreach(QAction* aCmd, actions()) {
+ bool toEnable = myObjectsList.size() == 1;
+ foreach(QAction* aCmd, actions())
+ {
aCmd->setEnabled(toEnable);
}
emit contextMenuRequested(theEvent);
{
myObjectsList.clear();
//Empty feature pointer means that selected root document
- myObjectsList.append(ObjectPtr());
+ myObjectsList.append(ObjectPtr());
- foreach(QAction* aCmd, actions()) {
+ foreach(QAction* aCmd, actions())
+ {
aCmd->setEnabled(true);
}
- QContextMenuEvent aEvent( QContextMenuEvent::Mouse, thePnt, myActiveDocLbl->mapToGlobal(thePnt) );
+ QContextMenuEvent aEvent(QContextMenuEvent::Mouse, thePnt, myActiveDocLbl->mapToGlobal(thePnt));
emit contextMenuRequested(&aEvent);
}
{
if (myObjectsList.size() > 0) {
ObjectPtr aFeature = myObjectsList.first();
- if (aFeature) { // Selection happens in TreeView
+ if (aFeature) { // Selection happens in TreeView
// Find index which corresponds the feature
QModelIndex aIndex;
- foreach(QModelIndex aIdx, selectedIndexes()) {
+ foreach(QModelIndex aIdx, selectedIndexes())
+ {
ObjectPtr aFea = dataModel()->object(aIdx);
if (dataModel()->object(aIdx)->isSame(aFeature)) {
aIndex = aIdx;
myTreeView->setCurrentIndex(aIndex);
myTreeView->edit(aIndex);
}
- } else { //Selection happens in Upper label
+ } else { //Selection happens in Upper label
myActiveDocLbl->setReadOnly(false);
myActiveDocLbl->setFocus();
myActiveDocLbl->selectAll();
}
//***************************************************
-void XGUI_ObjectsBrowser::setObjectsSelected(const QList<ObjectPtr>& theObjects)
+void XGUI_ObjectsBrowser::setObjectsSelected(const QObjectPtrList& theObjects)
{
QList<QModelIndex> theIndexes;
QItemSelectionModel* aSelectModel = myTreeView->selectionModel();
aSelectModel->clear();
- foreach(ObjectPtr aFeature, theObjects) {
+ foreach(ObjectPtr aFeature, theObjects)
+ {
QModelIndex aIndex = myDocModel->objectIndex(aFeature);
if (aIndex.isValid()) {
aSelectModel->select(aIndex, QItemSelectionModel::Select);
}
}
}
+
+//***************************************************
+void XGUI_ObjectsBrowser::processEvent(const std::shared_ptr<Events_Message>& theMessage)
+{
+ myDocModel->processEvent(theMessage);
+}
+
+
+//***************************************************
+void XGUI_ObjectsBrowser::clearContent()
+{
+ myObjectsList.clear();
+ myTreeView->clear();
+}