+ /// Actions on operations
+ enum OperationStateActionId {
+ Abort = 0,
+ Accept = 1,
+ AcceptPlus = 2,
+ Help = 3,
+ AbortAll = 4,
+ AcceptAll = 5,
+ Preview = 6
+ };
+
+ /// Add a command in the manager.
+ /// 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<Events_Message>& theMessage);
+
+ /// Return property panel's action like ok, cancel, help.
+ /// If there is no such action, it will be created.
+ QAction* operationStateAction(OperationStateActionId theId);