X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ContextMenuMgr.h;h=40de3f5335dffc244cdebb58e907e80421532eb7;hb=59a007784d1e103bcb352c515eb6feafa170f1ff;hp=a8255ff0cab25dc269bf109b82d373c7574c6280;hpb=c2ffb268ca15d135b371efbde80ff33d59a08f24;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ContextMenuMgr.h b/src/XGUI/XGUI_ContextMenuMgr.h index a8255ff0c..40de3f533 100644 --- a/src/XGUI/XGUI_ContextMenuMgr.h +++ b/src/XGUI/XGUI_ContextMenuMgr.h @@ -1,3 +1,4 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D --> #ifndef XGUI_ContextMenuMgr_H #define XGUI_ContextMenuMgr_H @@ -12,42 +13,107 @@ class QAction; class QContextMenuEvent; class QMenu; -class XGUI_EXPORT XGUI_ContextMenuMgr: public QObject +/** + * \ingroup GUI + * A claas wihich provides manement of context menu + */ +class XGUI_EXPORT XGUI_ContextMenuMgr : public QObject { Q_OBJECT -public: + public: + /// Constructor + /// \param theParent a parent object XGUI_ContextMenuMgr(XGUI_Workshop* theParent); virtual ~XGUI_ContextMenuMgr(); + /// Create all actions for context menus. It is called on creation of application void createActions(); - void addAction(const QString& theId, QAction* theAction); - + /// Returns action according to the given ID + /// \param theId an id of an action QAction* action(const QString& theId) const; + /// Returns action object by its Id (name) + /// \param theName is an Id of the action + QAction* actionByName(const QString& theName) const; + + /// Returns list of registered actions Ids QStringList actionIds() const; + /// update state of internal commands void updateCommandsStatus(); - void connectObjectBrowser() const; + /// Connect to object browser from workshop. Has to called at creation of viewer. + void connectObjectBrowser(); + + /// Connect to viewer from workshop. Has to called at creation of viewer. + void connectViewer(); - void connectViewer() const; + /// Add menu items for Object browser pop-up + void addObjBrowserMenu(QMenu*) const; + + /// Add menu items for Viewer pop-up + void addViewerMenu(QMenu*) const; + + /// Returns a list of object group names of the action + /// \param theName a name of the action + /// \return a list of group names + QStringList actionObjectGroups(const QString& theName); + + /// Updates menu for viewer + void updateViewerMenu(); signals: + /// Signal aabout triggered action + /// \param theId an id of triggered action + /// \param isChecked is checked flag void actionTriggered(const QString& theId, bool isChecked); -private slots: + /// A signal which is sent before context menu show + void beforeContextMenu(); + + /// A signal which is sent after context menu show + void afterContextMenu(); + + private slots: + /// Process action event + /// \param isChecked a checked action flag void onAction(bool isChecked); + /// Process context menu event + /// \param theEvent a context menu event void onContextMenuRequest(QContextMenuEvent* theEvent); -private: - QMenu* objectBrowserMenu() const; - QMenu* viewerMenu() const; + void onRename(); + + private: + /** + * Add action + * \param theId - string ID of the item + * \param theAction - action to add + */ + void addAction(const QString& theId, QAction* theAction); + + /// Updates menu for object browser + void updateObjectBrowserMenu(); + /// Creates menu for object browser + void buildObjBrowserMenu(); + + /// Creates menu for viewer + void buildViewerMenu(); + + /// Map of created actions [id : Action] QMap myActions; + /// Reference to workshop XGUI_Workshop* myWorkshop; + + typedef QList QActionsList; + QMap myObjBrowserMenus; + QMap myViewerMenu; + + QAction* mySeparator; }; -#endif \ No newline at end of file +#endif