X-Git-Url: http://git.salome-platform.org/gitweb/?a=blobdiff_plain;f=src%2FModuleBase%2FModuleBase_WidgetFactory.cpp;h=f32f0aca8dc7ce29cba19c7777daedfb0be209b5;hb=450d1bd65c11870d3942a30164518037b9a7503e;hp=dec5f78ab6efc24d0e717b0b784ca7128f3e0052;hpb=868158fe6d39b25e60ac528295b1c908821e4af5;p=modules%2Fshaper.git diff --git a/src/ModuleBase/ModuleBase_WidgetFactory.cpp b/src/ModuleBase/ModuleBase_WidgetFactory.cpp index dec5f78ab..f32f0aca8 100644 --- a/src/ModuleBase/ModuleBase_WidgetFactory.cpp +++ b/src/ModuleBase/ModuleBase_WidgetFactory.cpp @@ -29,6 +29,7 @@ #include #include #include +#include #include #include #include @@ -131,9 +132,20 @@ ModuleBase_PageBase* ModuleBase_WidgetFactory::createPageByType(const std::strin aPage->setTitle(aGroupName); aResult = aPage; } - + else if (theType == WDG_CHECK_GROUP) { + QString aGroupName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME)); + ModuleBase_WidgetCheckGroupBox* aPage = new ModuleBase_WidgetCheckGroupBox(theParent, + myWidgetApi, myParentId); + aPage->setTitle(aGroupName); + aResult = aPage; + } if (!aResult) - aResult = ModuleBase_WidgetCreatorFactory::get()->createPageByType(theType, theParent); + aResult = ModuleBase_WidgetCreatorFactory::get()->createPageByType(theType, theParent, + myWidgetApi, myParentId); + + ModuleBase_ModelWidget* aWidget = dynamic_cast(aResult); + if (aWidget) + myModelWidgets.append(aWidget); return aResult; } @@ -180,7 +192,8 @@ ModuleBase_ModelWidget* ModuleBase_WidgetFactory::createWidgetByType(const std:: } else { result = myWorkshop->module()->createWidgetByType(theType, theParent, myWidgetApi, myParentId); if (!result) - result = ModuleBase_WidgetCreatorFactory::get()->createWidgetByType(theType, theParent); + result = ModuleBase_WidgetCreatorFactory::get()->createWidgetByType(theType, theParent, + myWidgetApi, myParentId, myWorkshop); #ifdef _DEBUG if (!result) { qDebug("ModuleBase_WidgetFactory::fillWidget: find bad widget type %s", theType.c_str());