]> SALOME platform Git repositories - modules/gui.git/blob - src/SalomeApp/SalomeApp_Module.h
Salome HOME
644608c5d8c0f8aa6008c8988f7eb8cba6d2bdba
[modules/gui.git] / src / SalomeApp / SalomeApp_Module.h
1 // File:      SalomeApp_Module.h
2 // Created:   10/25/2004 11:33:06 AM
3 // Author:    Sergey LITONIN
4 // Copyright (C) CEA 2004
5
6 #ifndef SALOMEAPP_MODULE_H
7 #define SALOMEAPP_MODULE_H
8
9 #include "SalomeApp.h"
10 #include "SalomeApp_Selection.h"
11
12 #include <CAM_Module.h>
13
14 #include <string>
15
16 class QDockWindow;
17
18 class CAM_Study;
19
20 class QtxPopupMgr;
21
22 class SUIT_Operation;
23 class SUIT_Convertor;
24 class SUIT_ViewModel;
25 class SUIT_DataObject;
26
27 class SalomeApp_DataModel;
28 class SalomeApp_Application;
29 class SalomeApp_Preferences;
30 class SalomeApp_SelectionManager;
31 class SalomeApp_Operation;
32 class SalomeApp_SwitchOp;
33
34 /*!
35  * \brief Base class for all salome modules
36 */
37 class SALOMEAPP_EXPORT SalomeApp_Module : public CAM_Module
38 {
39   Q_OBJECT
40
41 public:
42   SalomeApp_Module( const QString& );
43   virtual ~SalomeApp_Module();
44
45   virtual void                        initialize( CAM_Application* );
46   virtual void                        windows( QMap<int, int>& ) const;
47   virtual void                        viewManagers( QStringList& ) const;
48
49   /*! engineIOR() should be a pure virtual method, to avoid logical errors!\n
50    * Implementation in derived classes can return the following values:\n
51    * module`s engine IOR - means that this is a standard SALOME module with a CORBA engine
52    * \li "" (empty string)   - means that this is a light module, default engine should be used for interaction with SALOMEDS persistence
53    * \li "-1"                - means that this is a light module, SALOMEDS persistence is not used at all\n
54    */
55   virtual QString                     engineIOR() const = 0;
56
57   virtual void                        contextMenuPopup( const QString&, QPopupMenu*, QString& );
58
59   virtual void                        createPreferences();
60   
61   /*! Convenient shortcuts*/
62  
63   SalomeApp_Application*              getApp() const;
64
65   virtual void                        update( const int );
66   // Update viewer or/and object browser etc. in accordance with update flags
67   // ( see SalomeApp_UpdateFlags enumeration ). Derived modules can redefine this method
68   // for their own purposes
69     
70   void                                updateObjBrowser( bool = true, SUIT_DataObject* = 0 );
71   // Update object bropwser ( for updating model or whole object browser use update() method
72   // can be used )
73   
74   virtual void                        selectionChanged();
75   virtual void                        preferencesChanged( const QString&, const QString& );
76
77   virtual void                        studyActivated() {};
78
79 public slots:
80   virtual bool                        activateModule( SUIT_Study* );
81   virtual bool                        deactivateModule( SUIT_Study* );
82
83   void                                MenuItem();
84
85 protected slots:
86   virtual void                        onModelSaved();
87   virtual void                        onModelOpened();
88   virtual void                        onModelClosed();
89   virtual void                        onOperationStopped( SUIT_Operation* );
90   virtual void                        onOperationDestroyed();
91
92 protected:
93   QtxPopupMgr*                        popupMgr();
94   SalomeApp_Preferences*              preferences() const;
95
96   virtual CAM_DataModel*              createDataModel();
97   virtual SalomeApp_Selection*        createSelection() const;
98   virtual void                        updateControls();
99
100   /*! Module stores operations in map. This method starts operation by id.
101    *  If operation isn't in map, then it will be created by createOperation method
102    *  and will be inserted to map
103    */
104   void                                startOperation( const int );
105
106   /*! Create operation by its id. You must not call this method, it will be called automatically
107    *  by startOperation. Please redefine this method in current module
108    */
109   virtual SalomeApp_Operation*        createOperation( const int ) const;
110
111   int                                 addPreference( const QString& label );
112   int                                 addPreference( const QString& label, const int pId, const int = -1,
113                                                      const QString& section = QString::null,
114                                                      const QString& param = QString::null );
115   QVariant                            preferenceProperty( const int, const QString& ) const;
116   void                                setPreferenceProperty( const int, const QString&, const QVariant& );
117
118 private:
119   typedef QMap<int,SalomeApp_Operation*> MapOfOperation;
120   
121 private:
122   QtxPopupMgr*          myPopupMgr;
123   MapOfOperation        myOperations;
124   SalomeApp_SwitchOp*   mySwitchOp;
125 };
126
127 #endif