#include <ModuleBase_OperationDescription.h>
#include <ModuleBase_WidgetFactory.h>
#include <ModuleBase_IModule.h>
+#include <ModuleBase_ResultPrs.h>
#include <ModelAPI_ResultConstruction.h>
ModuleBase_WidgetSelector::ModuleBase_WidgetSelector(QWidget* theParent,
ModuleBase_IWorkshop* theWorkshop,
- const Config_WidgetAPI* theData,
- const std::string& theParentId)
- : ModuleBase_WidgetValidated(theParent, theWorkshop, theData, theParentId)
+ const Config_WidgetAPI* theData)
+: ModuleBase_WidgetValidated(theParent, theWorkshop, theData)
{
}
//********************************************************************
void ModuleBase_WidgetSelector::onSelectionChanged()
{
- clearAttribute();
-
QList<ModuleBase_ViewerPrs> aSelected = getFilteredSelected();
-
bool isDone = setSelection(aSelected, true/*false*/);
+ updateOnSelectionChanged(isDone);
+}
+
+//********************************************************************
+void ModuleBase_WidgetSelector::updateOnSelectionChanged(const bool theDone)
+{
// "false" flag should be used here, it connects to the #26658 OCC bug, when the user click in
// the same place repeatedly without mouse moved. In the case validation by filters is not
// perfromed, so an invalid object is selected. E.g. distance constraint, selection of a point.
// we need to forget about previous validation result as the current selection can influence on it
clearValidatedCash();
- if (isDone)
+ if (theDone)
updateFocus();
}
+//********************************************************************
+QList<ModuleBase_ViewerPrs> ModuleBase_WidgetSelector::getAttributeSelection() const
+{
+ return QList<ModuleBase_ViewerPrs>();
+}
+
//********************************************************************
bool ModuleBase_WidgetSelector::acceptSubShape(const GeomShapePtr& theShape,
const ResultPtr& theResult) const
QIntList::const_iterator anIt = aShapeTypes.begin(), aLast = aShapeTypes.end();
for (; anIt != aLast; anIt++) {
- if (aShapeType == *anIt)
+ TopAbs_ShapeEnum aCurrentShapeType = (TopAbs_ShapeEnum)*anIt;
+ if (aShapeType == aCurrentShapeType)
aValid = true;
- else if (*anIt == TopAbs_FACE) {
+ else if (aCurrentShapeType == TopAbs_FACE) {
// try to process the construction shape only if there is no a selected shape in the viewer
if (!theShape.get() && theResult.get()) {
ResultConstructionPtr aCResult =
std::dynamic_pointer_cast<ModelAPI_ResultConstruction>(theResult);
aValid = aCResult.get() && aCResult->facesNum() > 0;
}
+ aValid = ModuleBase_ResultPrs::isValidShapeType(aCurrentShapeType, aShapeType);
}
}
return aValid;
}
//********************************************************************
-void ModuleBase_WidgetSelector::activateSelectionAndFilters(bool toActivate)
+bool ModuleBase_WidgetSelector::activateSelectionAndFilters(bool toActivate)
{
updateSelectionName();
} else {
myWorkshop->deactivateSubShapesSelection();
}
- activateFilters(toActivate);
+ return activateFilters(toActivate);
}
//********************************************************************
GeomShapePtr aShape;
getGeomSelection(thePrs, anObject, aShape);
- setObject(anObject, aShape);
+ ModuleBase_Tools::setObject(attributeToValidate(), anObject, aShape, myWorkshop, false);
return true;
}
ModuleBase_WidgetFactory aFactory(aXmlCfg, theWorkshop);
std::string anAttributeTitle;
- aFactory.getAttributeTitle(aFeature->getKind(), theAttribute->id(), anAttributeTitle);
+ aFactory.getAttributeTitle(theAttribute->id(), anAttributeTitle);
std::stringstream aStreamName;
aStreamName << theAttribute->owner()->data()->name() << "/"<< anAttributeTitle.c_str();