X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_WidgetFactory.cpp;h=bedab8cb3d1856681c88eb3140678b9c0f70e926;hb=fb22ba72114328242bb0bd465abbca43321dcfe4;hp=c5e6e58e8e0ab09104641196eaa4f74613ecdc3e;hpb=ec9278ffafa6d20d7efd4f9e5be9bdcfa1d6ed0d;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_WidgetFactory.cpp b/src/ModuleBase/ModuleBase_WidgetFactory.cpp index c5e6e58e8..bedab8cb3 100644 --- a/src/ModuleBase/ModuleBase_WidgetFactory.cpp +++ b/src/ModuleBase/ModuleBase_WidgetFactory.cpp @@ -11,14 +11,12 @@ #include #include -//#include -//#include #include #include #include #include +#include #include -//#include #include #include #include @@ -27,7 +25,12 @@ #include #include #include +#include #include +#include +#include +#include +#include #include #include @@ -64,216 +67,108 @@ ModuleBase_WidgetFactory::~ModuleBase_WidgetFactory() delete myWidgetApi; } -void ModuleBase_WidgetFactory::createWidget(QWidget* theParent) +void ModuleBase_WidgetFactory::createWidget(ModuleBase_PageBase* thePage) { myParentId = myWidgetApi->widgetId(); if (!myWidgetApi->toChildWidget()) return; - QVBoxLayout* aWidgetLay = new QVBoxLayout(theParent); - bool isStretchLayout = false; do { //Iterate over each node std::string aWdgType = myWidgetApi->widgetType(); - //Create a widget (doublevalue, groupbox, toolbox, etc. - QWidget* aWidget = createWidgetByType(aWdgType, theParent); - if (aWidget) { - if (!myWidgetApi->getBooleanAttribute(ATTR_INTERNAL, false)) { - aWidgetLay->addWidget(aWidget); - } else { - aWidget->setVisible(false); - } - } - if (myWidgetApi->isContainerWidget()) { + // Create PageGroup TODO: extract + if (myWidgetApi->isGroupBoxWidget()) { //if current widget is groupbox (container) process it's children recursively QString aGroupName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME)); - createWidget(aWidget); - ModuleBase_Tools::adjustMargins(aWidget); - QGroupBox* aGrBox = qobject_cast(aWidget); - aGrBox->setTitle(aGroupName); - } - if (myWidgetApi->isPagedWidget()) { - //If current widget is toolbox or switch-casebox then fetch all - //it's pages recursively and setup into the widget. - myWidgetApi->toChildWidget(); - do { - QString aPageName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME)); - QString aCaseId = qs(myWidgetApi->getProperty(_ID)); - QWidget* aPage = new QWidget(aWidget); - createWidget(aPage); - ModuleBase_Tools::adjustMargins(aPage); - if (aWdgType == WDG_SWITCH) { - ModuleBase_WidgetSwitch* aSwitch = qobject_cast(aWidget); - aSwitch->addPage(aPage, aPageName); - } else if (aWdgType == WDG_TOOLBOX) { - ModuleBase_WidgetToolbox* aToolbox = qobject_cast(aWidget); - aToolbox->addPage(aPage, aPageName, aCaseId); + ModuleBase_PageGroupBox* aPage = new ModuleBase_PageGroupBox(thePage->pageWidget()); + aPage->setTitle(aGroupName); + createWidget(aPage); + thePage->addPageWidget(aPage); + } else { + // Create a ModelWidget + ModuleBase_ModelWidget* aWidget = createWidgetByType(aWdgType, thePage->pageWidget()); + if (aWidget) { + if (!myWidgetApi->getBooleanAttribute(ATTR_INTERNAL, false)) { + thePage->addModelWidget(aWidget); + } else { + aWidget->setVisible(false); } - } while (myWidgetApi->toNextWidget()); - } - if (aWidget && !isStretchLayout) { - isStretchLayout = !hasExpandingControls(aWidget); + } + // Create PagedContainer TODO: extract + if (myWidgetApi->isPagedWidget()) { + //If current widget is toolbox or switch-casebox then fetch all + //it's pages recursively and setup into the widget. + myWidgetApi->toChildWidget(); + do { + QString aPageName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME)); + QString aCaseId = qs(myWidgetApi->getProperty(_ID)); + ModuleBase_PageBase* aPage = new ModuleBase_PageWidget(aWidget); + createWidget(aPage); + if (aWdgType == WDG_SWITCH || aWdgType == WDG_TOOLBOX) { + ModuleBase_PagedContainer* aContainer = qobject_cast(aWidget); + + QString anIconPath = qs( myWidgetApi->getProperty( CONTAINER_PAGE_ICON ) ); + QPixmap anIcon( anIconPath ); + aContainer->addPage( aPage, aPageName, aCaseId, anIcon ); + } + } while (myWidgetApi->toNextWidget()); + } } } while (myWidgetApi->toNextWidget()); - if (isStretchLayout) { - aWidgetLay->addStretch(1); - } - theParent->setLayout(aWidgetLay); -} -bool ModuleBase_WidgetFactory::hasExpandingControls(QWidget* theParent) -{ - bool result = false; - QList aListToCheck; - aListToCheck << theParent; - ModuleBase_ModelWidget* aModelWidget = qobject_cast(theParent); - if(aModelWidget) { - aListToCheck << aModelWidget->getControls(); - } - foreach(QWidget* eachWidget, aListToCheck) { - QSizePolicy::Policy aVPolicy = eachWidget->sizePolicy().verticalPolicy(); - if(aVPolicy & QSizePolicy::ExpandFlag) { - result = true; - } - } - return result; + thePage->alignToTop(); } -QWidget* ModuleBase_WidgetFactory::createWidgetByType(const std::string& theType, - QWidget* theParent) +ModuleBase_ModelWidget* ModuleBase_WidgetFactory::createWidgetByType(const std::string& theType, + QWidget* theParent) { - QWidget* result = NULL; - if (theType == WDG_DOUBLEVALUE) { - result = doubleSpinBoxControl(theParent); - - } else if (theType == WDG_INFO) { - result = labelControl(theParent); + ModuleBase_ModelWidget* result = NULL; + if (theType == WDG_INFO) { + result = new ModuleBase_WidgetLabel(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_ERRORINFO) { + result = new ModuleBase_WidgetErrorLabel(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_DOUBLEVALUE) { + result = new ModuleBase_WidgetDoubleValue(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_INTEGERVALUE) { + result = new ModuleBase_WidgetIntValue(theParent, myWidgetApi, myParentId); } else if (theType == WDG_SHAPE_SELECTOR) { - result = shapeSelectorControl(theParent); - + result = new ModuleBase_WidgetShapeSelector(theParent, myWorkshop, myWidgetApi, myParentId); } else if (theType == WDG_BOOLVALUE) { - result = booleanControl(theParent); - - } else if (theType == WDG_DOUBLEVALUE_EDITOR) { - result = doubleValueEditor(theParent); - + result = new ModuleBase_WidgetBoolValue(theParent, myWidgetApi, myParentId); + //} else if (theType == WDG_DOUBLEVALUE_EDITOR) { + // result = new ModuleBase_WidgetEditor(theParent, myWidgetApi, myParentId); } else if (theType == WDG_FILE_SELECTOR) { - result = fileSelectorControl(theParent); - + result = new ModuleBase_WidgetFileSelector(theParent, myWidgetApi, myParentId); } else if (theType == WDG_CHOICE) { - result = choiceControl(theParent); - + result = new ModuleBase_WidgetChoice(theParent, myWidgetApi, myParentId); } else if (theType == WDG_STRINGVALUE) { - result = lineEditControl(theParent); - + std::string aPlaceHolder = myWidgetApi->getProperty( WDG_PLACE_HOLDER ); + result = new ModuleBase_WidgetLineEdit( theParent, myWidgetApi, myParentId, aPlaceHolder ); + } else if (theType == WDG_EXPR_EDITOR) { + std::string aPlaceHolder = myWidgetApi->getProperty( WDG_PLACE_HOLDER ); + result = new ModuleBase_WidgetExprEditor( theParent, myWidgetApi, myParentId, aPlaceHolder ); } else if (theType == WDG_MULTISELECTOR) { - result = multiSelectorControl(theParent); - - } else if (myWidgetApi->isContainerWidget() || myWidgetApi->isPagedWidget()) { - result = createContainer(theType, theParent); - } else { - result = myWorkshop->module()->createWidgetByType(theType, theParent, myWidgetApi, - myParentId, myModelWidgets); -#ifdef _DEBUG - if (!result) {qDebug("ModuleBase_WidgetFactory::fillWidget: find bad widget type");} -#endif - } - return result; -} - -QWidget* ModuleBase_WidgetFactory::createContainer(const std::string& theType, QWidget* theParent) -{ - QWidget* aResult = NULL; - if (theType == WDG_GROUP || theType == WDG_CHECK_GROUP) { - QGroupBox* aGroupBox = new QGroupBox(theParent); - aGroupBox->setCheckable(theType == WDG_CHECK_GROUP); - aResult = aGroupBox; + result = new ModuleBase_WidgetMultiSelector(theParent, myWorkshop, myWidgetApi, myParentId); } else if (theType == WDG_TOOLBOX) { - ModuleBase_WidgetToolbox* aWdg = new ModuleBase_WidgetToolbox(theParent, myWidgetApi, myParentId); - myModelWidgets.append(aWdg); - aResult = aWdg; + result = new ModuleBase_WidgetToolbox(theParent, myWidgetApi, myParentId); } else if (theType == WDG_SWITCH) { - aResult = new ModuleBase_WidgetSwitch(theParent); - } else if (theType == WDG_TOOLBOX_BOX || theType == WDG_SWITCH_CASE) { + result = new ModuleBase_WidgetSwitch(theParent, myWidgetApi, myParentId); + } else if (theType == WDG_TOOLBOX_BOX || theType == WDG_SWITCH_CASE || + theType == NODE_VALIDATOR) { // Do nothing for "box" and "case" - aResult = NULL; + result = NULL; + } else { + result = myWorkshop->module()->createWidgetByType(theType, theParent, myWidgetApi, myParentId); + #ifdef _DEBUG + if (!result) { + qDebug("ModuleBase_WidgetFactory::fillWidget: find bad widget type %s", theType.c_str()); + } + #endif } -#ifdef _DEBUG - else {qDebug() << "ModuleBase_WidgetFactory::fillWidget: find bad container type";} -#endif - return aResult; -} - -QWidget* ModuleBase_WidgetFactory::labelControl(QWidget* theParent) -{ - ModuleBase_WidgetLabel* aWgt = - new ModuleBase_WidgetLabel(theParent, myWidgetApi, myParentId); - myModelWidgets.append(aWgt); - return aWgt; -} - -QWidget* ModuleBase_WidgetFactory::doubleSpinBoxControl(QWidget* theParent) -{ - ModuleBase_WidgetDoubleValue* aDblWgt = - new ModuleBase_WidgetDoubleValue(theParent, myWidgetApi, myParentId); - myModelWidgets.append(aDblWgt); - return aDblWgt; -} - -QWidget* ModuleBase_WidgetFactory::doubleValueEditor(QWidget* theParent) -{ - ModuleBase_WidgetEditor* aWidget = - new ModuleBase_WidgetEditor(theParent, myWidgetApi, myParentId); - myModelWidgets.append(aWidget); - return aWidget; -} - -QWidget* ModuleBase_WidgetFactory::shapeSelectorControl(QWidget* theParent) -{ - ModuleBase_WidgetShapeSelector* aSelector = - new ModuleBase_WidgetShapeSelector(theParent, myWorkshop, myWidgetApi, myParentId); - myModelWidgets.append(aSelector); - return aSelector; -} - -QWidget* ModuleBase_WidgetFactory::booleanControl(QWidget* theParent) -{ - ModuleBase_WidgetBoolValue* aBoolWgt = - new ModuleBase_WidgetBoolValue(theParent, myWidgetApi, myParentId); - myModelWidgets.append(aBoolWgt); - return aBoolWgt; -} - -QWidget* ModuleBase_WidgetFactory::fileSelectorControl(QWidget* theParent) -{ - ModuleBase_WidgetFileSelector* aFileSelectorWgt = - new ModuleBase_WidgetFileSelector(theParent, myWidgetApi, myParentId); - myModelWidgets.append(aFileSelectorWgt); - return aFileSelectorWgt; -} - -QWidget* ModuleBase_WidgetFactory::choiceControl(QWidget* theParent) -{ - ModuleBase_WidgetChoice* aChoiceWgt = - new ModuleBase_WidgetChoice(theParent, myWidgetApi,myParentId); - myModelWidgets.append(aChoiceWgt); - return aChoiceWgt; -} - -QWidget* ModuleBase_WidgetFactory::lineEditControl(QWidget* theParent) -{ - ModuleBase_WidgetLineEdit* aLineEditWgt = - new ModuleBase_WidgetLineEdit(theParent, myWidgetApi,myParentId); - myModelWidgets.append(aLineEditWgt); - return aLineEditWgt; -} - -QWidget* ModuleBase_WidgetFactory::multiSelectorControl(QWidget* theParent) -{ - ModuleBase_WidgetMultiSelector* aMultiselectorWgt = - new ModuleBase_WidgetMultiSelector(theParent, myWorkshop, myWidgetApi,myParentId); - myModelWidgets.append(aMultiselectorWgt); - return aMultiselectorWgt; + if (result) { + myModelWidgets.append(result); + } + return result; } QString ModuleBase_WidgetFactory::qs(const std::string& theStdString)