Salome HOME
Merge branch 'master' of newgeom:newgeom
[modules/shaper.git] / src / XGUI / XGUI_Workshop.h
index e745c25af8c8854191f385d698ce5cc71a180e66..50e0a44cc0759dc0702f330cc29d552712a5c36c 100644 (file)
@@ -1,7 +1,7 @@
 #ifndef XGUI_WORKSHOP_H
 #define XGUI_WORKSHOP_H
 
-#include <Event_Message.h>
+#include "XGUI.h"
 #include <Event_Listener.h>
 
 #include <QObject>
@@ -13,12 +13,19 @@ class XGUI_MainWindow;
 class XGUI_Command;
 class XGUI_Module;
 class XGUI_Workbench;
+class XGUI_SelectionMgr;
+class XGUI_Displayer;
 class ModuleBase_Operation;
+class ModuleBase_PropPanelOperation;
 
 class Config_FeatureMessage;
 class Config_PointerMessage;
 
-class XGUI_Workshop: public QObject, public Event_Listener
+/**\class XGUI_Workshop
+ * \ingroup GUI
+ * \brief Class which defines a configuration of the application (Workshop) and launches it.
+ */
+class XGUI_EXPORT XGUI_Workshop: public QObject, public Event_Listener
 {
 Q_OBJECT
 public:
@@ -26,28 +33,45 @@ public:
   XGUI_Workshop();
   virtual ~XGUI_Workshop();
 
+  //! Starting of the application
   void startApplication();
 
+  //! Returns main window (Desktop) of the application
   XGUI_MainWindow* mainWindow() const
   {
     return myMainWindow;
   }
 
+  //! Returns selection manager object
+  XGUI_SelectionMgr* selector() const { return mySelector; }
+
+  //! Returns displayer
+  XGUI_Displayer* displayer() const { return myDisplayer; }
+
+  //! Creates and adds a new workbench (menu group) with the given name and returns it
   XGUI_Workbench* addWorkbench(const QString& theName);
 
+  //! Returns the current operation or NULL
+  ModuleBase_Operation* currentOperation() { return myCurrentOperation; }
+
+  //! Redefinition of Event_Listener method
   virtual void processEvent(const Event_Message* theMessage);
 
 public slots:
+  void updateCommandStatus();
+
   void onNew();
   void onOpen();
   void onSave();
   void onSaveAs();
   void onExit();
+  void onUndo();
+  void onRedo();
 
 protected:
   //Event-loop processing methods:
   void addFeature(const Config_FeatureMessage*);
-  void fillPropertyPanel(ModuleBase_Operation* theOperation);
+  void fillPropertyPanel(ModuleBase_PropPanelOperation* theOperation);
   void connectToPropertyPanel(ModuleBase_Operation* theOperation);
   void setCurrentOperation(ModuleBase_Operation* theOperation);
 
@@ -60,6 +84,9 @@ private:
   XGUI_MainWindow* myMainWindow;
   XGUI_Module* myPartSetModule;
 
+  XGUI_SelectionMgr* mySelector;
+  XGUI_Displayer* myDisplayer;
+
   ModuleBase_Operation* myCurrentOperation;
 };