X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FXGUI%2FXGUI_ActionsMgr.h;h=0acc6a26a98b8254fc501c208b9f57b8b57e9c00;hb=9129370ff85bfb4c0c37d9f32f9d107041ec2fe8;hp=4a6ad4a6bc1d5e757bc882eab730bbf15f42eced;hpb=32d1a4d19ab1a5d7c172e9660130fcf8ecb1e520;p=modules%2Fshaper.git diff --git a/src/XGUI/XGUI_ActionsMgr.h b/src/XGUI/XGUI_ActionsMgr.h index 4a6ad4a6b..0acc6a26a 100644 --- a/src/XGUI/XGUI_ActionsMgr.h +++ b/src/XGUI/XGUI_ActionsMgr.h @@ -1,3 +1,5 @@ +// Copyright (C) 2014-20xx CEA/DEN, EDF R&D --> + /* * XGUI_ActionsMgr.h */ @@ -7,39 +9,80 @@ #include "XGUI.h" +#include +#include + +#include + #include #include #include #include #include -class XGUI_Command; class XGUI_Workshop; class XGUI_OperationMgr; class ModuleBase_Operation; class QAction; -class XGUI_EXPORT XGUI_ActionsMgr : public QObject +/** +* \ingroup GUI +* A class for management of actions (features) activation/deactivation +*/ +class XGUI_EXPORT XGUI_ActionsMgr : public QObject, public Events_Listener { -Q_OBJECT + Q_OBJECT public: + /// Constructor + /// \param theWorkshop an instance of workshop XGUI_ActionsMgr(XGUI_Workshop* theWorkshop); virtual ~XGUI_ActionsMgr(); + /// Actions on operations + enum OperationStateActionId { + Abort = 0, + Accept = 1, + Help = 2, + AbortAll = 3, + AcceptAll = 4 + }; + //! Add a command in the manager. - //! Please note that nested commands in the Salome mode (No XGUI_Command, pure QActions) + //! Please note that nested commands in the Salome mode (No AppElements_Command, pure QActions) //! won't be extracted and should be added manually using the addNestedCommands method. void addCommand(QAction* theCmd); + //! Sets relation between the command (with given Id) and it's nested actions. void addNestedCommands(const QString& theId, const QStringList& theCommands); + //! Returns list of nested commands by parent command Id + //! \param theId a parent command Id QStringList nestedCommands(const QString& theId) const; + /// Returns True if the given Id is an Id of nested command + /// \param theId an Id to check bool isNested(const QString& theId) const; + /// Registers shortcut (key sequence) for the command triggering + /// \param theKeySequence a key sequence to register + QKeySequence registerShortcut(const QKeySequence& theKeySequence); + + /// This is an overloaded function. + /// Registers shortcut (key sequence) for the command triggering + /// \param theKeySequence - string that contain a key sequence to register QKeySequence registerShortcut(const QString& theKeySequence); + //! Redefinition of Events_Listener method + virtual void processEvent(const std::shared_ptr& theMessage); + + //! Return property panel's action like ok, cancel, help. + //! If there is no such action, it will be created. + QAction* operationStateAction(OperationStateActionId theId, QObject* theParent = 0); + + /// Return info (icon, text, etc) about the action by the given id, if it was registered in the manager + ActionInfo actionInfoById(const QString& theId); + public slots: //! Update workbench actions according to OperationMgr state: //! No active operations: all actions but nested are available @@ -48,23 +91,31 @@ Q_OBJECT void update(); //! Sets all commands checked if it's operation is active. void updateCheckState(); + //! Updates actions according to current selection in the viewer + void updateOnViewSelection(); protected: //! Sets all actions to isEnabled state. void setAllEnabled(bool isEnabled); - //! Sets to isEnabled state all siblings of the given operation and it's parents recursively - void setNestedStackEnabled(ModuleBase_Operation* theOperation); //! Sets all nested actions to isEnabled state for the command with given ID. //! If ID is empty - all nested actions will be affected. void setNestedCommandsEnabled(bool isEnabled, const QString& theParent = QString()); + //! Sets to enabled state all siblings of the given operation and it's parents recursively + void setNestedStackEnabled(ModuleBase_Operation* theOperation); //! Sets the action with theId to theChecked state. void setActionChecked(const QString& theId, const bool theChecked); //! Sets the action with theId to theEnabled state. void setActionEnabled(const QString& theId, const bool theEnabled); + //! Updates actions according to their "document" tag + void updateByDocumentKind(); + //! Asks plugins about their features state, using the Events system + void updateByPlugins(FeaturePtr theActiveFeature); private: + QMap myActions; QMap myNestedActions; + QMap myOperationActions; QList myShortcuts; XGUI_Workshop* myWorkshop;