1 // Copyright (C) 2014-20xx CEA/DEN, EDF R&D
3 // File: ModuleBase_WidgetValidated.h
4 // Created: 12 Mar 2015
5 // Author: Natalia ERMOLAEVA
8 #ifndef MODULEBASE_WIDGETVALIDATED_H_
9 #define MODULEBASE_WIDGETVALIDATED_H_
11 #include <ModuleBase.h>
12 #include <ModuleBase_ModelWidget.h>
14 #include <GeomAPI_Shape.h>
15 #include <ModelAPI_Object.h>
17 #include <SelectMgr_ListOfFilter.hxx>
20 class ModuleBase_IWorkshop;
21 class ModuleBase_ISelection;
22 class ModelAPI_Validator;
23 class Config_WidgetAPI;
24 class Handle_SelectMgr_EntityOwner;
28 * Implementation of widget with validators and filters processing.
30 class MODULEBASE_EXPORT ModuleBase_WidgetValidated : public ModuleBase_ModelWidget
35 /// \param theParent the parent object
36 /// \param theData the widget configuation. The attribute of the model widget is obtained from
37 /// \param theParentId is Id of a parent of the current attribute
38 ModuleBase_WidgetValidated(QWidget* theParent,
39 const Config_WidgetAPI* theData,
40 const std::string& theParentId);
41 virtual ~ModuleBase_WidgetValidated();
43 /// Checks all widget validator if the owner is valid
44 /// \param theValue a selected presentation in the view
45 /// \return a boolean value
46 bool isValidSelection(const ModuleBase_ViewerPrs& theValue);
48 /// Set the given wrapped value to the current widget
49 /// This value should be processed in the widget according to the needs
50 /// The method is called by the current operation to process the operation preselection.
51 /// It is redefined to check the value validity and if it is, fill the attribute with by value
52 /// \param theValues the wrapped selection values
53 /// \param thePosition an index in the list of values, the values should be get from the index
54 virtual bool setSelection(const QList<ModuleBase_ViewerPrs>& theValues, int& thePosition);
57 /// Creates a backup of the current values of the attribute
58 /// It should be realized in the specific widget because of different
59 /// parameters of the current attribute
60 virtual void storeAttributeValue() = 0;
62 /// Creates a backup of the current values of the attribute
63 /// It should be realized in the specific widget because of different
64 /// parameters of the current attribute
65 /// \param theValid a boolean flag, if restore happens for valid parameters
66 virtual void restoreAttributeValue(const bool theValid) = 0;
68 /// Checks the widget validity. By default, it returns true.
69 /// \param theValue a selected presentation in the view
70 /// \return a boolean value
71 virtual bool isValidSelectionCustom(const ModuleBase_ViewerPrs& thePrs);
73 /// Fills the attribute with the value of the selected owner
74 /// \param theOwner a selected owner
75 virtual bool setSelectionCustom(const ModuleBase_ViewerPrs& thePrs) = 0;
77 virtual void removePresentations() {};
79 /// Checks the current attibute in all attribute validators
80 // \return true if all validators return that the attribute is valid
81 bool isValidAttribute() const;
83 /// It obtains selection filters from the workshop and activates them in the active viewer
84 /// \param theWorkshop an active workshop
85 /// \param toActivate a flag about activation or deactivation the filters
86 virtual void activateFilters(ModuleBase_IWorkshop* theWorkshop, const bool toActivate) const;
88 /// Puts additional validators to the given list
89 /// \param theValidators a list of validators
90 /// \param theArguments a list of validators arguments
91 virtual void customValidators(std::list<ModelAPI_Validator*>& theValidators,
92 std::list<std::list<std::string> >& theArguments) const;
95 #endif /* MODULEBASE_WIDGETVALIDATED_H_ */