X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_ModelWidget.cpp;h=939345b517beefd395652896b194802d34b728a9;hb=2ca8be5b9d184c33cbfd78b1259638f340eeb017;hp=cd56f06c363d259b3dbbfad4bdaafe1cd2b56da9;hpb=db1e462ad6a76ee857f47602ec9acba6315529c8;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_ModelWidget.cpp b/src/ModuleBase/ModuleBase_ModelWidget.cpp index cd56f06c3..939345b51 100644 --- a/src/ModuleBase/ModuleBase_ModelWidget.cpp +++ b/src/ModuleBase/ModuleBase_ModelWidget.cpp @@ -6,28 +6,43 @@ #include #include +#include +#include -#include "Config_WidgetAPI.h" +#include +#include +#include + +#include #include -ModuleBase_ModelWidget::ModuleBase_ModelWidget(QObject* theParent, const Config_WidgetAPI* theData) - : QObject(theParent), myHasDefaultValue(false) +ModuleBase_ModelWidget::ModuleBase_ModelWidget(QObject* theParent, const Config_WidgetAPI* theData, + const std::string& theParentId) + : QObject(theParent), + myParentId(theParentId) { + myIsComputedDefault = false; + myIsObligatory = theData ? theData->getBooleanAttribute(FEATURE_OBLIGATORY, true) : true; myAttributeID = theData ? theData->widgetId() : ""; } -bool ModuleBase_ModelWidget::isInitialized(FeaturePtr theFeature) const +bool ModuleBase_ModelWidget::isInitialized(ObjectPtr theObject) const { - return theFeature->data()->attribute(attributeID())->isInitialized(); + return theObject->data()->attribute(attributeID())->isInitialized(); } -bool ModuleBase_ModelWidget::canFocusTo(const std::string& theAttributeName) const +void ModuleBase_ModelWidget::enableFocusProcessing() { - return theAttributeName == attributeID(); + QList aMyControls = getControls(); + foreach(QWidget* eachControl, aMyControls) { + if(!myFocusInWidgets.contains(eachControl)) { + enableFocusProcessing(eachControl); + } + } } -void ModuleBase_ModelWidget::focusTo() +bool ModuleBase_ModelWidget::focusTo() { QList aControls = getControls(); QList::const_iterator anIt = aControls.begin(), aLast = aControls.end(); @@ -38,9 +53,31 @@ void ModuleBase_ModelWidget::focusTo() break; } } + return true; +} + + +void ModuleBase_ModelWidget::updateObject(ObjectPtr theObj) const +{ + Events_Loop::loop()->flush(Events_Loop::eventByName(EVENT_OBJECT_UPDATED)); + static Events_ID anEvent = Events_Loop::eventByName(EVENT_OBJECT_TO_REDISPLAY); + ModelAPI_EventCreator::get()->sendUpdated(theObj, anEvent); +} + +void ModuleBase_ModelWidget::enableFocusProcessing(QWidget* theWidget) +{ + theWidget->setFocusPolicy(Qt::StrongFocus); + theWidget->installEventFilter(this); + myFocusInWidgets.append(theWidget); } -std::string ModuleBase_ModelWidget::attributeID() const +bool ModuleBase_ModelWidget::eventFilter(QObject* theObject, QEvent *theEvent) { - return myAttributeID; + QWidget* aWidget = dynamic_cast(theObject); + if (theEvent->type() == QEvent::MouseButtonRelease && + myFocusInWidgets.contains(aWidget)) { + emit focusInWidget(this); + } + // pass the event on to the parent class + return QObject::eventFilter(theObject, theEvent); }