Utilize templates for Settings class

Use boost2::signals for the valueChanged signal (a LOT less messy to
        deal with than qt signals)
Remove unused settings classes (BoolSetting, FloatSetting, IntSetting,
        StringSetting)

What's left: Implement the remaining signals
This commit is contained in:
Rasmus Karlsson 2017-01-22 23:00:35 +01:00
parent 84be4c9046
commit 5429e62e73
13 changed files with 189 additions and 512 deletions

View file

@ -108,10 +108,6 @@ HEADERS += account.h \
widgets/signallabel.h \ widgets/signallabel.h \
widgets/textinputdialog.h \ widgets/textinputdialog.h \
windows.h \ windows.h \
settings/boolsetting.h \
settings/stringsetting.h \
settings/intsetting.h \
settings/floatsetting.h \
widgets/resizingtextedit.h widgets/resizingtextedit.h
PRECOMPILED_HEADER = PRECOMPILED_HEADER =

View file

@ -417,8 +417,8 @@ Message::layout(int width, bool enableEmoteMargins)
bool recalculateImages = this->emoteGeneration != Emotes::getGeneration(); bool recalculateImages = this->emoteGeneration != Emotes::getGeneration();
bool recalculateText = this->fontGeneration != Fonts::getGeneration(); bool recalculateText = this->fontGeneration != Fonts::getGeneration();
qreal emoteScale = settings.getEmoteScale().get(); qreal emoteScale = settings.emoteScale.get();
bool scaleEmotesByLineHeight = settings.getScaleEmotesByLineHeight().get(); bool scaleEmotesByLineHeight = settings.scaleEmotesByLineHeight.get();
if (recalculateImages || recalculateText) { if (recalculateImages || recalculateText) {
this->emoteGeneration = Emotes::getGeneration(); this->emoteGeneration = Emotes::getGeneration();

View file

@ -1,58 +0,0 @@
#ifndef BOOLSETTING_H
#define BOOLSETTING_H
#include "settings/setting.h"
#include <QString>
namespace chatterino {
namespace settings {
class BoolSetting : public Setting
{
Q_OBJECT
public:
BoolSetting(const QString &name, bool defaultValue)
: Setting(name)
, value(defaultValue)
, defaultValue(defaultValue)
{
}
bool
get() const
{
return this->value;
}
void
set(bool value)
{
if (this->value != value) {
this->value = value;
emit valueChanged(value);
}
}
void
save(const QSettings &settings) override
{
}
void
load(const QSettings &settings) override
{
}
signals:
void valueChanged(bool value);
private:
bool value;
bool defaultValue;
};
}
}
#endif // BOOLSETTING_H

View file

@ -1,58 +0,0 @@
#ifndef REALSETTING_H
#define REALSETTING_H
#include "settings/setting.h"
#include <QString>
namespace chatterino {
namespace settings {
class FloatSetting : public Setting
{
Q_OBJECT
public:
FloatSetting(const QString &name, qreal defaultValue,
qreal minValue = std::numeric_limits<qreal>::min(),
qreal maxValue = std::numeric_limits<qreal>::max())
: Setting(name)
, value(defaultValue)
, defaultValue(defaultValue)
, minValue(minValue)
, maxValue(maxValue)
{
}
qreal
get() const
{
return this->value;
}
qreal
set(qreal value)
{
return (this->value = std::max(std::min(value, maxValue), minValue));
}
void
save(const QSettings &settings) override
{
}
void
load(const QSettings &settings) override
{
}
private:
qreal value;
qreal defaultValue;
qreal minValue;
qreal maxValue;
};
}
}
#endif // REALSETTING_H

View file

@ -1,51 +0,0 @@
#ifndef INTSETTING_H
#define INTSETTING_H
#include "settings/setting.h"
#include <QString>
namespace chatterino {
namespace settings {
class IntSetting : public Setting
{
Q_OBJECT
public:
IntSetting(const QString &name, int defaultValue)
: Setting(name)
, value(defaultValue)
, defaultValue(defaultValue)
{
}
int
get() const
{
return this->value;
}
int
set(int value)
{
return (this->value = value);
}
void
save(const QSettings &settings) override
{
}
void
load(const QSettings &settings) override
{
}
private:
int value;
int defaultValue;
};
}
}
#endif // INTSETTING_H

View file

@ -3,22 +3,61 @@
#include <QSettings> #include <QSettings>
#include <QString> #include <QString>
#include <boost/signals2.hpp>
namespace chatterino { namespace chatterino {
namespace settings { namespace settings {
class Setting : public QObject class BaseSetting
{ {
Q_OBJECT
public: public:
explicit Setting(const QString &name) virtual void save(QSettings &settings) = 0;
: name(name) virtual void load(const QSettings &settings) = 0;
};
template <typename T>
class Setting : public BaseSetting
{
public:
Setting(const QString &_name, const T &defaultValue)
: name(_name)
, value(defaultValue)
{ {
} }
virtual void save(const QSettings &settings) = 0; const T &
virtual void load(const QSettings &settings) = 0; get() const
{
return this->value;
}
void
set(const T &newValue)
{
if (this->value != newValue) {
this->value = newValue;
this->valueChanged(newValue);
}
}
virtual void
save(QSettings &settings) final
{
settings.setValue(this->getName(), QVariant::fromValue(this->value));
}
virtual void
load(const QSettings &settings) final
{
QVariant newValue = settings.value(this->getName(), QVariant());
if (newValue.isValid()) {
assert(newValue.canConvert<T>());
this->value = newValue.value<T>();
}
}
boost::signals2::signal<void(const T &newValue)> valueChanged;
protected: protected:
const QString & const QString &
@ -29,8 +68,10 @@ protected:
private: private:
QString name; QString name;
T value;
}; };
}
} } // namespace settings
} // namespace chatterino
#endif // SETTING_H #endif // SETTING_H

View file

@ -6,13 +6,12 @@
namespace chatterino { namespace chatterino {
namespace settings { namespace settings {
Settings Settings::_; Settings Settings::instance;
Settings::Settings() Settings::Settings()
: settings( : settings(
QStandardPaths::writableLocation(QStandardPaths::AppDataLocation), QStandardPaths::writableLocation(QStandardPaths::AppDataLocation),
QSettings::IniFormat) QSettings::IniFormat)
, settingsItems()
, portable(false) , portable(false)
, wordTypeMask(messages::Word::Default) , wordTypeMask(messages::Word::Default)
, theme("", "dark") , theme("", "dark")
@ -43,62 +42,61 @@ Settings::Settings()
, windowTopMost("", true) , windowTopMost("", true)
, hideTabX("", false) , hideTabX("", false)
{ {
settingsItems.reserve(25); settingsItems.push_back(theme);
settingsItems.push_back(&theme); settingsItems.push_back(user);
settingsItems.push_back(&user); settingsItems.push_back(emoteScale);
settingsItems.push_back(&emoteScale); settingsItems.push_back(scaleEmotesByLineHeight);
settingsItems.push_back(&scaleEmotesByLineHeight); settingsItems.push_back(showTimestamps);
settingsItems.push_back(&showTimestamps); settingsItems.push_back(showTimestampSeconds);
settingsItems.push_back(&showTimestampSeconds); settingsItems.push_back(showLastMessageIndicator);
settingsItems.push_back(&showLastMessageIndicator); settingsItems.push_back(allowDouplicateMessages);
settingsItems.push_back(&allowDouplicateMessages); settingsItems.push_back(linksDoubleClickOnly);
settingsItems.push_back(&linksDoubleClickOnly); settingsItems.push_back(hideEmptyInput);
settingsItems.push_back(&hideEmptyInput); settingsItems.push_back(showMessageLength);
settingsItems.push_back(&showMessageLength); settingsItems.push_back(seperateMessages);
settingsItems.push_back(&seperateMessages); settingsItems.push_back(mentionUsersWithAt);
settingsItems.push_back(&mentionUsersWithAt); settingsItems.push_back(allowCommandsAtEnd);
settingsItems.push_back(&allowCommandsAtEnd); settingsItems.push_back(enableHighlights);
settingsItems.push_back(&enableHighlights); settingsItems.push_back(enableHighlightSound);
settingsItems.push_back(&enableHighlightSound); settingsItems.push_back(enableHighlightTaskbar);
settingsItems.push_back(&enableHighlightTaskbar); settingsItems.push_back(customHighlightSound);
settingsItems.push_back(&customHighlightSound); settingsItems.push_back(enableTwitchEmotes);
settingsItems.push_back(&enableTwitchEmotes); settingsItems.push_back(enableBttvEmotes);
settingsItems.push_back(&enableBttvEmotes); settingsItems.push_back(enableFfzEmotes);
settingsItems.push_back(&enableFfzEmotes); settingsItems.push_back(enableEmojis);
settingsItems.push_back(&enableEmojis); settingsItems.push_back(enableGifAnimations);
settingsItems.push_back(&enableGifAnimations); settingsItems.push_back(enableGifs);
settingsItems.push_back(&enableGifs); settingsItems.push_back(inlineWhispers);
settingsItems.push_back(&inlineWhispers); settingsItems.push_back(windowTopMost);
settingsItems.push_back(&windowTopMost); settingsItems.push_back(hideTabX);
settingsItems.push_back(&hideTabX);
QObject::connect(&showTimestamps, &BoolSetting::valueChanged, this, this->showTimestamps.valueChanged.connect(
&Settings::updateWordTypeMask); [this](const auto &) { this->updateWordTypeMask(); });
QObject::connect(&showTimestampSeconds, &BoolSetting::valueChanged, this, this->showTimestampSeconds.valueChanged.connect(
&Settings::updateWordTypeMask); [this](const auto &) { this->updateWordTypeMask(); });
QObject::connect(&enableBttvEmotes, &BoolSetting::valueChanged, this, this->enableBttvEmotes.valueChanged.connect(
&Settings::updateWordTypeMask); [this](const auto &) { this->updateWordTypeMask(); });
QObject::connect(&enableEmojis, &BoolSetting::valueChanged, this, this->enableEmojis.valueChanged.connect(
&Settings::updateWordTypeMask); [this](const auto &) { this->updateWordTypeMask(); });
QObject::connect(&enableFfzEmotes, &BoolSetting::valueChanged, this, this->enableFfzEmotes.valueChanged.connect(
&Settings::updateWordTypeMask); [this](const auto &) { this->updateWordTypeMask(); });
QObject::connect(&enableTwitchEmotes, &BoolSetting::valueChanged, this, this->enableTwitchEmotes.valueChanged.connect(
&Settings::updateWordTypeMask); [this](const auto &) { this->updateWordTypeMask(); });
} }
void void
Settings::save() Settings::save()
{ {
for (Setting *item : settingsItems) { for (auto &item : settingsItems) {
item->save(settings); item.get().save(settings);
} }
} }
void void
Settings::load() Settings::load()
{ {
for (Setting *item : settingsItems) { for (auto &item : settingsItems) {
item->load(settings); item.get().load(settings);
} }
} }
@ -109,7 +107,7 @@ Settings::isIgnoredEmote(const QString &)
} }
void void
Settings::updateWordTypeMask(bool) Settings::updateWordTypeMask()
{ {
using namespace messages; using namespace messages;
@ -143,5 +141,6 @@ Settings::updateWordTypeMask(bool)
emit wordTypeMaskChanged(); emit wordTypeMaskChanged();
// } // }
} }
}
} } // namespace settings
} // namespace chatterino

