X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ModuleConnector.cpp;h=7231a1b28c33b8e790775019ebcbffb6ae3befcb;hb=39aa2839a4269a2fc87cfe3b4487cce8f3df9a6f;hp=8fd52e598bfc06d6568a75d85aea966398421a86;hpb=344158ffea05b687f0d8313ec12013d695f295ff;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ModuleConnector.cpp b/src/XGUI/XGUI_ModuleConnector.cpp index 8fd52e598..7231a1b28 100644 --- a/src/XGUI/XGUI_ModuleConnector.cpp +++ b/src/XGUI/XGUI_ModuleConnector.cpp @@ -16,6 +16,7 @@ #include #include +#include #include @@ -31,8 +32,6 @@ XGUI_ModuleConnector::XGUI_ModuleConnector(XGUI_Workshop* theWorkshop) { XGUI_SelectionMgr* aSelector = myWorkshop->selector(); connect(aSelector, SIGNAL(selectionChanged()), this, SIGNAL(selectionChanged())); - - XGUI_OperationMgr* anOperationMgr = myWorkshop->operationMgr(); } XGUI_ModuleConnector::~XGUI_ModuleConnector() @@ -79,8 +78,11 @@ QObjectPtrList XGUI_ModuleConnector::activeObjects(const QObjectPtrList& theObjL void XGUI_ModuleConnector::activateSubShapesSelection(const QIntList& theTypes) { + QIntList aTypes = theTypes; + XGUI_Displayer* aDisp = myWorkshop->displayer(); - aDisp->activateObjects(theTypes, activeObjects(aDisp->displayedObjects())); + myWorkshop->module()->customSubShapesSelectionModes(aTypes); + aDisp->activateObjects(aTypes, activeObjects(aDisp->displayedObjects())); } void XGUI_ModuleConnector::deactivateSubShapesSelection() @@ -115,7 +117,7 @@ void XGUI_ModuleConnector::setSelected(const QList& the myWorkshop->selector()->clearSelection(); } else { aDisp->setSelected(theValues); - } + } } void XGUI_ModuleConnector::setStatusBarMessage(const QString& theMessage) @@ -128,6 +130,24 @@ bool XGUI_ModuleConnector::canStartOperation(QString theId) return myWorkshop->operationMgr()->canStartOperation(theId); } +void XGUI_ModuleConnector::processLaunchOperation(ModuleBase_Operation* theOperation) +{ + XGUI_OperationMgr* anOperationMgr = workshop()->operationMgr(); + + if (anOperationMgr->startOperation(theOperation)) { + ModuleBase_OperationFeature* aFOperation = + dynamic_cast(theOperation); + if (aFOperation) { + workshop()->propertyPanel()->updateContentWidget(aFOperation->feature()); + workshop()->propertyPanel()->createContentPanel(aFOperation->feature()); + } + if (!theOperation->getDescription()->hasXmlRepresentation()) { + if (theOperation->commit()) + workshop()->updateCommandStatus(); + } + } +} + ModuleBase_Operation* XGUI_ModuleConnector::findStartedOperation(const QString& theId) { return myWorkshop->operationMgr()->findOperation(theId); @@ -138,9 +158,9 @@ bool XGUI_ModuleConnector::canStopOperation(ModuleBase_Operation* theOperation) return myWorkshop->operationMgr()->canStopOperation(theOperation); } -void XGUI_ModuleConnector::abortOperation(ModuleBase_Operation* theOperation) +void XGUI_ModuleConnector::stopOperation(ModuleBase_Operation* theOperation) { - myWorkshop->operationMgr()->abortOperation(theOperation); + myWorkshop->operationMgr()->stopOperation(theOperation); } void XGUI_ModuleConnector::updateCommandStatus() @@ -148,9 +168,9 @@ void XGUI_ModuleConnector::updateCommandStatus() myWorkshop->updateCommandStatus(); } -QMainWindow* XGUI_ModuleConnector::desktop() const -{ - return myWorkshop->desktop(); +QMainWindow* XGUI_ModuleConnector::desktop() const +{ + return myWorkshop->desktop(); } @@ -158,8 +178,8 @@ std::shared_ptr XGUI_ModuleConnector::featureInfo(const Q { #ifdef HAVE_SALOME return myWorkshop->salomeConnector()->featureInfo(theId); -#else - AppElements_Command* aAction = +#else + AppElements_Command* aAction = dynamic_cast(myWorkshop->actionsMgr()->action(theId)); if (aAction) return aAction->featureMessage();