forked from qt-creator/qt-creator
Todo: Inline optiondialog.ui
Change-Id: I55f170220a075e4d8db86f17eb857325a33bf82c Reviewed-by: Christian Stenger <christian.stenger@qt.io>
This commit is contained in:
@@ -25,14 +25,20 @@
|
||||
****************************************************************************/
|
||||
|
||||
#include "optionsdialog.h"
|
||||
#include "ui_optionsdialog.h"
|
||||
|
||||
#include "keyworddialog.h"
|
||||
#include "keyword.h"
|
||||
#include "settings.h"
|
||||
#include "constants.h"
|
||||
|
||||
namespace Todo {
|
||||
namespace Internal {
|
||||
#include <utils/layoutbuilder.h>
|
||||
|
||||
#include <QCoreApplication>
|
||||
#include <QGroupBox>
|
||||
#include <QListWidget>
|
||||
#include <QPushButton>
|
||||
#include <QRadioButton>
|
||||
|
||||
namespace Todo::Internal {
|
||||
|
||||
class OptionsDialog final : public Core::IOptionsPageWidget
|
||||
{
|
||||
@@ -56,28 +62,79 @@ private:
|
||||
void editKeyword(QListWidgetItem *item);
|
||||
QSet<QString> keywordNames();
|
||||
|
||||
Ui::OptionsDialog ui;
|
||||
Settings *m_settings = nullptr;
|
||||
std::function<void()> m_onApply;
|
||||
|
||||
QListWidget *m_keywordsList;
|
||||
QPushButton *m_editKeywordButton;
|
||||
QPushButton *m_removeKeywordButton;
|
||||
QPushButton *resetKeywordsButton;
|
||||
QRadioButton *m_scanInProjectRadioButton;
|
||||
QRadioButton *m_scanInCurrentFileRadioButton;
|
||||
QRadioButton *m_scanInSubprojectRadioButton;
|
||||
};
|
||||
|
||||
OptionsDialog::OptionsDialog(Settings *settings, const std::function<void ()> &onApply)
|
||||
: m_settings(settings), m_onApply(onApply)
|
||||
{
|
||||
ui.setupUi(this);
|
||||
ui.keywordsList->setIconSize(QSize(16, 16));
|
||||
m_keywordsList = new QListWidget;
|
||||
m_keywordsList->setDragDropMode(QAbstractItemView::DragDrop);
|
||||
m_keywordsList->setDefaultDropAction(Qt::MoveAction);
|
||||
m_keywordsList->setSelectionBehavior(QAbstractItemView::SelectRows);
|
||||
m_keywordsList->setSortingEnabled(false);
|
||||
|
||||
auto addKeywordButton = new QPushButton(tr("Add"));
|
||||
m_editKeywordButton = new QPushButton(tr("Edit"));
|
||||
m_removeKeywordButton = new QPushButton(tr("Remove"));
|
||||
resetKeywordsButton = new QPushButton(tr("Reset"));
|
||||
|
||||
m_scanInProjectRadioButton = new QRadioButton(tr("Scan the whole active project"));
|
||||
m_scanInProjectRadioButton->setEnabled(true);
|
||||
|
||||
m_scanInCurrentFileRadioButton = new QRadioButton(tr("Scan only the currently edited document"));
|
||||
m_scanInCurrentFileRadioButton->setChecked(true);
|
||||
|
||||
m_scanInSubprojectRadioButton = new QRadioButton(tr("Scan the current subproject"));
|
||||
|
||||
using namespace Utils::Layouting;
|
||||
|
||||
Column {
|
||||
Group {
|
||||
Title(tr("Keywords")),
|
||||
Row {
|
||||
m_keywordsList,
|
||||
Column {
|
||||
addKeywordButton,
|
||||
m_editKeywordButton,
|
||||
m_removeKeywordButton,
|
||||
resetKeywordsButton,
|
||||
Stretch()
|
||||
}
|
||||
}
|
||||
},
|
||||
Group {
|
||||
Title(tr("Scanning scope")),
|
||||
Column {
|
||||
m_scanInProjectRadioButton,
|
||||
m_scanInCurrentFileRadioButton,
|
||||
m_scanInSubprojectRadioButton
|
||||
}
|
||||
}
|
||||
}.attachTo(this);
|
||||
|
||||
m_keywordsList->setIconSize(QSize(16, 16));
|
||||
setKeywordsButtonsEnabled();
|
||||
connect(ui.addKeywordButton, &QAbstractButton::clicked,
|
||||
connect(addKeywordButton, &QAbstractButton::clicked,
|
||||
this, &OptionsDialog::addKeywordButtonClicked);
|
||||
connect(ui.removeKeywordButton, &QAbstractButton::clicked,
|
||||
connect(m_removeKeywordButton, &QAbstractButton::clicked,
|
||||
this, &OptionsDialog::removeKeywordButtonClicked);
|
||||
connect(ui.editKeywordButton, &QAbstractButton::clicked,
|
||||
connect(m_editKeywordButton, &QAbstractButton::clicked,
|
||||
this, &OptionsDialog::editKeywordButtonClicked);
|
||||
connect(ui.resetKeywordsButton, &QAbstractButton::clicked,
|
||||
connect(resetKeywordsButton, &QAbstractButton::clicked,
|
||||
this, &OptionsDialog::resetKeywordsButtonClicked);
|
||||
connect(ui.keywordsList, &QListWidget::itemDoubleClicked,
|
||||
connect(m_keywordsList, &QListWidget::itemDoubleClicked,
|
||||
this, &OptionsDialog::editKeyword);
|
||||
connect(ui.keywordsList, &QListWidget::itemSelectionChanged,
|
||||
connect(m_keywordsList, &QListWidget::itemSelectionChanged,
|
||||
this, &OptionsDialog::setKeywordsButtonsEnabled);
|
||||
|
||||
setSettings(*m_settings);
|
||||
@@ -88,7 +145,7 @@ void OptionsDialog::addToKeywordsList(const Keyword &keyword)
|
||||
auto item = new QListWidgetItem(icon(keyword.iconType), keyword.name);
|
||||
item->setData(Qt::UserRole, static_cast<int>(keyword.iconType));
|
||||
item->setForeground(keyword.color);
|
||||
ui.keywordsList->addItem(item);
|
||||
m_keywordsList->addItem(item);
|
||||
}
|
||||
|
||||
QSet<QString> OptionsDialog::keywordNames()
|
||||
@@ -114,7 +171,7 @@ void OptionsDialog::addKeywordButtonClicked()
|
||||
|
||||
void OptionsDialog::editKeywordButtonClicked()
|
||||
{
|
||||
QListWidgetItem *item = ui.keywordsList->currentItem();
|
||||
QListWidgetItem *item = m_keywordsList->currentItem();
|
||||
editKeyword(item);
|
||||
}
|
||||
|
||||
@@ -140,7 +197,7 @@ void OptionsDialog::editKeyword(QListWidgetItem *item)
|
||||
|
||||
void OptionsDialog::removeKeywordButtonClicked()
|
||||
{
|
||||
delete ui.keywordsList->takeItem(ui.keywordsList->currentRow());
|
||||
delete m_keywordsList->takeItem(m_keywordsList->currentRow());
|
||||
}
|
||||
|
||||
void OptionsDialog::resetKeywordsButtonClicked()
|
||||
@@ -152,18 +209,18 @@ void OptionsDialog::resetKeywordsButtonClicked()
|
||||
|
||||
void OptionsDialog::setKeywordsButtonsEnabled()
|
||||
{
|
||||
const bool isSomethingSelected = !ui.keywordsList->selectedItems().isEmpty();
|
||||
ui.removeKeywordButton->setEnabled(isSomethingSelected);
|
||||
ui.editKeywordButton->setEnabled(isSomethingSelected);
|
||||
const bool isSomethingSelected = !m_keywordsList->selectedItems().isEmpty();
|
||||
m_removeKeywordButton->setEnabled(isSomethingSelected);
|
||||
m_editKeywordButton->setEnabled(isSomethingSelected);
|
||||
}
|
||||
|
||||
void OptionsDialog::setSettings(const Settings &settings)
|
||||
{
|
||||
ui.scanInCurrentFileRadioButton->setChecked(settings.scanningScope == ScanningScopeCurrentFile);
|
||||
ui.scanInProjectRadioButton->setChecked(settings.scanningScope == ScanningScopeProject);
|
||||
ui.scanInSubprojectRadioButton->setChecked(settings.scanningScope == ScanningScopeSubProject);
|
||||
m_scanInCurrentFileRadioButton->setChecked(settings.scanningScope == ScanningScopeCurrentFile);
|
||||
m_scanInProjectRadioButton->setChecked(settings.scanningScope == ScanningScopeProject);
|
||||
m_scanInSubprojectRadioButton->setChecked(settings.scanningScope == ScanningScopeSubProject);
|
||||
|
||||
ui.keywordsList->clear();
|
||||
m_keywordsList->clear();
|
||||
for (const Keyword &keyword : qAsConst(settings.keywords))
|
||||
addToKeywordsList(keyword);
|
||||
}
|
||||
@@ -172,16 +229,16 @@ Settings OptionsDialog::settingsFromUi()
|
||||
{
|
||||
Settings settings;
|
||||
|
||||
if (ui.scanInCurrentFileRadioButton->isChecked())
|
||||
if (m_scanInCurrentFileRadioButton->isChecked())
|
||||
settings.scanningScope = ScanningScopeCurrentFile;
|
||||
else if (ui.scanInSubprojectRadioButton->isChecked())
|
||||
else if (m_scanInSubprojectRadioButton->isChecked())
|
||||
settings.scanningScope = ScanningScopeSubProject;
|
||||
else
|
||||
settings.scanningScope = ScanningScopeProject;
|
||||
|
||||
settings.keywords.clear();
|
||||
for (int i = 0; i < ui.keywordsList->count(); ++i) {
|
||||
QListWidgetItem *item = ui.keywordsList->item(i);
|
||||
for (int i = 0; i < m_keywordsList->count(); ++i) {
|
||||
QListWidgetItem *item = m_keywordsList->item(i);
|
||||
|
||||
Keyword keyword;
|
||||
keyword.name = item->text();
|
||||
@@ -220,5 +277,4 @@ TodoOptionsPage::TodoOptionsPage(Settings *settings, const std::function<void ()
|
||||
setWidgetCreator([settings, onApply] { return new OptionsDialog(settings, onApply); });
|
||||
}
|
||||
|
||||
} // namespace Internal
|
||||
} // namespace Todo
|
||||
} // Todo::Internal
|
||||
|
||||
Reference in New Issue
Block a user