View file

@ -2,10 +2,7 @@
#define APPSETTINGS_H #define APPSETTINGS_H
#include "messages/word.h" #include "messages/word.h"
#include "settings/boolsetting.h"
#include "settings/floatsetting.h"
#include "settings/setting.h" #include "settings/setting.h"
#include "settings/stringsetting.h"
#include <QSettings> #include <QSettings>
@ -20,7 +17,7 @@ public:
static Settings & static Settings &
getInstance() getInstance()
{ {
return _; return instance;
} }
void load(); void load();
@ -52,12 +49,12 @@ signals:
private: private:
Settings(); Settings();
static Settings _; static Settings instance;
void updateWordTypeMask(bool); void updateWordTypeMask();
QSettings settings; QSettings settings;
std::vector<Setting *> settingsItems; std::vector<std::reference_wrapper<BaseSetting>> settingsItems;
// template <class T> // template <class T>
// T // T
@ -71,174 +68,37 @@ private:
messages::Word::Type wordTypeMask; messages::Word::Type wordTypeMask;
private:
StringSetting theme;
StringSetting user;
FloatSetting emoteScale;
BoolSetting scaleEmotesByLineHeight;
BoolSetting showTimestamps;
BoolSetting showTimestampSeconds;
BoolSetting showLastMessageIndicator;
BoolSetting allowDouplicateMessages;
BoolSetting linksDoubleClickOnly;
BoolSetting hideEmptyInput;
BoolSetting showMessageLength;
BoolSetting seperateMessages;
BoolSetting mentionUsersWithAt;
BoolSetting allowCommandsAtEnd;
BoolSetting enableHighlights;
BoolSetting enableHighlightSound;
BoolSetting enableHighlightTaskbar;
BoolSetting customHighlightSound;
BoolSetting enableTwitchEmotes;
BoolSetting enableBttvEmotes;
BoolSetting enableFfzEmotes;
BoolSetting enableEmojis;
BoolSetting enableGifAnimations;
BoolSetting enableGifs;
BoolSetting inlineWhispers;
BoolSetting windowTopMost;
BoolSetting hideTabX;
// settings
public: public:
StringSetting & Setting<QString> theme;
getTheme() Setting<QString> user;
{ Setting<float> emoteScale;
return this->theme; Setting<bool> scaleEmotesByLineHeight;
} Setting<bool> showTimestamps;
StringSetting & Setting<bool> showTimestampSeconds;
getUser() Setting<bool> showLastMessageIndicator;
{ Setting<bool> allowDouplicateMessages;
return this->user; Setting<bool> linksDoubleClickOnly;
} Setting<bool> hideEmptyInput;
FloatSetting & Setting<bool> showMessageLength;
getEmoteScale() Setting<bool> seperateMessages;
{ Setting<bool> mentionUsersWithAt;
return this->emoteScale; Setting<bool> allowCommandsAtEnd;
} Setting<bool> enableHighlights;
BoolSetting & Setting<bool> enableHighlightSound;
getScaleEmotesByLineHeight() Setting<bool> enableHighlightTaskbar;
{ Setting<bool> customHighlightSound;
return this->scaleEmotesByLineHeight; Setting<bool> enableTwitchEmotes;
} Setting<bool> enableBttvEmotes;
BoolSetting & Setting<bool> enableFfzEmotes;
getShowTimestamps() Setting<bool> enableEmojis;
{ Setting<bool> enableGifAnimations;
return this->showTimestamps; Setting<bool> enableGifs;
} Setting<bool> inlineWhispers;
BoolSetting & Setting<bool> windowTopMost;
getShowTimestampSeconds() Setting<bool> hideTabX;
{
return this->showTimestampSeconds;
}
BoolSetting &
getShowLastMessageIndicator()
{
return this->showLastMessageIndicator;
}
BoolSetting &
getAllowDouplicateMessages()
{
return this->allowDouplicateMessages;
}
BoolSetting &
getLinksDoubleClickOnly()
{
return this->linksDoubleClickOnly;
}
BoolSetting &
getHideEmptyInput()
{
return this->hideEmptyInput;
}
BoolSetting &
getShowMessageLength()
{
return this->showMessageLength;
}
BoolSetting &
getSeperateMessages()
{
return this->seperateMessages;
}
BoolSetting &
getMentionUsersWithAt()
{
return this->mentionUsersWithAt;
}
BoolSetting &
getAllowCommandsAtEnd()
{
return this->allowCommandsAtEnd;
}
BoolSetting &
getEnableHighlights()
{
return this->enableHighlights;
}
BoolSetting &
getEnableHighlightSound()
{
return this->enableHighlightSound;
}
BoolSetting &
getEnableHighlightTaskbar()
{
return this->enableHighlightTaskbar;
}
BoolSetting &
getCustomHighlightSound()
{
return this->customHighlightSound;
}
BoolSetting &
getEnableTwitchEmotes()
{
return this->enableTwitchEmotes;
}
BoolSetting &
getEnableBttvEmotes()
{
return this->enableBttvEmotes;
}
BoolSetting &
getEnableFfzEmotes()
{
return this->enableFfzEmotes;
}
BoolSetting &
getEnableEmojis()
{
return this->enableEmojis;
}
BoolSetting &
getEnableGifAnimations()
{
return this->enableGifAnimations;
}
BoolSetting &
getEnableGifs()
{
return this->enableGifs;
}
BoolSetting &
getInlineWhispers()
{
return this->inlineWhispers;
}
BoolSetting &
getWindowTopMost()
{
return this->windowTopMost;
}
BoolSetting &
getHideTabX()
{
return this->hideTabX;
}
}; };
}
} } // namespace settings
} // namespace chatterino
#endif // APPSETTINGS_H #endif // APPSETTINGS_H

