forked from qt-creator/qt-creator
Wizards: introduce ObjectToFieldWidgetConverter
With it as a wrapper we can register any QObject to use widget based field mechanism from QWizard. It also helps to avoid the necessity for inheritance to just adjust the text property of a widget. Can not remove the TextCheckBox, because it is used in some old C++ wizards. Change-Id: I85a85a834714a4b38b501c13357fa8c8bb02b5bd Reviewed-by: Tim Jenssen <tim.jenssen@qt.io>
This commit is contained in:
@@ -31,9 +31,44 @@
|
|||||||
#include <QString>
|
#include <QString>
|
||||||
#include <QWizardPage>
|
#include <QWizardPage>
|
||||||
|
|
||||||
|
#include <functional>
|
||||||
|
|
||||||
namespace Utils {
|
namespace Utils {
|
||||||
|
|
||||||
class Wizard;
|
class Wizard;
|
||||||
|
namespace Internal {
|
||||||
|
|
||||||
|
class QTCREATOR_UTILS_EXPORT ObjectToFieldWidgetConverter : public QWidget
|
||||||
|
{
|
||||||
|
Q_OBJECT
|
||||||
|
Q_PROPERTY(QString text READ text NOTIFY textChanged)
|
||||||
|
|
||||||
|
public:
|
||||||
|
template <class T, typename... Arguments>
|
||||||
|
static ObjectToFieldWidgetConverter *create(T *sender, void (T::*member)(Arguments...), const std::function<QString()> &toTextFunction)
|
||||||
|
{
|
||||||
|
auto widget = new ObjectToFieldWidgetConverter();
|
||||||
|
widget->toTextFunction = toTextFunction;
|
||||||
|
connect(sender, &QObject::destroyed, widget, &QObject::deleteLater);
|
||||||
|
connect(sender, member, widget, [widget] () {
|
||||||
|
emit widget->textChanged(widget->text());
|
||||||
|
});
|
||||||
|
return widget;
|
||||||
|
}
|
||||||
|
|
||||||
|
signals:
|
||||||
|
void textChanged(const QString&);
|
||||||
|
|
||||||
|
private:
|
||||||
|
ObjectToFieldWidgetConverter () = default;
|
||||||
|
|
||||||
|
// is used by the property text
|
||||||
|
QString text() {return toTextFunction();}
|
||||||
|
std::function<QString()> toTextFunction;
|
||||||
|
};
|
||||||
|
|
||||||
|
} // Internal
|
||||||
|
|
||||||
class QTCREATOR_UTILS_EXPORT WizardPage : public QWizardPage
|
class QTCREATOR_UTILS_EXPORT WizardPage : public QWizardPage
|
||||||
{
|
{
|
||||||
Q_OBJECT
|
Q_OBJECT
|
||||||
@@ -43,6 +78,13 @@ public:
|
|||||||
|
|
||||||
virtual void pageWasAdded(); // called when this page was added to a Utils::Wizard
|
virtual void pageWasAdded(); // called when this page was added to a Utils::Wizard
|
||||||
|
|
||||||
|
template<class T, typename... Arguments>
|
||||||
|
void registerObjectAsFieldWithName(const QString &name, T *sender, void (T::*changeSignal)(Arguments...),
|
||||||
|
const std::function<QString()> &senderToString)
|
||||||
|
{
|
||||||
|
registerFieldWithName(name, Internal::ObjectToFieldWidgetConverter::create(sender, changeSignal, senderToString), "text", SIGNAL(textChanged(QString)));
|
||||||
|
}
|
||||||
|
|
||||||
void registerFieldWithName(const QString &name, QWidget *widget,
|
void registerFieldWithName(const QString &name, QWidget *widget,
|
||||||
const char *property = 0, const char *changedSignal = 0);
|
const char *property = 0, const char *changedSignal = 0);
|
||||||
|
|
||||||
|
@@ -33,7 +33,6 @@
|
|||||||
#include <utils/fancylineedit.h>
|
#include <utils/fancylineedit.h>
|
||||||
#include <utils/qtcassert.h>
|
#include <utils/qtcassert.h>
|
||||||
#include <utils/stringutils.h>
|
#include <utils/stringutils.h>
|
||||||
#include <utils/textfieldcheckbox.h>
|
|
||||||
#include <utils/textfieldcombobox.h>
|
#include <utils/textfieldcombobox.h>
|
||||||
#include <utils/theme/theme.h>
|
#include <utils/theme/theme.h>
|
||||||
|
|
||||||
@@ -702,16 +701,23 @@ bool CheckBoxField::parseData(const QVariant &data, QString *errorMessage)
|
|||||||
QWidget *CheckBoxField::createWidget(const QString &displayName, JsonFieldPage *page)
|
QWidget *CheckBoxField::createWidget(const QString &displayName, JsonFieldPage *page)
|
||||||
{
|
{
|
||||||
Q_UNUSED(page);
|
Q_UNUSED(page);
|
||||||
return new TextFieldCheckBox(displayName);
|
return new QCheckBox(displayName);
|
||||||
}
|
}
|
||||||
|
|
||||||
void CheckBoxField::setup(JsonFieldPage *page, const QString &name)
|
void CheckBoxField::setup(JsonFieldPage *page, const QString &name)
|
||||||
{
|
{
|
||||||
auto w = qobject_cast<TextFieldCheckBox *>(widget());
|
auto w = qobject_cast<QCheckBox *>(widget());
|
||||||
QTC_ASSERT(w, return);
|
QTC_ASSERT(w, return);
|
||||||
QObject::connect(w, &TextFieldCheckBox::clicked,
|
page->registerObjectAsFieldWithName<QCheckBox>(name, w, &QCheckBox::stateChanged, [this, page, w] () -> QString {
|
||||||
page, [this, page]() { m_isModified = true; page->completeChanged();});
|
if (w->checkState() == Qt::Checked)
|
||||||
page->registerFieldWithName(name, w, "compareText", SIGNAL(textChanged(QString)));
|
return page->expander()->expand(m_checkedValue);
|
||||||
|
return page->expander()->expand(m_uncheckedValue);
|
||||||
|
});
|
||||||
|
|
||||||
|
QObject::connect(w, &QCheckBox::stateChanged, page, [this, page]() {
|
||||||
|
m_isModified = true;
|
||||||
|
emit page->completeChanged();
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
bool CheckBoxField::validate(MacroExpander *expander, QString *message)
|
bool CheckBoxField::validate(MacroExpander *expander, QString *message)
|
||||||
@@ -720,7 +726,7 @@ bool CheckBoxField::validate(MacroExpander *expander, QString *message)
|
|||||||
return false;
|
return false;
|
||||||
|
|
||||||
if (!m_isModified) {
|
if (!m_isModified) {
|
||||||
auto w = qobject_cast<TextFieldCheckBox *>(widget());
|
auto w = qobject_cast<QCheckBox *>(widget());
|
||||||
QTC_ASSERT(w, return false);
|
QTC_ASSERT(w, return false);
|
||||||
w->setChecked(JsonWizard::boolFromVariant(m_checkedExpression, expander));
|
w->setChecked(JsonWizard::boolFromVariant(m_checkedExpression, expander));
|
||||||
}
|
}
|
||||||
@@ -729,10 +735,8 @@ bool CheckBoxField::validate(MacroExpander *expander, QString *message)
|
|||||||
|
|
||||||
void CheckBoxField::initializeData(MacroExpander *expander)
|
void CheckBoxField::initializeData(MacroExpander *expander)
|
||||||
{
|
{
|
||||||
auto w = qobject_cast<TextFieldCheckBox *>(widget());
|
auto w = qobject_cast<QCheckBox *>(widget());
|
||||||
QTC_ASSERT(widget(), return);
|
QTC_ASSERT(widget(), return);
|
||||||
w->setTrueText(expander->expand(m_checkedValue));
|
|
||||||
w->setFalseText(expander->expand(m_uncheckedValue));
|
|
||||||
|
|
||||||
w->setChecked(JsonWizard::boolFromVariant(m_checkedExpression, expander));
|
w->setChecked(JsonWizard::boolFromVariant(m_checkedExpression, expander));
|
||||||
}
|
}
|
||||||
|
@@ -42,7 +42,6 @@ QT_END_NAMESPACE
|
|||||||
|
|
||||||
namespace Utils {
|
namespace Utils {
|
||||||
class MacroExpander;
|
class MacroExpander;
|
||||||
class TextFieldCheckBox;
|
|
||||||
class TextFieldComboBox;
|
class TextFieldComboBox;
|
||||||
} // namespace Utils
|
} // namespace Utils
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user