const std::string& theParentId)
: QWidget(theParent),
myParentId(theParentId),
- myIsEditing(false)
+ myIsEditing(false),
+ myState(Stored)
{
myDefaultValue = theData->getProperty(ATTR_DEFAULT);
myUseReset = theData->getBooleanAttribute(ATTR_USE_RESET, true);
myIsObligatory = theData->getBooleanAttribute(ATTR_OBLIGATORY, true);
connect(this, SIGNAL(valuesChanged()), this, SLOT(onWidgetValuesChanged()));
+ connect(this, SIGNAL(valuesModified()), this, SLOT(onWidgetValuesModified()));
+}
+
+bool ModuleBase_ModelWidget::reset()
+{
+ bool aResult = resetCustom();
+ if (aResult)
+ setValueState(Reset);
+
+ return aResult;
}
bool ModuleBase_ModelWidget::isInitialized(ObjectPtr theObject) const
if (isComputedDefault()) {
if (myFeature->compute(myAttributeID)) {
restoreValue();
- }
+ }
}
else {
storeValue();
bool ModuleBase_ModelWidget::storeValue()
{
+ setValueState(Stored);
+
emit beforeValuesChanged();
bool isDone = storeValueCustom();
emit afterValuesChanged();
return isDone;
}
+void ModuleBase_ModelWidget::setValueState(const ValueState& theState)
+{
+ if (myState == theState)
+ return;
+
+ myState = theState;
+ emit valueStateChanged();
+}
+
bool ModuleBase_ModelWidget::restoreValue()
{
emit beforeValuesRestored();
return isDone;
}
+void ModuleBase_ModelWidget::storeValueByApply()
+{
+ // do not emit signal about update the currenty feature object
+ // in order to do not perform additional redisplay in the viewer.
+ // It should happens by finish operation of the apply action
+ storeValueCustom();
+}
+
void ModuleBase_ModelWidget::updateObject(ObjectPtr theObj)
{
- // the viewer update should be blocked in order to avoid the temporary feature content
- // when the solver processes the feature, the redisplay message can be flushed
- // what caused the display in the viewer preliminary states of object
- // e.g. fillet feature, angle value change
- std::shared_ptr<Events_Message> aMsg = std::shared_ptr<Events_Message>(
- new Events_Message(Events_Loop::eventByName(EVENT_UPDATE_VIEWER_BLOCKED)));
- Events_Loop::loop()->send(aMsg);
+ blockUpdateViewer(true);
Events_Loop::loop()->flush(Events_Loop::eventByName(EVENT_OBJECT_UPDATED));
- // the viewer update should be unblocked
- aMsg = std::shared_ptr<Events_Message>(
- new Events_Message(Events_Loop::eventByName(EVENT_UPDATE_VIEWER_UNBLOCKED)));
- Events_Loop::loop()->send(aMsg);
+ blockUpdateViewer(false);
}
void ModuleBase_ModelWidget::moveObject(ObjectPtr theObj)
{
+ //blockUpdateViewer(true);
+
static Events_ID anEvent = Events_Loop::eventByName(EVENT_OBJECT_MOVED);
ModelAPI_EventCreator::get()->sendUpdated(theObj, anEvent);
Events_Loop::loop()->flush(anEvent);
+
+ //blockUpdateViewer(false);
+}
+
+bool ModuleBase_ModelWidget::isEventProcessed(QKeyEvent* theEvent)
+{
+ return false;
}
bool ModuleBase_ModelWidget::eventFilter(QObject* theObject, QEvent *theEvent)
if (getControls().contains(aWidget)) {
emit focusInWidget(this);
}
- }
+ }
// pass the event on to the parent class
return QObject::eventFilter(theObject, theEvent);
{
storeValue();
}
+
+//**************************************************************
+void ModuleBase_ModelWidget::onWidgetValuesModified()
+{
+ setValueState(Modified);
+}
+
+//**************************************************************
+void ModuleBase_ModelWidget::blockUpdateViewer(const bool theValue)
+{
+ // the viewer update should be blocked in order to avoid the temporary feature content
+ // when the solver processes the feature, the redisplay message can be flushed
+ // what caused the display in the viewer preliminary states of object
+ // e.g. fillet feature, angle value change
+ std::shared_ptr<Events_Message> aMsg;
+ if (theValue) {
+ aMsg = std::shared_ptr<Events_Message>(
+ new Events_Message(Events_Loop::eventByName(EVENT_UPDATE_VIEWER_BLOCKED)));
+ }
+ else {
+ // the viewer update should be unblocked
+ aMsg = std::shared_ptr<Events_Message>(
+ new Events_Message(Events_Loop::eventByName(EVENT_UPDATE_VIEWER_UNBLOCKED)));
+ }
+ Events_Loop::loop()->send(aMsg);
+}