Provide way to show a variable chooser widget.

For the Qt Creator variables, currently used in the external tools.
The variable chooser looks if the current focus widget has a variable
support property set and is a line edit, text edit or plain text edit.
For line edits it adds a little icon button that shows the chooser.
This commit is contained in:
con
2011-03-03 20:50:25 +01:00
parent 79c899636b
commit efc817d8e0
4 changed files with 85 additions and 18 deletions

View File

@@ -261,6 +261,8 @@ const char * const SETTINGS_DEFAULTTEXTENCODING = "General/DefaultFileEncoding";
const char * const ALL_FILES_FILTER = QT_TRANSLATE_NOOP("Core", "All Files (*)"); const char * const ALL_FILES_FILTER = QT_TRANSLATE_NOOP("Core", "All Files (*)");
const char * const VARIABLE_SUPPORT_PROPERTY = "QtCreator.VariableSupport";
const int TARGET_ICON_SIZE = 32; const int TARGET_ICON_SIZE = 32;
} // namespace Constants } // namespace Constants

View File

@@ -37,6 +37,7 @@
#include <utils/qtcassert.h> #include <utils/qtcassert.h>
#include <coreplugin/coreconstants.h> #include <coreplugin/coreconstants.h>
#include <coreplugin/variablechooser.h>
#include <QtCore/QTextStream> #include <QtCore/QTextStream>
#include <QtCore/QFile> #include <QtCore/QFile>
@@ -398,6 +399,11 @@ ExternalToolConfig::ExternalToolConfig(QWidget *parent) :
connect(ui->toolTree->selectionModel(), SIGNAL(currentChanged(QModelIndex,QModelIndex)), connect(ui->toolTree->selectionModel(), SIGNAL(currentChanged(QModelIndex,QModelIndex)),
this, SLOT(handleCurrentChanged(QModelIndex,QModelIndex))); this, SLOT(handleCurrentChanged(QModelIndex,QModelIndex)));
ui->executable->lineEdit()->setProperty(Constants::VARIABLE_SUPPORT_PROPERTY, true);
ui->arguments->setProperty(Constants::VARIABLE_SUPPORT_PROPERTY, true);
ui->workingDirectory->lineEdit()->setProperty(Constants::VARIABLE_SUPPORT_PROPERTY, true);
ui->inputText->setProperty(Constants::VARIABLE_SUPPORT_PROPERTY, true);
connect(ui->description, SIGNAL(editingFinished()), this, SLOT(updateCurrentItem())); connect(ui->description, SIGNAL(editingFinished()), this, SLOT(updateCurrentItem()));
connect(ui->executable, SIGNAL(editingFinished()), this, SLOT(updateCurrentItem())); connect(ui->executable, SIGNAL(editingFinished()), this, SLOT(updateCurrentItem()));
connect(ui->executable, SIGNAL(browsingFinished()), this, SLOT(updateCurrentItem())); connect(ui->executable, SIGNAL(browsingFinished()), this, SLOT(updateCurrentItem()));
@@ -420,7 +426,8 @@ ExternalToolConfig::ExternalToolConfig(QWidget *parent) :
connect(addCategory, SIGNAL(triggered()), this, SLOT(addCategory())); connect(addCategory, SIGNAL(triggered()), this, SLOT(addCategory()));
showInfoForItem(QModelIndex()); showInfoForItem(QModelIndex());
// updateButtons(ui->toolTree->currentItem());
new VariableChooser(this);
} }
ExternalToolConfig::~ExternalToolConfig() ExternalToolConfig::~ExternalToolConfig()

View File