View file

@ -1,61 +0,0 @@
#ifndef STRINGSETTING_H
#define STRINGSETTING_H
#include "settings/setting.h"
#include <QString>
namespace chatterino {
namespace settings {
class StringSetting : public Setting
{
Q_OBJECT
public:
StringSetting(const QString &name, const QString &defaultValue)
: Setting(name)
, value(defaultValue)
, defaultValue(defaultValue)
{
}
const QString &
get() const
{
return this->value;
}
const QString &
set(const QString &value)
{
this->value = value;
QString tmp = value;
emit valueChanged(tmp);
return this->value;
}
void
save(const QSettings &settings) override
{
}
void
load(const QSettings &settings) override
{
}
signals:
void valueChanged(const QString &value);
private:
QString value;
QString defaultValue;
};
}
}
#endif // STRINGSETTING_H

View file

@ -41,18 +41,23 @@ ChatWidgetInput::ChatWidgetInput()
this->refreshTheme(); this->refreshTheme();
this->setMessageLengthVisisble( this->setMessageLengthVisisble(
settings::Settings::getInstance().getShowMessageLength().get()); settings::Settings::getInstance().showMessageLength.get());
QObject::connect(&settings::Settings::getInstance().getShowMessageLength(), /* XXX(pajlada): FIX THIS
QObject::connect(&settings::Settings::getInstance().showMessageLength,
&settings::BoolSetting::valueChanged, this, &settings::BoolSetting::valueChanged, this,
&ChatWidgetInput::setMessageLengthVisisble); &ChatWidgetInput::setMessageLengthVisisble);
*/
} }
ChatWidgetInput::~ChatWidgetInput() ChatWidgetInput::~ChatWidgetInput()
{ {
/* XXX(pajlada): FIX THIS
QObject::disconnect( QObject::disconnect(
&settings::Settings::getInstance().getShowMessageLength(), &settings::Settings::getInstance().getShowMessageLength(),
&settings::BoolSetting::valueChanged, this, &ChatWidgetInput::setMessageLengthVisisble); &settings::BoolSetting::valueChanged, this,
&ChatWidgetInput::setMessageLengthVisisble);
*/
} }
void void

