X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_Workshop.h;h=3f857ff12400d7f12e68d8f34869a788b504ac65;hb=d86c77d1c6210bbe04fbc3e5b00f9e212e1ec930;hp=6c9034d49e30d95b990a8cade7b9627bea1f6db5;hpb=37bf139347283d16d59b08079d52be5f6f29a38c;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_Workshop.h b/src/XGUI/XGUI_Workshop.h index 6c9034d49..3f857ff12 100644 --- a/src/XGUI/XGUI_Workshop.h +++ b/src/XGUI/XGUI_Workshop.h @@ -16,12 +16,19 @@ class XGUI_Workbench; class XGUI_SelectionMgr; class XGUI_Displayer; class XGUI_OperationMgr; +class XGUI_SalomeConnector; +class XGUI_ObjectsBrowser; +class XGUI_ActionsMgr; +class XGUI_ErrorDialog; class ModuleBase_Operation; class ModuleBase_PropPanelOperation; class Config_FeatureMessage; class Config_PointerMessage; +class QWidget; +class QDockWidget; + /**\class XGUI_Workshop * \ingroup GUI * \brief Class which defines a configuration of the application (Workshop) and launches it. @@ -31,7 +38,7 @@ class XGUI_EXPORT XGUI_Workshop: public QObject, public Events_Listener Q_OBJECT public: - XGUI_Workshop(); + XGUI_Workshop(XGUI_SalomeConnector* theConnector = 0); virtual ~XGUI_Workshop(); //! Starting of the application @@ -47,7 +54,7 @@ public: XGUI_SelectionMgr* selector() const { return mySelector; } //! Returns displayer - XGUI_Displayer* displayer() const { return myDisplayer; } + XGUI_Displayer* displayer() const; //! ! Returns operation manager. XGUI_OperationMgr* operationMgr() const { return myOperationMgr; } @@ -58,6 +65,19 @@ public: //! Redefinition of Events_Listener method virtual void processEvent(const Events_Message* theMessage); + XGUI_SalomeConnector* salomeConnector() const { return mySalomeConnector; } + + //! Returns true if the application works as SALOME module + bool isSalomeMode() const { return mySalomeConnector != 0; } + + //! Returns Object browser + XGUI_ObjectsBrowser* objectBrowser() const { return myObjectBrowser; } + + void salomeViewerSelectionChanged(); + +signals: + void salomeViewerSelection(); + public slots: void updateCommandStatus(); @@ -69,10 +89,22 @@ public slots: void onUndo(); void onRedo(); + void showPropertyPanel(); + void hidePropertyPanel(); + void showObjectBrowser(); + void hideObjectBrowser(); + + void onFeatureTriggered(); + void changeCurrentDocument(); + +signals: + void errorOccurred(const QString&); + protected: //Event-loop processing methods: void addFeature(const Config_FeatureMessage*); void connectWithOperation(ModuleBase_Operation* theOperation); + void saveDocument(QString theName); protected slots: /// SLOT, that is called after the operation is started. Update workshop state according to @@ -89,13 +121,24 @@ private: XGUI_Module* loadModule(const QString& theModule); bool activateModule(); + QDockWidget* createObjectBrowser(QWidget* theParent); + QDockWidget* createPropertyPanel(QWidget* theParent); + + // Creates Dock widgets: Object browser and Property panel + void createDockWidgets(); + void setPropertyPannelTitle(const QString& theTitle); + + QString myCurrentFile; XGUI_MainWindow* myMainWindow; XGUI_Module* myPartSetModule; - + XGUI_ObjectsBrowser* myObjectBrowser; + QDockWidget* myPropertyPanelDock; XGUI_SelectionMgr* mySelector; XGUI_Displayer* myDisplayer; - XGUI_OperationMgr* myOperationMgr; ///< manager to manipulate through the operations + XGUI_ActionsMgr* myActionsMgr; + XGUI_SalomeConnector* mySalomeConnector; + XGUI_ErrorDialog* myErrorDlg; }; #endif