forked from qt-creator/qt-creator
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:
@@ -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
|
||||||
|
@@ -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()
|
||||||
|
@@ -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();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@@ -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;
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
Reference in New Issue
Block a user