mirror of
https://github.com/Chatterino/chatterino2.git
synced 2024-11-21 22:24:07 +01:00
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:
parent
84be4c9046
commit
5429e62e73
13 changed files with 189 additions and 512 deletions
|
@ -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 =
|
||||||
|
|
|
@ -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();
|
||||||
|
|
|
@ -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
|
|
|
@ -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
|
|
|
@ -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
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
|
|
@ -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
|
||||||
|
|
|
@ -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));
|
||||||
|
|
|
@ -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
|
||||||
|
|
|
@ -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
|
||||||
|
|
Loading…
Reference in a new issue