@@ -34,6 +34,7 @@
#include "variablechooser.h" #include "variablechooser.h"
#include "ui_variablechooser.h" #include "ui_variablechooser.h"
#include "variablemanager.h" #include "variablemanager.h"
#include "coreconstants.h"
using namespace Core; using namespace Core;
@@ -44,7 +45,6 @@ VariableChooser::VariableChooser(QWidget *parent) :
m_textEdit(0), m_textEdit(0),
m_plainTextEdit(0) m_plainTextEdit(0)
{ {
setAttribute(Qt::WA_DeleteOnClose);
ui->setupUi(this); ui->setupUi(this);
m_defaultDescription = ui->variableDescription->text(); m_defaultDescription = ui->variableDescription->text();
ui->variableList->setAttribute(Qt::WA_MacSmallSize); ui->variableList->setAttribute(Qt::WA_MacSmallSize);
@@ -63,12 +63,13 @@ VariableChooser::VariableChooser(QWidget *parent) :
connect(ui->variableList, SIGNAL(itemActivated(QListWidgetItem*)), connect(ui->variableList, SIGNAL(itemActivated(QListWidgetItem*)),
this, SLOT(handleItemActivated(QListWidgetItem*))); this, SLOT(handleItemActivated(QListWidgetItem*)));
connect(qApp, SIGNAL(focusChanged(QWidget*,QWidget*)), connect(qApp, SIGNAL(focusChanged(QWidget*,QWidget*)),
this, SLOT(updateCurrentEditor(QWidget*))); this, SLOT(updateCurrentEditor(QWidget*,QWidget*)));
updateCurrentEditor(qApp->focusWidget()); updateCurrentEditor(0, qApp->focusWidget());
} }
VariableChooser::~VariableChooser() VariableChooser::~VariableChooser()
{ {
delete m_iconButton;
delete ui; delete ui;
} }
@@ -80,21 +81,70 @@ void VariableChooser::updateDescription(const QString &variable)
ui->variableDescription->setText(VariableManager::instance()->variableDescription(variable)); ui->variableDescription->setText(VariableManager::instance()->variableDescription(variable));
} }
void VariableChooser::updateCurrentEditor(QWidget *widget) void VariableChooser::updateCurrentEditor(QWidget *old, QWidget *widget)
{ {
if (QLineEdit *lineEdit = qobject_cast<QLineEdit *>(widget)) { Q_UNUSED(old)
m_lineEdit = lineEdit; if (!widget) // we might loose focus, but then keep the previous state
m_textEdit = 0; return;
m_plainTextEdit = 0; // prevent children of the chooser itself, and limit to children of chooser's parent
} else if (QTextEdit *textEdit = qobject_cast<QTextEdit *>(widget)) { bool handle = false;
m_lineEdit = 0; QWidget *parent = widget;
m_textEdit = textEdit; while (parent) {
m_plainTextEdit = 0; if (parent == this)
} else if (QPlainTextEdit *plainTextEdit = qobject_cast<QPlainTextEdit *>(widget)) { return;
m_lineEdit = 0; if (parent == this->parentWidget()) {
m_textEdit = 0; handle = true;
m_plainTextEdit = plainTextEdit; break;
}
parent = parent->parentWidget();
} }
if (!handle)
return;
QLineEdit *previousLineEdit = m_lineEdit;
m_lineEdit = 0;
m_textEdit = 0;
m_plainTextEdit = 0;
QVariant variablesSupportProperty = variablesSupportProperty = widget->property(Constants::VARIABLE_SUPPORT_PROPERTY);
bool supportsVariables = (variablesSupportProperty.isValid()
? variablesSupportProperty.toBool() : false);
if (QLineEdit *lineEdit = qobject_cast<QLineEdit *>(widget)) {
m_lineEdit = (supportsVariables ? lineEdit : 0);
} else if (QTextEdit *textEdit = qobject_cast<QTextEdit *>(widget)) {
m_textEdit = (supportsVariables ? textEdit : 0);
} else if (QPlainTextEdit *plainTextEdit = qobject_cast<QPlainTextEdit *>(widget)) {
m_plainTextEdit = (supportsVariables ? plainTextEdit : 0);
}
if (!(m_lineEdit || m_textEdit || m_plainTextEdit))
hide();
if (m_lineEdit != previousLineEdit) {
if (previousLineEdit)
previousLineEdit->setTextMargins(0, 0, 0, 0);
if (m_iconButton) {
m_iconButton->hide();
m_iconButton->setParent(0);
}
if (m_lineEdit) {
if (!m_iconButton)
createIconButton();
int margin = m_iconButton->pixmap().width() + 8;
if (style()->inherits("OxygenStyle"))
margin = qMax(24, margin);
m_lineEdit->setTextMargins(0, 0, margin, 0);
m_iconButton->setParent(m_lineEdit);
m_iconButton->setGeometry(m_lineEdit->rect().adjusted(
m_lineEdit->width() - (margin + 4), 0, 0, 0));
m_iconButton->show();
}
}
}
void VariableChooser::createIconButton()
{
m_iconButton = new Utils::IconButton;
m_iconButton->setPixmap(QPixmap(QLatin1String(":/core/images/replace.png")));
m_iconButton->setToolTip(tr("Insert variable"));
m_iconButton->hide();
connect(m_iconButton, SIGNAL(clicked()), this, SLOT(show()));
} }
void VariableChooser::handleItemActivated(QListWidgetItem *item) void VariableChooser::handleItemActivated(QListWidgetItem *item)
@@ -108,9 +158,12 @@ void VariableChooser::insertVariable(const QString &variable)
const QString &text = QLatin1String("${") + variable + QLatin1String("}"); const QString &text = QLatin1String("${") + variable + QLatin1String("}");
if (m_lineEdit) { if (m_lineEdit) {
m_lineEdit->insert(text); m_lineEdit->insert(text);
m_lineEdit->activateWindow();
} else if (m_textEdit) { } else if (m_textEdit) {
m_textEdit->insertPlainText(text); m_textEdit->insertPlainText(text);
m_textEdit->activateWindow();
} else if (m_plainTextEdit) { } else if (m_plainTextEdit) {
m_plainTextEdit->insertPlainText(text); m_plainTextEdit->insertPlainText(text);
m_plainTextEdit->activateWindow();
} }
} }

View File

@@ -36,6 +36,8 @@
#include "core_global.h" #include "core_global.h"
#include <utils/fancylineedit.h>
#include <QtCore/QPointer> #include <QtCore/QPointer>
#include <QtGui/QWidget> #include <QtGui/QWidget>
#include <QtGui/QLineEdit> #include <QtGui/QLineEdit>
@@ -59,16 +61,19 @@ public:
private slots: private slots:
void updateDescription(const QString &variable); void updateDescription(const QString &variable);
void updateCurrentEditor(QWidget *widget); void updateCurrentEditor(QWidget *old, QWidget *widget);
void handleItemActivated(QListWidgetItem *item); void handleItemActivated(QListWidgetItem *item);
void insertVariable(const QString &variable); void insertVariable(const QString &variable);
private: private:
void createIconButton();
Ui::VariableChooser *ui; Ui::VariableChooser *ui;
QString m_defaultDescription; QString m_defaultDescription;
QPointer<QLineEdit> m_lineEdit; QPointer<QLineEdit> m_lineEdit;
QPointer<QTextEdit> m_textEdit; QPointer<QTextEdit> m_textEdit;
QPointer<QPlainTextEdit> m_plainTextEdit; QPointer<QPlainTextEdit> m_plainTextEdit;
QPointer<Utils::IconButton> m_iconButton;
}; };