Salome HOME
Merge branch 'Dev_1.2.0' of newgeom:newgeom into Dev_1.2.0
[modules/shaper.git] / src / ModuleBase / ModuleBase_WidgetValidated.h
index eb0f8fa7fc2a4505ffcbc873bc40a4c36f68cbff..0ac6657e7d302fe66846362903933581a8412ec6 100644 (file)
@@ -18,6 +18,8 @@
 
 class QWidget;
 class ModuleBase_IWorkshop;
+class ModuleBase_ISelection;
+class ModelAPI_Validator;
 class Config_WidgetAPI;
 class Handle_SelectMgr_EntityOwner;
 
@@ -47,8 +49,9 @@ class MODULEBASE_EXPORT ModuleBase_WidgetValidated : public ModuleBase_ModelWidg
   /// This value should be processed in the widget according to the needs
   /// The method is called by the current operation to process the operation preselection.
   /// It is redefined to check the value validity and if it is, fill the attribute with by value
-  /// \param theValue the wrapped widget value
-  virtual bool setSelection(ModuleBase_ViewerPrs theValue);
+  /// \param theValues the wrapped selection values
+  /// \param thePosition an index in the list of values, the values should be get from the index
+  virtual bool setSelection(const QList<ModuleBase_ViewerPrs>& theValues, int& thePosition);
 
 protected:
   /// Creates a backup of the current values of the attribute
@@ -76,6 +79,22 @@ protected:
   /// \param theWorkshop an active workshop
   /// \param toActivate a flag about activation or deactivation the filters
   virtual void activateFilters(ModuleBase_IWorkshop* theWorkshop, const bool toActivate) const;
+
+  /// Puts additional validators to the given list
+  /// \param theValidators a list of validators
+  /// \param theArguments a list of validators arguments
+  virtual void customValidators(std::list<ModelAPI_Validator*>& theValidators,
+                                std::list<std::list<std::string> >& theArguments) const;
+
+  /// Returns a list of selected presentations. Firstly it is obtained from the viewer,
+  /// if there are not selected objects in the viewer, it get the selection from the object browser.
+  /// If the browser has selected objects, the viewer prs objects are created with only object
+  /// field of the presentation initialized. The widget should accept the selection in the object
+  /// browser at the same way as in the viewer.
+  /// \param theSelection a selection, where the selected objects and presentations are found
+  /// \return a list of presentations
+  QList<ModuleBase_ViewerPrs> getSelectedEntitiesOrObjects(ModuleBase_ISelection* theSelection) const;
+
 };
 
 #endif /* MODULEBASE_WIDGETVALIDATED_H_ */