#include <ModuleBase_WidgetToolbox.h>
#include <ModuleBase_PageBase.h>
#include <ModuleBase_PageGroupBox.h>
+#include <ModuleBase_WidgetCheckGroupBox.h>
#include <ModuleBase_PageWidget.h>
#include <ModuleBase_WidgetExprEditor.h>
#include <ModuleBase_WidgetCreatorFactory.h>
do { //Iterate over each node
std::string aWdgType = myWidgetApi->widgetType();
// Create PageGroup TODO: extract
- if (myWidgetApi->isGroupBoxWidget()) {
+ if (myWidgetApi->isGroupBoxWidget() ||
+ ModuleBase_WidgetCreatorFactory::get()->hasPageWidget(aWdgType)) {
+
//if current widget is groupbox (container) process it's children recursively
- QString aGroupName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME));
- ModuleBase_PageGroupBox* aPage = new ModuleBase_PageGroupBox(thePage->pageWidget());
- aPage->setTitle(aGroupName);
+ ModuleBase_PageBase* aPage = createPageByType(aWdgType, thePage->pageWidget());
+
createWidget(aPage);
thePage->addPageWidget(aPage);
} else {
thePage->alignToTop();
}
+ModuleBase_PageBase* ModuleBase_WidgetFactory::createPageByType(const std::string& theType,
+ QWidget* theParent)
+{
+ ModuleBase_PageBase* aResult = NULL;
+
+ if (theType == WDG_GROUP) {
+ QString aGroupName = qs(myWidgetApi->getProperty(CONTAINER_PAGE_NAME));
+ ModuleBase_PageGroupBox* aPage = new ModuleBase_PageGroupBox(theParent);
+ 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,
+ myWidgetApi, myParentId);
+
+ ModuleBase_ModelWidget* aWidget = dynamic_cast<ModuleBase_ModelWidget*>(aResult);
+ if (aWidget)
+ myModelWidgets.append(aWidget);
+
+ return aResult;
+}
+
ModuleBase_ModelWidget* ModuleBase_WidgetFactory::createWidgetByType(const std::string& theType,
QWidget* theParent)
{
} 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());