-// Copyright (C) 2014-20xx CEA/DEN, EDF R&D
-
-// File: ModuleBase_WidgetChoice.cpp
-// Created: 03 Sept 2014
-// Author: Vitaly Smetannikov
+// Copyright (C) 2014-2017 CEA/DEN, EDF R&D
+//
+// This library is free software; you can redistribute it and/or
+// modify it under the terms of the GNU Lesser General Public
+// License as published by the Free Software Foundation; either
+// version 2.1 of the License, or (at your option) any later version.
+//
+// This library is distributed in the hope that it will be useful,
+// but WITHOUT ANY WARRANTY; without even the implied warranty of
+// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
+// Lesser General Public License for more details.
+//
+// You should have received a copy of the GNU Lesser General Public
+// License along with this library; if not, write to the Free Software
+// Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+//
+// See http://www.salome-platform.org/ or
+// email : webmaster.salome@opencascade.com<mailto:webmaster.salome@opencascade.com>
+//
#include "ModuleBase_WidgetChoice.h"
-#include <ModuleBase_Tools.h>
+#include "ModuleBase_Tools.h"
+#include "ModuleBase_IconFactory.h"
#include <ModelAPI_AttributeInteger.h>
+#include <ModelAPI_AttributeStringArray.h>
#include <ModelAPI_Data.h>
#include <Config_WidgetAPI.h>
+#include <Config_PropManager.h>
#include <QWidget>
#include <QLayout>
#include <QRadioButton>
#include <QToolButton>
-
-ModuleBase_WidgetChoice::ModuleBase_WidgetChoice(QWidget* theParent,
- const Config_WidgetAPI* theData,
- const std::string& theParentId)
- : ModuleBase_ModelWidget(theParent, theData, theParentId), myCombo(0), myButtons(0)
+ModuleBase_WidgetChoice::ModuleBase_WidgetChoice(QWidget* theParent,
+ const Config_WidgetAPI* theData)
+: ModuleBase_ModelWidget(theParent, theData), myCombo(0), myButtons(0)
{
QHBoxLayout* aLayout = new QHBoxLayout(this);
ModuleBase_Tools::adjustMargins(aLayout);
- QString aLabelText = QString::fromStdString(theData->widgetLabel());
+ QString aLabelText = translate(theData->widgetLabel());
QString aLabelIcon = QString::fromStdString(theData->widgetIcon());
std::string aTypes = theData->getProperty("string_list");
- QStringList aList = QString(aTypes.c_str()).split(' ');
+ QStringList aList;
+
+ foreach(QString aType, QString(aTypes.c_str()).split(' ')) {
+ aList.append(translate(aType.toStdString()));
+ }
+ if (aTypes.empty()) {
+ myStringListAttribute = theData->getProperty("string_list_attribute");
+ if (!myStringListAttribute.empty())
+ aList.clear();
+ }
+ if (theData->getBooleanAttribute("use_in_title", false))
+ myButtonTitles = aList;
+ bool aHasDefaultValue;
+ int aDefaultVal = QString::fromStdString(getDefaultValue()).toInt(&aHasDefaultValue);
// Widget type can be combobox or radiobuttons
std::string aWgtType = theData->getProperty("widget_type");
if ((aWgtType.length() > 0) && (aWgtType == "radiobuttons")) {
std::string aWgtDir = theData->getProperty("buttons_dir");
if (aWgtDir == "horizontal")
aBtnLayout = new QHBoxLayout(aGroupBox);
- else
+ else
aBtnLayout = new QVBoxLayout(aGroupBox);
ModuleBase_Tools::adjustMargins(aBtnLayout);
int aId = 0;
foreach(QString aBtnTxt, aList) {
QToolButton* aBtn = new QToolButton(aGroupBox);
+ aBtn->setFocusPolicy(Qt::StrongFocus);
aBtn->setCheckable(true);
aBtn->setToolTip(aBtnTxt);
- QPixmap aIcon(aIconList.at(aId));
+ QPixmap aIcon = ModuleBase_IconFactory::loadPixmap(aIconList.at(aId));
aBtn->setIcon(aIcon);
aBtn->setIconSize(aIcon.size());
-
+
aBtnLayout->addWidget(aBtn);
myButtons->addButton(aBtn, aId++);
}
myButtons->addButton(aBtn, aId++);
}
}
- myButtons->button(0)->setChecked(true);
+ int aCheckedId = aHasDefaultValue ? aDefaultVal : 0;
+ myButtons->button(aDefaultVal)->setChecked(true);
connect(myButtons, SIGNAL(buttonClicked(int)), this, SLOT(onCurrentIndexChanged(int)));
} else {
myLabel = new QLabel(aLabelText, this);
if (!aLabelIcon.isEmpty())
- myLabel->setPixmap(QPixmap(aLabelIcon));
+ myLabel->setPixmap(ModuleBase_IconFactory::loadPixmap(aLabelIcon));
aLayout->addWidget(myLabel);
std::string aToolstr = theData->widgetTooltip();
myCombo = new QComboBox(this);
aLayout->addWidget(myCombo, 1);
-
+
myCombo->addItems(aList);
+ if (aHasDefaultValue && aDefaultVal < aList.size())
+ myCombo->setCurrentIndex(aDefaultVal);
+
connect(myCombo, SIGNAL(currentIndexChanged(int)), this, SLOT(onCurrentIndexChanged(int)));
}
}
ModuleBase_WidgetChoice::~ModuleBase_WidgetChoice()
{
}
-
-bool ModuleBase_WidgetChoice::storeValueCustom() const
+
+bool ModuleBase_WidgetChoice::storeValueCustom()
{
DataPtr aData = myFeature->data();
std::shared_ptr<ModelAPI_AttributeInteger> aIntAttr = aData->integer(attributeID());
if (aIntAttr->value() != -1) {
if (myCombo) {
bool isBlocked = myCombo->blockSignals(true);
+ if (myCombo->count() == 0 && !myStringListAttribute.empty()) {
+ AttributeStringArrayPtr aStrAttr = aData->stringArray(myStringListAttribute);
+ if (aStrAttr) {
+ for (int i = 0; i < aStrAttr->size(); i++) {
+ myCombo->insertItem(i, aStrAttr->value(i).c_str());
+ }
+ }
+ }
myCombo->setCurrentIndex(aIntAttr->value());
myCombo->blockSignals(isBlocked);
} else {
bool isBlocked = myButtons->blockSignals(true);
- myButtons->button(aIntAttr->value())->setChecked(true);
+ if (aIntAttr->isInitialized())
+ myButtons->button(aIntAttr->value())->setChecked(true);
+ else {
+ bool aHasDefaultValue;
+ int aDefaultVal = QString::fromStdString(getDefaultValue()).toInt(&aHasDefaultValue);
+ myButtons->button(aHasDefaultValue ? aDefaultVal : 0)->setChecked(true);
+ }
myButtons->blockSignals(isBlocked);
+ emit itemSelected(this, aIntAttr->value());
}
}
return true;
bool ModuleBase_WidgetChoice::focusTo()
{
if (myCombo)
- myCombo->setFocus();
+ ModuleBase_Tools::setFocus(myCombo, "ModuleBase_WidgetChoice::focusTo()");
else
- myButtons->button(0)->setFocus();
+ return false;
return true;
}
return aControls;
}
+QString ModuleBase_WidgetChoice::getPropertyPanelTitle(int theIndex)
+{
+ QString aTitle;
+ if (myButtonTitles.length() > theIndex)
+ aTitle = myButtonTitles[theIndex];
+ return aTitle;
+}
+
void ModuleBase_WidgetChoice::onCurrentIndexChanged(int theIndex)
{
emit valuesChanged();
// Don't transfer focus
// emit focusOutWidget(this);
+
+ emit itemSelected(this, theIndex);
}