View file

@ -24,24 +24,28 @@ NotebookTab::NotebookTab(Notebook *notebook)
this->calcSize(); this->calcSize();
this->setAcceptDrops(true); this->setAcceptDrops(true);
/* XXX(pajlada): Fix this
QObject::connect(&settings::Settings::getInstance().getHideTabX(), QObject::connect(&settings::Settings::getInstance().getHideTabX(),
&settings::BoolSetting::valueChanged, this, &settings::BoolSetting::valueChanged, this,
&NotebookTab::hideTabXChanged); &NotebookTab::hideTabXChanged);
*/
this->setMouseTracking(true); this->setMouseTracking(true);
} }
NotebookTab::~NotebookTab() NotebookTab::~NotebookTab()
{ {
/* XXX(pajlada): Fix this
QObject::disconnect(&settings::Settings::getInstance().getHideTabX(), QObject::disconnect(&settings::Settings::getInstance().getHideTabX(),
&settings::BoolSetting::valueChanged, this, &settings::BoolSetting::valueChanged, this,
&NotebookTab::hideTabXChanged); &NotebookTab::hideTabXChanged);
*/
} }
void void
NotebookTab::calcSize() NotebookTab::calcSize()
{ {
if (settings::Settings::getInstance().getHideTabX().get()) { if (settings::Settings::getInstance().hideTabX.get()) {
this->resize(this->fontMetrics().width(this->text) + 8, 24); this->resize(this->fontMetrics().width(this->text) + 8, 24);
} else { } else {
this->resize(this->fontMetrics().width(this->text) + 8 + 24, 24); this->resize(this->fontMetrics().width(this->text) + 8 + 24, 24);
@ -101,13 +105,12 @@ NotebookTab::paintEvent(QPaintEvent *)
QRect rect( QRect rect(
0, 0, 0, 0,
width() - width() - (settings::Settings::getInstance().hideTabX.get() ? 0 : 16),
(settings::Settings::getInstance().getHideTabX().get() ? 0 : 16),
height()); height());
painter.drawText(rect, this->text, QTextOption(Qt::AlignCenter)); painter.drawText(rect, this->text, QTextOption(Qt::AlignCenter));
if (!settings::Settings::getInstance().getHideTabX().get() && if (!settings::Settings::getInstance().hideTabX.get() &&
(this->mouseOver || this->selected)) { (this->mouseOver || this->selected)) {
if (this->mouseOverX) { if (this->mouseOverX) {
painter.fillRect(this->getXRect(), QColor(0, 0, 0, 64)); painter.fillRect(this->getXRect(), QColor(0, 0, 0, 64));

View file

@ -82,17 +82,16 @@ SettingsDialog::addTabs()
auto group = new QGroupBox("Messages"); auto group = new QGroupBox("Messages");
auto v = new QVBoxLayout(); auto v = new QVBoxLayout();
v->addWidget( v->addWidget(createCheckbox("Show timestamp", settings.showTimestamps));
createCheckbox("Show timestamp", settings.getShowTimestamps()));
v->addWidget(createCheckbox("Show seconds in timestamp", v->addWidget(createCheckbox("Show seconds in timestamp",
settings.getShowTimestampSeconds())); settings.showTimestampSeconds));
v->addWidget(createCheckbox( v->addWidget(createCheckbox(
"Allow sending duplicate messages (add a space at the end)", "Allow sending duplicate messages (add a space at the end)",
settings.getAllowDouplicateMessages())); settings.allowDouplicateMessages));
v->addWidget(createCheckbox("Seperate messages", v->addWidget(
settings.getSeperateMessages())); createCheckbox("Seperate messages", settings.seperateMessages));
v->addWidget(createCheckbox("Show message length", v->addWidget(
settings.getShowMessageLength())); createCheckbox("Show message length", settings.showMessageLength));
group->setLayout(v); group->setLayout(v);
@ -106,15 +105,15 @@ SettingsDialog::addTabs()
// Behaviour // Behaviour
vbox = new QVBoxLayout(); vbox = new QVBoxLayout();
vbox->addWidget(createCheckbox("Hide input box if empty", vbox->addWidget(
settings.getHideEmptyInput())); createCheckbox("Hide input box if empty", settings.hideEmptyInput));
vbox->addWidget( vbox->addWidget(
createCheckbox("Mention users with a @ (except in commands)", createCheckbox("Mention users with a @ (except in commands)",
settings.getMentionUsersWithAt())); settings.mentionUsersWithAt));
vbox->addWidget( vbox->addWidget(
createCheckbox("Window always on top", settings.getWindowTopMost())); createCheckbox("Window always on top", settings.windowTopMost));
vbox->addWidget(createCheckbox("Show last read message indicator", vbox->addWidget(createCheckbox("Show last read message indicator",
settings.getShowLastMessageIndicator())); settings.showLastMessageIndicator));
{ {
auto v = new QVBoxLayout(); auto v = new QVBoxLayout();
@ -142,19 +141,17 @@ SettingsDialog::addTabs()
// Emotes // Emotes
vbox = new QVBoxLayout(); vbox = new QVBoxLayout();
vbox->addWidget(createCheckbox("Enable Twitch Emotes",
settings.getEnableTwitchEmotes()));
vbox->addWidget(createCheckbox("Enable BetterTTV Emotes",
settings.getEnableBttvEmotes()));
vbox->addWidget(createCheckbox("Enable FrankerFaceZ Emotes",
settings.getEnableFfzEmotes()));
vbox->addWidget( vbox->addWidget(
createCheckbox("Enable Gif Emotes", settings.getEnableGifs())); createCheckbox("Enable Twitch Emotes", settings.enableTwitchEmotes));
vbox->addWidget( vbox->addWidget(
createCheckbox("Enable Emojis", settings.getEnableEmojis())); createCheckbox("Enable BetterTTV Emotes", settings.enableBttvEmotes));
vbox->addWidget(
createCheckbox("Enable FrankerFaceZ Emotes", settings.enableFfzEmotes));
vbox->addWidget(createCheckbox("Enable Gif Emotes", settings.enableGifs));
vbox->addWidget(createCheckbox("Enable Emojis", settings.enableEmojis));
vbox->addWidget(createCheckbox("Enable Twitch Emotes", vbox->addWidget(
settings.getEnableTwitchEmotes())); createCheckbox("Enable Twitch Emotes", settings.enableTwitchEmotes));
vbox->addStretch(1); vbox->addStretch(1);
addTab(vbox, "Emotes", ":/images/Emoji_Color_1F60A_19.png"); addTab(vbox, "Emotes", ":/images/Emoji_Color_1F60A_19.png");
@ -189,18 +186,6 @@ SettingsDialog::addTabs()
tabs.addStretch(1); tabs.addStretch(1);
} }
QCheckBox *
SettingsDialog::createCheckbox(const QString &title,
settings::BoolSetting &setting)
{
auto checkbox = new QCheckBox(title);
QObject::connect(checkbox, &QCheckBox::toggled, this,
[&setting, this](bool state) { setting.set(state); });
return checkbox;
}
void void
SettingsDialog::addTab(QLayout *layout, QString title, QString imageRes) SettingsDialog::addTab(QLayout *layout, QString title, QString imageRes)
{ {
@ -238,5 +223,19 @@ SettingsDialog::select(SettingsDialogTab *tab)
"border-right: none;"); "border-right: none;");
selectedTab = tab; selectedTab = tab;
} }
/// Widget creation helpers
QCheckBox *
SettingsDialog::createCheckbox(const QString &title,
settings::Setting<bool> &setting)
{
auto checkbox = new QCheckBox(title);
QObject::connect(checkbox, &QCheckBox::toggled, this,
[&setting, this](bool state) { setting.set(state); });
return checkbox;
} }
}
} // namespace widgets
} // namespace chatterino

View file

@ -40,10 +40,12 @@ private:
SettingsDialogTab *selectedTab = NULL; SettingsDialogTab *selectedTab = NULL;
/// Widget creation helpers
QCheckBox *createCheckbox(const QString &title, QCheckBox *createCheckbox(const QString &title,
settings::BoolSetting &setting); settings::Setting<bool> &setting);
}; };
}
} } // namespace widgets
} // namespace chatterino
#endif // SETTINGSDIALOG_H #endif // SETTINGSDIALOG_H