diff --git a/src/chatlog/chatmessage.cpp b/src/chatlog/chatmessage.cpp
index a6fb8fc36..10a3b3e5f 100644
--- a/src/chatlog/chatmessage.cpp
+++ b/src/chatlog/chatmessage.cpp
@@ -41,8 +41,9 @@
#define TIME_COL_WIDTH 90.0
-ChatMessage::ChatMessage(DocumentCache& documentCache_)
+ChatMessage::ChatMessage(DocumentCache& documentCache_, Settings& settings_)
: documentCache{documentCache_}
+ , settings{settings_}
{
}
@@ -51,16 +52,17 @@ ChatMessage::~ChatMessage() = default;
ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QString& rawMessage,
MessageType type, bool isMe, MessageState state,
const QDateTime& date, DocumentCache& documentCache,
- SmileyPack& smileyPack, bool colorizeName)
+ SmileyPack& smileyPack, Settings& settings,
+ bool colorizeName)
{
- ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache));
+ ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache, settings));
QString text = rawMessage.toHtmlEscaped();
QString senderText = sender;
auto textType = Text::NORMAL;
// smileys
- if (Settings::getInstance().getUseEmoticons())
+ if (settings.getUseEmoticons())
text = smileyPack.smileyfied(text);
// quotes (green text)
@@ -68,7 +70,7 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QSt
text = TextFormatter::highlightURI(text);
// text styling
- Settings::StyleType styleType = Settings::getInstance().getStylePreference();
+ Settings::StyleType styleType = settings.getStylePreference();
if (styleType != Settings::StyleType::NONE) {
text = TextFormatter::applyMarkdown(text, styleType == Settings::StyleType::WITH_CHARS);
}
@@ -90,7 +92,7 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QSt
}
// Note: Eliding cannot be enabled for RichText items. (QTBUG-17207)
- QFont baseFont = Settings::getInstance().getChatMessageFont();
+ QFont baseFont = settings.getChatMessageFont();
QFont authorFont = baseFont;
if (isMe)
authorFont.setBold(true);
@@ -110,25 +112,25 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QSt
}
}
- msg->addColumn(new Text(documentCache, senderText, authorFont, true, sender, textType, color),
+ msg->addColumn(new Text(documentCache, settings, senderText, authorFont, true, sender, textType, color),
ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right));
- msg->addColumn(new Text(documentCache, text, baseFont, false, ((type == ACTION) && isMe)
+ msg->addColumn(new Text(documentCache, settings, text, baseFont, false, ((type == ACTION) && isMe)
? QString("%1 %2").arg(sender, rawMessage)
: rawMessage),
ColumnFormat(1.0, ColumnFormat::VariableSize));
switch (state) {
case MessageState::complete:
- msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(),
- baseFont, documentCache),
+ msg->addColumn(new Timestamp(date, settings.getTimestampFormat(),
+ baseFont, documentCache, settings),
ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right));
break;
case MessageState::pending:
- msg->addColumn(new Spinner(Style::getImagePath("chatArea/spinner.svg"), QSize(16, 16), 360.0 / 1.6),
+ msg->addColumn(new Spinner(Style::getImagePath("chatArea/spinner.svg", settings), QSize(16, 16), 360.0 / 1.6),
ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right));
break;
case MessageState::broken:
- msg->addColumn(new Broken(Style::getImagePath("chatArea/error.svg"), QSize(16, 16)),
+ msg->addColumn(new Broken(Style::getImagePath("chatArea/error.svg", settings), QSize(16, 16)),
ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right));
break;
}
@@ -137,32 +139,32 @@ ChatMessage::Ptr ChatMessage::createChatMessage(const QString& sender, const QSt
ChatMessage::Ptr ChatMessage::createChatInfoMessage(const QString& rawMessage,
SystemMessageType type, const QDateTime& date,
- DocumentCache& documentCache)
+ DocumentCache& documentCache, Settings& settings)
{
- ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache));
+ ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache, settings));
QString text = rawMessage.toHtmlEscaped();
QString img;
switch (type) {
case INFO:
- img = Style::getImagePath("chatArea/info.svg");
+ img = Style::getImagePath("chatArea/info.svg", settings);
break;
case ERROR:
- img = Style::getImagePath("chatArea/error.svg");
+ img = Style::getImagePath("chatArea/error.svg", settings);
break;
case TYPING:
- img = Style::getImagePath("chatArea/typing.svg");
+ img = Style::getImagePath("chatArea/typing.svg", settings);
break;
}
- QFont baseFont = Settings::getInstance().getChatMessageFont();
+ QFont baseFont = settings.getChatMessageFont();
msg->addColumn(new Image(QSize(18, 18), img),
ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right));
- msg->addColumn(new Text(documentCache, "" + text + "", baseFont, false, text),
+ msg->addColumn(new Text(documentCache, settings, "" + text + "", baseFont, false, text),
ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left));
- msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(),
- baseFont, documentCache),
+ msg->addColumn(new Timestamp(date, settings.getTimestampFormat(),
+ baseFont, documentCache, settings),
ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right));
return msg;
@@ -170,31 +172,34 @@ ChatMessage::Ptr ChatMessage::createChatInfoMessage(const QString& rawMessage,
ChatMessage::Ptr ChatMessage::createFileTransferMessage(const QString& sender, CoreFile& coreFile,
ToxFile file, bool isMe, const QDateTime& date,
- DocumentCache& documentCache)
+ DocumentCache& documentCache,
+ Settings& settings)
{
- ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache));
+ ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache, settings));
- QFont baseFont = Settings::getInstance().getChatMessageFont();
+ QFont baseFont = settings.getChatMessageFont();
QFont authorFont = baseFont;
if (isMe) {
authorFont.setBold(true);
}
- msg->addColumn(new Text(documentCache, sender, authorFont, true),
+ msg->addColumn(new Text(documentCache, settings, sender, authorFont, true),
ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right));
- msg->addColumn(new ChatLineContentProxy(new FileTransferWidget(nullptr, coreFile, file), 320, 0.6f),
+ msg->addColumn(new ChatLineContentProxy(new FileTransferWidget(nullptr, coreFile, file, settings), 320, 0.6f),
ColumnFormat(1.0, ColumnFormat::VariableSize));
- msg->addColumn(new Timestamp(date, Settings::getInstance().getTimestampFormat(), baseFont, documentCache),
+ msg->addColumn(new Timestamp(date, settings.getTimestampFormat(), baseFont,
+ documentCache, settings),
ColumnFormat(TIME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right));
return msg;
}
-ChatMessage::Ptr ChatMessage::createTypingNotification(DocumentCache& documentCache)
+ChatMessage::Ptr ChatMessage::createTypingNotification(DocumentCache& documentCache,
+ Settings& settings)
{
- ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache));
+ ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache, settings));
- QFont baseFont = Settings::getInstance().getChatMessageFont();
+ QFont baseFont = settings.getChatMessageFont();
// Note: "[user]..." is just a placeholder. The actual text is set in
// ChatForm::setFriendTyping()
@@ -203,9 +208,9 @@ ChatMessage::Ptr ChatMessage::createTypingNotification(DocumentCache& documentCa
// user received typing notifications constantly since contact came online.
// This causes "[user]..." to be displayed in place of user nick, as long
// as user will keep typing. Issue #1280
- msg->addColumn(new NotificationIcon(QSize(18, 18)),
+ msg->addColumn(new NotificationIcon(settings, QSize(18, 18)),
ColumnFormat(NAME_COL_WIDTH, ColumnFormat::FixedSize, ColumnFormat::Right));
- msg->addColumn(new Text(documentCache, "[user]...", baseFont, false, ""),
+ msg->addColumn(new Text(documentCache, settings, "[user]...", baseFont, false, ""),
ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Left));
return msg;
@@ -219,14 +224,15 @@ ChatMessage::Ptr ChatMessage::createTypingNotification(DocumentCache& documentCa
*
* @return created message
*/
-ChatMessage::Ptr ChatMessage::createBusyNotification(DocumentCache& documentCache)
+ChatMessage::Ptr ChatMessage::createBusyNotification(DocumentCache& documentCache,
+ Settings& settings)
{
- ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache));
- QFont baseFont = Settings::getInstance().getChatMessageFont();
+ ChatMessage::Ptr msg = ChatMessage::Ptr(new ChatMessage(documentCache, settings));
+ QFont baseFont = settings.getChatMessageFont();
baseFont.setPixelSize(baseFont.pixelSize() + 2);
baseFont.setBold(true);
- msg->addColumn(new Text(documentCache, QObject::tr("Reformatting text...", "Waiting for text to be reformatted"), baseFont, false, ""),
+ msg->addColumn(new Text(documentCache, settings, QObject::tr("Reformatting text...", "Waiting for text to be reformatted"), baseFont, false, ""),
ColumnFormat(1.0, ColumnFormat::VariableSize, ColumnFormat::Center));
return msg;
@@ -234,15 +240,16 @@ ChatMessage::Ptr ChatMessage::createBusyNotification(DocumentCache& documentCach
void ChatMessage::markAsDelivered(const QDateTime& time)
{
- QFont baseFont = Settings::getInstance().getChatMessageFont();
+ QFont baseFont = settings.getChatMessageFont();
// remove the spinner and replace it by $time
- replaceContent(2, new Timestamp(time, Settings::getInstance().getTimestampFormat(), baseFont, documentCache));
+ replaceContent(2, new Timestamp(time, settings.getTimestampFormat(),
+ baseFont, documentCache, settings));
}
void ChatMessage::markAsBroken()
{
- replaceContent(2, new Broken(Style::getImagePath("chatArea/error.svg"), QSize(16, 16)));
+ replaceContent(2, new Broken(Style::getImagePath("chatArea/error.svg", settings), QSize(16, 16)));
}
QString ChatMessage::toString() const
diff --git a/src/chatlog/chatmessage.h b/src/chatlog/chatmessage.h
index 83d1ab74d..41ab104ea 100644
--- a/src/chatlog/chatmessage.h
+++ b/src/chatlog/chatmessage.h
@@ -29,6 +29,7 @@ class CoreFile;
class QGraphicsScene;
class DocumentCache;
class SmileyPack;
+class Settings;
class ChatMessage : public ChatLine
{
@@ -49,7 +50,7 @@ public:
ALERT,
};
- explicit ChatMessage(DocumentCache& documentCache);
+ ChatMessage(DocumentCache&, Settings&);
~ChatMessage();
ChatMessage(const ChatMessage&) = default;
ChatMessage(ChatMessage&&) = default;
@@ -57,14 +58,14 @@ public:
static ChatMessage::Ptr createChatMessage(const QString& sender, const QString& rawMessage,
MessageType type, bool isMe, MessageState state,
const QDateTime& date, DocumentCache&,
- SmileyPack& smileyPack, bool colorizeName = false);
+ SmileyPack&, Settings&, bool colorizeName = false);
static ChatMessage::Ptr createChatInfoMessage(const QString& rawMessage, SystemMessageType type,
- const QDateTime& date, DocumentCache&);
+ const QDateTime& date, DocumentCache&, Settings&);
static ChatMessage::Ptr createFileTransferMessage(const QString& sender, CoreFile& coreFile,
ToxFile file, bool isMe, const QDateTime& date,
- DocumentCache&);
- static ChatMessage::Ptr createTypingNotification(DocumentCache&);
- static ChatMessage::Ptr createBusyNotification(DocumentCache&);
+ DocumentCache&, Settings&);
+ static ChatMessage::Ptr createTypingNotification(DocumentCache&, Settings&);
+ static ChatMessage::Ptr createBusyNotification(DocumentCache&, Settings&);
void markAsDelivered(const QDateTime& time);
void markAsBroken();
@@ -81,4 +82,5 @@ protected:
private:
bool action = false;
DocumentCache& documentCache;
+ Settings& settings;
};
diff --git a/src/chatlog/chatwidget.cpp b/src/chatlog/chatwidget.cpp
index 7e47c539d..85acf400a 100644
--- a/src/chatlog/chatwidget.cpp
+++ b/src/chatlog/chatwidget.cpp
@@ -62,17 +62,16 @@ T clamp(T x, T min, T max)
return x;
}
-ChatMessage::Ptr createDateMessage(QDateTime timestamp, DocumentCache& documentCache)
+ChatMessage::Ptr createDateMessage(QDateTime timestamp, DocumentCache& documentCache, Settings& settings)
{
- const auto& s = Settings::getInstance();
const auto date = timestamp.date();
- auto dateText = date.toString(s.getDateFormat());
- return ChatMessage::createChatInfoMessage(dateText, ChatMessage::INFO, QDateTime(), documentCache);
+ auto dateText = date.toString(settings.getDateFormat());
+ return ChatMessage::createChatInfoMessage(dateText, ChatMessage::INFO, QDateTime(), documentCache, settings);
}
ChatMessage::Ptr createMessage(const QString& displayName, bool isSelf, bool colorizeNames,
const ChatLogMessage& chatLogMessage, DocumentCache& documentCache,
- SmileyPack& smileyPack)
+ SmileyPack& smileyPack, Settings& settings)
{
auto messageType = chatLogMessage.message.isAction ? ChatMessage::MessageType::ACTION
: ChatMessage::MessageType::NORMAL;
@@ -90,12 +89,12 @@ ChatMessage::Ptr createMessage(const QString& displayName, bool isSelf, bool col
const auto timestamp = chatLogMessage.message.timestamp;
return ChatMessage::createChatMessage(displayName, chatLogMessage.message.content, messageType,
isSelf, chatLogMessage.state, timestamp, documentCache,
- smileyPack, colorizeNames);
+ smileyPack, settings, colorizeNames);
}
void renderMessageRaw(const QString& displayName, bool isSelf, bool colorizeNames,
const ChatLogMessage& chatLogMessage, ChatLine::Ptr& chatLine,
- DocumentCache& documentCache, SmileyPack& smileyPack)
+ DocumentCache& documentCache, SmileyPack& smileyPack, Settings& settings)
{
// HACK: This is kind of gross, but there's not an easy way to fit this into
// the existing architecture. This shouldn't ever fail since we should only
@@ -112,7 +111,7 @@ void renderMessageRaw(const QString& displayName, bool isSelf, bool colorizeName
}
} else {
chatLine = createMessage(displayName, isSelf, colorizeNames, chatLogMessage,
- documentCache, smileyPack);
+ documentCache, smileyPack, settings);
}
}
@@ -209,13 +208,14 @@ ChatLogIdx clampedAdd(ChatLogIdx idx, int val, IChatLog& chatLog)
ChatWidget::ChatWidget(IChatLog& chatLog_, const Core& core_, DocumentCache& documentCache_,
- SmileyPack& smileyPack_, QWidget* parent)
+ SmileyPack& smileyPack_, Settings& settings_, QWidget* parent)
: QGraphicsView(parent)
, chatLog(chatLog_)
, core(core_)
, chatLineStorage(new ChatLineStorage())
, documentCache(documentCache_)
, smileyPack{smileyPack_}
+ , settings(settings_)
{
// Create the scene
busyScene = new QGraphicsScene(this);
@@ -223,7 +223,7 @@ ChatWidget::ChatWidget(IChatLog& chatLog_, const Core& core_, DocumentCache& doc
scene->setItemIndexMethod(QGraphicsScene::BspTreeIndex);
setScene(scene);
- busyNotification = ChatMessage::createBusyNotification(documentCache);
+ busyNotification = ChatMessage::createBusyNotification(documentCache, settings);
busyNotification->addToScene(busyScene);
busyNotification->visibilityChanged(true);
@@ -548,7 +548,7 @@ void ChatWidget::insertChatlines(std::map chatLines)
if (!chatLineStorage->contains(date)) {
// If there is no dateline for the given date we need to insert it
// above the line we'd like to insert.
- auto dateLine = createDateMessage(date, documentCache);
+ auto dateLine = createDateMessage(date, documentCache, settings);
chatLineStorage->insertDateLine(date, dateLine);
dateLine->addToScene(scene);
dateLine->visibilityChanged(false);
@@ -797,7 +797,7 @@ void ChatWidget::fontChanged(const QFont& font)
void ChatWidget::reloadTheme()
{
- setStyleSheet(Style::getStylesheet("chatArea/chatArea.css"));
+ setStyleSheet(Style::getStylesheet("chatArea/chatArea.css", settings));
setBackgroundBrush(QBrush(Style::getColor(Style::GroundBase), Qt::SolidPattern));
selectionRectColor = Style::getColor(Style::SelectText);
selGraphItem->setBrush(QBrush(selectionRectColor));
@@ -1400,7 +1400,7 @@ bool ChatWidget::isActiveFileTransfer(ChatLine::Ptr l)
void ChatWidget::setTypingNotification()
{
- typingNotification = ChatMessage::createTypingNotification(documentCache);
+ typingNotification = ChatMessage::createTypingNotification(documentCache, settings);
typingNotification->visibilityChanged(true);
typingNotification->setVisible(false);
typingNotification->addToScene(scene);
@@ -1419,7 +1419,7 @@ void ChatWidget::renderItem(const ChatLogItem& item, bool hideName, bool coloriz
const auto& chatLogMessage = item.getContentAsMessage();
renderMessageRaw(item.getDisplayName(), isSelf, colorizeNames_, chatLogMessage,
- chatMessage, documentCache, smileyPack);
+ chatMessage, documentCache, smileyPack, settings);
break;
}
@@ -1433,7 +1433,7 @@ void ChatWidget::renderItem(const ChatLogItem& item, bool hideName, bool coloriz
auto chatMessageType = getChatMessageType(systemMessage);
chatMessage = ChatMessage::createChatInfoMessage(systemMessage.toString(),
- chatMessageType, QDateTime::currentDateTime(), documentCache);
+ chatMessageType, QDateTime::currentDateTime(), documentCache, settings);
// Ignore caller's decision to hide the name. We show the icon in the
// slot of the sender's name so we always want it visible
hideName = false;
@@ -1453,7 +1453,7 @@ void ChatWidget::renderFile(QString displayName, ToxFile file, bool isSelf, QDat
CoreFile* coreFile = core.getCoreFile();
assert(coreFile);
chatMessage = ChatMessage::createFileTransferMessage(displayName, *coreFile,
- file, isSelf, timestamp, documentCache);
+ file, isSelf, timestamp, documentCache, settings);
} else {
auto proxy = static_cast(chatMessage->getContent(1));
assert(proxy->getWidgetType() == ChatLineContentProxy::FileTransferWidgetType);
diff --git a/src/chatlog/chatwidget.h b/src/chatlog/chatwidget.h
index 1028f7abc..de2d03426 100644
--- a/src/chatlog/chatwidget.h
+++ b/src/chatlog/chatwidget.h
@@ -35,6 +35,7 @@ class QTimer;
class ChatLineContent;
struct ToxFile;
class SmileyPack;
+class Settings;
class ChatLineStorage;
@@ -44,7 +45,7 @@ class ChatWidget : public QGraphicsView
Q_OBJECT
public:
ChatWidget(IChatLog& chatLog_, const Core& core_, DocumentCache&, SmileyPack&,
- QWidget* parent = nullptr);
+ Settings&, QWidget* parent = nullptr);
virtual ~ChatWidget();
void insertChatlines(std::map chatLines);
@@ -218,4 +219,5 @@ private:
std::vector> renderCompletionFns;
DocumentCache& documentCache;
SmileyPack& smileyPack;
+ Settings& settings;
};
diff --git a/src/chatlog/content/filetransferwidget.cpp b/src/chatlog/content/filetransferwidget.cpp
index 411dad209..b2e5e3d98 100644
--- a/src/chatlog/content/filetransferwidget.cpp
+++ b/src/chatlog/content/filetransferwidget.cpp
@@ -48,7 +48,8 @@
// The rightButton is used to cancel a file transfer, or to open the directory a file was
// downloaded to.
-FileTransferWidget::FileTransferWidget(QWidget* parent, CoreFile& _coreFile, ToxFile file)
+FileTransferWidget::FileTransferWidget(QWidget* parent, CoreFile& _coreFile,
+ ToxFile file, Settings& settings_)
: QWidget(parent)
, coreFile{_coreFile}
, ui(new Ui::FileTransferWidget)
@@ -57,6 +58,7 @@ FileTransferWidget::FileTransferWidget(QWidget* parent, CoreFile& _coreFile, Tox
, buttonColor(Style::getColor(Style::TransferWait))
, buttonBackgroundColor(Style::getColor(Style::GroundBase))
, active(true)
+ , settings(settings_)
{
ui->setupUi(this);
@@ -158,7 +160,7 @@ void FileTransferWidget::setBackgroundColor(const QColor& c, bool whiteFont)
setProperty("fontColor", whiteFont ? "white" : "black");
- setStyleSheet(Style::getStylesheet("fileTransferInstance/filetransferWidget.css"));
+ setStyleSheet(Style::getStylesheet("fileTransferInstance/filetransferWidget.css", settings));
Style::repolish(this);
update();
@@ -377,11 +379,11 @@ void FileTransferWidget::setupButtons(ToxFile const& file)
switch (file.status) {
case ToxFile::TRANSMITTING:
- ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/pause.svg")));
+ ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/pause.svg", settings)));
ui->leftButton->setObjectName("pause");
ui->leftButton->setToolTip(tr("Pause transfer"));
- ui->rightButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/no.svg")));
+ ui->rightButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/no.svg", settings)));
ui->rightButton->setObjectName("cancel");
ui->rightButton->setToolTip(tr("Cancel transfer"));
@@ -390,16 +392,16 @@ void FileTransferWidget::setupButtons(ToxFile const& file)
case ToxFile::PAUSED:
if (file.pauseStatus.localPaused()) {
- ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/arrow_white.svg")));
+ ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/arrow_white.svg", settings)));
ui->leftButton->setObjectName("resume");
ui->leftButton->setToolTip(tr("Resume transfer"));
} else {
- ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/pause.svg")));
+ ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/pause.svg", settings)));
ui->leftButton->setObjectName("pause");
ui->leftButton->setToolTip(tr("Pause transfer"));
}
- ui->rightButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/no.svg")));
+ ui->rightButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/no.svg", settings)));
ui->rightButton->setObjectName("cancel");
ui->rightButton->setToolTip(tr("Cancel transfer"));
@@ -407,16 +409,16 @@ void FileTransferWidget::setupButtons(ToxFile const& file)
break;
case ToxFile::INITIALIZING:
- ui->rightButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/no.svg")));
+ ui->rightButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/no.svg", settings)));
ui->rightButton->setObjectName("cancel");
ui->rightButton->setToolTip(tr("Cancel transfer"));
if (file.direction == ToxFile::SENDING) {
- ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/pause.svg")));
+ ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/pause.svg", settings)));
ui->leftButton->setObjectName("pause");
ui->leftButton->setToolTip(tr("Pause transfer"));
} else {
- ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/yes.svg")));
+ ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/yes.svg", settings)));
ui->leftButton->setObjectName("accept");
ui->leftButton->setToolTip(tr("Accept transfer"));
}
@@ -427,12 +429,12 @@ void FileTransferWidget::setupButtons(ToxFile const& file)
ui->rightButton->hide();
break;
case ToxFile::FINISHED:
- ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/yes.svg")));
+ ui->leftButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/yes.svg", settings)));
ui->leftButton->setObjectName("ok");
ui->leftButton->setToolTip(tr("Open file"));
ui->leftButton->show();
- ui->rightButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/dir.svg")));
+ ui->rightButton->setIcon(QIcon(Style::getImagePath("fileTransferInstance/dir.svg", settings)));
ui->rightButton->setObjectName("dir");
ui->rightButton->setToolTip(tr("Open file directory"));
ui->rightButton->show();
@@ -466,7 +468,7 @@ void FileTransferWidget::handleButton(QPushButton* btn)
QString path =
QFileDialog::getSaveFileName(Q_NULLPTR,
tr("Save a file", "Title of the file saving dialog"),
- Settings::getInstance().getGlobalAutoAcceptDir() + "/"
+ settings.getGlobalAutoAcceptDir() + "/"
+ fileInfo.fileName);
acceptTransfer(path);
}
diff --git a/src/chatlog/content/filetransferwidget.h b/src/chatlog/content/filetransferwidget.h
index 3b639e836..dbcbe0ecc 100644
--- a/src/chatlog/content/filetransferwidget.h
+++ b/src/chatlog/content/filetransferwidget.h
@@ -33,13 +33,14 @@ class FileTransferWidget;
class QVariantAnimation;
class QPushButton;
+class Settings;
class FileTransferWidget : public QWidget
{
Q_OBJECT
public:
- explicit FileTransferWidget(QWidget* parent, CoreFile& _coreFile, ToxFile file);
+ FileTransferWidget(QWidget* parent, CoreFile& _coreFile, ToxFile file, Settings&);
virtual ~FileTransferWidget();
bool isActive() const;
void onFileTransferUpdate(ToxFile file);
@@ -88,5 +89,6 @@ private:
bool active;
QTime lastTransmissionUpdate;
ToxFile::FileStatus lastStatus = ToxFile::INITIALIZING;
+ Settings& settings;
};
diff --git a/src/chatlog/content/notificationicon.cpp b/src/chatlog/content/notificationicon.cpp
index 81299d816..92a805182 100644
--- a/src/chatlog/content/notificationicon.cpp
+++ b/src/chatlog/content/notificationicon.cpp
@@ -25,10 +25,10 @@
#include
#include
-NotificationIcon::NotificationIcon(QSize Size)
+NotificationIcon::NotificationIcon(Settings& settings, QSize Size)
: size(Size)
{
- pmap = PixmapCache::getInstance().get(Style::getImagePath("chatArea/typing.svg"), size);
+ pmap = PixmapCache::getInstance().get(Style::getImagePath("chatArea/typing.svg", settings), size);
// Timer for the animation, if the Widget is not redrawn, no paint events will
// arrive and the timer will not be restarted, so this stops automatically
diff --git a/src/chatlog/content/notificationicon.h b/src/chatlog/content/notificationicon.h
index a609a9849..3da46eb21 100644
--- a/src/chatlog/content/notificationicon.h
+++ b/src/chatlog/content/notificationicon.h
@@ -25,11 +25,13 @@
#include
#include
+class Settings;
+
class NotificationIcon : public ChatLineContent
{
Q_OBJECT
public:
- explicit NotificationIcon(QSize size);
+ explicit NotificationIcon(Settings&, QSize size);
QRectF boundingRect() const override;
void paint(QPainter* painter, const QStyleOptionGraphicsItem* option,
diff --git a/src/chatlog/content/text.cpp b/src/chatlog/content/text.cpp
index 7aad51063..d506c8791 100644
--- a/src/chatlog/content/text.cpp
+++ b/src/chatlog/content/text.cpp
@@ -31,16 +31,17 @@
#include
#include
-Text::Text(DocumentCache& documentCache_, const QString& txt, const QFont& font,
- bool enableElide, const QString& rwText, const TextType& type,
+Text::Text(DocumentCache& documentCache_, Settings& settings_, const QString& txt,
+ const QFont& font, bool enableElide, const QString& rwText, const TextType& type,
const QColor& custom)
: rawText(rwText)
, elide(enableElide)
, defFont(font)
- , defStyleSheet(Style::getStylesheet(QStringLiteral("chatArea/innerStyle.css"), font))
+ , defStyleSheet(Style::getStylesheet(QStringLiteral("chatArea/innerStyle.css"), settings_, font))
, textType(type)
, customColor(custom)
, documentCache(documentCache_)
+ , settings{settings_}
{
color = textColor();
setText(txt);
@@ -251,7 +252,7 @@ void Text::visibilityChanged(bool visible)
void Text::reloadTheme()
{
- defStyleSheet = Style::getStylesheet(QStringLiteral("chatArea/innerStyle.css"), defFont);
+ defStyleSheet = Style::getStylesheet(QStringLiteral("chatArea/innerStyle.css"), settings, defFont);
color = textColor();
dirty = true;
regenerate();
diff --git a/src/chatlog/content/text.h b/src/chatlog/content/text.h
index fef9669b4..7805df782 100644
--- a/src/chatlog/content/text.h
+++ b/src/chatlog/content/text.h
@@ -26,6 +26,7 @@
class QTextDocument;
class DocumentCache;
+class Settings;
class Text : public ChatLineContent
{
@@ -39,7 +40,7 @@ public:
CUSTOM
};
- Text(DocumentCache&, const QString& txt = "", const QFont& font = QFont(),
+ Text(DocumentCache&, Settings&, const QString& txt = "", const QFont& font = QFont(),
bool enableElide = false, const QString& rawText = QString(),
const TextType& type = NORMAL,
const QColor& custom = Style::getColor(Style::MainText));
@@ -113,4 +114,5 @@ private:
QColor color;
QColor customColor;
DocumentCache& documentCache;
+ Settings& settings;
};
diff --git a/src/chatlog/content/timestamp.cpp b/src/chatlog/content/timestamp.cpp
index 8772ffbd8..a19c9588c 100644
--- a/src/chatlog/content/timestamp.cpp
+++ b/src/chatlog/content/timestamp.cpp
@@ -19,8 +19,10 @@
#include "timestamp.h"
-Timestamp::Timestamp(const QDateTime& time_, const QString& format, const QFont& font, DocumentCache& documentCache_)
- : Text(documentCache_, time_.toString(format), font, false, time_.toString(format))
+Timestamp::Timestamp(const QDateTime& time_, const QString& format,
+ const QFont& font, DocumentCache& documentCache_, Settings& settings_)
+ : Text(documentCache_, settings_, time_.toString(format), font, false,
+ time_.toString(format))
{
time = time_;
}
diff --git a/src/chatlog/content/timestamp.h b/src/chatlog/content/timestamp.h
index d6e9c63ff..4632b4a82 100644
--- a/src/chatlog/content/timestamp.h
+++ b/src/chatlog/content/timestamp.h
@@ -25,13 +25,14 @@
class QTextDocument;
class DocumentCache;
+class Settings;
class Timestamp : public Text
{
Q_OBJECT
public:
Timestamp(const QDateTime& time_, const QString& format, const QFont& font,
- DocumentCache&);
+ DocumentCache&, Settings&);
QDateTime getTime();
protected:
diff --git a/src/chatlog/customtextdocument.cpp b/src/chatlog/customtextdocument.cpp
index c078b84d4..9334771b0 100644
--- a/src/chatlog/customtextdocument.cpp
+++ b/src/chatlog/customtextdocument.cpp
@@ -26,9 +26,11 @@
#include
#include
-CustomTextDocument::CustomTextDocument(SmileyPack& smileyPack_, QObject* parent)
+CustomTextDocument::CustomTextDocument(SmileyPack& smileyPack_,
+ Settings& settings_, QObject* parent)
: QTextDocument(parent)
, smileyPack(smileyPack_)
+ , settings(settings_)
{
setUndoRedoEnabled(false);
setUseDesignMetrics(false);
@@ -37,8 +39,8 @@ CustomTextDocument::CustomTextDocument(SmileyPack& smileyPack_, QObject* parent)
QVariant CustomTextDocument::loadResource(int type, const QUrl& name)
{
if (type == QTextDocument::ImageResource && name.scheme() == "key") {
- QSize size = QSize(Settings::getInstance().getEmojiFontPointSize(),
- Settings::getInstance().getEmojiFontPointSize());
+ QSize size = QSize(settings.getEmojiFontPointSize(),
+ settings.getEmojiFontPointSize());
QString fileName = QUrl::fromPercentEncoding(name.toEncoded()).mid(4).toHtmlEscaped();
std::shared_ptr icon = smileyPack.getAsIcon(fileName);
diff --git a/src/chatlog/customtextdocument.h b/src/chatlog/customtextdocument.h
index ce329f6cc..2f06cf2a3 100644
--- a/src/chatlog/customtextdocument.h
+++ b/src/chatlog/customtextdocument.h
@@ -26,12 +26,13 @@
class QIcon;
class SmileyPack;
+class Settings;
class CustomTextDocument : public QTextDocument
{
Q_OBJECT
public:
- explicit CustomTextDocument(SmileyPack&, QObject* parent = nullptr);
+ CustomTextDocument(SmileyPack&, Settings&, QObject* parent = nullptr);
protected:
virtual QVariant loadResource(int type, const QUrl& name);
@@ -39,4 +40,5 @@ protected:
private:
QList> emoticonIcons;
SmileyPack& smileyPack;
+ Settings& settings;
};
diff --git a/src/chatlog/documentcache.cpp b/src/chatlog/documentcache.cpp
index 3d47a96a3..beffae599 100644
--- a/src/chatlog/documentcache.cpp
+++ b/src/chatlog/documentcache.cpp
@@ -20,8 +20,9 @@
#include "documentcache.h"
#include "customtextdocument.h"
-DocumentCache::DocumentCache(SmileyPack& smileyPack_)
+DocumentCache::DocumentCache(SmileyPack& smileyPack_, Settings& settings_)
: smileyPack{smileyPack_}
+ , settings{settings_}
{
}
DocumentCache::~DocumentCache()
@@ -33,7 +34,7 @@ DocumentCache::~DocumentCache()
QTextDocument* DocumentCache::pop()
{
if (documents.empty())
- documents.push(new CustomTextDocument(smileyPack));
+ documents.push(new CustomTextDocument(smileyPack, settings));
return documents.pop();
}
diff --git a/src/chatlog/documentcache.h b/src/chatlog/documentcache.h
index 8c72663e9..20e74596a 100644
--- a/src/chatlog/documentcache.h
+++ b/src/chatlog/documentcache.h
@@ -23,11 +23,12 @@
class QTextDocument;
class SmileyPack;
+class Settings;
class DocumentCache
{
public:
- explicit DocumentCache(SmileyPack& smileyPack);
+ DocumentCache(SmileyPack&, Settings&);
~DocumentCache();
DocumentCache(DocumentCache&) = delete;
DocumentCache& operator=(const DocumentCache&) = delete;
@@ -37,4 +38,5 @@ public:
private:
QStack documents;
SmileyPack& smileyPack;
+ Settings& settings;
};
diff --git a/src/friendlist.cpp b/src/friendlist.cpp
index 0a874741b..156d3fdf8 100644
--- a/src/friendlist.cpp
+++ b/src/friendlist.cpp
@@ -29,14 +29,14 @@
QHash FriendList::friendList;
QHash FriendList::id2key;
-Friend* FriendList::addFriend(uint32_t friendId, const ToxPk& friendPk)
+Friend* FriendList::addFriend(uint32_t friendId, const ToxPk& friendPk, Settings& settings)
{
auto friendChecker = friendList.find(friendPk);
if (friendChecker != friendList.end()) {
qWarning() << "addFriend: friendPk already taken";
}
- QString alias = Settings::getInstance().getFriendAlias(friendPk);
+ QString alias = settings.getFriendAlias(friendPk);
Friend* newfriend = new Friend(friendId, friendPk, alias);
friendList[friendPk] = newfriend;
id2key[friendId] = friendPk;
@@ -59,12 +59,12 @@ const ToxPk& FriendList::id2Key(uint32_t friendId)
return id2key[friendId];
}
-void FriendList::removeFriend(const ToxPk& friendPk, bool fake)
+void FriendList::removeFriend(const ToxPk& friendPk, Settings& settings, bool fake)
{
auto f_it = friendList.find(friendPk);
if (f_it != friendList.end()) {
if (!fake)
- Settings::getInstance().removeFriendSettings(f_it.value()->getPublicKey());
+ settings.removeFriendSettings(f_it.value()->getPublicKey());
friendList.erase(f_it);
}
}
diff --git a/src/friendlist.h b/src/friendlist.h
index 4761b3161..0beb434eb 100644
--- a/src/friendlist.h
+++ b/src/friendlist.h
@@ -29,15 +29,16 @@ class Friend;
class QByteArray;
class QString;
class ToxPk;
+class Settings;
class FriendList
{
public:
- static Friend* addFriend(uint32_t friendId, const ToxPk& friendPk);
+ static Friend* addFriend(uint32_t friendId, const ToxPk& friendPk, Settings&);
static Friend* findFriend(const ToxPk& friendPk);
static const ToxPk& id2Key(uint32_t friendId);
static QList getAllFriends();
- static void removeFriend(const ToxPk& friendPk, bool fake = false);
+ static void removeFriend(const ToxPk& friendPk, Settings&, bool fake = false);
static void clear();
static QString decideNickname(const ToxPk& friendPk, const QString& origName);
diff --git a/src/ipc.cpp b/src/ipc.cpp
index 19f1f20e5..b5b7bd9c7 100644
--- a/src/ipc.cpp
+++ b/src/ipc.cpp
@@ -189,9 +189,9 @@ bool IPC::isCurrentOwner()
* @brief Register a handler for an IPC event
* @param handler The handler callback. Should not block for more than a second, at worst
*/
-void IPC::registerEventHandler(const QString& name, IPCEventHandler handler)
+void IPC::registerEventHandler(const QString& name, IPCEventHandler handler, void* userData)
{
- eventHandlers[name] = handler;
+ eventHandlers[name] = {handler, userData};
}
bool IPC::isEventAccepted(time_t time)
@@ -269,11 +269,11 @@ IPC::IPCEvent* IPC::fetchEvent()
return nullptr;
}
-bool IPC::runEventHandler(IPCEventHandler handler, const QByteArray& arg)
+bool IPC::runEventHandler(IPCEventHandler handler, const QByteArray& arg, void* userData)
{
bool result = false;
if (QThread::currentThread() == qApp->thread()) {
- result = handler(arg);
+ result = handler(arg, userData);
} else {
QMetaObject::invokeMethod(this, "runEventHandler", Qt::BlockingQueuedConnection,
Q_RETURN_ARG(bool, result), Q_ARG(IPCEventHandler, handler),
@@ -313,7 +313,7 @@ void IPC::processEvents()
QString name = QString::fromUtf8(evt->name);
auto it = eventHandlers.find(name);
if (it != eventHandlers.end()) {
- evt->accepted = runEventHandler(it.value(), evt->data);
+ evt->accepted = runEventHandler(it.value().handler, evt->data, it.value().userData);
qDebug() << "Processed event:" << name << "posted:" << evt->posted
<< "accepted:" << evt->accepted;
if (evt->dest == 0) {
diff --git a/src/ipc.h b/src/ipc.h
index 3bcacfab7..57642cdce 100644
--- a/src/ipc.h
+++ b/src/ipc.h
@@ -27,7 +27,7 @@
#include
#include
-using IPCEventHandler = std::function;
+using IPCEventHandler = std::function;
#define IPC_PROTOCOL_VERSION "2"
@@ -68,7 +68,7 @@ public:
time_t postEvent(const QString& name, const QByteArray& data = QByteArray(), uint32_t dest = 0);
bool isCurrentOwner();
- void registerEventHandler(const QString& name, IPCEventHandler handler);
+ void registerEventHandler(const QString& name, IPCEventHandler handler, void* userData);
bool isEventAccepted(time_t time);
bool waitUntilAccepted(time_t time, int32_t timeout = -1);
bool isAttached() const;
@@ -78,15 +78,20 @@ public slots:
private:
IPCMemory* global();
- bool runEventHandler(IPCEventHandler handler, const QByteArray& arg);
+ bool runEventHandler(IPCEventHandler handler, const QByteArray& arg, void* userData);
IPCEvent* fetchEvent();
void processEvents();
bool isCurrentOwnerNoLock();
private:
+ struct Callback
+ {
+ IPCEventHandler handler;
+ void* userData;
+ };
QTimer timer;
uint64_t globalId;
uint32_t profileId;
QSharedMemory globalMemory;
- QMap eventHandlers;
+ QMap eventHandlers;
};
diff --git a/src/main.cpp b/src/main.cpp
index 2921e37d6..a0bbde80a 100644
--- a/src/main.cpp
+++ b/src/main.cpp
@@ -55,19 +55,23 @@ QList* logBuffer =
QMutex* logBufferMutex = new QMutex();
#endif
+std::unique_ptr settings;
+std::unique_ptr toxSave;
+
void cleanup()
{
// force save early even though destruction saves, because Windows OS will
// close qTox before cleanup() is finished if logging out or shutting down,
// once the top level window has exited, which occurs in ~Widget within
// ~Nexus. Re-ordering Nexus destruction is not trivial.
- auto& s = Settings::getInstance();
- s.saveGlobal();
- s.savePersonal();
- s.sync();
+ if (settings) {
+ settings->saveGlobal();
+ settings->savePersonal();
+ settings->sync();
+ }
Nexus::destroyInstance();
- Settings::destroyInstance();
+ settings.reset();
qDebug() << "Cleanup success";
#ifdef LOG_TO_FILE
@@ -183,8 +187,9 @@ void logMessageHandler(QtMsgType type, const QMessageLogContext& ctxt, const QSt
std::unique_ptr uriDialog;
-bool toxURIEventHandler(const QByteArray& eventData)
+bool toxURIEventHandler(const QByteArray& eventData, void* userData)
{
+ std::ignore = userData;
if (!eventData.startsWith("tox:")) {
return false;
}
@@ -196,7 +201,8 @@ bool toxURIEventHandler(const QByteArray& eventData)
uriDialog->handleToxURI(eventData);
return true;
}
-}
+
+} // namespace
int main(int argc, char* argv[])
{
@@ -230,8 +236,9 @@ int main(int argc, char* argv[])
qWarning() << "Couldn't load font";
}
- Settings& settings = Settings::getInstance();
- QString locale = settings.getTranslation();
+ settings = std::unique_ptr(new Settings());
+
+ QString locale = settings->getTranslation();
// We need to init the resources in the translations_library explicitely.
// See https://doc.qt.io/qt-5/resources.html#using-resources-in-a-library
Q_INIT_RESOURCE(translations);
@@ -272,10 +279,10 @@ int main(int argc, char* argv[])
QObject::tr("(SOCKS5/HTTP/NONE):(ADDRESS):(PORT)")));
parser.process(*a);
- uint32_t profileId = settings.getCurrentProfileId();
+ uint32_t profileId = settings->getCurrentProfileId();
IPC ipc(profileId);
if (ipc.isAttached()) {
- QObject::connect(&settings, &Settings::currentProfileIdChanged, &ipc, &IPC::setProfileId);
+ QObject::connect(settings.get(), &Settings::currentProfileIdChanged, &ipc, &IPC::setProfileId);
} else {
qWarning() << "Can't init IPC, maybe we're in a jail? Continuing with reduced multi-client functionality.";
}
@@ -287,7 +294,7 @@ int main(int argc, char* argv[])
}
#ifdef LOG_TO_FILE
- QString logFileDir = settings.getPaths().getAppCacheDirPath();
+ QString logFileDir = settings->getPaths().getAppCacheDirPath();
QDir(logFileDir).mkpath(".");
QString logfile = logFileDir + "qtox.log";
@@ -333,14 +340,14 @@ int main(int argc, char* argv[])
qDebug() << "commit: " << GIT_VERSION;
QString profileName;
- bool autoLogin = settings.getAutoLogin();
+ bool autoLogin = settings->getAutoLogin();
uint32_t ipcDest = 0;
bool doIpc = ipc.isAttached();
QString eventType, firstParam;
if (parser.isSet("p")) {
profileName = parser.value("p");
- if (!Profile::exists(profileName)) {
+ if (!Profile::exists(profileName, settings->getPaths())) {
qWarning() << "-p profile" << profileName + ".tox"
<< "doesn't exist, opening login screen";
doIpc = false;
@@ -353,7 +360,7 @@ int main(int argc, char* argv[])
doIpc = false;
autoLogin = false;
} else {
- profileName = settings.getCurrentProfile();
+ profileName = settings->getCurrentProfile();
}
if (parser.positionalArguments().empty()) {
@@ -398,14 +405,14 @@ int main(int argc, char* argv[])
// TODO(kriby): Consider moving application initializing variables into a globalSettings object
// note: Because Settings is shouldering global settings as well as model specific ones it
// cannot be integrated into a central model object yet
- nexus.setSettings(&settings);
+ nexus.setSettings(settings.get());
auto& cameraSource = Nexus::getCameraSource();
// Autologin
// TODO (kriby): Shift responsibility of linking views to model objects from nexus
// Further: generate view instances separately (loginScreen, mainGUI, audio)
Profile* profile = nullptr;
- if (autoLogin && Profile::exists(profileName) && !Profile::isEncrypted(profileName)) {
- profile = Profile::loadProfile(profileName, QString(), settings, &parser, cameraSource);
+ if (autoLogin && Profile::exists(profileName, settings->getPaths()) && !Profile::isEncrypted(profileName, settings->getPaths())) {
+ profile = Profile::loadProfile(profileName, QString(), *settings, &parser, cameraSource);
if (!profile) {
QMessageBox::information(nullptr, QObject::tr("Error"),
QObject::tr("Failed to load profile automatically."));
@@ -426,16 +433,16 @@ int main(int argc, char* argv[])
if (ipc.isAttached()) {
// Start to accept Inter-process communication
- ipc.registerEventHandler("uri", &toxURIEventHandler);
- ipc.registerEventHandler("save", &toxSaveEventHandler);
- ipc.registerEventHandler("activate", &toxActivateEventHandler);
+ ipc.registerEventHandler("uri", &toxURIEventHandler, uriDialog.get());
+ ipc.registerEventHandler("save", &ToxSave::toxSaveEventHandler, toxSave.get());
+ ipc.registerEventHandler("activate", &toxActivateEventHandler, nullptr);
}
// Event was not handled by already running instance therefore we handle it ourselves
if (eventType == "uri") {
uriDialog->handleToxURI(firstParam.toUtf8());
} else if (eventType == "save") {
- handleToxSave(firstParam.toUtf8());
+ toxSave->handleToxSave(firstParam.toUtf8());
}
QObject::connect(a.get(), &QApplication::aboutToQuit, cleanup);
diff --git a/src/model/chatroom/friendchatroom.cpp b/src/model/chatroom/friendchatroom.cpp
index a56d02063..df5e69bf0 100644
--- a/src/model/chatroom/friendchatroom.cpp
+++ b/src/model/chatroom/friendchatroom.cpp
@@ -42,10 +42,11 @@ QString getShortName(const QString& name)
}
-FriendChatroom::FriendChatroom(Friend* frnd_, IDialogsManager* dialogsManager_, Core& core_)
+FriendChatroom::FriendChatroom(Friend* frnd_, IDialogsManager* dialogsManager_, Core& core_, Settings& settings_)
: frnd{frnd_}
, dialogsManager{dialogsManager_}
, core{core_}
+ , settings{settings_}
{
}
@@ -74,13 +75,13 @@ bool FriendChatroom::canBeInvited() const
int FriendChatroom::getCircleId() const
{
- return Settings::getInstance().getFriendCircleID(frnd->getPublicKey());
+ return settings.getFriendCircleID(frnd->getPublicKey());
}
QString FriendChatroom::getCircleName() const
{
const auto circleId = getCircleId();
- return Settings::getInstance().getCircleName(circleId);
+ return settings.getCircleName(circleId);
}
void FriendChatroom::inviteToNewGroup()
@@ -93,13 +94,13 @@ void FriendChatroom::inviteToNewGroup()
QString FriendChatroom::getAutoAcceptDir() const
{
const auto pk = frnd->getPublicKey();
- return Settings::getInstance().getAutoAcceptDir(pk);
+ return settings.getAutoAcceptDir(pk);
}
void FriendChatroom::setAutoAcceptDir(const QString& dir)
{
const auto pk = frnd->getPublicKey();
- Settings::getInstance().setAutoAcceptDir(pk, dir);
+ settings.setAutoAcceptDir(pk, dir);
}
void FriendChatroom::disableAutoAccept()
@@ -138,13 +139,12 @@ QVector FriendChatroom::getOtherCircles() const
{
QVector circles;
const auto currentCircleId = getCircleId();
- const auto& s = Settings::getInstance();
- for (int i = 0; i < s.getCircleCount(); ++i) {
+ for (int i = 0; i < settings.getCircleCount(); ++i) {
if (i == currentCircleId) {
continue;
}
- const auto name = getShortName(s.getCircleName(i));
+ const auto name = getShortName(settings.getCircleName(i));
const CircleToDisplay circle = { name, i };
circles.push_back(circle);
}
diff --git a/src/model/chatroom/friendchatroom.h b/src/model/chatroom/friendchatroom.h
index fb50b30cb..39515e0be 100644
--- a/src/model/chatroom/friendchatroom.h
+++ b/src/model/chatroom/friendchatroom.h
@@ -29,6 +29,7 @@ class Core;
class IDialogsManager;
class Friend;
class Group;
+class Settings;
struct GroupToDisplay
{
@@ -46,7 +47,8 @@ class FriendChatroom : public QObject, public Chatroom
{
Q_OBJECT
public:
- FriendChatroom(Friend* frnd_, IDialogsManager* dialogsManager_, Core& core_);
+ FriendChatroom(Friend* frnd_, IDialogsManager* dialogsManager_, Core& core_,
+ Settings& settings_);
Contact* getContact() override;
@@ -87,4 +89,5 @@ private:
Friend* frnd{nullptr};
IDialogsManager* dialogsManager{nullptr};
Core& core;
+ Settings& settings;
};
diff --git a/src/model/profile/profileinfo.cpp b/src/model/profile/profileinfo.cpp
index 71015d531..f423b7124 100644
--- a/src/model/profile/profileinfo.cpp
+++ b/src/model/profile/profileinfo.cpp
@@ -99,9 +99,10 @@ bool tryRemoveFile(const QString& filepath)
* @param profile Pointer to Profile.
* @note All pointers parameters shouldn't be null.
*/
-ProfileInfo::ProfileInfo(Core* core_, Profile* profile_)
+ProfileInfo::ProfileInfo(Core* core_, Profile* profile_, Settings& settings_)
: profile{profile_}
, core{core_}
+ , settings{settings_}
{
connect(core_, &Core::idSet, this, &ProfileInfo::idChanged);
connect(core_, &Core::usernameSet, this, &ProfileInfo::usernameChanged);
@@ -193,7 +194,7 @@ IProfileInfo::RenameResult ProfileInfo::renameProfile(const QString& name)
QString newName = sanitize(name);
- if (Profile::exists(newName)) {
+ if (Profile::exists(newName, settings.getPaths())) {
return RenameResult::ProfileAlreadyExists;
}
@@ -220,7 +221,7 @@ IProfileInfo::SaveResult ProfileInfo::exportProfile(const QString& path) const
return SaveResult::NoWritePermission;
}
- if (!QFile::copy(Settings::getInstance().getPaths().getSettingsDirPath() + current, path)) {
+ if (!QFile::copy(settings.getPaths().getSettingsDirPath() + current, path)) {
return SaveResult::Error;
}
@@ -244,9 +245,9 @@ QStringList ProfileInfo::removeProfile()
void ProfileInfo::logout()
{
// TODO(kriby): Refactor all of these invokeMethod calls with connect() properly when possible
- Settings::getInstance().saveGlobal();
+ settings.saveGlobal();
QMetaObject::invokeMethod(&Nexus::getInstance(), "showLogin",
- Q_ARG(QString, Settings::getInstance().getCurrentProfile()));
+ Q_ARG(QString, settings.getCurrentProfile()));
}
/**
diff --git a/src/model/profile/profileinfo.h b/src/model/profile/profileinfo.h
index aac863ee9..ba3fe4eea 100644
--- a/src/model/profile/profileinfo.h
+++ b/src/model/profile/profileinfo.h
@@ -28,12 +28,13 @@ class Core;
class QFile;
class QPoint;
class Profile;
+class Settings;
class ProfileInfo : public QObject, public IProfileInfo
{
Q_OBJECT
public:
- ProfileInfo(Core* core_, Profile* profile_);
+ ProfileInfo(Core* core_, Profile* profile_, Settings&);
bool setPassword(const QString& password) override;
bool deletePassword() override;
@@ -66,4 +67,5 @@ private:
IProfileInfo::SetAvatarResult scalePngToAvatar(QByteArray& avatar);
Profile* const profile;
Core* const core;
+ Settings& settings;
};
diff --git a/src/nexus.cpp b/src/nexus.cpp
index 171cded1d..4c7051e8e 100644
--- a/src/nexus.cpp
+++ b/src/nexus.cpp
@@ -63,9 +63,7 @@ Nexus::Nexus(QObject* parent)
: QObject(parent)
, profile{nullptr}
, widget{nullptr}
- , cameraSource(new CameraSource())
{
- assert(cameraSource);
}
Nexus::~Nexus()
@@ -163,7 +161,7 @@ int Nexus::showLogin(const QString& profileName)
delete profile;
profile = nullptr;
- LoginScreen loginScreen{profileName};
+ LoginScreen loginScreen{*settings, profileName};
connectLoginScreen(loginScreen);
QCoreApplication::sendPostedEvents(nullptr, QEvent::DeferredDelete);
@@ -198,6 +196,7 @@ void Nexus::bootstrapWithProfile(Profile* p)
void Nexus::setSettings(Settings* settings_)
{
+ cameraSource = std::unique_ptr(new CameraSource{*settings_});
if (settings) {
QObject::disconnect(this, &Nexus::saveGlobal, settings, &Settings::saveGlobal);
}
@@ -231,7 +230,7 @@ void Nexus::showMainGUI()
assert(profile);
// Create GUI
- widget = new Widget(*profile, *audioControl, *cameraSource);
+ widget = new Widget(*profile, *audioControl, *cameraSource, *settings);
// Start GUI
widget->init();
diff --git a/src/persistence/history.cpp b/src/persistence/history.cpp
index d776f4666..508882b88 100644
--- a/src/persistence/history.cpp
+++ b/src/persistence/history.cpp
@@ -707,8 +707,9 @@ FileDbInsertionData::FileDbInsertionData()
* @brief Prepares the database to work with the history.
* @param db This database will be prepared for use with the history.
*/
-History::History(std::shared_ptr db_)
+History::History(std::shared_ptr db_, Settings& settings_)
: db(db_)
+ , settings(settings_)
{
if (!isValid()) {
qWarning() << "Database not open, init failed";
@@ -1385,7 +1386,7 @@ void History::markAsDelivered(RowId messageId)
*/
bool History::historyAccessBlocked()
{
- if (!Settings::getInstance().getEnableLogging()) {
+ if (!settings.getEnableLogging()) {
assert(false);
qCritical() << "Blocked history access while history is disabled";
return true;
diff --git a/src/persistence/history.h b/src/persistence/history.h
index 2ac73322e..e5f57f3fb 100644
--- a/src/persistence/history.h
+++ b/src/persistence/history.h
@@ -38,6 +38,7 @@
class Profile;
class HistoryKeeper;
+class Settings;
enum class HistMessageContentType
{
@@ -185,7 +186,7 @@ public:
};
public:
- explicit History(std::shared_ptr db);
+ History(std::shared_ptr db, Settings&);
~History();
bool isValid();
@@ -245,4 +246,5 @@ private:
// This needs to be a shared pointer to avoid callback lifetime issues
QHash fileInfos;
+ Settings& settings;
};
diff --git a/src/persistence/profile.cpp b/src/persistence/profile.cpp
index fe150acd9..8c85ca005 100644
--- a/src/persistence/profile.cpp
+++ b/src/persistence/profile.cpp
@@ -132,7 +132,8 @@ fail:
* @return Pointer to the tox encryption key.
*/
std::unique_ptr createToxData(const QString& name, const QString& password,
- const QString& filePath, CreateToxDataError& error)
+ const QString& filePath, CreateToxDataError& error,
+ Paths& paths)
{
std::unique_ptr newKey;
if (!password.isEmpty()) {
@@ -153,7 +154,7 @@ std::unique_ptr createToxData(const QString& name, const QString& pa
return nullptr;
}
- if (!ProfileLocker::lock(name)) {
+ if (!ProfileLocker::lock(name, paths)) {
error = CreateToxDataError::LOCK_FAILED;
return nullptr;
}
@@ -318,14 +319,14 @@ Profile* Profile::loadProfile(const QString& name, const QString& password, Sett
return nullptr;
}
- if (!ProfileLocker::lock(name)) {
+ Paths& paths = settings.getPaths();
+ if (!ProfileLocker::lock(name, paths)) {
qWarning() << "Failed to lock profile " << name;
return nullptr;
}
LoadToxDataError error;
QByteArray toxsave = QByteArray();
- Paths& paths = settings.getPaths();
QString path = paths.getSettingsDirPath() + name + ".tox";
std::unique_ptr tmpKey = loadToxData(password, path, toxsave, error);
if (logLoadToxDataError(error, path)) {
@@ -359,7 +360,7 @@ Profile* Profile::createProfile(const QString& name, const QString& password, Se
CreateToxDataError error;
Paths& paths = settings.getPaths();
QString path = paths.getSettingsDirPath() + name + ".tox";
- std::unique_ptr tmpKey = createToxData(name, password, path, error);
+ std::unique_ptr tmpKey = createToxData(name, password, path, error, paths);
if (logCreateToxDataError(error, name)) {
return nullptr;
@@ -385,7 +386,7 @@ Profile::~Profile()
onSaveToxSave();
settings.savePersonal(this);
settings.sync();
- ProfileLocker::assertLock();
+ ProfileLocker::assertLock(paths);
assert(ProfileLocker::getCurLockName() == name);
ProfileLocker::unlock();
}
@@ -395,9 +396,9 @@ Profile::~Profile()
* @param extension Raw extension, e.g. "jpeg" not ".jpeg".
* @return Vector of filenames.
*/
-QStringList Profile::getFilesByExt(QString extension)
+QStringList Profile::getFilesByExt(QString extension, Settings& settings)
{
- QDir dir(Settings::getInstance().getPaths().getSettingsDirPath());
+ QDir dir(settings.getPaths().getSettingsDirPath());
QStringList out;
dir.setFilter(QDir::Files | QDir::NoDotAndDotDot);
dir.setNameFilters(QStringList("*." + extension));
@@ -414,13 +415,13 @@ QStringList Profile::getFilesByExt(QString extension)
* @brief Scan for profile, automatically importing them if needed.
* @warning NOT thread-safe.
*/
-const QStringList Profile::getAllProfileNames()
+const QStringList Profile::getAllProfileNames(Settings& settings)
{
profiles.clear();
- QStringList toxfiles = getFilesByExt("tox"), inifiles = getFilesByExt("ini");
+ QStringList toxfiles = getFilesByExt("tox", settings), inifiles = getFilesByExt("ini", settings);
for (const QString& toxfile : toxfiles) {
if (!inifiles.contains(toxfile)) {
- Settings::getInstance().createPersonal(toxfile);
+ settings.createPersonal(toxfile);
}
profiles.append(toxfile);
@@ -490,7 +491,7 @@ void Profile::onAvatarOfferReceived(uint32_t friendId, uint32_t fileId, const QB
bool Profile::saveToxSave(QByteArray data)
{
assert(!isRemoved);
- ProfileLocker::assertLock();
+ ProfileLocker::assertLock(paths);
assert(ProfileLocker::getCurLockName() == name);
QString path = paths.getSettingsDirPath() + name + ".tox";
@@ -634,9 +635,10 @@ void Profile::loadDatabase(QString password)
// At this point it's too early to load the personal settings (Nexus will do it), so we always
// load
// the history, and if it fails we can't change the setting now, but we keep a nullptr
- database = std::make_shared(getDbPath(name), password, salt);
+ database = std::make_shared(getDbPath(name, settings.getPaths()),
+ password, salt);
if (database && database->isOpen()) {
- history.reset(new History(database));
+ history.reset(new History(database, settings));
} else {
qWarning() << "Failed to open database for profile" << name;
GUI::showError(QObject::tr("Error"),
@@ -804,9 +806,9 @@ void Profile::removeAvatar(const ToxPk& owner)
}
}
-bool Profile::exists(QString name)
+bool Profile::exists(QString name, Paths& paths)
{
- QString path = Settings::getInstance().getPaths().getSettingsDirPath() + name;
+ QString path = paths.getSettingsDirPath() + name;
return QFile::exists(path + ".tox");
}
@@ -825,10 +827,10 @@ bool Profile::isEncrypted() const
* @param name Profile name.
* @return True if profile is encrypted, false otherwise.
*/
-bool Profile::isEncrypted(QString name)
+bool Profile::isEncrypted(QString name, Paths& paths)
{
uint8_t data[TOX_PASS_ENCRYPTION_EXTRA_LENGTH] = {0};
- QString path = Settings::getInstance().getPaths().getSettingsDirPath() + name + ".tox";
+ QString path = paths.getSettingsDirPath() + name + ".tox";
QFile saveFile(path);
if (!saveFile.open(QIODevice::ReadOnly)) {
qWarning() << "Couldn't open tox save " << path;
@@ -879,7 +881,7 @@ QStringList Profile::remove()
qWarning() << "Could not remove file " << profileConfig.fileName();
}
- QString dbPath = getDbPath(name);
+ QString dbPath = getDbPath(name, settings.getPaths());
if (database && database->isOpen() && !database->remove() && QFile::exists(dbPath)) {
ret.push_back(dbPath);
qWarning() << "Could not remove file " << dbPath;
@@ -901,7 +903,7 @@ bool Profile::rename(QString newName)
QString path = paths.getSettingsDirPath() + name,
newPath = paths.getSettingsDirPath() + newName;
- if (!ProfileLocker::lock(newName)) {
+ if (!ProfileLocker::lock(newName, paths)) {
return false;
}
@@ -985,7 +987,7 @@ QString Profile::setPassword(const QString& newPassword)
* @param profileName Profile name.
* @return Path to database.
*/
-QString Profile::getDbPath(const QString& profileName)
+QString Profile::getDbPath(const QString& profileName, Paths& paths)
{
- return Settings::getInstance().getPaths().getSettingsDirPath() + profileName + ".db";
+ return paths.getSettingsDirPath() + profileName + ".db";
}
diff --git a/src/persistence/profile.h b/src/persistence/profile.h
index 8ccef6050..fcbd93f4a 100644
--- a/src/persistence/profile.h
+++ b/src/persistence/profile.h
@@ -74,11 +74,11 @@ public:
bool rename(QString newName);
- static const QStringList getAllProfileNames();
+ static const QStringList getAllProfileNames(Settings&);
- static bool exists(QString name);
- static bool isEncrypted(QString name);
- static QString getDbPath(const QString& profileName);
+ static bool exists(QString name, Paths&);
+ static bool isEncrypted(QString name, Paths&);
+ static QString getDbPath(const QString& profileName, Paths&);
signals:
void selfAvatarChanged(const QPixmap& pixmap);
@@ -106,7 +106,7 @@ private slots:
private:
Profile(const QString& name_, std::unique_ptr passkey_, Paths& paths_, Settings &settings_);
- static QStringList getFilesByExt(QString extension);
+ static QStringList getFilesByExt(QString extension, Settings& settings);
QString avatarPath(const ToxPk& owner, bool forceUnencrypted = false);
bool saveToxSave(QByteArray data);
void initCore(const QByteArray& toxsave, Settings &s, bool isNewProfile, CameraSource&);
diff --git a/src/persistence/profilelocker.cpp b/src/persistence/profilelocker.cpp
index 0e0ab19a4..342a4a08c 100644
--- a/src/persistence/profilelocker.cpp
+++ b/src/persistence/profilelocker.cpp
@@ -20,6 +20,7 @@
#include "profilelocker.h"
#include "src/persistence/settings.h"
+#include "src/persistence/paths.h"
#include
#include
@@ -36,9 +37,9 @@ using namespace std;
unique_ptr ProfileLocker::lockfile;
QString ProfileLocker::curLockName;
-QString ProfileLocker::lockPathFromName(const QString& name)
+QString ProfileLocker::lockPathFromName(const QString& name, const Paths& paths)
{
- return Settings::getInstance().getPaths().getSettingsDirPath() + '/' + name + ".lock";
+ return paths.getSettingsDirPath() + '/' + name + ".lock";
}
/**
@@ -49,13 +50,13 @@ QString ProfileLocker::lockPathFromName(const QString& name)
* @param profile Profile name to check.
* @return True, if profile locked, false otherwise.
*/
-bool ProfileLocker::isLockable(QString profile)
+bool ProfileLocker::isLockable(QString profile, Paths& paths)
{
// If we already have the lock, it's definitely lockable
if (lockfile && curLockName == profile)
return true;
- QLockFile newLock(lockPathFromName(profile));
+ QLockFile newLock(lockPathFromName(profile, paths));
return newLock.tryLock();
}
@@ -64,12 +65,12 @@ bool ProfileLocker::isLockable(QString profile)
* @param profile Profile to lock.
* @return Returns true if we already own the lock.
*/
-bool ProfileLocker::lock(QString profile)
+bool ProfileLocker::lock(QString profile, Paths& paths)
{
if (lockfile && curLockName == profile)
return true;
- QLockFile* newLock = new QLockFile(lockPathFromName(profile));
+ QLockFile* newLock = new QLockFile(lockPathFromName(profile, paths));
newLock->setStaleLockTime(0);
if (!newLock->tryLock()) {
delete newLock;
@@ -101,17 +102,17 @@ void ProfileLocker::unlock()
* If we can't get a lock, exit qTox immediately.
* If we never had a lock in the first place, exit immediately.
*/
-void ProfileLocker::assertLock()
+void ProfileLocker::assertLock(Paths& paths)
{
if (!lockfile) {
qCritical() << "assertLock: We don't seem to own any lock!";
deathByBrokenLock();
}
- if (!QFile(lockPathFromName(curLockName)).exists()) {
+ if (!QFile(lockPathFromName(curLockName, paths)).exists()) {
QString tmp = curLockName;
unlock();
- if (lock(tmp)) {
+ if (lock(tmp, paths)) {
qCritical() << "assertLock: Lock file was lost, but could be restored";
} else {
qCritical() << "assertLock: Lock file was lost, and could *NOT* be restored";
diff --git a/src/persistence/profilelocker.h b/src/persistence/profilelocker.h
index 87968aac8..1ea7bb7e0 100644
--- a/src/persistence/profilelocker.h
+++ b/src/persistence/profilelocker.h
@@ -23,21 +23,23 @@
#include
#include
+class Paths;
+
class ProfileLocker
{
private:
ProfileLocker() = delete;
public:
- static bool isLockable(QString profile);
- static bool lock(QString profile);
+ static bool isLockable(QString profile, Paths&);
+ static bool lock(QString profile, Paths&);
static void unlock();
static bool hasLock();
static QString getCurLockName();
- static void assertLock();
+ static void assertLock(Paths&);
private:
- static QString lockPathFromName(const QString& name);
+ static QString lockPathFromName(const QString& name, const Paths&);
static void deathByBrokenLock();
private:
diff --git a/src/persistence/settings.cpp b/src/persistence/settings.cpp
index c9563f963..335d18f6a 100644
--- a/src/persistence/settings.cpp
+++ b/src/persistence/settings.cpp
@@ -61,7 +61,6 @@
*/
const QString Settings::globalSettingsFile = "qtox.ini";
-Settings* Settings::settings{nullptr};
CompatibleRecursiveMutex Settings::bigLock;
QThread* Settings::settingsThread{nullptr};
static constexpr int GLOBAL_SETTINGS_VERSION = 1;
@@ -87,23 +86,6 @@ Settings::~Settings()
delete settingsThread;
}
-/**
- * @brief Returns the singleton instance.
- */
-Settings& Settings::getInstance()
-{
- if (!settings)
- settings = new Settings();
-
- return *settings;
-}
-
-void Settings::destroyInstance()
-{
- delete settings;
- settings = nullptr;
-}
-
void Settings::loadGlobal()
{
QMutexLocker locker{&bigLock};
@@ -624,7 +606,7 @@ void Settings::resetToDefault()
void Settings::saveGlobal()
{
if (QThread::currentThread() != settingsThread)
- return (void)QMetaObject::invokeMethod(&getInstance(), "saveGlobal");
+ return (void)QMetaObject::invokeMethod(this, "saveGlobal");
QMutexLocker locker{&bigLock};
if (!loaded)
@@ -778,7 +760,7 @@ void Settings::savePersonal(Profile* profile)
return;
}
if (QThread::currentThread() != settingsThread)
- return (void)QMetaObject::invokeMethod(&getInstance(), "savePersonal",
+ return (void)QMetaObject::invokeMethod(this, "savePersonal",
Q_ARG(Profile*, profile));
savePersonal(profile->getName(), profile->getPasskey());
}
@@ -942,7 +924,7 @@ bool Settings::getAutorun() const
QMutexLocker locker{&bigLock};
#ifdef QTOX_PLATFORM_EXT
- return Platform::getAutorun();
+ return Platform::getAutorun(*this);
#else
return false;
#endif
@@ -951,10 +933,10 @@ bool Settings::getAutorun() const
void Settings::setAutorun(bool newValue)
{
#ifdef QTOX_PLATFORM_EXT
- bool autorun = Platform::getAutorun();
+ bool autorun = Platform::getAutorun(*this);
if (newValue != autorun) {
- Platform::setAutorun(newValue);
+ Platform::setAutorun(*this, newValue);
emit autorunChanged(autorun);
}
#else
@@ -2261,7 +2243,7 @@ void Settings::createSettingsDir()
void Settings::sync()
{
if (QThread::currentThread() != settingsThread) {
- QMetaObject::invokeMethod(&getInstance(), "sync", Qt::BlockingQueuedConnection);
+ QMetaObject::invokeMethod(this, "sync", Qt::BlockingQueuedConnection);
return;
}
diff --git a/src/persistence/settings.h b/src/persistence/settings.h
index c56e16db7..1e1baee7c 100644
--- a/src/persistence/settings.h
+++ b/src/persistence/settings.h
@@ -145,8 +145,10 @@ public:
};
public:
- static Settings& getInstance();
- static void destroyInstance();
+ Settings();
+ ~Settings();
+ Settings(Settings& settings) = delete;
+ Settings& operator=(const Settings&) = delete;
Paths& getPaths();
void createSettingsDir();
@@ -568,11 +570,6 @@ public:
private:
struct friendProp;
-
- Settings();
- ~Settings();
- Settings(Settings& settings) = delete;
- Settings& operator=(const Settings&) = delete;
void savePersonal(QString profileName, const ToxEncrypt* passkey);
friendProp& getOrInsertFriendPropRef(const ToxPk& id);
static ICoreSettings::ProxyType fixInvalidProxyType(ICoreSettings::ProxyType proxyType);
@@ -712,7 +709,6 @@ private:
int themeColor;
static CompatibleRecursiveMutex bigLock;
- static Settings* settings;
static const QString globalSettingsFile;
static QThread* settingsThread;
Paths paths;
diff --git a/src/persistence/smileypack.cpp b/src/persistence/smileypack.cpp
index 61105edf8..16e3ce2d5 100644
--- a/src/persistence/smileypack.cpp
+++ b/src/persistence/smileypack.cpp
@@ -105,12 +105,13 @@ bool isAscii(const QString& string)
} // namespace
-SmileyPack::SmileyPack()
+SmileyPack::SmileyPack(Settings& settings_)
: cleanupTimer{new QTimer(this)}
+ , settings{settings_}
{
loadingMutex.lock();
- QtConcurrent::run(this, &SmileyPack::load, Settings::getInstance().getSmileyPack());
- connect(&Settings::getInstance(), &Settings::smileyPackChanged, this,
+ QtConcurrent::run(this, &SmileyPack::load, settings.getSmileyPack());
+ connect(&settings, &Settings::smileyPackChanged, this,
&SmileyPack::onSmileyPackChanged);
connect(cleanupTimer, &QTimer::timeout, this, &SmileyPack::cleanupIconsCache);
cleanupTimer->start(CLEANUP_TIMEOUT);
@@ -348,5 +349,5 @@ std::shared_ptr SmileyPack::getAsIcon(const QString& emoticon) const
void SmileyPack::onSmileyPackChanged()
{
loadingMutex.lock();
- QtConcurrent::run(this, &SmileyPack::load, Settings::getInstance().getSmileyPack());
+ QtConcurrent::run(this, &SmileyPack::load, settings.getSmileyPack());
}
diff --git a/src/persistence/smileypack.h b/src/persistence/smileypack.h
index b6aa72cff..8bbf46733 100644
--- a/src/persistence/smileypack.h
+++ b/src/persistence/smileypack.h
@@ -27,13 +27,14 @@
#include
class QTimer;
+class Settings;
class SmileyPack : public QObject
{
Q_OBJECT
public:
- SmileyPack();
+ explicit SmileyPack(Settings&);
SmileyPack(SmileyPack&) = delete;
SmileyPack& operator=(const SmileyPack&) = delete;
~SmileyPack() override;
@@ -61,4 +62,5 @@ private:
QTimer* cleanupTimer;
QRegularExpression smilify;
mutable QMutex loadingMutex;
+ Settings& settings;
};
diff --git a/src/persistence/toxsave.cpp b/src/persistence/toxsave.cpp
index 8b63a119e..f670174de 100644
--- a/src/persistence/toxsave.cpp
+++ b/src/persistence/toxsave.cpp
@@ -18,17 +18,24 @@
*/
#include "toxsave.h"
+#include "src/persistence/settings.h"
#include "src/widget/gui.h"
#include "src/widget/tool/profileimporter.h"
#include
-bool toxSaveEventHandler(const QByteArray& eventData)
+ToxSave::ToxSave(Settings& settings_)
+ : settings{settings_}
+{}
+
+bool ToxSave::toxSaveEventHandler(const QByteArray& eventData, void* userData)
{
+ auto toxSave = static_cast(userData);
+
if (!eventData.endsWith(".tox")) {
return false;
}
- handleToxSave(eventData);
+ toxSave->handleToxSave(eventData);
return true;
}
@@ -38,8 +45,8 @@ bool toxSaveEventHandler(const QByteArray& eventData)
* @param path Path to .tox file.
* @return True if import success, false, otherwise.
*/
-bool handleToxSave(const QString& path)
+bool ToxSave::handleToxSave(const QString& path)
{
- ProfileImporter importer(GUI::getMainWidget());
+ ProfileImporter importer(settings, GUI::getMainWidget());
return importer.importProfile(path);
}
diff --git a/src/persistence/toxsave.h b/src/persistence/toxsave.h
index ca64ad488..f7efbd3a8 100644
--- a/src/persistence/toxsave.h
+++ b/src/persistence/toxsave.h
@@ -21,8 +21,15 @@
class QString;
class QByteArray;
+class Settings;
-bool handleToxSave(const QString& path);
+class ToxSave
+{
+public:
+ explicit ToxSave(Settings&);
+ bool handleToxSave(const QString& path);
+ static bool toxSaveEventHandler(const QByteArray& eventData, void* userData);
-// Internals
-bool toxSaveEventHandler(const QByteArray& eventData);
+private:
+ Settings& settings;
+};
diff --git a/src/platform/autorun.h b/src/platform/autorun.h
index ffe168772..677254f32 100644
--- a/src/platform/autorun.h
+++ b/src/platform/autorun.h
@@ -21,10 +21,10 @@
#ifdef QTOX_PLATFORM_EXT
-
+class Settings;
namespace Platform {
-bool setAutorun(bool on);
-bool getAutorun();
+bool setAutorun(const Settings&, bool on);
+bool getAutorun(const Settings&);
}
#endif // QTOX_PLATFORM_EXT
diff --git a/src/platform/autorun_osx.cpp b/src/platform/autorun_osx.cpp
index 3b764636d..7c9a6ecfd 100644
--- a/src/platform/autorun_osx.cpp
+++ b/src/platform/autorun_osx.cpp
@@ -28,7 +28,7 @@ namespace {
int state;
} // namespace
-bool Platform::setAutorun(bool on)
+bool Platform::setAutorun(const Settings&, bool on)
{
QString qtoxPlist =
QDir::cleanPath(QStandardPaths::writableLocation(QStandardPaths::HomeLocation)
@@ -45,7 +45,7 @@ bool Platform::setAutorun(bool on)
return true;
}
-bool Platform::getAutorun()
+bool Platform::getAutorun(const Settings&)
{
return state;
}
diff --git a/src/platform/autorun_win.cpp b/src/platform/autorun_win.cpp
index f0d445022..2fd357161 100644
--- a/src/platform/autorun_win.cpp
+++ b/src/platform/autorun_win.cpp
@@ -45,19 +45,19 @@ inline tstring toTString(QString s)
} // namespace
namespace Platform {
-inline tstring currentCommandLine()
+inline tstring currentCommandLine(const Settings& settings)
{
return toTString("\"" + QApplication::applicationFilePath().replace('/', '\\') + "\" -p \""
- + Settings::getInstance().getCurrentProfile() + "\"");
+ + settings.getCurrentProfile() + "\"");
}
-inline tstring currentRegistryKeyName()
+inline tstring currentRegistryKeyName(const Settings& settings)
{
- return toTString("qTox - " + Settings::getInstance().getCurrentProfile());
+ return toTString("qTox - " + settings.getCurrentProfile());
}
}
-bool Platform::setAutorun(bool on)
+bool Platform::setAutorun(const Settings& settings, bool on)
{
HKEY key = nullptr;
if (RegOpenKeyEx(HKEY_CURRENT_USER, TEXT("Software\\Microsoft\\Windows\\CurrentVersion\\Run"),
@@ -66,10 +66,10 @@ bool Platform::setAutorun(bool on)
return false;
bool result = false;
- tstring keyName = currentRegistryKeyName();
+ tstring keyName = currentRegistryKeyName(settings);
if (on) {
- tstring path = currentCommandLine();
+ tstring path = currentCommandLine(settings);
result = RegSetValueEx(key, keyName.c_str(), 0, REG_SZ, const_cast(reinterpret_cast(path.c_str())),
path.length() * sizeof(TCHAR))
== ERROR_SUCCESS;
@@ -80,7 +80,7 @@ bool Platform::setAutorun(bool on)
return result;
}
-bool Platform::getAutorun()
+bool Platform::getAutorun(const Settings& settings)
{
HKEY key = nullptr;
if (RegOpenKeyEx(HKEY_CURRENT_USER, TEXT("Software\\Microsoft\\Windows\\CurrentVersion\\Run"),
@@ -88,7 +88,7 @@ bool Platform::getAutorun()
!= ERROR_SUCCESS)
return false;
- tstring keyName = currentRegistryKeyName();
+ tstring keyName = currentRegistryKeyName(settings);
TCHAR path[MAX_PATH] = {0};
DWORD length = sizeof(path);
diff --git a/src/platform/autorun_xdg.cpp b/src/platform/autorun_xdg.cpp
index 3524d638e..21f2dc182 100644
--- a/src/platform/autorun_xdg.cpp
+++ b/src/platform/autorun_xdg.cpp
@@ -33,9 +33,9 @@ QString getAutostartDirPath()
return config + "/autostart";
}
-QString getAutostartFilePath(QString dir)
+QString getAutostartFilePath(const Settings& settings, QString dir)
{
- return dir + "/qTox - " + Settings::getInstance().getCurrentProfile() + ".desktop";
+ return dir + "/qTox - " + settings.getCurrentProfile() + ".desktop";
}
QString currentBinPath()
@@ -50,17 +50,17 @@ QString currentBinPath()
}
}
-inline QString profileRunCommand()
+inline QString profileRunCommand(const Settings& settings)
{
return "\"" + currentBinPath() + "\" -p \""
- + Settings::getInstance().getCurrentProfile() + "\"";
+ + settings.getCurrentProfile() + "\"";
}
} // namespace
-bool Platform::setAutorun(bool on)
+bool Platform::setAutorun(const Settings& settings, bool on)
{
QString dirPath = getAutostartDirPath();
- QFile desktop(getAutostartFilePath(dirPath));
+ QFile desktop(getAutostartFilePath(settings, dirPath));
if (on) {
if (!QDir().mkpath(dirPath) || !desktop.open(QFile::WriteOnly | QFile::Truncate))
return false;
@@ -68,7 +68,7 @@ bool Platform::setAutorun(bool on)
desktop.write("Type=Application\n");
desktop.write("Name=qTox\n");
desktop.write("Exec=");
- desktop.write(profileRunCommand().toUtf8());
+ desktop.write(profileRunCommand(settings).toUtf8());
desktop.write("\n");
desktop.close();
return true;
@@ -76,7 +76,7 @@ bool Platform::setAutorun(bool on)
return desktop.remove();
}
-bool Platform::getAutorun()
+bool Platform::getAutorun(const Settings& settings)
{
- return QFile(getAutostartFilePath(getAutostartDirPath())).exists();
+ return QFile(getAutostartFilePath(settings, getAutostartDirPath())).exists();
}
diff --git a/src/platform/desktop_notifications/desktopnotify.cpp b/src/platform/desktop_notifications/desktopnotify.cpp
index 1f4f24d1a..678deeb91 100644
--- a/src/platform/desktop_notifications/desktopnotify.cpp
+++ b/src/platform/desktop_notifications/desktopnotify.cpp
@@ -27,9 +27,10 @@
#include
#include
-DesktopNotify::DesktopNotify()
+DesktopNotify::DesktopNotify(Settings& settings_)
: notifyCore{Snore::SnoreCore::instance()}
, snoreIcon{":/img/icons/qtox.svg"}
+ , settings{settings_}
{
notifyCore.loadPlugins(Snore::SnorePlugin::Backend);
@@ -44,8 +45,7 @@ DesktopNotify::DesktopNotify()
void DesktopNotify::notifyMessage(const NotificationData& notificationData)
{
- const Settings& s = Settings::getInstance();
- if(!(s.getNotify() && s.getDesktopNotify())) {
+ if(!(settings.getNotify() && settings.getDesktopNotify())) {
return;
}
diff --git a/src/platform/desktop_notifications/desktopnotify.h b/src/platform/desktop_notifications/desktopnotify.h
index f162de3c3..ebaf5e471 100644
--- a/src/platform/desktop_notifications/desktopnotify.h
+++ b/src/platform/desktop_notifications/desktopnotify.h
@@ -28,11 +28,13 @@
#include
#include
+class Settings;
+
class DesktopNotify : public QObject
{
Q_OBJECT
public:
- DesktopNotify();
+ explicit DesktopNotify(Settings&);
public slots:
void notifyMessage(const NotificationData& notificationData);
@@ -49,4 +51,5 @@ private:
Snore::Icon snoreIcon;
Snore::Notification lastNotification;
uint latestId;
+ Settings& settings;
};
diff --git a/src/video/cameradevice.cpp b/src/video/cameradevice.cpp
index 6b82253d8..61ab2d2e7 100644
--- a/src/video/cameradevice.cpp
+++ b/src/video/cameradevice.cpp
@@ -79,14 +79,16 @@ AvFindInputFormatRet iformat{nullptr};
QHash CameraDevice::openDevices;
QMutex CameraDevice::openDeviceLock, CameraDevice::iformatLock;
-CameraDevice::CameraDevice(const QString& devName_, AVFormatContext* context_)
+CameraDevice::CameraDevice(const QString& devName_, AVFormatContext* context_,
+ Settings& settings_)
: devName{devName_}
, context{context_}
, refcount{1}
+ , settings{settings_}
{
}
-CameraDevice* CameraDevice::open(QString devName, AVDictionary** options)
+CameraDevice* CameraDevice::open(Settings& settings, QString devName, AVDictionary** options)
{
openDeviceLock.lock();
AVFormatContext* fctx = nullptr;
@@ -131,7 +133,7 @@ CameraDevice* CameraDevice::open(QString devName, AVDictionary** options)
fctx->max_analyze_duration = aduration;
#endif
- dev = new CameraDevice{devName, fctx};
+ dev = new CameraDevice{devName, fctx, settings};
openDevices[devName] = dev;
out:
@@ -151,7 +153,7 @@ out:
* @param mode Mode of device to open.
* @return CameraDevice if the device could be opened, nullptr otherwise.
*/
-CameraDevice* CameraDevice::open(QString devName, VideoMode mode)
+CameraDevice* CameraDevice::open(Settings& settings, QString devName, VideoMode mode)
{
if (!getDefaultInputFormat())
return nullptr;
@@ -237,7 +239,7 @@ CameraDevice* CameraDevice::open(QString devName, VideoMode mode)
std::ignore = mode;
}
- CameraDevice* dev = open(devName, &options);
+ CameraDevice* dev = open(settings, devName, &options);
if (options) {
av_dict_free(&options);
}
@@ -395,9 +397,9 @@ QVector> CameraDevice::getDeviceList()
* @return The short name of the default device
* This is either the device in the settings or the system default.
*/
-QString CameraDevice::getDefaultDeviceName()
+QString CameraDevice::getDefaultDeviceName(Settings& settings)
{
- QString defaultdev = Settings::getInstance().getVideoDev();
+ QString defaultdev = settings.getVideoDev();
if (!getDefaultInputFormat())
return defaultdev;
diff --git a/src/video/cameradevice.h b/src/video/cameradevice.h
index 34a8b064e..17200944d 100644
--- a/src/video/cameradevice.h
+++ b/src/video/cameradevice.h
@@ -31,11 +31,12 @@ struct AVFormatContext;
struct AVInputFormat;
struct AVDeviceInfoList;
struct AVDictionary;
+class Settings;
class CameraDevice
{
public:
- static CameraDevice* open(QString devName, VideoMode mode = VideoMode());
+ static CameraDevice* open(Settings&, QString devName, VideoMode mode = VideoMode());
void open();
bool close();
@@ -45,13 +46,13 @@ public:
static QString getPixelFormatString(uint32_t pixel_format);
static bool betterPixelFormat(uint32_t a, uint32_t b);
- static QString getDefaultDeviceName();
+ static QString getDefaultDeviceName(Settings& settings);
static bool isScreen(const QString& devName);
private:
- CameraDevice(const QString& devName_, AVFormatContext* context_);
- static CameraDevice* open(QString devName, AVDictionary** options);
+ CameraDevice(const QString& devName_, AVFormatContext* context_, Settings&);
+ static CameraDevice* open(Settings&, QString devName, AVDictionary** options);
static bool getDefaultInputFormat();
static QVector> getRawDeviceListGeneric();
static QVector getScreenModes();
@@ -64,4 +65,5 @@ private:
std::atomic_int refcount;
static QHash openDevices;
static QMutex openDeviceLock, iformatLock;
+ Settings& settings;
};
diff --git a/src/video/camerasource.cpp b/src/video/camerasource.cpp
index 4e0774c90..e248e4684 100644
--- a/src/video/camerasource.cpp
+++ b/src/video/camerasource.cpp
@@ -90,7 +90,7 @@ extern "C" {
* @brief Remember how many times we subscribed for RAII
*/
-CameraSource::CameraSource()
+CameraSource::CameraSource(Settings& settings_)
: deviceThread{new QThread}
, deviceName{"none"}
, device{nullptr}
@@ -103,6 +103,7 @@ CameraSource::CameraSource()
, videoStreamIndex{-1}
, isNone_{true}
, subscriptions{0}
+ , settings{settings_}
{
qRegisterMetaType("VideoMode");
deviceThread->setObjectName("Device thread");
@@ -126,12 +127,12 @@ CameraSource::CameraSource()
*/
void CameraSource::setupDefault()
{
- QString deviceName_ = CameraDevice::getDefaultDeviceName();
+ QString deviceName_ = CameraDevice::getDefaultDeviceName(settings);
bool isScreen = CameraDevice::isScreen(deviceName_);
- VideoMode mode_ = VideoMode(Settings::getInstance().getScreenRegion());
+ VideoMode mode_ = VideoMode(settings.getScreenRegion());
if (!isScreen) {
- mode_ = VideoMode(Settings::getInstance().getCamVideoRes());
- mode_.FPS = Settings::getInstance().getCamVideoFPS();
+ mode_ = VideoMode(settings.getCamVideoRes());
+ mode_.FPS = settings.getCamVideoFPS();
}
setupDevice(deviceName_, mode_);
@@ -260,7 +261,7 @@ void CameraSource::openDevice()
}
// We need to create a new CameraDevice
- device = CameraDevice::open(deviceName, mode);
+ device = CameraDevice::open(settings, deviceName, mode);
if (!device) {
qWarning() << "Failed to open device!";
diff --git a/src/video/camerasource.h b/src/video/camerasource.h
index df73fedb5..fa90a3024 100644
--- a/src/video/camerasource.h
+++ b/src/video/camerasource.h
@@ -30,13 +30,14 @@
class CameraDevice;
struct AVCodecContext;
+class Settings;
class CameraSource : public VideoSource
{
Q_OBJECT
public:
- CameraSource();
+ explicit CameraSource(Settings&);
~CameraSource();
void setupDefault();
bool isNone() const;
@@ -76,4 +77,5 @@ private:
std::atomic_bool isNone_;
std::atomic_int subscriptions;
+ Settings& settings;
};
diff --git a/src/video/netcamview.cpp b/src/video/netcamview.cpp
index 0e9713352..aba02910e 100644
--- a/src/video/netcamview.cpp
+++ b/src/video/netcamview.cpp
@@ -47,12 +47,14 @@ const int BTN_PANEL_WIDTH = 250;
const auto BTN_STYLE_SHEET_PATH = QStringLiteral("chatForm/fullScreenButtons.css");
}
-NetCamView::NetCamView(ToxPk friendPk_, CameraSource& cameraSource_, QWidget* parent)
+NetCamView::NetCamView(ToxPk friendPk_, CameraSource& cameraSource_,
+ Settings& settings_, QWidget* parent)
: QWidget(parent)
, selfFrame{nullptr}
, friendPk{friendPk_}
, e(false)
, cameraSource{cameraSource_}
+ , settings{settings_}
{
verLayout = new QVBoxLayout(this);
setWindowTitle(tr("Tox video"));
@@ -77,7 +79,7 @@ NetCamView::NetCamView(ToxPk friendPk_, CameraSource& cameraSource_, QWidget* pa
setStyleSheet("NetCamView { background-color: #c1c1c1; }");
buttonPanel = new QFrame(this);
- buttonPanel->setStyleSheet(Style::getStylesheet(BTN_STYLE_SHEET_PATH));
+ buttonPanel->setStyleSheet(Style::getStylesheet(BTN_STYLE_SHEET_PATH, settings));
buttonPanel->setGeometry(0, 0, BTN_PANEL_WIDTH, BTN_PANEL_HEIGHT);
QHBoxLayout* buttonPanelLayout = new QHBoxLayout(buttonPanel);
@@ -155,7 +157,7 @@ NetCamView::NetCamView(ToxPk friendPk_, CameraSource& cameraSource_, QWidget* pa
videoSurface->setAvatar(pixmap);
});
- QRect videoSize = Settings::getInstance().getCamVideoRes();
+ QRect videoSize = settings.getCamVideoRes();
qDebug() << "SIZER" << videoSize;
}
@@ -239,7 +241,7 @@ void NetCamView::setShowMessages(bool show, bool notify)
toggleMessagesButton->setText(tr("Show messages"));
if (notify) {
- toggleMessagesButton->setIcon(QIcon(Style::getImagePath("chatArea/info.svg")));
+ toggleMessagesButton->setIcon(QIcon(Style::getImagePath("chatArea/info.svg", settings)));
}
}
@@ -301,7 +303,7 @@ QPushButton* NetCamView::createButton(const QString& name, const QString& state)
btn->setAttribute(Qt::WA_LayoutUsesWidgetRect);
btn->setObjectName(name);
btn->setProperty("state", QVariant(state));
- btn->setStyleSheet(Style::getStylesheet(BTN_STYLE_SHEET_PATH));
+ btn->setStyleSheet(Style::getStylesheet(BTN_STYLE_SHEET_PATH, settings));
return btn;
}
@@ -324,7 +326,7 @@ void NetCamView::toggleButtonState(QPushButton* btn)
btn->setProperty("state", BTN_STATE_RED);
}
- btn->setStyleSheet(Style::getStylesheet(BTN_STYLE_SHEET_PATH));
+ btn->setStyleSheet(Style::getStylesheet(BTN_STYLE_SHEET_PATH, settings));
}
void NetCamView::updateButtonState(QPushButton* btn, bool active)
@@ -335,7 +337,7 @@ void NetCamView::updateButtonState(QPushButton* btn, bool active)
btn->setProperty("state", BTN_STATE_RED);
}
- btn->setStyleSheet(Style::getStylesheet(BTN_STYLE_SHEET_PATH));
+ btn->setStyleSheet(Style::getStylesheet(BTN_STYLE_SHEET_PATH, settings));
}
void NetCamView::keyPressEvent(QKeyEvent *event)
diff --git a/src/video/netcamview.h b/src/video/netcamview.h
index cadd7ab6e..c56348e9a 100644
--- a/src/video/netcamview.h
+++ b/src/video/netcamview.h
@@ -35,13 +35,14 @@ class QKeyEvent;
class QCloseEvent;
class QShowEvent;
class CameraSource;
+class Settings;
class NetCamView : public QWidget
{
Q_OBJECT
public:
- NetCamView(ToxPk friendPk_, CameraSource&, QWidget* parent = nullptr);
+ NetCamView(ToxPk friendPk_, CameraSource&, Settings&, QWidget* parent = nullptr);
~NetCamView();
virtual void show(VideoSource* source, const QString& title);
@@ -97,4 +98,5 @@ private:
QPushButton* endVideoButton = nullptr;
QPushButton* exitFullScreenButton = nullptr;
CameraSource& cameraSource;
+ Settings& settings;
};
diff --git a/src/widget/about/aboutfriendform.cpp b/src/widget/about/aboutfriendform.cpp
index 34a1446cc..95a30218d 100644
--- a/src/widget/about/aboutfriendform.cpp
+++ b/src/widget/about/aboutfriendform.cpp
@@ -36,10 +36,11 @@ QString getAutoAcceptDir(const QString& dir)
} // namespace
-AboutFriendForm::AboutFriendForm(std::unique_ptr _about, QWidget* parent)
+AboutFriendForm::AboutFriendForm(std::unique_ptr about_, Settings& settings_, QWidget* parent)
: QDialog(parent)
, ui(new Ui::AboutFriendForm)
- , about{std::move(_about)}
+ , about{std::move(about_)}
+ , settings{settings_}
{
ui->setupUi(this);
ui->label_4->hide();
@@ -97,7 +98,7 @@ void AboutFriendForm::onAutoAcceptDirClicked()
void AboutFriendForm::reloadTheme()
{
- setStyleSheet(Style::getStylesheet("window/general.css"));
+ setStyleSheet(Style::getStylesheet("window/general.css", settings));
}
void AboutFriendForm::onAutoAcceptDirChanged(const QString& path)
diff --git a/src/widget/about/aboutfriendform.h b/src/widget/about/aboutfriendform.h
index c9088c3d0..46885802a 100644
--- a/src/widget/about/aboutfriendform.h
+++ b/src/widget/about/aboutfriendform.h
@@ -30,17 +30,20 @@ namespace Ui {
class AboutFriendForm;
}
+class Settings;
+
class AboutFriendForm : public QDialog
{
Q_OBJECT
public:
- AboutFriendForm(std::unique_ptr about, QWidget* parent = nullptr);
+ AboutFriendForm(std::unique_ptr about, Settings&, QWidget* parent = nullptr);
~AboutFriendForm();
private:
Ui::AboutFriendForm* ui;
const std::unique_ptr about;
+ Settings& settings;
signals:
void histroyRemoved();
diff --git a/src/widget/categorywidget.cpp b/src/widget/categorywidget.cpp
index e8a0b4369..0473232a4 100644
--- a/src/widget/categorywidget.cpp
+++ b/src/widget/categorywidget.cpp
@@ -38,8 +38,9 @@ void CategoryWidget::emitChatroomWidget(QLayout* layout, int index)
}
}
-CategoryWidget::CategoryWidget(bool compact_, QWidget* parent)
+CategoryWidget::CategoryWidget(bool compact_, Settings& settings_, QWidget* parent)
: GenericChatItemWidget(compact_, parent)
+ , settings{settings_}
{
container = new QWidget(this);
container->setObjectName("circleWidgetContainer");
@@ -49,7 +50,7 @@ CategoryWidget::CategoryWidget(bool compact_, QWidget* parent)
statusLabel->setObjectName("status");
statusLabel->setTextFormat(Qt::PlainText);
- statusPic.setPixmap(QPixmap(Style::getImagePath("chatArea/scrollBarRightArrow.svg")));
+ statusPic.setPixmap(QPixmap(Style::getImagePath("chatArea/scrollBarRightArrow.svg", settings)));
fullLayout = new QVBoxLayout(this);
fullLayout->setSpacing(0);
@@ -96,9 +97,9 @@ void CategoryWidget::setExpanded(bool isExpanded, bool save)
QString pixmapPath;
if (isExpanded)
- pixmapPath = Style::getImagePath("chatArea/scrollBarDownArrow.svg");
+ pixmapPath = Style::getImagePath("chatArea/scrollBarDownArrow.svg", settings);
else
- pixmapPath = Style::getImagePath("chatArea/scrollBarRightArrow.svg");
+ pixmapPath = Style::getImagePath("chatArea/scrollBarRightArrow.svg", settings);
statusPic.setPixmap(QPixmap(pixmapPath));
if (save)
diff --git a/src/widget/categorywidget.h b/src/widget/categorywidget.h
index e7d41287b..928523fd3 100644
--- a/src/widget/categorywidget.h
+++ b/src/widget/categorywidget.h
@@ -28,12 +28,13 @@ class FriendListWidget;
class FriendWidget;
class QVBoxLayout;
class QHBoxLayout;
+class Settings;
class CategoryWidget : public GenericChatItemWidget
{
Q_OBJECT
public:
- explicit CategoryWidget(bool compact_, QWidget* parent = nullptr);
+ explicit CategoryWidget(bool compact_, Settings&, QWidget* parent = nullptr);
bool isExpanded() const;
void setExpanded(bool isExpanded, bool save = true);
@@ -83,4 +84,5 @@ private:
QWidget* container;
QFrame* lineFrame;
bool expanded = false;
+ Settings& settings;
};
diff --git a/src/widget/chatformheader.cpp b/src/widget/chatformheader.cpp
index 24e16d301..490218a39 100644
--- a/src/widget/chatformheader.cpp
+++ b/src/widget/chatformheader.cpp
@@ -81,12 +81,12 @@ const QString MIC_TOOL_TIP[] = {
};
template
-QPushButton* createButton(const QString& name, T* self, Fun onClickSlot)
+QPushButton* createButton(const QString& name, T* self, Fun onClickSlot, Settings& settings)
{
QPushButton* btn = new QPushButton();
btn->setAttribute(Qt::WA_LayoutUsesWidgetRect);
btn->setObjectName(name);
- btn->setStyleSheet(Style::getStylesheet(STYLE_PATH));
+ btn->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
QObject::connect(btn, &QPushButton::clicked, self, onClickSlot);
return btn;
}
@@ -108,13 +108,14 @@ void setStateName(QAbstractButton* btn, State state)
}
-ChatFormHeader::ChatFormHeader(QWidget* parent)
+ChatFormHeader::ChatFormHeader(Settings& settings_, QWidget* parent)
: QWidget(parent)
, mode{Mode::AV}
, callState{CallButtonState::Disabled}
, videoState{CallButtonState::Disabled}
, volState{ToolButtonState::Disabled}
, micState{ToolButtonState::Disabled}
+ , settings{settings_}
{
QHBoxLayout* headLayout = new QHBoxLayout();
avatar = new MaskablePixmapWidget(this, AVATAR_SIZE, ":/img/avatar_mask.svg");
@@ -140,10 +141,10 @@ ChatFormHeader::ChatFormHeader(QWidget* parent)
headTextLayout->addLayout(nameLine);
headTextLayout->addStretch();
- micButton = createButton("micButton", this, &ChatFormHeader::micMuteToggle);
- volButton = createButton("volButton", this, &ChatFormHeader::volMuteToggle);
- callButton = createButton("callButton", this, &ChatFormHeader::callTriggered);
- videoButton = createButton("videoButton", this, &ChatFormHeader::videoCallTriggered);
+ micButton = createButton("micButton", this, &ChatFormHeader::micMuteToggle, settings);
+ volButton = createButton("volButton", this, &ChatFormHeader::volMuteToggle, settings);
+ callButton = createButton("callButton", this, &ChatFormHeader::callTriggered, settings);
+ videoButton = createButton("videoButton", this, &ChatFormHeader::videoCallTriggered, settings);
QVBoxLayout* micButtonsLayout = new QVBoxLayout();
micButtonsLayout->setSpacing(MIC_BUTTONS_LAYOUT_SPACING);
@@ -218,7 +219,7 @@ void ChatFormHeader::showOutgoingCall(bool video)
void ChatFormHeader::createCallConfirm(bool video)
{
QWidget* btn = video ? videoButton : callButton;
- callConfirm = std::unique_ptr(new CallConfirmWidget(btn));
+ callConfirm = std::unique_ptr(new CallConfirmWidget(settings, btn));
connect(callConfirm.get(), &CallConfirmWidget::accepted, this, &ChatFormHeader::callAccepted);
connect(callConfirm.get(), &CallConfirmWidget::rejected, this, &ChatFormHeader::callRejected);
}
@@ -302,11 +303,11 @@ QSize ChatFormHeader::getAvatarSize() const
void ChatFormHeader::reloadTheme()
{
- setStyleSheet(Style::getStylesheet("chatArea/chatHead.css"));
- callButton->setStyleSheet(Style::getStylesheet(STYLE_PATH));
- videoButton->setStyleSheet(Style::getStylesheet(STYLE_PATH));
- volButton->setStyleSheet(Style::getStylesheet(STYLE_PATH));
- micButton->setStyleSheet(Style::getStylesheet(STYLE_PATH));
+ setStyleSheet(Style::getStylesheet("chatArea/chatHead.css", settings));
+ callButton->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
+ videoButton->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
+ volButton->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
+ micButton->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
}
void ChatFormHeader::addWidget(QWidget* widget, int stretch, Qt::Alignment alignment)
diff --git a/src/widget/chatformheader.h b/src/widget/chatformheader.h
index 37f4b2438..68d6dc3c6 100644
--- a/src/widget/chatformheader.h
+++ b/src/widget/chatformheader.h
@@ -34,6 +34,7 @@ class QToolButton;
class CallConfirmWidget;
class QLabel;
class ExtensionStatus;
+class Settings;
class ChatFormHeader : public QWidget
{
@@ -58,7 +59,7 @@ public:
AV = Audio | Video
};
- ChatFormHeader(QWidget* parent = nullptr);
+ ChatFormHeader(Settings&, QWidget* parent = nullptr);
~ChatFormHeader();
void setName(const QString& newName);
@@ -119,4 +120,5 @@ private:
ToolButtonState micState;
std::unique_ptr callConfirm;
+ Settings& settings;
};
diff --git a/src/widget/circlewidget.cpp b/src/widget/circlewidget.cpp
index db6a8bf9d..da499bcc1 100644
--- a/src/widget/circlewidget.cpp
+++ b/src/widget/circlewidget.cpp
@@ -40,12 +40,14 @@
QHash CircleWidget::circleList;
-CircleWidget::CircleWidget(const Core &core_, FriendListWidget* parent, int id_)
- : CategoryWidget(isCompact(), parent)
+CircleWidget::CircleWidget(const Core &core_, FriendListWidget* parent, int id_,
+ Settings& settings_)
+ : CategoryWidget(isCompact(), settings_, parent)
, id(id_)
, core{core_}
+ , settings{settings_}
{
- setName(Settings::getInstance().getCircleName(id), false);
+ setName(settings.getCircleName(id), false);
circleList[id] = this;
connect(nameLabel, &CroppingLabel::editFinished, [this](const QString& newName) {
@@ -58,7 +60,7 @@ CircleWidget::CircleWidget(const Core &core_, FriendListWidget* parent, int id_)
nameLabel->minimizeMaximumWidth();
});
- setExpanded(Settings::getInstance().getCircleExpanded(id), false);
+ setExpanded(settings.getCircleExpanded(id), false);
updateStatus();
}
@@ -104,7 +106,7 @@ void CircleWidget::contextMenuEvent(QContextMenuEvent* event)
friendList->removeCircleWidget(this);
- int replacedCircle = Settings::getInstance().removeCircle(id);
+ int replacedCircle = settings.removeCircle(id);
auto circleReplace = circleList.find(replacedCircle);
if (circleReplace != circleList.end())
@@ -114,7 +116,7 @@ void CircleWidget::contextMenuEvent(QContextMenuEvent* event)
circleList.remove(replacedCircle);
} else if (selectedItem == openAction) {
- ContentDialog* dialog = new ContentDialog(core);
+ ContentDialog* dialog = new ContentDialog(core, settings);
emit newContentDialog(*dialog);
for (int i = 0; i < friendOnlineLayout()->count(); ++i) {
QWidget* const widget = friendOnlineLayout()->itemAt(i)->widget();
@@ -179,11 +181,11 @@ void CircleWidget::dropEvent(QDropEvent* event)
return;
// Save CircleWidget before changing the Id
- int circleId = Settings::getInstance().getFriendCircleID(toxPk);
+ int circleId = settings.getFriendCircleID(toxPk);
CircleWidget* circleWidget = getFromID(circleId);
addFriendWidget(widget, f->getStatus());
- Settings::getInstance().savePersonal();
+ settings.savePersonal();
if (circleWidget != nullptr) {
circleWidget->updateStatus();
@@ -194,20 +196,20 @@ void CircleWidget::dropEvent(QDropEvent* event)
void CircleWidget::onSetName()
{
- Settings::getInstance().setCircleName(id, getName());
+ settings.setCircleName(id, getName());
}
void CircleWidget::onExpand()
{
- Settings::getInstance().setCircleExpanded(id, isExpanded());
- Settings::getInstance().savePersonal();
+ settings.setCircleExpanded(id, isExpanded());
+ settings.savePersonal();
}
void CircleWidget::onAddFriendWidget(FriendWidget* w)
{
const Friend* f = w->getFriend();
ToxPk toxId = f->getPublicKey();
- Settings::getInstance().setFriendCircleID(toxId, id);
+ settings.setFriendCircleID(toxId, id);
}
void CircleWidget::updateID(int index)
@@ -228,7 +230,7 @@ void CircleWidget::updateID(int index)
if (friendWidget) {
const Friend* f = friendWidget->getFriend();
- Settings::getInstance().setFriendCircleID(f->getPublicKey(), id);
+ settings.setFriendCircleID(f->getPublicKey(), id);
}
}
@@ -238,7 +240,7 @@ void CircleWidget::updateID(int index)
if (friendWidget) {
const Friend* f = friendWidget->getFriend();
- Settings::getInstance().setFriendCircleID(f->getPublicKey(), id);
+ settings.setFriendCircleID(f->getPublicKey(), id);
}
}
}
diff --git a/src/widget/circlewidget.h b/src/widget/circlewidget.h
index 50ffd22e7..1d76079e7 100644
--- a/src/widget/circlewidget.h
+++ b/src/widget/circlewidget.h
@@ -23,12 +23,13 @@
class ContentDialog;
class Core;
+class Settings;
class CircleWidget final : public CategoryWidget
{
Q_OBJECT
public:
- explicit CircleWidget(const Core& core_, FriendListWidget* parent, int id_);
+ CircleWidget(const Core& core_, FriendListWidget* parent, int id_, Settings&);
~CircleWidget();
void editName();
@@ -54,4 +55,5 @@ private:
int id;
const Core& core;
+ Settings& settings;
};
diff --git a/src/widget/contentdialog.cpp b/src/widget/contentdialog.cpp
index b072b7b07..80b3f0bfa 100644
--- a/src/widget/contentdialog.cpp
+++ b/src/widget/contentdialog.cpp
@@ -53,23 +53,22 @@ const QSize minSize(minHeight, minWidget);
const QSize defaultSize(720, 400);
} // namespace
-ContentDialog::ContentDialog(const Core &core, QWidget* parent)
+ContentDialog::ContentDialog(const Core &core, Settings& settings_, QWidget* parent)
: ActivateDialog(parent, Qt::Window)
, splitter{new QSplitter(this)}
, friendLayout{new FriendListLayout(this)}
, activeChatroomWidget(nullptr)
, videoSurfaceSize(QSize())
, videoCount(0)
+ , settings{settings_}
{
- const Settings& s = Settings::getInstance();
-
friendLayout->setMargin(0);
friendLayout->setSpacing(0);
layouts = {friendLayout->getLayoutOnline(), groupLayout.getLayout(),
friendLayout->getLayoutOffline()};
- if (s.getGroupchatPosition()) {
+ if (settings.getGroupchatPosition()) {
#if (QT_VERSION >= QT_VERSION_CHECK(5, 13, 0))
layouts.swapItemsAt(0, 1);
#else
@@ -82,7 +81,7 @@ ContentDialog::ContentDialog(const Core &core, QWidget* parent)
friendWidget->setAutoFillBackground(true);
friendWidget->setLayout(friendLayout);
- onGroupchatPositionChanged(s.getGroupchatPosition());
+ onGroupchatPositionChanged(settings.getGroupchatPosition());
friendScroll = new QScrollArea(this);
friendScroll->setMinimumWidth(minWidget);
@@ -95,7 +94,7 @@ ContentDialog::ContentDialog(const Core &core, QWidget* parent)
QWidget* contentWidget = new QWidget(this);
contentWidget->setAutoFillBackground(true);
- contentLayout = new ContentLayout(contentWidget);
+ contentLayout = new ContentLayout(settings, contentWidget);
contentLayout->setMargin(0);
contentLayout->setSpacing(0);
@@ -113,7 +112,7 @@ ContentDialog::ContentDialog(const Core &core, QWidget* parent)
setAttribute(Qt::WA_DeleteOnClose);
setObjectName("detached");
- QByteArray geometry = s.getDialogGeometry();
+ QByteArray geometry = settings.getDialogGeometry();
if (!geometry.isNull()) {
restoreGeometry(geometry);
@@ -122,7 +121,7 @@ ContentDialog::ContentDialog(const Core &core, QWidget* parent)
}
SplitterRestorer restorer(splitter);
- restorer.restore(s.getDialogSplitterState(), size());
+ restorer.restore(settings.getDialogSplitterState(), size());
username = core.getUsername();
@@ -136,7 +135,7 @@ ContentDialog::ContentDialog(const Core &core, QWidget* parent)
new QShortcut(Qt::CTRL + Qt::Key_PageUp, this, SLOT(previousContact()));
new QShortcut(Qt::CTRL + Qt::Key_PageDown, this, SLOT(nextContact()));
- connect(&s, &Settings::groupchatPositionChanged, this, &ContentDialog::onGroupchatPositionChanged);
+ connect(&settings, &Settings::groupchatPositionChanged, this, &ContentDialog::onGroupchatPositionChanged);
connect(splitter, &QSplitter::splitterMoved, this, &ContentDialog::saveSplitterState);
Translator::registerHandler(std::bind(&ContentDialog::retranslateUi, this), this);
@@ -155,10 +154,10 @@ void ContentDialog::closeEvent(QCloseEvent* event)
FriendWidget* ContentDialog::addFriend(std::shared_ptr chatroom, GenericChatForm* form)
{
- const auto compact = Settings::getInstance().getCompactLayout();
+ const auto compact = settings.getCompactLayout();
auto frnd = chatroom->getFriend();
const auto& friendPk = frnd->getPublicKey();
- auto friendWidget = new FriendWidget(chatroom, compact);
+ auto friendWidget = new FriendWidget(chatroom, compact, settings);
emit connectFriendWidget(*friendWidget);
contactWidgets[friendPk] = friendWidget;
friendLayout->addFriendWidget(friendWidget, frnd->getStatus());
@@ -179,8 +178,8 @@ GroupWidget* ContentDialog::addGroup(std::shared_ptr chatroom, Ge
{
const auto g = chatroom->getGroup();
const auto& groupId = g->getPersistentId();
- const auto compact = Settings::getInstance().getCompactLayout();
- auto groupWidget = new GroupWidget(chatroom, compact);
+ const auto compact = settings.getCompactLayout();
+ auto groupWidget = new GroupWidget(chatroom, compact, settings);
contactWidgets[groupId] = groupWidget;
groupLayout.addSortedWidget(groupWidget);
contactChatForms[groupId] = form;
@@ -312,7 +311,7 @@ void ContentDialog::cycleContacts(bool forward, bool inverse)
}
if (!inverse && index == currentLayout->count() - 1) {
- bool groupsOnTop = Settings::getInstance().getGroupchatPosition();
+ bool groupsOnTop = settings.getGroupchatPosition();
bool offlineEmpty = friendLayout->getLayoutOffline()->isEmpty();
bool onlineEmpty = friendLayout->getLayoutOnline()->isEmpty();
bool groupsEmpty = groupLayout.getLayout()->isEmpty();
@@ -439,8 +438,8 @@ void ContentDialog::setUsername(const QString& newName)
void ContentDialog::reloadTheme()
{
- setStyleSheet(Style::getStylesheet("contentDialog/contentDialog.css"));
- friendScroll->setStyleSheet(Style::getStylesheet("friendList/friendList.css"));
+ setStyleSheet(Style::getStylesheet("contentDialog/contentDialog.css", settings));
+ friendScroll->setStyleSheet(Style::getStylesheet("friendList/friendList.css", settings));
}
bool ContentDialog::event(QEvent* event)
@@ -677,7 +676,7 @@ void ContentDialog::retranslateUi()
*/
void ContentDialog::saveDialogGeometry()
{
- Settings::getInstance().setDialogGeometry(saveGeometry());
+ settings.setDialogGeometry(saveGeometry());
}
/**
@@ -685,7 +684,7 @@ void ContentDialog::saveDialogGeometry()
*/
void ContentDialog::saveSplitterState()
{
- Settings::getInstance().setDialogSplitterState(splitter->saveState());
+ settings.setDialogSplitterState(splitter->saveState());
}
bool ContentDialog::hasContact(const ContactId& contactId) const
diff --git a/src/widget/contentdialog.h b/src/widget/contentdialog.h
index 8e6d6386c..512990cce 100644
--- a/src/widget/contentdialog.h
+++ b/src/widget/contentdialog.h
@@ -45,12 +45,13 @@ class GroupWidget;
class QCloseEvent;
class QSplitter;
class QScrollArea;
+class Settings;
class ContentDialog : public ActivateDialog, public IDialogs
{
Q_OBJECT
public:
- explicit ContentDialog(const Core& core, QWidget* parent = nullptr);
+ ContentDialog(const Core& core, Settings&, QWidget* parent = nullptr);
~ContentDialog() override;
FriendWidget* addFriend(std::shared_ptr chatroom, GenericChatForm* form);
@@ -135,4 +136,5 @@ private:
QHash contactChatForms;
QString username;
+ Settings& settings;
};
diff --git a/src/widget/contentlayout.cpp b/src/widget/contentlayout.cpp
index d72c792f1..7fdd0d68a 100644
--- a/src/widget/contentlayout.cpp
+++ b/src/widget/contentlayout.cpp
@@ -24,14 +24,16 @@
#include
#include
-ContentLayout::ContentLayout()
+ContentLayout::ContentLayout(Settings& settings_)
: QVBoxLayout()
+ , settings{settings_}
{
init();
}
-ContentLayout::ContentLayout(QWidget* parent)
+ContentLayout::ContentLayout(Settings& settings_, QWidget* parent)
: QVBoxLayout(parent)
+ , settings{settings_}
{
init();
@@ -70,8 +72,8 @@ ContentLayout::~ContentLayout()
void ContentLayout::reloadTheme()
{
#ifndef Q_OS_MAC
- mainHead->setStyleSheet(Style::getStylesheet("settings/mainHead.css"));
- mainContent->setStyleSheet(Style::getStylesheet("window/general.css"));
+ mainHead->setStyleSheet(Style::getStylesheet("settings/mainHead.css", settings));
+ mainContent->setStyleSheet(Style::getStylesheet("window/general.css", settings));
#endif
}
@@ -113,10 +115,10 @@ void ContentLayout::init()
mainContent->setLayout(new QVBoxLayout);
mainContent->setSizePolicy(QSizePolicy::MinimumExpanding, QSizePolicy::MinimumExpanding);
- if (QStyleFactory::keys().contains(Settings::getInstance().getStyle())
- && Settings::getInstance().getStyle() != "None") {
- mainHead->setStyle(QStyleFactory::create(Settings::getInstance().getStyle()));
- mainContent->setStyle(QStyleFactory::create(Settings::getInstance().getStyle()));
+ if (QStyleFactory::keys().contains(settings.getStyle())
+ && settings.getStyle() != "None") {
+ mainHead->setStyle(QStyleFactory::create(settings.getStyle()));
+ mainContent->setStyle(QStyleFactory::create(settings.getStyle()));
}
connect(&GUI::getInstance(), &GUI::themeReload, this, &ContentLayout::reloadTheme);
diff --git a/src/widget/contentlayout.h b/src/widget/contentlayout.h
index fd315a45e..bc01cdc51 100644
--- a/src/widget/contentlayout.h
+++ b/src/widget/contentlayout.h
@@ -22,11 +22,13 @@
#include
#include
+class Settings;
+
class ContentLayout : public QVBoxLayout
{
public:
- ContentLayout();
- explicit ContentLayout(QWidget* parent);
+ ContentLayout(Settings&);
+ explicit ContentLayout(Settings&, QWidget* parent);
~ContentLayout();
void clear();
@@ -35,6 +37,7 @@ public:
QHBoxLayout mainHLineLayout;
QWidget* mainContent;
QWidget* mainHead;
+ Settings& settings;
public slots:
void reloadTheme();
diff --git a/src/widget/emoticonswidget.cpp b/src/widget/emoticonswidget.cpp
index 63da7d765..e9fb79aab 100644
--- a/src/widget/emoticonswidget.cpp
+++ b/src/widget/emoticonswidget.cpp
@@ -31,10 +31,11 @@
#include
-EmoticonsWidget::EmoticonsWidget(SmileyPack& smileyPack, QWidget* parent)
+EmoticonsWidget::EmoticonsWidget(SmileyPack& smileyPack, Settings& settings,
+ QWidget* parent)
: QMenu(parent)
{
- setStyleSheet(Style::getStylesheet("emoticonWidget/emoticonWidget.css"));
+ setStyleSheet(Style::getStylesheet("emoticonWidget/emoticonWidget.css", settings));
setLayout(&layout);
layout.addWidget(&stack);
@@ -57,7 +58,7 @@ EmoticonsWidget::EmoticonsWidget(SmileyPack& smileyPack, QWidget* parent)
int col = 0;
// respect configured emoticon size
- const int px = Settings::getInstance().getEmojiFontPointSize();
+ const int px = settings.getEmojiFontPointSize();
const QSize size(px, px);
// create pages
diff --git a/src/widget/emoticonswidget.h b/src/widget/emoticonswidget.h
index 592a0fb2e..28a744da7 100644
--- a/src/widget/emoticonswidget.h
+++ b/src/widget/emoticonswidget.h
@@ -28,12 +28,13 @@
class QIcon;
class SmileyPack;
+class Settings;
class EmoticonsWidget : public QMenu
{
Q_OBJECT
public:
- explicit EmoticonsWidget(SmileyPack&, QWidget* parent = nullptr);
+ EmoticonsWidget(SmileyPack&, Settings&, QWidget* parent = nullptr);
signals:
void insertEmoticon(QString str);
diff --git a/src/widget/form/addfriendform.cpp b/src/widget/form/addfriendform.cpp
index 6b843f1bf..2de6646f7 100644
--- a/src/widget/form/addfriendform.cpp
+++ b/src/widget/form/addfriendform.cpp
@@ -61,8 +61,9 @@ namespace
* @brief Cached username so we can retranslate the invite message
*/
-AddFriendForm::AddFriendForm(ToxId _ownId)
- : ownId{_ownId}
+AddFriendForm::AddFriendForm(ToxId ownId_, Settings& settings_)
+ : ownId{ownId_}
+ , settings{settings_}
{
tabWidget = new QTabWidget();
main = new QWidget(tabWidget);
@@ -122,9 +123,9 @@ AddFriendForm::AddFriendForm(ToxId _ownId)
retranslateUi();
Translator::registerHandler(std::bind(&AddFriendForm::retranslateUi, this), this);
- const int size = Settings::getInstance().getFriendRequestSize();
+ const int size = settings.getFriendRequestSize();
for (int i = 0; i < size; ++i) {
- Settings::Request request = Settings::getInstance().getFriendRequest(i);
+ Settings::Request request = settings.getFriendRequest(i);
addFriendRequestWidget(request.address, request.message);
}
}
@@ -180,7 +181,7 @@ void AddFriendForm::setMode(Mode mode)
bool AddFriendForm::addFriendRequest(const QString& friendAddress, const QString& message_)
{
- if (Settings::getInstance().addFriendRequest(friendAddress, message_)) {
+ if (settings.addFriendRequest(friendAddress, message_)) {
addFriendRequestWidget(friendAddress, message_);
if (isShown()) {
onCurrentChanged(tabWidget->currentIndex());
@@ -292,7 +293,7 @@ void AddFriendForm::onIdChanged(const QString& id)
isValidId ? QStringLiteral("%1 (%2)") : QStringLiteral("%1 (%2)");
toxIdLabel.setText(labelText.arg(toxIdText, toxIdComment));
toxId.setStyleSheet(isValidOrEmpty ? QStringLiteral("")
- : Style::getStylesheet("addFriendForm/toxId.css"));
+ : Style::getStylesheet("addFriendForm/toxId.css", settings));
toxId.setToolTip(isValidOrEmpty ? QStringLiteral("") : tr("Invalid Tox ID format"));
sendButton.setEnabled(isValidId);
@@ -311,11 +312,11 @@ void AddFriendForm::setIdFromClipboard()
void AddFriendForm::deleteFriendRequest(const ToxId& toxId_)
{
- const int size = Settings::getInstance().getFriendRequestSize();
+ const int size = settings.getFriendRequestSize();
for (int i = 0; i < size; ++i) {
- Settings::Request request = Settings::getInstance().getFriendRequest(i);
+ Settings::Request request = settings.getFriendRequest(i);
if (toxId_.getPublicKey() == ToxPk(request.address)) {
- Settings::getInstance().removeFriendRequest(i);
+ settings.removeFriendRequest(i);
return;
}
}
@@ -328,10 +329,10 @@ void AddFriendForm::onFriendRequestAccepted()
const int index = requestsLayout->indexOf(friendWidget);
removeFriendRequestWidget(friendWidget);
const int indexFromEnd = requestsLayout->count() - index - 1;
- const Settings::Request request = Settings::getInstance().getFriendRequest(indexFromEnd);
+ const Settings::Request request = settings.getFriendRequest(indexFromEnd);
emit friendRequestAccepted(ToxPk{request.address});
- Settings::getInstance().removeFriendRequest(indexFromEnd);
- Settings::getInstance().savePersonal();
+ settings.removeFriendRequest(indexFromEnd);
+ settings.savePersonal();
}
void AddFriendForm::onFriendRequestRejected()
@@ -341,15 +342,15 @@ void AddFriendForm::onFriendRequestRejected()
const int index = requestsLayout->indexOf(friendWidget);
removeFriendRequestWidget(friendWidget);
const int indexFromEnd = requestsLayout->count() - index - 1;
- Settings::getInstance().removeFriendRequest(indexFromEnd);
- Settings::getInstance().savePersonal();
+ settings.removeFriendRequest(indexFromEnd);
+ settings.savePersonal();
}
void AddFriendForm::onCurrentChanged(int index)
{
- if (index == FriendRequest && Settings::getInstance().getUnreadFriendRequests() != 0) {
- Settings::getInstance().clearUnreadFriendRequests();
- Settings::getInstance().savePersonal();
+ if (index == FriendRequest && settings.getUnreadFriendRequests() != 0) {
+ settings.clearUnreadFriendRequests();
+ settings.savePersonal();
emit friendRequestsSeen();
}
}
diff --git a/src/widget/form/addfriendform.h b/src/widget/form/addfriendform.h
index d843eba2a..ebfafd9dd 100644
--- a/src/widget/form/addfriendform.h
+++ b/src/widget/form/addfriendform.h
@@ -33,6 +33,7 @@
class QTabWidget;
class ContentLayout;
+class Settings;
class AddFriendForm : public QObject
{
@@ -45,7 +46,7 @@ public:
FriendRequest = 2
};
- AddFriendForm(ToxId _ownId);
+ AddFriendForm(ToxId ownId_, Settings&);
AddFriendForm(const AddFriendForm&) = delete;
AddFriendForm& operator=(const AddFriendForm&) = delete;
~AddFriendForm();
@@ -113,4 +114,5 @@ private:
QList contactsToImport;
ToxId ownId;
+ Settings& settings;
};
diff --git a/src/widget/form/chatform.cpp b/src/widget/form/chatform.cpp
index c7736db7f..b0c0e92cb 100644
--- a/src/widget/form/chatform.cpp
+++ b/src/widget/form/chatform.cpp
@@ -108,14 +108,15 @@ QString secondsToDHMS(quint32 duration)
ChatForm::ChatForm(Profile& profile, Friend* chatFriend, IChatLog& chatLog_,
IMessageDispatcher& messageDispatcher_, DocumentCache& documentCache_,
- SmileyPack& smileyPack_, CameraSource& cameraSource_)
+ SmileyPack& smileyPack_, CameraSource& cameraSource_, Settings& settings_)
: GenericChatForm(profile.getCore(), chatFriend, chatLog_, messageDispatcher_,
- documentCache_, smileyPack_)
+ documentCache_, smileyPack_, settings_)
, core{profile.getCore()}
, f(chatFriend)
, isTyping{false}
, lastCallIsVideo{false}
, cameraSource{cameraSource_}
+ , settings{settings_}
{
setName(f->getDisplayedName());
@@ -146,7 +147,7 @@ ChatForm::ChatForm(Profile& profile, Friend* chatFriend, IChatLog& chatLog_,
imagePreview->setStyleSheet("QPushButton { border: 0px }");
imagePreview->hide();
- auto cancelIcon = QIcon(Style::getImagePath("rejectCall/rejectCall.svg"));
+ auto cancelIcon = QIcon(Style::getImagePath("rejectCall/rejectCall.svg", settings));
QPushButton* cancelButton = new QPushButton(imagePreview);
cancelButton->setFixedSize(20, 20);
cancelButton->move(QPoint(80, 0));
@@ -258,7 +259,7 @@ void ChatForm::onExtensionSupportChanged(ExtensionSet extensions)
void ChatForm::onTextEditChanged()
{
- if (!Settings::getInstance().getTypingNotification()) {
+ if (!settings.getTypingNotification()) {
if (isTyping) {
isTyping = false;
core.sendTyping(f->getId(), false);
@@ -323,7 +324,7 @@ void ChatForm::onAvInvite(uint32_t friendId, bool video)
auto testedFlag = video ? Settings::AutoAcceptCall::Video : Settings::AutoAcceptCall::Audio;
// AutoAcceptCall is set for this friend
- if (Settings::getInstance().getAutoAcceptCall(f->getPublicKey()).testFlag(testedFlag)) {
+ if (settings.getAutoAcceptCall(f->getPublicKey()).testFlag(testedFlag)) {
qDebug() << "automatic call answer";
CoreAV* coreav = core.getAv();
QMetaObject::invokeMethod(coreav, "answerCall", Qt::QueuedConnection,
@@ -470,7 +471,7 @@ void ChatForm::onFriendStatusChanged(const ToxPk& friendPk, Status::Status statu
updateCallButtons();
- if (Settings::getInstance().getStatusChangeNotificationEnabled()) {
+ if (settings.getStatusChangeNotificationEnabled()) {
QString fStatus = Status::getTitle(status);
addSystemInfoMessage(QDateTime::currentDateTime(), SystemMessageType::peerStateChange,
{f->getDisplayedName(), fStatus});
@@ -511,7 +512,8 @@ std::unique_ptr ChatForm::createNetcam()
{
qDebug() << "creating netcam";
uint32_t friendId = f->getId();
- std::unique_ptr view = std::unique_ptr(new NetCamView(f->getPublicKey(), cameraSource, this));
+ std::unique_ptr view = std::unique_ptr(
+ new NetCamView(f->getPublicKey(), cameraSource, settings, this));
CoreAV* av = core.getAv();
VideoSource* source = av->getVideoSourceFromCall(friendId);
view->show(source, f->getDisplayedName());
@@ -610,14 +612,14 @@ void ChatForm::sendImageFromPreview()
return;
}
- QDir(Settings::getInstance().getPaths().getAppDataDirPath()).mkpath("images");
+ QDir(settings.getPaths().getAppDataDirPath()).mkpath("images");
// use ~ISO 8601 for screenshot timestamp, considering FS limitations
// https://en.wikipedia.org/wiki/ISO_8601
// Windows has to be supported, thus filename can't have `:` in it :/
// Format should be: `qTox_Screenshot_yyyy-MM-dd HH-mm-ss.zzz.png`
QString filepath = QString("%1images%2qTox_Image_%3.png")
- .arg(Settings::getInstance().getPaths().getAppDataDirPath())
+ .arg(settings.getPaths().getAppDataDirPath())
.arg(QDir::separator())
.arg(QDateTime::currentDateTime().toString("yyyy-MM-dd HH-mm-ss.zzz"));
QFile file(filepath);
diff --git a/src/widget/form/chatform.h b/src/widget/form/chatform.h
index 1d3c5c85c..eed70ca51 100644
--- a/src/widget/form/chatform.h
+++ b/src/widget/form/chatform.h
@@ -44,6 +44,7 @@ class QMoveEvent;
class ImagePreviewButton;
class DocumentCache;
class SmileyPack;
+class Settings;
class ChatForm : public GenericChatForm
{
@@ -51,7 +52,7 @@ class ChatForm : public GenericChatForm
public:
ChatForm(Profile& profile, Friend* chatFriend, IChatLog& chatLog_,
IMessageDispatcher& messageDispatcher_, DocumentCache&, SmileyPack&,
- CameraSource&);
+ CameraSource&, Settings&);
~ChatForm() override;
void setStatusMessage(const QString& newMessage);
@@ -143,4 +144,5 @@ private:
bool lastCallIsVideo;
std::unique_ptr netcam;
CameraSource& cameraSource;
+ Settings& settings;
};
diff --git a/src/widget/form/filesform.cpp b/src/widget/form/filesform.cpp
index 3991b3a22..49d942830 100644
--- a/src/widget/form/filesform.cpp
+++ b/src/widget/form/filesform.cpp
@@ -324,8 +324,9 @@ namespace FileTransferList
return true;
}
- Delegate::Delegate(QWidget* parent)
+ Delegate::Delegate(Settings& settings_, QWidget* parent)
: QStyledItemDelegate(parent)
+ , settings{settings_}
{}
void Delegate::paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const
@@ -358,11 +359,11 @@ namespace FileTransferList
}
const auto localPaused = data.toBool();
QPixmap pausePixmap = localPaused
- ? QPixmap(Style::getImagePath("fileTransferInstance/arrow_black.svg"))
- : QPixmap(Style::getImagePath("fileTransferInstance/pause_dark.svg"));
+ ? QPixmap(Style::getImagePath("fileTransferInstance/arrow_black.svg", settings))
+ : QPixmap(Style::getImagePath("fileTransferInstance/pause_dark.svg", settings));
QApplication::style()->drawItemPixmap(painter, pauseRect(option), Qt::AlignCenter, pausePixmap);
- QPixmap stopPixmap(Style::getImagePath("fileTransferInstance/no_dark.svg"));
+ QPixmap stopPixmap(Style::getImagePath("fileTransferInstance/no_dark.svg", settings));
QApplication::style()->drawItemPixmap(painter, stopRect(option), Qt::AlignCenter, stopPixmap);
return;
}
@@ -401,7 +402,7 @@ namespace FileTransferList
}
- View::View(QAbstractItemModel* model, QWidget* parent)
+ View::View(QAbstractItemModel* model, Settings& settings, QWidget* parent)
: QTableView(parent)
{
setModel(model);
@@ -416,14 +417,14 @@ namespace FileTransferList
setShowGrid(false);
setSelectionBehavior(QAbstractItemView::SelectRows);
setSelectionMode(QAbstractItemView::SingleSelection);
- setItemDelegate(new Delegate(this));
+ setItemDelegate(new Delegate(settings, this));
}
View::~View() = default;
} // namespace FileTransferList
-FilesForm::FilesForm(CoreFile& coreFile)
+FilesForm::FilesForm(CoreFile& coreFile, Settings& settings)
: QObject()
{
head = new QWidget();
@@ -453,8 +454,8 @@ FilesForm::FilesForm(CoreFile& coreFile)
connect(sentModel, &FileTransferList::Model::togglePause, pauseFile);
connect(sentModel, &FileTransferList::Model::cancel, cancelFileSend);
- recvd = new FileTransferList::View(recvdModel);
- sent = new FileTransferList::View(sentModel);
+ recvd = new FileTransferList::View(recvdModel, settings);
+ sent = new FileTransferList::View(sentModel, settings);
main.addTab(recvd, QString());
main.addTab(sent, QString());
diff --git a/src/widget/form/filesform.h b/src/widget/form/filesform.h
index b39c8035f..a4b6f221a 100644
--- a/src/widget/form/filesform.h
+++ b/src/widget/form/filesform.h
@@ -34,6 +34,7 @@
class ContentLayout;
class QTableView;
+class Settings;
namespace FileTransferList
{
@@ -88,16 +89,18 @@ namespace FileTransferList
class Delegate : public QStyledItemDelegate
{
public:
- Delegate(QWidget* parent = nullptr);
+ Delegate(Settings&, QWidget* parent = nullptr);
void paint(QPainter* painter, const QStyleOptionViewItem& option, const QModelIndex& index) const override;
bool editorEvent(QEvent* event, QAbstractItemModel* model, const QStyleOptionViewItem& option, const QModelIndex& index) override;
+ private:
+ Settings& settings;
};
class View : public QTableView
{
public:
- View(QAbstractItemModel* model, QWidget* parent = nullptr);
+ View(QAbstractItemModel* model, Settings&, QWidget* parent = nullptr);
~View();
};
@@ -108,7 +111,7 @@ class FilesForm : public QObject
Q_OBJECT
public:
- FilesForm(CoreFile& coreFile);
+ FilesForm(CoreFile& coreFile, Settings&);
~FilesForm();
bool isShown() const;
diff --git a/src/widget/form/genericchatform.cpp b/src/widget/form/genericchatform.cpp
index 2585533e5..3aa525632 100644
--- a/src/widget/form/genericchatform.cpp
+++ b/src/widget/form/genericchatform.cpp
@@ -121,7 +121,7 @@ namespace
{
template
-QPushButton* createButton(const QString& name, T* self, Fun onClickSlot)
+QPushButton* createButton(const QString& name, T* self, Fun onClickSlot, Settings& settings)
{
QPushButton* btn = new QPushButton();
// Fix for incorrect layouts on OS X as per
@@ -129,7 +129,7 @@ QPushButton* createButton(const QString& name, T* self, Fun onClickSlot)
btn->setAttribute(Qt::WA_LayoutUsesWidgetRect);
btn->setObjectName(name);
btn->setProperty("state", "green");
- btn->setStyleSheet(Style::getStylesheet(STYLE_PATH));
+ btn->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
QObject::connect(btn, &QPushButton::clicked, self, onClickSlot);
return btn;
}
@@ -138,7 +138,7 @@ QPushButton* createButton(const QString& name, T* self, Fun onClickSlot)
GenericChatForm::GenericChatForm(const Core& core_, const Contact* contact, IChatLog& chatLog_,
IMessageDispatcher& messageDispatcher_, DocumentCache& documentCache,
- SmileyPack& smileyPack_, QWidget* parent_)
+ SmileyPack& smileyPack_, Settings& settings_, QWidget* parent_)
: QWidget(parent_, Qt::Window)
, core{core_}
, audioInputFlag(false)
@@ -146,33 +146,34 @@ GenericChatForm::GenericChatForm(const Core& core_, const Contact* contact, ICha
, chatLog(chatLog_)
, messageDispatcher(messageDispatcher_)
, smileyPack{smileyPack_}
+ , settings{settings_}
{
curRow = 0;
- headWidget = new ChatFormHeader();
- searchForm = new SearchForm();
+ headWidget = new ChatFormHeader(settings);
+ searchForm = new SearchForm(settings);
dateInfo = new QLabel(this);
- chatWidget = new ChatWidget(chatLog_, core, documentCache, smileyPack, this);
+ chatWidget = new ChatWidget(chatLog_, core, documentCache, smileyPack,
+ settings, this);
searchForm->hide();
dateInfo->setAlignment(Qt::AlignHCenter);
dateInfo->setVisible(false);
// settings
- const Settings& s = Settings::getInstance();
- connect(&s, &Settings::emojiFontPointSizeChanged, chatWidget, &ChatWidget::forceRelayout);
- connect(&s, &Settings::chatMessageFontChanged, this, &GenericChatForm::onChatMessageFontChanged);
+ connect(&settings, &Settings::emojiFontPointSizeChanged, chatWidget, &ChatWidget::forceRelayout);
+ connect(&settings, &Settings::chatMessageFontChanged, this, &GenericChatForm::onChatMessageFontChanged);
msgEdit = new ChatTextEdit();
#ifdef SPELL_CHECKING
- if (s.getSpellCheckingEnabled()) {
+ if (settings.getSpellCheckingEnabled()) {
decorator = new Sonnet::SpellCheckDecorator(msgEdit);
}
#endif
- sendButton = createButton("sendButton", this, &GenericChatForm::onSendTriggered);
- emoteButton = createButton("emoteButton", this, &GenericChatForm::onEmoteButtonClicked);
+ sendButton = createButton("sendButton", this, &GenericChatForm::onSendTriggered, settings);
+ emoteButton = createButton("emoteButton", this, &GenericChatForm::onEmoteButtonClicked, settings);
- fileButton = createButton("fileButton", this, &GenericChatForm::onAttachClicked);
- screenshotButton = createButton("screenshotButton", this, &GenericChatForm::onScreenshotClicked);
+ fileButton = createButton("fileButton", this, &GenericChatForm::onAttachClicked, settings);
+ screenshotButton = createButton("screenshotButton", this, &GenericChatForm::onScreenshotClicked, settings);
// TODO: Make updateCallButtons (see ChatForm) abstract
// and call here to set tooltips.
@@ -351,15 +352,14 @@ QDateTime GenericChatForm::getLatestTime() const
void GenericChatForm::reloadTheme()
{
- const Settings& s = Settings::getInstance();
- setStyleSheet(Style::getStylesheet("genericChatForm/genericChatForm.css"));
- msgEdit->setStyleSheet(Style::getStylesheet("msgEdit/msgEdit.css")
- + fontToCss(s.getChatMessageFont(), "QTextEdit"));
+ setStyleSheet(Style::getStylesheet("genericChatForm/genericChatForm.css", settings));
+ msgEdit->setStyleSheet(Style::getStylesheet("msgEdit/msgEdit.css", settings)
+ + fontToCss(settings.getChatMessageFont(), "QTextEdit"));
- emoteButton->setStyleSheet(Style::getStylesheet(STYLE_PATH));
- fileButton->setStyleSheet(Style::getStylesheet(STYLE_PATH));
- screenshotButton->setStyleSheet(Style::getStylesheet(STYLE_PATH));
- sendButton->setStyleSheet(Style::getStylesheet(STYLE_PATH));
+ emoteButton->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
+ fileButton->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
+ screenshotButton->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
+ sendButton->setStyleSheet(Style::getStylesheet(STYLE_PATH, settings));
}
void GenericChatForm::setName(const QString& newName)
@@ -456,7 +456,7 @@ void GenericChatForm::onEmoteButtonClicked()
if (smileyPack.getEmoticons().empty())
return;
- EmoticonsWidget widget(smileyPack);
+ EmoticonsWidget widget(smileyPack, settings);
connect(&widget, SIGNAL(insertEmoticon(QString)), this, SLOT(onEmoteInsertRequested(QString)));
widget.installEventFilter(this);
@@ -494,7 +494,7 @@ void GenericChatForm::onChatMessageFontChanged(const QFont& font)
chatWidget->fontChanged(font);
chatWidget->forceRelayout();
// message editor
- msgEdit->setStyleSheet(Style::getStylesheet("msgEdit/msgEdit.css")
+ msgEdit->setStyleSheet(Style::getStylesheet("msgEdit/msgEdit.css", settings)
+ fontToCss(font, "QTextEdit"));
}
@@ -708,7 +708,7 @@ void GenericChatForm::updateShowDateInfo(const ChatLine::Ptr& prevLine, const Ch
const auto date = getTime(effectiveTopLine);
if (date.isValid() && date.date() != QDate::currentDate()) {
- const auto dateText = QStringLiteral("%1<\b>").arg(date.toString(Settings::getInstance().getDateFormat()));
+ const auto dateText = QStringLiteral("%1<\b>").arg(date.toString(settings.getDateFormat()));
dateInfo->setText(dateText);
dateInfo->setVisible(true);
} else {
diff --git a/src/widget/form/genericchatform.h b/src/widget/form/genericchatform.h
index ac58209ea..1c64cfb71 100644
--- a/src/widget/form/genericchatform.h
+++ b/src/widget/form/genericchatform.h
@@ -55,6 +55,7 @@ class IMessageDispatcher;
struct Message;
class DocumentCache;
class SmileyPack;
+class Settings;
namespace Ui {
class MainWindow;
@@ -72,7 +73,7 @@ class GenericChatForm : public QWidget
public:
GenericChatForm(const Core& core_, const Contact* contact, IChatLog& chatLog_,
IMessageDispatcher& messageDispatcher_, DocumentCache&,
- SmileyPack&, QWidget* parent_ = nullptr);
+ SmileyPack&, Settings&, QWidget* parent_ = nullptr);
~GenericChatForm() override;
void setName(const QString& newName);
@@ -169,4 +170,5 @@ protected:
IChatLog& chatLog;
IMessageDispatcher& messageDispatcher;
SmileyPack& smileyPack;
+ Settings& settings;
};
diff --git a/src/widget/form/groupchatform.cpp b/src/widget/form/groupchatform.cpp
index d3ef074ef..eb9d019b9 100644
--- a/src/widget/form/groupchatform.cpp
+++ b/src/widget/form/groupchatform.cpp
@@ -37,6 +37,7 @@
#include "src/widget/tool/croppinglabel.h"
#include "src/widget/translator.h"
#include "src/persistence/igroupsettings.h"
+#include "src/persistence/settings.h"
#include
#include
@@ -83,9 +84,9 @@ QString editName(const QString& name)
*/
GroupChatForm::GroupChatForm(Core& core_, Group* chatGroup, IChatLog& chatLog_,
- IMessageDispatcher& messageDispatcher_, IGroupSettings& settings_, DocumentCache& documentCache_,
+ IMessageDispatcher& messageDispatcher_, Settings& settings_, DocumentCache& documentCache_,
SmileyPack& smileyPack_)
- : GenericChatForm(core_, chatGroup, chatLog_, messageDispatcher_, documentCache_, smileyPack_)
+ : GenericChatForm(core_, chatGroup, chatLog_, messageDispatcher_, documentCache_, smileyPack_, settings_)
, core{core_}
, group(chatGroup)
, inCall(false)
@@ -216,7 +217,7 @@ void GroupChatForm::updateUserNames()
label->setProperty("peerType", LABEL_PEER_TYPE_MUTED);
}
- label->setStyleSheet(Style::getStylesheet(PEER_LABEL_STYLE_SHEET_PATH));
+ label->setStyleSheet(Style::getStylesheet(PEER_LABEL_STYLE_SHEET_PATH, settings));
peerLabels.insert(peerPk, label);
}
@@ -285,7 +286,7 @@ void GroupChatForm::peerAudioPlaying(ToxPk peerPk)
});
}
- peerLabels[peerPk]->setStyleSheet(Style::getStylesheet(PEER_LABEL_STYLE_SHEET_PATH));
+ peerLabels[peerPk]->setStyleSheet(Style::getStylesheet(PEER_LABEL_STYLE_SHEET_PATH, settings));
peerAudioTimers[peerPk]->start(500);
}
@@ -433,7 +434,7 @@ void GroupChatForm::onLabelContextMenuRequested(const QPoint& localPos)
} else {
toggleMuteAction = contextMenu->addAction(muteString);
}
- contextMenu->setStyleSheet(Style::getStylesheet(PEER_LABEL_STYLE_SHEET_PATH));
+ contextMenu->setStyleSheet(Style::getStylesheet(PEER_LABEL_STYLE_SHEET_PATH, settings));
const QAction* selectedItem = contextMenu->exec(pos);
if (selectedItem == toggleMuteAction) {
diff --git a/src/widget/form/groupchatform.h b/src/widget/form/groupchatform.h
index 0febf3bfc..d89604ec3 100644
--- a/src/widget/form/groupchatform.h
+++ b/src/widget/form/groupchatform.h
@@ -21,6 +21,7 @@
#include "genericchatform.h"
#include "src/core/toxpk.h"
+#include "src/persistence/igroupsettings.h"
#include
namespace Ui {
@@ -34,7 +35,6 @@ class GroupId;
class IMessageDispatcher;
struct Message;
class Settings;
-class IGroupSettings;
class DocumentCache;
class SmileyPack;
@@ -43,7 +43,7 @@ class GroupChatForm : public GenericChatForm
Q_OBJECT
public:
GroupChatForm(Core& core_, Group* chatGroup, IChatLog& chatLog_,
- IMessageDispatcher& messageDispatcher_, IGroupSettings& settings_,
+ IMessageDispatcher& messageDispatcher_, Settings& settings_,
DocumentCache&, SmileyPack&);
~GroupChatForm();
@@ -84,5 +84,5 @@ private:
QLabel* nusersLabel;
TabCompleter* tabber;
bool inCall;
- IGroupSettings& settings;
+ Settings& settings;
};
diff --git a/src/widget/form/groupinviteform.cpp b/src/widget/form/groupinviteform.cpp
index 4b6b6e8d7..74dba591f 100644
--- a/src/widget/form/groupinviteform.cpp
+++ b/src/widget/form/groupinviteform.cpp
@@ -45,12 +45,13 @@
* @brief This form contains all group invites you received
*/
-GroupInviteForm::GroupInviteForm()
+GroupInviteForm::GroupInviteForm(Settings& settings_)
: headWidget(new QWidget(this))
, headLabel(new QLabel(this))
, createButton(new QPushButton(this))
, inviteBox(new QGroupBox(this))
, scroll(new QScrollArea(this))
+ , settings{settings_}
{
QVBoxLayout* layout = new QVBoxLayout(this);
connect(createButton, &QPushButton::clicked,
@@ -123,7 +124,7 @@ bool GroupInviteForm::addGroupInvite(const GroupInvite& inviteInfo)
}
}
- GroupInviteWidget* widget = new GroupInviteWidget(this, inviteInfo);
+ GroupInviteWidget* widget = new GroupInviteWidget(this, inviteInfo, settings);
scroll->widget()->layout()->addWidget(widget);
invites.append(widget);
connect(widget, &GroupInviteWidget::accepted, [this] (const GroupInvite& inviteInfo_) {
diff --git a/src/widget/form/groupinviteform.h b/src/widget/form/groupinviteform.h
index 2db5b5815..ab3d9bd5b 100644
--- a/src/widget/form/groupinviteform.h
+++ b/src/widget/form/groupinviteform.h
@@ -32,6 +32,7 @@ class QLabel;
class QPushButton;
class QScrollArea;
class QSignalMapper;
+class Settings;
namespace Ui {
class MainWindow;
@@ -41,7 +42,7 @@ class GroupInviteForm : public QWidget
{
Q_OBJECT
public:
- GroupInviteForm();
+ explicit GroupInviteForm(Settings&);
~GroupInviteForm();
void show(ContentLayout* contentLayout);
@@ -67,4 +68,5 @@ private:
QGroupBox* inviteBox;
QList invites;
QScrollArea* scroll;
+ Settings& settings;
};
diff --git a/src/widget/form/groupinvitewidget.cpp b/src/widget/form/groupinvitewidget.cpp
index 4bc4b8cc4..f245c8057 100644
--- a/src/widget/form/groupinvitewidget.cpp
+++ b/src/widget/form/groupinvitewidget.cpp
@@ -35,13 +35,14 @@
* and provides buttons to accept/reject it
*/
-GroupInviteWidget::GroupInviteWidget(QWidget* parent, const GroupInvite& invite)
+GroupInviteWidget::GroupInviteWidget(QWidget* parent, const GroupInvite& invite, Settings& settings_)
: QWidget(parent)
, acceptButton(new QPushButton(this))
, rejectButton(new QPushButton(this))
, inviteMessageLabel(new CroppingLabel(this))
, widgetLayout(new QHBoxLayout(this))
, inviteInfo(invite)
+ , settings{settings_}
{
connect(acceptButton, &QPushButton::clicked, [=]() { emit accepted(inviteInfo); });
connect(rejectButton, &QPushButton::clicked, [=]() { emit rejected(inviteInfo); });
@@ -59,8 +60,8 @@ void GroupInviteWidget::retranslateUi()
{
QString name = Nexus::getCore()->getFriendUsername(inviteInfo.getFriendId());
QDateTime inviteDate = inviteInfo.getInviteDate();
- QString date = inviteDate.toString(Settings::getInstance().getDateFormat());
- QString time = inviteDate.toString(Settings::getInstance().getTimestampFormat());
+ QString date = inviteDate.toString(settings.getDateFormat());
+ QString time = inviteDate.toString(settings.getTimestampFormat());
inviteMessageLabel->setText(
tr("Invited by %1 on %2 at %3.").arg("%1").arg(name.toHtmlEscaped(), date, time));
diff --git a/src/widget/form/groupinvitewidget.h b/src/widget/form/groupinvitewidget.h
index 433f1fa2d..502554d01 100644
--- a/src/widget/form/groupinvitewidget.h
+++ b/src/widget/form/groupinvitewidget.h
@@ -27,12 +27,13 @@ class CroppingLabel;
class QHBoxLayout;
class QPushButton;
+class Settings;
class GroupInviteWidget : public QWidget
{
Q_OBJECT
public:
- GroupInviteWidget(QWidget* parent, const GroupInvite& invite);
+ GroupInviteWidget(QWidget* parent, const GroupInvite& invite, Settings&);
void retranslateUi();
const GroupInvite getInviteInfo() const;
@@ -46,4 +47,5 @@ private:
CroppingLabel* inviteMessageLabel;
QHBoxLayout* widgetLayout;
GroupInvite inviteInfo;
+ Settings& settings;
};
diff --git a/src/widget/form/profileform.cpp b/src/widget/form/profileform.cpp
index 6fe2fa6da..6f2196b27 100644
--- a/src/widget/form/profileform.cpp
+++ b/src/widget/form/profileform.cpp
@@ -99,10 +99,12 @@ const QPair CAN_NOT_CHANGE_PASSWORD = {
};
} // namespace
-ProfileForm::ProfileForm(IProfileInfo* profileInfo_, QWidget* parent)
+ProfileForm::ProfileForm(IProfileInfo* profileInfo_, Settings& settings_,
+ QWidget* parent)
: QWidget{parent}
, qr{nullptr}
, profileInfo{profileInfo_}
+ , settings{settings_}
{
bodyUI = new Ui::IdentitySettings;
bodyUI->setupUi(this);
@@ -131,7 +133,7 @@ ProfileForm::ProfileForm(IProfileInfo* profileInfo_, QWidget* parent)
profilePicture->installEventFilter(this);
profilePicture->setAccessibleName("Profile avatar");
profilePicture->setAccessibleDescription("Set a profile avatar shown to all contacts");
- profilePicture->setStyleSheet(Style::getStylesheet("window/profile.css"));
+ profilePicture->setStyleSheet(Style::getStylesheet("window/profile.css", settings));
connect(profilePicture, &MaskablePixmapWidget::clicked, this, &ProfileForm::onAvatarClicked);
connect(profilePicture, &MaskablePixmapWidget::customContextMenuRequested,
this, &ProfileForm::showProfilePictureContextMenu);
@@ -212,8 +214,8 @@ void ProfileForm::show(ContentLayout* contentLayout)
contentLayout->mainContent->layout()->addWidget(this);
QWidget::show();
prFileLabelUpdate();
- bool portable = Settings::getInstance().getMakeToxPortable();
- QString defaultPath = QDir(Settings::getInstance().getPaths().getSettingsDirPath()).path().trimmed();
+ bool portable = settings.getMakeToxPortable();
+ QString defaultPath = QDir(settings.getPaths().getSettingsDirPath()).path().trimmed();
QString appPath = QApplication::applicationDirPath();
QString dirPath = portable ? appPath : defaultPath;
diff --git a/src/widget/form/profileform.h b/src/widget/form/profileform.h
index 51639074d..ac6c2029c 100644
--- a/src/widget/form/profileform.h
+++ b/src/widget/form/profileform.h
@@ -29,6 +29,7 @@ class ContentLayout;
class CroppingLabel;
class IProfileInfo;
class MaskablePixmapWidget;
+class Settings;
namespace Ui {
class IdentitySettings;
@@ -52,7 +53,7 @@ class ProfileForm : public QWidget
{
Q_OBJECT
public:
- ProfileForm(IProfileInfo* profileInfo_, QWidget* parent = nullptr);
+ ProfileForm(IProfileInfo* profileInfo_, Settings&, QWidget* parent = nullptr);
~ProfileForm();
void show(ContentLayout* contentLayout);
bool isShown() const;
@@ -92,4 +93,5 @@ private:
QRWidget* qr;
ClickableTE* toxId;
IProfileInfo* profileInfo;
+ Settings& settings;
};
diff --git a/src/widget/form/searchsettingsform.cpp b/src/widget/form/searchsettingsform.cpp
index 013a80e45..041443ef3 100644
--- a/src/widget/form/searchsettingsform.cpp
+++ b/src/widget/form/searchsettingsform.cpp
@@ -23,9 +23,10 @@
#include "src/widget/style.h"
#include "src/widget/form/loadhistorydialog.h"
-SearchSettingsForm::SearchSettingsForm(QWidget *parent) :
- QWidget(parent),
- ui(new Ui::SearchSettingsForm)
+SearchSettingsForm::SearchSettingsForm(Settings& settings_, QWidget *parent)
+ : QWidget(parent)
+ , ui(new Ui::SearchSettingsForm)
+ , settings{settings_}
{
ui->setupUi(this);
@@ -99,13 +100,13 @@ ParameterSearch SearchSettingsForm::getParameterSearch()
void SearchSettingsForm::reloadTheme()
{
- ui->choiceDateButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
- ui->startDateLabel->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/labels.css")));
+ ui->choiceDateButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
+ ui->startDateLabel->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/labels.css"), settings));
}
void SearchSettingsForm::updateStartDateLabel()
{
- ui->startDateLabel->setText(startDate.toString(Settings::getInstance().getDateFormat()));
+ ui->startDateLabel->setText(startDate.toString(settings.getDateFormat()));
}
void SearchSettingsForm::setUpdate(const bool isUpdate_)
@@ -121,7 +122,7 @@ void SearchSettingsForm::onStartSearchSelected(const int index)
ui->startDateLabel->setEnabled(true);
ui->choiceDateButton->setProperty("state", QStringLiteral("green"));
- ui->choiceDateButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
+ ui->choiceDateButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
if (startDate.isNull()) {
startDate = QDate::currentDate();
@@ -133,7 +134,7 @@ void SearchSettingsForm::onStartSearchSelected(const int index)
ui->startDateLabel->setEnabled(false);
ui->choiceDateButton->setProperty("state", QString());
- ui->choiceDateButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
+ ui->choiceDateButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
}
setUpdate(true);
diff --git a/src/widget/form/searchsettingsform.h b/src/widget/form/searchsettingsform.h
index 3782c1d76..6d31fcef9 100644
--- a/src/widget/form/searchsettingsform.h
+++ b/src/widget/form/searchsettingsform.h
@@ -25,13 +25,14 @@
namespace Ui {
class SearchSettingsForm;
}
+class Settings;
class SearchSettingsForm : public QWidget
{
Q_OBJECT
public:
- explicit SearchSettingsForm(QWidget *parent = nullptr);
+ explicit SearchSettingsForm(Settings&, QWidget *parent = nullptr);
~SearchSettingsForm();
ParameterSearch getParameterSearch();
@@ -41,6 +42,7 @@ private:
Ui::SearchSettingsForm *ui;
QDate startDate;
bool isUpdate{false};
+ Settings& settings;
void updateStartDateLabel();
void setUpdate(const bool isUpdate_);
diff --git a/src/widget/form/settings/advancedform.cpp b/src/widget/form/settings/advancedform.cpp
index 73cfad0c6..4d2e6d9b4 100644
--- a/src/widget/form/settings/advancedform.cpp
+++ b/src/widget/form/settings/advancedform.cpp
@@ -41,30 +41,30 @@
* Is also contains "Reset settings" button and "Make portable" checkbox.
*/
-AdvancedForm::AdvancedForm()
+AdvancedForm::AdvancedForm(Settings& settings_)
: GenericForm(QPixmap(":/img/settings/general.png"))
, bodyUI(new Ui::AdvancedSettings)
+ , settings{settings_}
{
bodyUI->setupUi(this);
// block all child signals during initialization
const RecursiveSignalBlocker signalBlocker(this);
- Settings& s = Settings::getInstance();
- bodyUI->cbEnableIPv6->setChecked(s.getEnableIPv6());
- bodyUI->cbMakeToxPortable->setChecked(Settings::getInstance().getMakeToxPortable());
- bodyUI->proxyAddr->setText(s.getProxyAddr());
- quint16 port = s.getProxyPort();
+ bodyUI->cbEnableIPv6->setChecked(settings.getEnableIPv6());
+ bodyUI->cbMakeToxPortable->setChecked(settings.getMakeToxPortable());
+ bodyUI->proxyAddr->setText(settings.getProxyAddr());
+ quint16 port = settings.getProxyPort();
if (port > 0) {
bodyUI->proxyPort->setValue(port);
}
- int index = static_cast(s.getProxyType());
+ int index = static_cast(settings.getProxyType());
bodyUI->proxyType->setCurrentIndex(index);
on_proxyType_currentIndexChanged(index);
- const bool udpEnabled = !s.getForceTCP() && (s.getProxyType() == Settings::ProxyType::ptNone);
+ const bool udpEnabled = !settings.getForceTCP() && (settings.getProxyType() == Settings::ProxyType::ptNone);
bodyUI->cbEnableUDP->setChecked(udpEnabled);
- bodyUI->cbEnableLanDiscovery->setChecked(s.getEnableLanDiscovery() && udpEnabled);
+ bodyUI->cbEnableLanDiscovery->setChecked(settings.getEnableLanDiscovery() && udpEnabled);
bodyUI->cbEnableLanDiscovery->setEnabled(udpEnabled);
QString warningBody = tr("Unless you %1 know what you are doing, "
@@ -95,7 +95,7 @@ AdvancedForm::~AdvancedForm()
void AdvancedForm::on_cbMakeToxPortable_stateChanged()
{
- Settings::getInstance().setMakeToxPortable(bodyUI->cbMakeToxPortable->isChecked());
+ settings.setMakeToxPortable(bodyUI->cbMakeToxPortable->isChecked());
}
void AdvancedForm::on_btnExportLog_clicked()
{
@@ -107,7 +107,7 @@ void AdvancedForm::on_btnExportLog_clicked()
return;
}
- QString logFileDir = Settings::getInstance().getPaths().getAppCacheDirPath();
+ QString logFileDir = settings.getPaths().getAppCacheDirPath();
QString logfile = logFileDir + "qtox.log";
QFile file(logfile);
@@ -126,7 +126,7 @@ void AdvancedForm::on_btnExportLog_clicked()
void AdvancedForm::on_btnCopyDebug_clicked()
{
- QString logFileDir = Settings::getInstance().getPaths().getAppCacheDirPath();
+ QString logFileDir = settings.getPaths().getAppCacheDirPath();
QString logfile = logFileDir + "qtox.log";
QFile file(logfile);
@@ -163,32 +163,32 @@ void AdvancedForm::on_resetButton_clicked()
if (!result)
return;
- Settings::getInstance().resetToDefault();
+ settings.resetToDefault();
GUI::showInfo(titile, "Changes will take effect after restart");
}
void AdvancedForm::on_cbEnableIPv6_stateChanged()
{
- Settings::getInstance().setEnableIPv6(bodyUI->cbEnableIPv6->isChecked());
+ settings.setEnableIPv6(bodyUI->cbEnableIPv6->isChecked());
}
void AdvancedForm::on_cbEnableUDP_stateChanged()
{
const bool enableUdp = bodyUI->cbEnableUDP->isChecked();
- Settings::getInstance().setForceTCP(!enableUdp);
- const bool enableLanDiscovery = Settings::getInstance().getEnableLanDiscovery();
+ settings.setForceTCP(!enableUdp);
+ const bool enableLanDiscovery = settings.getEnableLanDiscovery();
bodyUI->cbEnableLanDiscovery->setEnabled(enableUdp);
bodyUI->cbEnableLanDiscovery->setChecked(enableUdp && enableLanDiscovery);
}
void AdvancedForm::on_cbEnableLanDiscovery_stateChanged()
{
- Settings::getInstance().setEnableLanDiscovery(bodyUI->cbEnableLanDiscovery->isChecked());
+ settings.setEnableLanDiscovery(bodyUI->cbEnableLanDiscovery->isChecked());
}
void AdvancedForm::on_proxyAddr_editingFinished()
{
- Settings::getInstance().setProxyAddr(bodyUI->proxyAddr->text());
+ settings.setProxyAddr(bodyUI->proxyAddr->text());
}
void AdvancedForm::on_proxyPort_valueChanged(int port)
@@ -197,7 +197,7 @@ void AdvancedForm::on_proxyPort_valueChanged(int port)
port = 0;
}
- Settings::getInstance().setProxyPort(port);
+ settings.setProxyPort(port);
}
void AdvancedForm::on_proxyType_currentIndexChanged(int index)
@@ -211,7 +211,7 @@ void AdvancedForm::on_proxyType_currentIndexChanged(int index)
bodyUI->cbEnableUDP->setEnabled(!proxyEnabled);
bodyUI->cbEnableUDP->setChecked(!proxyEnabled);
- Settings::getInstance().setProxyType(proxytype);
+ settings.setProxyType(proxytype);
}
/**
diff --git a/src/widget/form/settings/advancedform.h b/src/widget/form/settings/advancedform.h
index 6e14a7d55..304767488 100644
--- a/src/widget/form/settings/advancedform.h
+++ b/src/widget/form/settings/advancedform.h
@@ -22,6 +22,7 @@
#include "genericsettings.h"
class Core;
+class Settings;
namespace Ui {
class AdvancedSettings;
@@ -31,7 +32,7 @@ class AdvancedForm : public GenericForm
{
Q_OBJECT
public:
- AdvancedForm();
+ explicit AdvancedForm(Settings&);
~AdvancedForm();
QString getFormName() final
{
@@ -58,4 +59,5 @@ private:
private:
Ui::AdvancedSettings* bodyUI;
+ Settings& settings;
};
diff --git a/src/widget/form/settings/generalform.cpp b/src/widget/form/settings/generalform.cpp
index 378d85158..0e5178f4e 100644
--- a/src/widget/form/settings/generalform.cpp
+++ b/src/widget/form/settings/generalform.cpp
@@ -96,9 +96,10 @@ QStringList locales = {
*
* This form contains all settings that are not suited to other forms
*/
-GeneralForm::GeneralForm(SettingsWidget* myParent)
+GeneralForm::GeneralForm(SettingsWidget* myParent, Settings& settings_)
: GenericForm(QPixmap(":/img/settings/general.png"))
, bodyUI(new Ui::GeneralSettings)
+ , settings{settings_}
{
parent = myParent;
@@ -107,8 +108,6 @@ GeneralForm::GeneralForm(SettingsWidget* myParent)
// block all child signals during initialization
const RecursiveSignalBlocker signalBlocker(this);
- Settings& s = Settings::getInstance();
-
#ifndef UPDATE_CHECK_ENABLED
bodyUI->checkUpdates->setVisible(false);
#endif
@@ -117,7 +116,7 @@ GeneralForm::GeneralForm(SettingsWidget* myParent)
bodyUI->cbSpellChecking->setVisible(false);
#endif
- bodyUI->checkUpdates->setChecked(s.getCheckUpdates());
+ bodyUI->checkUpdates->setChecked(settings.getCheckUpdates());
for (int i = 0; i < locales.size(); ++i) {
QString langName;
@@ -136,29 +135,29 @@ GeneralForm::GeneralForm(SettingsWidget* myParent)
bodyUI->transComboBox->insertItem(i, langName);
}
- bodyUI->transComboBox->setCurrentIndex(locales.indexOf(s.getTranslation()));
+ bodyUI->transComboBox->setCurrentIndex(locales.indexOf(settings.getTranslation()));
- bodyUI->cbAutorun->setChecked(s.getAutorun());
+ bodyUI->cbAutorun->setChecked(settings.getAutorun());
- bodyUI->cbSpellChecking->setChecked(s.getSpellCheckingEnabled());
- bodyUI->lightTrayIcon->setChecked(s.getLightTrayIcon());
- bool showSystemTray = s.getShowSystemTray();
+ bodyUI->cbSpellChecking->setChecked(settings.getSpellCheckingEnabled());
+ bodyUI->lightTrayIcon->setChecked(settings.getLightTrayIcon());
+ bool showSystemTray = settings.getShowSystemTray();
bodyUI->showSystemTray->setChecked(showSystemTray);
- bodyUI->startInTray->setChecked(s.getAutostartInTray());
+ bodyUI->startInTray->setChecked(settings.getAutostartInTray());
bodyUI->startInTray->setEnabled(showSystemTray);
- bodyUI->minimizeToTray->setChecked(s.getMinimizeToTray());
+ bodyUI->minimizeToTray->setChecked(settings.getMinimizeToTray());
bodyUI->minimizeToTray->setEnabled(showSystemTray);
- bodyUI->closeToTray->setChecked(s.getCloseToTray());
+ bodyUI->closeToTray->setChecked(settings.getCloseToTray());
bodyUI->closeToTray->setEnabled(showSystemTray);
- bodyUI->statusChanges->setChecked(s.getStatusChangeNotificationEnabled());
- bodyUI->groupJoinLeaveMessages->setChecked(s.getShowGroupJoinLeaveMessages());
+ bodyUI->statusChanges->setChecked(settings.getStatusChangeNotificationEnabled());
+ bodyUI->groupJoinLeaveMessages->setChecked(settings.getShowGroupJoinLeaveMessages());
- bodyUI->autoAwaySpinBox->setValue(s.getAutoAwayTime());
- bodyUI->autoSaveFilesDir->setText(s.getGlobalAutoAcceptDir());
- bodyUI->maxAutoAcceptSizeMB->setValue(static_cast(s.getMaxAutoAcceptSize()) / 1024 / 1024);
- bodyUI->autoacceptFiles->setChecked(s.getAutoSaveEnabled());
+ bodyUI->autoAwaySpinBox->setValue(settings.getAutoAwayTime());
+ bodyUI->autoSaveFilesDir->setText(settings.getGlobalAutoAcceptDir());
+ bodyUI->maxAutoAcceptSizeMB->setValue(static_cast(settings.getMaxAutoAcceptSize()) / 1024 / 1024);
+ bodyUI->autoacceptFiles->setChecked(settings.getAutoSaveEnabled());
#ifndef QTOX_PLATFORM_EXT
@@ -179,71 +178,71 @@ GeneralForm::~GeneralForm()
void GeneralForm::on_transComboBox_currentIndexChanged(int index)
{
const QString& locale = locales[index];
- Settings::getInstance().setTranslation(locale);
+ settings.setTranslation(locale);
Translator::translate(locale);
}
void GeneralForm::on_cbAutorun_stateChanged()
{
- Settings::getInstance().setAutorun(bodyUI->cbAutorun->isChecked());
+ settings.setAutorun(bodyUI->cbAutorun->isChecked());
}
void GeneralForm::on_cbSpellChecking_stateChanged()
{
- Settings::getInstance().setSpellCheckingEnabled(bodyUI->cbSpellChecking->isChecked());
+ settings.setSpellCheckingEnabled(bodyUI->cbSpellChecking->isChecked());
}
void GeneralForm::on_showSystemTray_stateChanged()
{
- Settings::getInstance().setShowSystemTray(bodyUI->showSystemTray->isChecked());
- Settings::getInstance().saveGlobal();
+ settings.setShowSystemTray(bodyUI->showSystemTray->isChecked());
+ settings.saveGlobal();
}
void GeneralForm::on_startInTray_stateChanged()
{
- Settings::getInstance().setAutostartInTray(bodyUI->startInTray->isChecked());
+ settings.setAutostartInTray(bodyUI->startInTray->isChecked());
}
void GeneralForm::on_closeToTray_stateChanged()
{
- Settings::getInstance().setCloseToTray(bodyUI->closeToTray->isChecked());
+ settings.setCloseToTray(bodyUI->closeToTray->isChecked());
}
void GeneralForm::on_lightTrayIcon_stateChanged()
{
- Settings::getInstance().setLightTrayIcon(bodyUI->lightTrayIcon->isChecked());
+ settings.setLightTrayIcon(bodyUI->lightTrayIcon->isChecked());
emit updateIcons();
}
void GeneralForm::on_minimizeToTray_stateChanged()
{
- Settings::getInstance().setMinimizeToTray(bodyUI->minimizeToTray->isChecked());
+ settings.setMinimizeToTray(bodyUI->minimizeToTray->isChecked());
}
void GeneralForm::on_statusChanges_stateChanged()
{
- Settings::getInstance().setStatusChangeNotificationEnabled(bodyUI->statusChanges->isChecked());
+ settings.setStatusChangeNotificationEnabled(bodyUI->statusChanges->isChecked());
}
void GeneralForm::on_groupJoinLeaveMessages_stateChanged()
{
- Settings::getInstance().setShowGroupJoinLeaveMessages(bodyUI->groupJoinLeaveMessages->isChecked());
+ settings.setShowGroupJoinLeaveMessages(bodyUI->groupJoinLeaveMessages->isChecked());
}
void GeneralForm::on_autoAwaySpinBox_editingFinished()
{
int minutes = bodyUI->autoAwaySpinBox->value();
- Settings::getInstance().setAutoAwayTime(minutes);
+ settings.setAutoAwayTime(minutes);
}
void GeneralForm::on_autoacceptFiles_stateChanged()
{
- Settings::getInstance().setAutoSaveEnabled(bodyUI->autoacceptFiles->isChecked());
+ settings.setAutoSaveEnabled(bodyUI->autoacceptFiles->isChecked());
}
void GeneralForm::on_autoSaveFilesDir_clicked()
{
- QString previousDir = Settings::getInstance().getGlobalAutoAcceptDir();
+ QString previousDir = settings.getGlobalAutoAcceptDir();
QString directory =
QFileDialog::getExistingDirectory(Q_NULLPTR,
tr("Choose an auto accept directory", "popup title"),
@@ -251,7 +250,7 @@ void GeneralForm::on_autoSaveFilesDir_clicked()
if (directory.isEmpty()) // cancel was pressed
directory = previousDir;
- Settings::getInstance().setGlobalAutoAcceptDir(directory);
+ settings.setGlobalAutoAcceptDir(directory);
bodyUI->autoSaveFilesDir->setText(directory);
}
@@ -260,12 +259,12 @@ void GeneralForm::on_maxAutoAcceptSizeMB_editingFinished()
auto newMaxSizeMB = bodyUI->maxAutoAcceptSizeMB->value();
auto newMaxSizeB = std::lround(newMaxSizeMB * 1024 * 1024);
- Settings::getInstance().setMaxAutoAcceptSize(newMaxSizeB);
+ settings.setMaxAutoAcceptSize(newMaxSizeB);
}
void GeneralForm::on_checkUpdates_stateChanged()
{
- Settings::getInstance().setCheckUpdates(bodyUI->checkUpdates->isChecked());
+ settings.setCheckUpdates(bodyUI->checkUpdates->isChecked());
}
/**
diff --git a/src/widget/form/settings/generalform.h b/src/widget/form/settings/generalform.h
index 9aa6d966a..684b705bf 100644
--- a/src/widget/form/settings/generalform.h
+++ b/src/widget/form/settings/generalform.h
@@ -26,12 +26,13 @@ class GeneralSettings;
}
class SettingsWidget;
+class Settings;
class GeneralForm : public GenericForm
{
Q_OBJECT
public:
- explicit GeneralForm(SettingsWidget* parent);
+ explicit GeneralForm(SettingsWidget* parent, Settings&);
~GeneralForm();
QString getFormName() final
{
@@ -63,4 +64,5 @@ private:
private:
Ui::GeneralSettings* bodyUI;
SettingsWidget* parent;
+ Settings& settings;
};
diff --git a/src/widget/form/settings/privacyform.cpp b/src/widget/form/settings/privacyform.cpp
index 8de2e298e..1817716ec 100644
--- a/src/widget/form/settings/privacyform.cpp
+++ b/src/widget/form/settings/privacyform.cpp
@@ -39,10 +39,11 @@
#include
#include
-PrivacyForm::PrivacyForm(Core* _core)
+PrivacyForm::PrivacyForm(Core* core_, Settings& settings_)
: GenericForm(QPixmap(":/img/settings/privacy.png"))
, bodyUI(new Ui::PrivacySettings)
- , core{_core}
+ , core{core_}
+ , settings{settings_}
{
bodyUI->setupUi(this);
@@ -61,7 +62,7 @@ PrivacyForm::~PrivacyForm()
void PrivacyForm::on_cbKeepHistory_stateChanged()
{
- Settings::getInstance().setEnableLogging(bodyUI->cbKeepHistory->isChecked());
+ settings.setEnableLogging(bodyUI->cbKeepHistory->isChecked());
if (!bodyUI->cbKeepHistory->isChecked()) {
emit clearAllReceipts();
QMessageBox::StandardButton dialogDelHistory;
@@ -77,7 +78,7 @@ void PrivacyForm::on_cbKeepHistory_stateChanged()
void PrivacyForm::on_cbTypingNotification_stateChanged()
{
- Settings::getInstance().setTypingNotification(bodyUI->cbTypingNotification->isChecked());
+ settings.setTypingNotification(bodyUI->cbTypingNotification->isChecked());
}
void PrivacyForm::on_nospamLineEdit_editingFinished()
@@ -93,10 +94,10 @@ void PrivacyForm::on_nospamLineEdit_editingFinished()
void PrivacyForm::showEvent(QShowEvent*)
{
- const Settings& s = Settings::getInstance();
+ const Settings& s = settings;
bodyUI->nospamLineEdit->setText(core->getSelfId().getNoSpamString());
bodyUI->cbTypingNotification->setChecked(s.getTypingNotification());
- bodyUI->cbKeepHistory->setChecked(Settings::getInstance().getEnableLogging());
+ bodyUI->cbKeepHistory->setChecked(settings.getEnableLogging());
bodyUI->blackListTextEdit->setText(s.getBlackList().join('\n'));
}
@@ -125,7 +126,7 @@ void PrivacyForm::on_nospamLineEdit_textChanged()
void PrivacyForm::on_blackListTextEdit_textChanged()
{
const QStringList strlist = bodyUI->blackListTextEdit->toPlainText().split('\n');
- Settings::getInstance().setBlackList(strlist);
+ settings.setBlackList(strlist);
}
void PrivacyForm::retranslateUi()
diff --git a/src/widget/form/settings/privacyform.h b/src/widget/form/settings/privacyform.h
index a1d61f44c..18e45967f 100644
--- a/src/widget/form/settings/privacyform.h
+++ b/src/widget/form/settings/privacyform.h
@@ -22,6 +22,7 @@
#include "genericsettings.h"
class Core;
+class Settings;
namespace Ui {
class PrivacySettings;
@@ -31,7 +32,7 @@ class PrivacyForm : public GenericForm
{
Q_OBJECT
public:
- PrivacyForm(Core* _core);
+ PrivacyForm(Core* core_, Settings&);
~PrivacyForm();
QString getFormName() final
{
@@ -56,4 +57,5 @@ private:
private:
Ui::PrivacySettings* bodyUI;
Core* core;
+ Settings& settings;
};
diff --git a/src/widget/form/settings/userinterfaceform.cpp b/src/widget/form/settings/userinterfaceform.cpp
index 6f5c0feb6..0131856e1 100644
--- a/src/widget/form/settings/userinterfaceform.cpp
+++ b/src/widget/form/settings/userinterfaceform.cpp
@@ -54,9 +54,11 @@
*
* Restores all controls from the settings.
*/
-UserInterfaceForm::UserInterfaceForm(SmileyPack& smileyPack_, SettingsWidget* myParent)
+UserInterfaceForm::UserInterfaceForm(SmileyPack& smileyPack_, Settings& settings_,
+ SettingsWidget* myParent)
: GenericForm(QPixmap(":/img/settings/general.png"))
, smileyPack{smileyPack_}
+ , settings{settings_}
{
parent = myParent;
@@ -66,46 +68,45 @@ UserInterfaceForm::UserInterfaceForm(SmileyPack& smileyPack_, SettingsWidget* my
// block all child signals during initialization
const RecursiveSignalBlocker signalBlocker(this);
- Settings& s = Settings::getInstance();
- const QFont chatBaseFont = s.getChatMessageFont();
+ const QFont chatBaseFont = settings.getChatMessageFont();
bodyUI->txtChatFontSize->setValue(QFontInfo(chatBaseFont).pixelSize());
bodyUI->txtChatFont->setCurrentFont(chatBaseFont);
- int index = static_cast(s.getStylePreference());
+ int index = static_cast(settings.getStylePreference());
bodyUI->textStyleComboBox->setCurrentIndex(index);
- bodyUI->useNameColors->setChecked(s.getEnableGroupChatsColor());
+ bodyUI->useNameColors->setChecked(settings.getEnableGroupChatsColor());
- bodyUI->notify->setChecked(s.getNotify());
+ bodyUI->notify->setChecked(settings.getNotify());
// Note: UI is boolean inversed from settings to maintain setting file backwards compatibility
- bodyUI->groupOnlyNotfiyWhenMentioned->setChecked(!s.getGroupAlwaysNotify());
- bodyUI->groupOnlyNotfiyWhenMentioned->setEnabled(s.getNotify());
- bodyUI->notifySound->setChecked(s.getNotifySound());
- bodyUI->notifyHide->setChecked(s.getNotifyHide());
- bodyUI->notifySound->setEnabled(s.getNotify());
- bodyUI->busySound->setChecked(s.getBusySound());
- bodyUI->busySound->setEnabled(s.getNotifySound() && s.getNotify());
+ bodyUI->groupOnlyNotfiyWhenMentioned->setChecked(!settings.getGroupAlwaysNotify());
+ bodyUI->groupOnlyNotfiyWhenMentioned->setEnabled(settings.getNotify());
+ bodyUI->notifySound->setChecked(settings.getNotifySound());
+ bodyUI->notifyHide->setChecked(settings.getNotifyHide());
+ bodyUI->notifySound->setEnabled(settings.getNotify());
+ bodyUI->busySound->setChecked(settings.getBusySound());
+ bodyUI->busySound->setEnabled(settings.getNotifySound() && settings.getNotify());
#if DESKTOP_NOTIFICATIONS
- bodyUI->desktopNotify->setChecked(s.getDesktopNotify());
- bodyUI->desktopNotify->setEnabled(s.getNotify());
+ bodyUI->desktopNotify->setChecked(settings.getDesktopNotify());
+ bodyUI->desktopNotify->setEnabled(settings.getNotify());
#else
bodyUI->desktopNotify->hide();
#endif
- bodyUI->showWindow->setChecked(s.getShowWindow());
+ bodyUI->showWindow->setChecked(settings.getShowWindow());
- bodyUI->cbGroupchatPosition->setChecked(s.getGroupchatPosition());
- bodyUI->cbCompactLayout->setChecked(s.getCompactLayout());
- bodyUI->cbSeparateWindow->setChecked(s.getSeparateWindow());
- bodyUI->cbDontGroupWindows->setChecked(s.getDontGroupWindows());
- bodyUI->cbDontGroupWindows->setEnabled(s.getSeparateWindow());
- bodyUI->cbShowIdenticons->setChecked(s.getShowIdenticons());
+ bodyUI->cbGroupchatPosition->setChecked(settings.getGroupchatPosition());
+ bodyUI->cbCompactLayout->setChecked(settings.getCompactLayout());
+ bodyUI->cbSeparateWindow->setChecked(settings.getSeparateWindow());
+ bodyUI->cbDontGroupWindows->setChecked(settings.getDontGroupWindows());
+ bodyUI->cbDontGroupWindows->setEnabled(settings.getSeparateWindow());
+ bodyUI->cbShowIdenticons->setChecked(settings.getShowIdenticons());
- bodyUI->useEmoticons->setChecked(s.getUseEmoticons());
+ bodyUI->useEmoticons->setChecked(settings.getUseEmoticons());
for (auto entry : SmileyPack::listSmileyPacks())
bodyUI->smileyPackBrowser->addItem(entry.first, entry.second);
smileLabels = {bodyUI->smile1, bodyUI->smile2, bodyUI->smile3, bodyUI->smile4, bodyUI->smile5};
- int currentPack = bodyUI->smileyPackBrowser->findData(s.getSmileyPack());
+ int currentPack = bodyUI->smileyPackBrowser->findData(settings.getSmileyPack());
bodyUI->smileyPackBrowser->setCurrentIndex(currentPack);
reloadSmileys();
bodyUI->smileyPackBrowser->setEnabled(bodyUI->useEmoticons->isChecked());
@@ -114,8 +115,8 @@ UserInterfaceForm::UserInterfaceForm(SmileyPack& smileyPack_, SettingsWidget* my
bodyUI->styleBrowser->addItems(QStyleFactory::keys());
QString style;
- if (QStyleFactory::keys().contains(s.getStyle()))
- style = s.getStyle();
+ if (QStyleFactory::keys().contains(settings.getStyle()))
+ style = settings.getStyle();
else
style = tr("None");
@@ -124,8 +125,8 @@ UserInterfaceForm::UserInterfaceForm(SmileyPack& smileyPack_, SettingsWidget* my
for (QString color : Style::getThemeColorNames())
bodyUI->themeColorCBox->addItem(color);
- bodyUI->themeColorCBox->setCurrentIndex(s.getThemeColor());
- bodyUI->emoticonSize->setValue(s.getEmojiFontPointSize());
+ bodyUI->themeColorCBox->setCurrentIndex(settings.getThemeColor());
+ bodyUI->emoticonSize->setValue(settings.getEmojiFontPointSize());
QLocale ql;
QStringList timeFormats;
@@ -138,7 +139,7 @@ UserInterfaceForm::UserInterfaceForm(SmileyPack& smileyPack_, SettingsWidget* my
QRegularExpression re(QString("^[^\\n]{0,%0}$").arg(MAX_FORMAT_LENGTH));
QRegularExpressionValidator* validator = new QRegularExpressionValidator(re, this);
- QString timeFormat = s.getTimestampFormat();
+ QString timeFormat = settings.getTimestampFormat();
if (!re.match(timeFormat).hasMatch())
timeFormat = timeFormats[0];
@@ -159,7 +160,7 @@ UserInterfaceForm::UserInterfaceForm(SmileyPack& smileyPack_, SettingsWidget* my
dateFormats.removeDuplicates();
bodyUI->dateFormats->addItems(dateFormats);
- QString dateFormat = s.getDateFormat();
+ QString dateFormat = settings.getDateFormat();
if (!re.match(dateFormat).hasMatch())
dateFormat = dateFormats[0];
@@ -180,9 +181,9 @@ UserInterfaceForm::~UserInterfaceForm()
void UserInterfaceForm::on_styleBrowser_currentIndexChanged(QString style)
{
if (bodyUI->styleBrowser->currentIndex() == 0)
- Settings::getInstance().setStyle("None");
+ settings.setStyle("None");
else
- Settings::getInstance().setStyle(style);
+ settings.setStyle(style);
setStyle(QStyleFactory::create(style));
parent->setBodyHeadStyle(style);
@@ -190,7 +191,7 @@ void UserInterfaceForm::on_styleBrowser_currentIndexChanged(QString style)
void UserInterfaceForm::on_emoticonSize_editingFinished()
{
- Settings::getInstance().setEmojiFontPointSize(bodyUI->emoticonSize->value());
+ settings.setEmojiFontPointSize(bodyUI->emoticonSize->value());
}
void UserInterfaceForm::on_timestamp_editTextChanged(const QString& format)
@@ -198,8 +199,8 @@ void UserInterfaceForm::on_timestamp_editTextChanged(const QString& format)
QString timeExample = QTime::currentTime().toString(format);
bodyUI->timeExample->setText(timeExample);
- Settings::getInstance().setTimestampFormat(format);
- QString locale = Settings::getInstance().getTranslation();
+ settings.setTimestampFormat(format);
+ QString locale = settings.getTranslation();
Translator::translate(locale);
}
@@ -208,14 +209,14 @@ void UserInterfaceForm::on_dateFormats_editTextChanged(const QString& format)
QString dateExample = QDate::currentDate().toString(format);
bodyUI->dateExample->setText(dateExample);
- Settings::getInstance().setDateFormat(format);
- QString locale = Settings::getInstance().getTranslation();
+ settings.setDateFormat(format);
+ QString locale = settings.getTranslation();
Translator::translate(locale);
}
void UserInterfaceForm::on_useEmoticons_stateChanged()
{
- Settings::getInstance().setUseEmoticons(bodyUI->useEmoticons->isChecked());
+ settings.setUseEmoticons(bodyUI->useEmoticons->isChecked());
bodyUI->smileyPackBrowser->setEnabled(bodyUI->useEmoticons->isChecked());
}
@@ -223,13 +224,13 @@ void UserInterfaceForm::on_textStyleComboBox_currentTextChanged()
{
Settings::StyleType styleType =
static_cast(bodyUI->textStyleComboBox->currentIndex());
- Settings::getInstance().setStylePreference(styleType);
+ settings.setStylePreference(styleType);
}
void UserInterfaceForm::on_smileyPackBrowser_currentIndexChanged(int index)
{
QString filename = bodyUI->smileyPackBrowser->itemData(index).toString();
- Settings::getInstance().setSmileyPack(filename);
+ settings.setSmileyPack(filename);
reloadSmileys();
}
@@ -273,7 +274,7 @@ void UserInterfaceForm::reloadSmileys()
void UserInterfaceForm::on_notify_stateChanged()
{
const bool notify = bodyUI->notify->isChecked();
- Settings::getInstance().setNotify(notify);
+ settings.setNotify(notify);
bodyUI->groupOnlyNotfiyWhenMentioned->setEnabled(notify);
bodyUI->notifySound->setEnabled(notify);
bodyUI->busySound->setEnabled(notify && bodyUI->notifySound->isChecked());
@@ -283,64 +284,64 @@ void UserInterfaceForm::on_notify_stateChanged()
void UserInterfaceForm::on_notifySound_stateChanged()
{
const bool notify = bodyUI->notifySound->isChecked();
- Settings::getInstance().setNotifySound(notify);
+ settings.setNotifySound(notify);
bodyUI->busySound->setEnabled(notify);
}
void UserInterfaceForm::on_desktopNotify_stateChanged()
{
const bool notify = bodyUI->desktopNotify->isChecked();
- Settings::getInstance().setDesktopNotify(notify);
+ settings.setDesktopNotify(notify);
}
void UserInterfaceForm::on_busySound_stateChanged()
{
- Settings::getInstance().setBusySound(bodyUI->busySound->isChecked());
+ settings.setBusySound(bodyUI->busySound->isChecked());
}
void UserInterfaceForm::on_showWindow_stateChanged()
{
- Settings::getInstance().setShowWindow(bodyUI->showWindow->isChecked());
+ settings.setShowWindow(bodyUI->showWindow->isChecked());
}
void UserInterfaceForm::on_groupOnlyNotfiyWhenMentioned_stateChanged()
{
// Note: UI is boolean inversed from settings to maintain setting file backwards compatibility
- Settings::getInstance().setGroupAlwaysNotify(!bodyUI->groupOnlyNotfiyWhenMentioned->isChecked());
+ settings.setGroupAlwaysNotify(!bodyUI->groupOnlyNotfiyWhenMentioned->isChecked());
}
void UserInterfaceForm::on_cbCompactLayout_stateChanged()
{
- Settings::getInstance().setCompactLayout(bodyUI->cbCompactLayout->isChecked());
+ settings.setCompactLayout(bodyUI->cbCompactLayout->isChecked());
}
void UserInterfaceForm::on_cbSeparateWindow_stateChanged()
{
bool checked = bodyUI->cbSeparateWindow->isChecked();
bodyUI->cbDontGroupWindows->setEnabled(checked);
- Settings::getInstance().setSeparateWindow(checked);
+ settings.setSeparateWindow(checked);
}
void UserInterfaceForm::on_cbDontGroupWindows_stateChanged()
{
- Settings::getInstance().setDontGroupWindows(bodyUI->cbDontGroupWindows->isChecked());
+ settings.setDontGroupWindows(bodyUI->cbDontGroupWindows->isChecked());
}
void UserInterfaceForm::on_cbGroupchatPosition_stateChanged()
{
- Settings::getInstance().setGroupchatPosition(bodyUI->cbGroupchatPosition->isChecked());
+ settings.setGroupchatPosition(bodyUI->cbGroupchatPosition->isChecked());
}
void UserInterfaceForm::on_cbShowIdenticons_stateChanged()
{
- Settings::getInstance().setShowIdenticons(bodyUI->cbShowIdenticons->isChecked());
+ settings.setShowIdenticons(bodyUI->cbShowIdenticons->isChecked());
}
void UserInterfaceForm::on_themeColorCBox_currentIndexChanged(int)
{
int index = bodyUI->themeColorCBox->currentIndex();
- Settings::getInstance().setThemeColor(index);
- Style::setThemeColor(index);
+ settings.setThemeColor(index);
+ Style::setThemeColor(settings, index);
Style::applyTheme();
}
@@ -356,7 +357,7 @@ void UserInterfaceForm::retranslateUi()
// Restore text style index once translation is complete
bodyUI->textStyleComboBox->setCurrentIndex(
- static_cast(Settings::getInstance().getStylePreference()));
+ static_cast(settings.getStylePreference()));
QStringList colorThemes(Style::getThemeColorNames());
for (int i = 0; i < colorThemes.size(); ++i) {
@@ -374,12 +375,12 @@ void UserInterfaceForm::on_txtChatFont_currentFontChanged(const QFont& f)
if (QFontInfo(tmpFont).pixelSize() != px)
tmpFont.setPixelSize(px);
- Settings::getInstance().setChatMessageFont(tmpFont);
+ settings.setChatMessageFont(tmpFont);
}
void UserInterfaceForm::on_txtChatFontSize_valueChanged(int px)
{
- Settings& s = Settings::getInstance();
+ Settings& s = settings;
QFont tmpFont = s.getChatMessageFont();
const int fontSize = QFontInfo(tmpFont).pixelSize();
@@ -391,10 +392,10 @@ void UserInterfaceForm::on_txtChatFontSize_valueChanged(int px)
void UserInterfaceForm::on_useNameColors_stateChanged(int value)
{
- Settings::getInstance().setEnableGroupChatsColor(value);
+ settings.setEnableGroupChatsColor(value);
}
void UserInterfaceForm::on_notifyHide_stateChanged(int value)
{
- Settings::getInstance().setNotifyHide(value);
+ settings.setNotifyHide(value);
}
diff --git a/src/widget/form/settings/userinterfaceform.h b/src/widget/form/settings/userinterfaceform.h
index f1d228ef7..a75172e02 100644
--- a/src/widget/form/settings/userinterfaceform.h
+++ b/src/widget/form/settings/userinterfaceform.h
@@ -27,6 +27,7 @@
namespace Ui {
class UserInterfaceSettings;
}
+class Settings;
class SmileyPack;
@@ -34,7 +35,7 @@ class UserInterfaceForm : public GenericForm
{
Q_OBJECT
public:
- UserInterfaceForm(SmileyPack&, SettingsWidget* myParent);
+ UserInterfaceForm(SmileyPack&, Settings&, SettingsWidget* myParent);
~UserInterfaceForm();
QString getFormName() final
{
@@ -77,4 +78,5 @@ private:
Ui::UserInterfaceSettings* bodyUI;
const int MAX_FORMAT_LENGTH = 128;
SmileyPack& smileyPack;
+ Settings& settings;
};
diff --git a/src/widget/form/settingswidget.cpp b/src/widget/form/settingswidget.cpp
index 66ea14a6f..1e2ebdd47 100644
--- a/src/widget/form/settingswidget.cpp
+++ b/src/widget/form/settingswidget.cpp
@@ -42,12 +42,13 @@
#include
SettingsWidget::SettingsWidget(UpdateCheck* updateCheck, IAudioControl& audio,
- Core* core, SmileyPack& smileyPack, CameraSource& cameraSource, Widget* parent)
+ Core* core, SmileyPack& smileyPack, CameraSource& cameraSource,
+ Settings& settings, Widget* parent)
: QWidget(parent, Qt::Window)
{
CoreAV* coreAV = core->getAv();
- IAudioSettings* audioSettings = &Settings::getInstance();
- IVideoSettings* videoSettings = &Settings::getInstance();
+ IAudioSettings* audioSettings = &settings;
+ IVideoSettings* videoSettings = &settings;
setAttribute(Qt::WA_DeleteOnClose);
@@ -57,16 +58,16 @@ SettingsWidget::SettingsWidget(UpdateCheck* updateCheck, IAudioControl& audio,
settingsWidgets->setTabPosition(QTabWidget::North);
bodyLayout->addWidget(settingsWidgets.get());
- std::unique_ptr gfrm(new GeneralForm(this));
+ std::unique_ptr gfrm(new GeneralForm(this, settings));
connect(gfrm.get(), &GeneralForm::updateIcons, parent, &Widget::updateIcons);
- std::unique_ptr uifrm(new UserInterfaceForm(smileyPack, this));
- std::unique_ptr pfrm(new PrivacyForm(core));
+ std::unique_ptr uifrm(new UserInterfaceForm(smileyPack, settings, this));
+ std::unique_ptr pfrm(new PrivacyForm(core, settings));
connect(pfrm.get(), &PrivacyForm::clearAllReceipts, parent, &Widget::clearAllReceipts);
AVForm* rawAvfrm = new AVForm(audio, coreAV, cameraSource, audioSettings, videoSettings);
std::unique_ptr avfrm(rawAvfrm);
- std::unique_ptr expfrm(new AdvancedForm());
+ std::unique_ptr expfrm(new AdvancedForm(settings));
std::unique_ptr abtfrm(new AboutForm(updateCheck));
#if UPDATE_CHECK_ENABLED
diff --git a/src/widget/form/settingswidget.h b/src/widget/form/settingswidget.h
index 66cbe1cb1..a91581957 100644
--- a/src/widget/form/settingswidget.h
+++ b/src/widget/form/settingswidget.h
@@ -40,12 +40,14 @@ class UpdateCheck;
class Widget;
class SmileyPack;
class CameraSource;
+class Settings;
class SettingsWidget : public QWidget
{
Q_OBJECT
public:
- SettingsWidget(UpdateCheck* updateCheck, IAudioControl& audio, Core *core, SmileyPack&, CameraSource&, Widget* parent = nullptr);
+ SettingsWidget(UpdateCheck* updateCheck, IAudioControl& audio, Core *core,
+ SmileyPack&, CameraSource&, Settings&, Widget* parent = nullptr);
~SettingsWidget();
bool isShown() const;
diff --git a/src/widget/friendlistwidget.cpp b/src/widget/friendlistwidget.cpp
index bc894992c..a6cb344f5 100644
--- a/src/widget/friendlistwidget.cpp
+++ b/src/widget/friendlistwidget.cpp
@@ -85,9 +85,9 @@ Time getTimeBucket(const QDateTime& date)
return Time::LongAgo;
}
-QDateTime getActiveTimeFriend(const Friend* contact)
+QDateTime getActiveTimeFriend(const Friend* contact, Settings& settings)
{
- return Settings::getInstance().getFriendActivity(contact->getPublicKey());
+ return settings.getFriendActivity(contact->getPublicKey());
}
qint64 timeUntilTomorrow()
@@ -99,9 +99,11 @@ qint64 timeUntilTomorrow()
}
} // namespace
-FriendListWidget::FriendListWidget(const Core &_core, Widget* parent, bool groupsOnTop)
+FriendListWidget::FriendListWidget(const Core &core_, Widget* parent,
+ Settings& settings_, bool groupsOnTop)
: QWidget(parent)
- , core{_core}
+ , core{core_}
+ , settings{settings_}
{
int countContacts = core.getFriendList().size();
manager = new FriendListManager(countContacts, this);
@@ -114,7 +116,7 @@ FriendListWidget::FriendListWidget(const Core &_core, Widget* parent, bool group
listLayout->setSpacing(0);
listLayout->setMargin(0);
- mode = Settings::getInstance().getFriendSortingMode();
+ mode = settings.getFriendSortingMode();
dayTimer = new QTimer(this);
dayTimer->setTimerType(Qt::VeryCoarseTimer);
@@ -126,7 +128,7 @@ FriendListWidget::FriendListWidget(const Core &_core, Widget* parent, bool group
FriendListWidget::~FriendListWidget()
{
- for (int i = 0; i < Settings::getInstance().getCircleCount(); ++i) {
+ for (int i = 0; i < settings.getCircleCount(); ++i) {
CircleWidget* circle = CircleWidget::getFromID(i);
delete circle;
}
@@ -138,7 +140,7 @@ void FriendListWidget::setMode(SortingMode mode_)
return;
mode = mode_;
- Settings::getInstance().setFriendSortingMode(mode);
+ settings.setFriendSortingMode(mode);
manager->setSortRequired();
}
@@ -153,7 +155,7 @@ void FriendListWidget::sortByMode()
cleanMainLayout();
- for (int i = 0; i < Settings::getInstance().getCircleCount(); ++i) {
+ for (int i = 0; i < settings.getCircleCount(); ++i) {
addCircleWidget(i);
}
@@ -188,7 +190,7 @@ void FriendListWidget::sortByMode()
if (!manager->needHideCircles()) {
//Sorts circles alphabetically and adds them to the layout
QVector circles;
- for (int i = 0; i < Settings::getInstance().getCircleCount(); ++i) {
+ for (int i = 0; i < settings.getCircleCount(); ++i) {
circles.push_back(CircleWidget::getFromID(i));
}
@@ -215,7 +217,7 @@ void FriendListWidget::sortByMode()
}
cleanMainLayout();
- QLocale ql(Settings::getInstance().getTranslation());
+ QLocale ql(settings.getTranslation());
QDate today = QDate::currentDate();
#define COMMENT "Category for sorting friends by activity"
// clang-format off
@@ -242,9 +244,9 @@ void FriendListWidget::sortByMode()
}
activityLayout = new QVBoxLayout();
- bool compact = Settings::getInstance().getCompactLayout();
+ bool compact = settings.getCompactLayout();
for (Time t : names.keys()) {
- CategoryWidget* category = new CategoryWidget(compact, this);
+ CategoryWidget* category = new CategoryWidget(compact, settings, this);
category->setName(names[t]);
activityLayout->addWidget(category);
}
@@ -336,7 +338,7 @@ FriendListWidget::getItemsFromCircle(CircleWidget *circle) const
CategoryWidget* FriendListWidget::getTimeCategoryWidget(const Friend* frd) const
{
- const auto activityTime = getActiveTimeFriend(frd);
+ const auto activityTime = getActiveTimeFriend(frd, settings);
int timeIndex = static_cast(getTimeBucket(activityTime));
QWidget* widget = activityLayout->itemAt(timeIndex)->widget();
return qobject_cast(widget);
@@ -371,7 +373,7 @@ void FriendListWidget::removeGroupWidget(GroupWidget* w)
void FriendListWidget::removeFriendWidget(FriendWidget* w)
{
const Friend* contact = w->getFriend();
- int id = Settings::getInstance().getFriendCircleID(contact->getPublicKey());
+ int id = settings.getFriendCircleID(contact->getPublicKey());
CircleWidget* circleWidget = CircleWidget::getFromID(id);
if (circleWidget != nullptr) {
circleWidget->removeFriendWidget(w, contact->getStatus());
@@ -454,7 +456,7 @@ void FriendListWidget::cycleContacts(GenericChatroomWidget* activeChatroomWidget
return;
}
- const auto activityTime = getActiveTimeFriend(friendWidget->getFriend());
+ const auto activityTime = getActiveTimeFriend(friendWidget->getFriend(), settings);
index = static_cast(getTimeBucket(activityTime));
QWidget* widget_ = activityLayout->itemAt(index)->widget();
CategoryWidget* categoryWidget = qobject_cast(widget_);
@@ -541,7 +543,7 @@ void FriendListWidget::dropEvent(QDropEvent* event)
return;
// Save CircleWidget before changing the Id
- int circleId = Settings::getInstance().getFriendCircleID(f->getPublicKey());
+ int circleId = settings.getFriendCircleID(f->getPublicKey());
CircleWidget* circleWidget = CircleWidget::getFromID(circleId);
moveWidget(widget, f->getStatus(), true);
@@ -568,12 +570,12 @@ void FriendListWidget::moveWidget(FriendWidget* widget, Status::Status s, bool a
{
if (mode == SortingMode::Name) {
const Friend* f = widget->getFriend();
- int circleId = Settings::getInstance().getFriendCircleID(f->getPublicKey());
+ int circleId = settings.getFriendCircleID(f->getPublicKey());
CircleWidget* circleWidget = CircleWidget::getFromID(circleId);
if (circleWidget == nullptr || add) {
if (circleId != -1) {
- Settings::getInstance().setFriendCircleID(f->getPublicKey(), -1);
+ settings.setFriendCircleID(f->getPublicKey(), -1);
manager->setSortRequired();
} else {
itemsChanged();
@@ -607,13 +609,13 @@ void FriendListWidget::updateActivityTime(const QDateTime& time)
CircleWidget* FriendListWidget::createCircleWidget(int id)
{
if (id == -1)
- id = Settings::getInstance().addCircle();
+ id = settings.addCircle();
if (CircleWidget::getFromID(id) != nullptr) {
return CircleWidget::getFromID(id);
}
- CircleWidget* circleWidget = new CircleWidget(core, this, id);
+ CircleWidget* circleWidget = new CircleWidget(core, this, id, settings);
emit connectCircleWidget(*circleWidget);
connect(this, &FriendListWidget::onCompactChanged, circleWidget, &CircleWidget::onCompactChanged);
connect(circleWidget, &CircleWidget::renameRequested, this, &FriendListWidget::renameCircleWidget);
diff --git a/src/widget/friendlistwidget.h b/src/widget/friendlistwidget.h
index 33717ed55..afa18fee9 100644
--- a/src/widget/friendlistwidget.h
+++ b/src/widget/friendlistwidget.h
@@ -38,13 +38,14 @@ class GenericChatroomWidget;
class CategoryWidget;
class Friend;
class IFriendListItem;
+class Settings;
class FriendListWidget : public QWidget
{
Q_OBJECT
public:
using SortingMode = Settings::FriendListSortingMode;
- explicit FriendListWidget(const Core& _core, Widget* parent, bool groupsOnTop = true);
+ FriendListWidget(const Core&, Widget* parent, Settings&, bool groupsOnTop = true);
~FriendListWidget();
void setMode(SortingMode mode);
SortingMode getMode() const;
@@ -97,4 +98,5 @@ private:
FriendListManager* manager;
const Core& core;
+ Settings& settings;
};
diff --git a/src/widget/friendwidget.cpp b/src/widget/friendwidget.cpp
index 124af4e7a..472d9fb26 100644
--- a/src/widget/friendwidget.cpp
+++ b/src/widget/friendwidget.cpp
@@ -56,10 +56,11 @@
* For example, used on friend list.
* When you click should open the chat with friend. Widget has a context menu.
*/
-FriendWidget::FriendWidget(std::shared_ptr chatroom_, bool compact_)
- : GenericChatroomWidget(compact_)
+FriendWidget::FriendWidget(std::shared_ptr chatroom_, bool compact_, Settings& settings_)
+ : GenericChatroomWidget(compact_, settings_)
, chatroom{chatroom_}
, isDefaultAvatar{true}
+ , settings{settings_}
{
avatar->setPixmap(QPixmap(":/img/contact.svg"));
statusPic.setPixmap(QPixmap(Status::getIconPath(Status::Status::Offline)));
@@ -188,10 +189,11 @@ void FriendWidget::removeChatWindow()
namespace {
-std::tuple getCircleAndFriendList(const Friend* frnd, FriendWidget* fw)
+std::tuple getCircleAndFriendList(const Friend* frnd,
+ FriendWidget* fw, Settings& settings)
{
const auto pk = frnd->getPublicKey();
- const auto circleId = Settings::getInstance().getFriendCircleID(pk);
+ const auto circleId = settings.getFriendCircleID(pk);
auto circleWidget = CircleWidget::getFromID(circleId);
auto w = circleWidget ? static_cast(circleWidget) : static_cast(fw);
auto friendList = qobject_cast(w->parentWidget());
@@ -205,7 +207,7 @@ void FriendWidget::moveToNewCircle()
const auto frnd = chatroom->getFriend();
CircleWidget* circleWidget;
FriendListWidget* friendList;
- std::tie(circleWidget, friendList) = getCircleAndFriendList(frnd, this);
+ std::tie(circleWidget, friendList) = getCircleAndFriendList(frnd, this, settings);
if (circleWidget != nullptr) {
circleWidget->updateStatus();
@@ -215,7 +217,7 @@ void FriendWidget::moveToNewCircle()
friendList->addCircleWidget(this);
} else {
const auto pk = frnd->getPublicKey();
- auto& s = Settings::getInstance();
+ auto& s = settings;
auto circleId = s.addCircle();
s.setFriendCircleID(pk, circleId);
}
@@ -226,13 +228,13 @@ void FriendWidget::removeFromCircle()
const auto frnd = chatroom->getFriend();
CircleWidget* circleWidget;
FriendListWidget* friendList;
- std::tie(circleWidget, friendList) = getCircleAndFriendList(frnd, this);
+ std::tie(circleWidget, friendList) = getCircleAndFriendList(frnd, this, settings);
if (friendList != nullptr) {
friendList->moveWidget(this, frnd->getStatus(), true);
} else {
const auto pk = frnd->getPublicKey();
- auto& s = Settings::getInstance();
+ auto& s = settings;
s.setFriendCircleID(pk, -1);
}
@@ -245,8 +247,8 @@ void FriendWidget::moveToCircle(int newCircleId)
{
const auto frnd = chatroom->getFriend();
const auto pk = frnd->getPublicKey();
- const auto oldCircleId = Settings::getInstance().getFriendCircleID(pk);
- auto& s = Settings::getInstance();
+ const auto oldCircleId = settings.getFriendCircleID(pk);
+ auto& s = settings;
auto oldCircleWidget = CircleWidget::getFromID(oldCircleId);
auto newCircleWidget = CircleWidget::getFromID(newCircleId);
@@ -279,9 +281,9 @@ void FriendWidget::changeAutoAccept(bool enable)
void FriendWidget::showDetails()
{
const auto frnd = chatroom->getFriend();
- const auto iabout = new AboutFriend(frnd, &Settings::getInstance());
+ const auto iabout = new AboutFriend(frnd, &settings);
std::unique_ptr about = std::unique_ptr(iabout);
- const auto aboutUser = new AboutFriendForm(std::move(about), this);
+ const auto aboutUser = new AboutFriendForm(std::move(about), settings, this);
connect(aboutUser, &AboutFriendForm::histroyRemoved, this, &FriendWidget::friendHistoryRemoved);
aboutUser->show();
}
@@ -313,7 +315,7 @@ void FriendWidget::updateStatusLight()
statusPic.setPixmap(QPixmap(Status::getIconPath(frnd->getStatus(), event)));
if (event) {
- const Settings& s = Settings::getInstance();
+ const Settings& s = settings;
const uint32_t circleId = s.getFriendCircleID(frnd->getPublicKey());
CircleWidget* circleWidget = CircleWidget::getFromID(circleId);
if (circleWidget) {
@@ -383,7 +385,7 @@ QString FriendWidget::getNameItem() const
QDateTime FriendWidget::getLastActivity() const
{
const auto frnd = chatroom->getFriend();
- return Settings::getInstance().getFriendActivity(frnd->getPublicKey());
+ return settings.getFriendActivity(frnd->getPublicKey());
}
QWidget *FriendWidget::getWidget()
diff --git a/src/widget/friendwidget.h b/src/widget/friendwidget.h
index 10ba1465e..c188350ec 100644
--- a/src/widget/friendwidget.h
+++ b/src/widget/friendwidget.h
@@ -29,12 +29,13 @@ class FriendChatroom;
class QPixmap;
class MaskablePixmapWidget;
class CircleWidget;
+class Settings;
class FriendWidget : public GenericChatroomWidget, public IFriendListItem
{
Q_OBJECT
public:
- FriendWidget(std::shared_ptr chatform_, bool compact_);
+ FriendWidget(std::shared_ptr chatform_, bool compact_, Settings&);
void contextMenuEvent(QContextMenuEvent* event) final;
void setAsActiveChatroom() final;
@@ -85,4 +86,5 @@ private slots:
public:
std::shared_ptr chatroom;
bool isDefaultAvatar;
+ Settings& settings;
};
diff --git a/src/widget/genericchatroomwidget.cpp b/src/widget/genericchatroomwidget.cpp
index f70db1709..e1acaa267 100644
--- a/src/widget/genericchatroomwidget.cpp
+++ b/src/widget/genericchatroomwidget.cpp
@@ -25,9 +25,10 @@
#include
#include
-GenericChatroomWidget::GenericChatroomWidget(bool compact_, QWidget* parent)
+GenericChatroomWidget::GenericChatroomWidget(bool compact_, Settings& settings_, QWidget* parent)
: GenericChatItemWidget(compact_, parent)
, active{false}
+ , settings{settings_}
{
// avatar
QSize size;
@@ -47,8 +48,7 @@ GenericChatroomWidget::GenericChatroomWidget(bool compact_, QWidget* parent)
nameLabel->setForegroundRole(QPalette::WindowText);
nameLabel->setObjectName("nameLabelObj");
- Settings& s = Settings::getInstance();
- connect(&s, &Settings::compactLayoutChanged, this, &GenericChatroomWidget::compactChange);
+ connect(&settings, &Settings::compactLayoutChanged, this, &GenericChatroomWidget::compactChange);
setAutoFillBackground(true);
reloadTheme();
@@ -158,7 +158,7 @@ QString GenericChatroomWidget::getTitle() const
void GenericChatroomWidget::reloadTheme()
{
- setStyleSheet(Style::getStylesheet("genericChatRoomWidget/genericChatRoomWidget.css"));
+ setStyleSheet(Style::getStylesheet("genericChatRoomWidget/genericChatRoomWidget.css", settings));
}
void GenericChatroomWidget::activate()
diff --git a/src/widget/genericchatroomwidget.h b/src/widget/genericchatroomwidget.h
index 42a4c38bf..031a1378c 100644
--- a/src/widget/genericchatroomwidget.h
+++ b/src/widget/genericchatroomwidget.h
@@ -29,11 +29,13 @@ class ContentLayout;
class Friend;
class Group;
class Contact;
+class Settings;
+
class GenericChatroomWidget : public GenericChatItemWidget
{
Q_OBJECT
public:
- explicit GenericChatroomWidget(bool compact, QWidget* parent = nullptr);
+ explicit GenericChatroomWidget(bool compact, Settings&, QWidget* parent = nullptr);
public slots:
virtual void setAsActiveChatroom() = 0;
@@ -83,4 +85,5 @@ protected:
MaskablePixmapWidget* avatar;
CroppingLabel* statusMessageLabel;
bool active;
+ Settings& settings;
};
diff --git a/src/widget/groupwidget.cpp b/src/widget/groupwidget.cpp
index 8cdf00852..2d0b394da 100644
--- a/src/widget/groupwidget.cpp
+++ b/src/widget/groupwidget.cpp
@@ -41,8 +41,8 @@
#include "src/widget/widget.h"
#include "tool/croppinglabel.h"
-GroupWidget::GroupWidget(std::shared_ptr chatroom_, bool compact_)
- : GenericChatroomWidget(compact_)
+GroupWidget::GroupWidget(std::shared_ptr chatroom_, bool compact_, Settings& settings_)
+ : GenericChatroomWidget(compact_, settings_)
, groupId{chatroom_->getGroup()->getPersistentId()}
, chatroom{chatroom_}
{
diff --git a/src/widget/groupwidget.h b/src/widget/groupwidget.h
index 4f69643be..a63197556 100644
--- a/src/widget/groupwidget.h
+++ b/src/widget/groupwidget.h
@@ -27,11 +27,13 @@
#include
+class Settings;
+
class GroupWidget final : public GenericChatroomWidget, public IFriendListItem
{
Q_OBJECT
public:
- GroupWidget(std::shared_ptr chatroom_, bool compact);
+ GroupWidget(std::shared_ptr chatroom_, bool compact, Settings&);
~GroupWidget();
void setAsInactiveChatroom() final;
void setAsActiveChatroom() final;
diff --git a/src/widget/loginscreen.cpp b/src/widget/loginscreen.cpp
index 369e187e9..29fc5dd82 100644
--- a/src/widget/loginscreen.cpp
+++ b/src/widget/loginscreen.cpp
@@ -27,15 +27,18 @@
#include "src/widget/style.h"
#include "src/widget/tool/profileimporter.h"
#include "src/widget/translator.h"
+#include "src/persistence/settings.h"
#include
#include
#include
#include
-LoginScreen::LoginScreen(const QString& initialProfileName, QWidget* parent)
+LoginScreen::LoginScreen(Settings& settings_, const QString& initialProfileName,
+ QWidget* parent)
: QDialog(parent)
, ui(new Ui::LoginScreen)
, quitShortcut{QKeySequence(Qt::CTRL + Qt::Key_Q), this}
+ , settings{settings_}
{
ui->setupUi(this);
@@ -60,7 +63,7 @@ LoginScreen::LoginScreen(const QString& initialProfileName, QWidget* parent)
connect(ui->importButton, &QPushButton::clicked, this, &LoginScreen::onImportProfile);
reset(initialProfileName);
- setStyleSheet(Style::getStylesheet("loginScreen/loginScreen.css"));
+ setStyleSheet(Style::getStylesheet("loginScreen/loginScreen.css", settings));
retranslateUi();
Translator::registerHandler(std::bind(&LoginScreen::retranslateUi, this), this);
@@ -83,7 +86,7 @@ void LoginScreen::reset(const QString& initialProfileName)
ui->loginPassword->clear();
ui->loginUsernames->clear();
- QStringList allProfileNames = Profile::getAllProfileNames();
+ QStringList allProfileNames = Profile::getAllProfileNames(settings);
if (allProfileNames.isEmpty()) {
ui->stackedWidget->setCurrentIndex(0);
@@ -166,7 +169,7 @@ void LoginScreen::onCreateNewProfile()
return;
}
- if (Profile::exists(name)) {
+ if (Profile::exists(name, settings.getPaths())) {
QMessageBox::critical(this, tr("Couldn't create a new profile"),
tr("A profile with this name already exists."));
return;
@@ -181,7 +184,7 @@ void LoginScreen::onLoginUsernameSelected(const QString& name)
return;
ui->loginPassword->clear();
- if (Profile::isEncrypted(name)) {
+ if (Profile::isEncrypted(name, settings.getPaths())) {
ui->loginPasswordLabel->show();
ui->loginPassword->show();
// there is no way to do autologin if profile is encrypted, and
@@ -210,7 +213,7 @@ void LoginScreen::onLogin()
return;
}
- if (!ProfileLocker::isLockable(name)) {
+ if (!ProfileLocker::isLockable(name, settings.getPaths())) {
QMessageBox::critical(this, tr("Couldn't load this profile"),
tr("This profile is already in use."));
return;
@@ -237,7 +240,7 @@ void LoginScreen::retranslateUi()
void LoginScreen::onImportProfile()
{
- ProfileImporter pi(this);
+ ProfileImporter pi(settings, this);
if (pi.importProfile()) {
reset();
}
diff --git a/src/widget/loginscreen.h b/src/widget/loginscreen.h
index e0063d42d..beaed6a79 100644
--- a/src/widget/loginscreen.h
+++ b/src/widget/loginscreen.h
@@ -25,6 +25,7 @@
#include
class Profile;
+class Settings;
namespace Ui {
class LoginScreen;
@@ -35,7 +36,7 @@ class LoginScreen : public QDialog
Q_OBJECT
public:
- LoginScreen(const QString& initialProfileName = QString(), QWidget* parent = nullptr);
+ LoginScreen(Settings&, const QString& initialProfileName = QString(), QWidget* parent = nullptr);
~LoginScreen();
bool event(QEvent* event) final;
@@ -73,4 +74,5 @@ private:
private:
Ui::LoginScreen* ui;
QShortcut quitShortcut;
+ Settings& settings;
};
diff --git a/src/widget/notificationedgewidget.cpp b/src/widget/notificationedgewidget.cpp
index dc7cc2a41..432c00f20 100644
--- a/src/widget/notificationedgewidget.cpp
+++ b/src/widget/notificationedgewidget.cpp
@@ -19,16 +19,17 @@
#include "notificationedgewidget.h"
#include "style.h"
+#include "src/persistence/settings.h"
#include
#include
#include
-NotificationEdgeWidget::NotificationEdgeWidget(Position position, QWidget* parent)
+NotificationEdgeWidget::NotificationEdgeWidget(Position position, Settings& settings, QWidget* parent)
: QWidget(parent)
{
setAttribute(Qt::WA_StyledBackground); // Show background.
- setStyleSheet(Style::getStylesheet("notificationEdge/notificationEdge.css"));
+ setStyleSheet(Style::getStylesheet("notificationEdge/notificationEdge.css", settings));
QHBoxLayout* layout = new QHBoxLayout(this);
layout->addStretch();
@@ -39,9 +40,9 @@ NotificationEdgeWidget::NotificationEdgeWidget(Position position, QWidget* paren
QLabel* arrowLabel = new QLabel(this);
if (position == Top)
- arrowLabel->setPixmap(QPixmap(Style::getImagePath("chatArea/scrollBarUpArrow.svg")));
+ arrowLabel->setPixmap(QPixmap(Style::getImagePath("chatArea/scrollBarUpArrow.svg", settings)));
else
- arrowLabel->setPixmap(QPixmap(Style::getImagePath("chatArea/scrollBarDownArrow.svg")));
+ arrowLabel->setPixmap(QPixmap(Style::getImagePath("chatArea/scrollBarDownArrow.svg", settings)));
layout->addWidget(arrowLabel);
layout->addStretch();
diff --git a/src/widget/notificationedgewidget.h b/src/widget/notificationedgewidget.h
index 149d0633c..5b286885c 100644
--- a/src/widget/notificationedgewidget.h
+++ b/src/widget/notificationedgewidget.h
@@ -22,6 +22,7 @@
#include
class QLabel;
+class Settings;
class NotificationEdgeWidget final : public QWidget
{
@@ -33,7 +34,7 @@ public:
Bottom
};
- explicit NotificationEdgeWidget(Position position, QWidget* parent = nullptr);
+ NotificationEdgeWidget(Position position, Settings&, QWidget* parent = nullptr);
void updateNotificationCount(int count);
signals:
diff --git a/src/widget/notificationscrollarea.cpp b/src/widget/notificationscrollarea.cpp
index 60742c1c6..4d86f2014 100644
--- a/src/widget/notificationscrollarea.cpp
+++ b/src/widget/notificationscrollarea.cpp
@@ -31,7 +31,7 @@ NotificationScrollArea::NotificationScrollArea(QWidget* parent)
&NotificationScrollArea::updateVisualTracking);
}
-void NotificationScrollArea::trackWidget(GenericChatroomWidget* widget)
+void NotificationScrollArea::trackWidget(Settings& settings, GenericChatroomWidget* widget)
{
if (trackedWidgets.find(widget) != trackedWidgets.end())
return;
@@ -41,7 +41,7 @@ void NotificationScrollArea::trackWidget(GenericChatroomWidget* widget)
if (visibility == Above) {
if (referencesAbove++ == 0) {
assert(topEdge == nullptr);
- topEdge = new NotificationEdgeWidget(NotificationEdgeWidget::Top, this);
+ topEdge = new NotificationEdgeWidget(NotificationEdgeWidget::Top, settings, this);
connect(topEdge, &NotificationEdgeWidget::clicked, this,
&NotificationScrollArea::findPreviousWidget);
recalculateTopEdge();
@@ -51,7 +51,7 @@ void NotificationScrollArea::trackWidget(GenericChatroomWidget* widget)
} else {
if (referencesBelow++ == 0) {
assert(bottomEdge == nullptr);
- bottomEdge = new NotificationEdgeWidget(NotificationEdgeWidget::Bottom, this);
+ bottomEdge = new NotificationEdgeWidget(NotificationEdgeWidget::Bottom, settings, this);
connect(bottomEdge, &NotificationEdgeWidget::clicked, this,
&NotificationScrollArea::findNextWidget);
recalculateBottomEdge();
diff --git a/src/widget/notificationscrollarea.h b/src/widget/notificationscrollarea.h
index c6cd76dd1..ffbbb6456 100644
--- a/src/widget/notificationscrollarea.h
+++ b/src/widget/notificationscrollarea.h
@@ -24,6 +24,7 @@
class GenericChatroomWidget;
class NotificationEdgeWidget;
+class Settings;
class NotificationScrollArea final : public AdjustingScrollArea
{
@@ -31,7 +32,7 @@ public:
explicit NotificationScrollArea(QWidget* parent = nullptr);
public slots:
- void trackWidget(GenericChatroomWidget* widget);
+ void trackWidget(Settings& settings, GenericChatroomWidget* widget);
void updateVisualTracking();
void updateTracking(GenericChatroomWidget* widget);
diff --git a/src/widget/searchform.cpp b/src/widget/searchform.cpp
index d9f29482d..1448d6370 100644
--- a/src/widget/searchform.cpp
+++ b/src/widget/searchform.cpp
@@ -36,7 +36,9 @@ static std::array STATE_NAME = {
QStringLiteral("red"),
};
-SearchForm::SearchForm(QWidget* parent) : QWidget(parent)
+SearchForm::SearchForm(Settings& settings_, QWidget* parent)
+ : QWidget(parent)
+ , settings{settings_}
{
QVBoxLayout* layout = new QVBoxLayout();
QHBoxLayout* layoutNavigation = new QHBoxLayout();
@@ -44,12 +46,12 @@ SearchForm::SearchForm(QWidget* parent) : QWidget(parent)
QSpacerItem *lSpacer = new QSpacerItem(20, 20, QSizePolicy::Expanding, QSizePolicy::Ignored);
QSpacerItem *rSpacer = new QSpacerItem(20, 20, QSizePolicy::Expanding, QSizePolicy::Ignored);
searchLine = new LineEdit();
- settings = new SearchSettingsForm();
+ searchSettingsForm = new SearchSettingsForm(settings);
messageLabel = new QLabel();
- settings->setVisible(false);
+ searchSettingsForm->setVisible(false);
messageLabel->setProperty("state", QStringLiteral("red"));
- messageLabel->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/labels.css")));
+ messageLabel->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/labels.css"),settings));
messageLabel->setText(tr("The text could not be found."));
messageLabel->setVisible(false);
@@ -69,7 +71,7 @@ SearchForm::SearchForm(QWidget* parent) : QWidget(parent)
layoutNavigation->addWidget(hideButton);
layout->addLayout(layoutNavigation);
- layout->addWidget(settings);
+ layout->addWidget(searchSettingsForm);
layoutMessage->addSpacerItem(lSpacer);
layoutMessage->addWidget(messageLabel);
@@ -91,7 +93,7 @@ SearchForm::SearchForm(QWidget* parent) : QWidget(parent)
connect(startButton, &QPushButton::clicked, this, &SearchForm::clickedStart);
connect(settingsButton, &QPushButton::clicked, this, &SearchForm::clickedSearch);
- connect(settings, &SearchSettingsForm::updateSettings, this, &SearchForm::changedState);
+ connect(searchSettingsForm, &SearchSettingsForm::updateSettings, this, &SearchForm::changedState);
connect(&GUI::getInstance(), &GUI::themeReload, this, &SearchForm::reloadTheme);
}
@@ -123,13 +125,13 @@ void SearchForm::insertEditor(const QString &text)
void SearchForm::reloadTheme()
{
- settingsButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
- upButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
- downButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
- hideButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
- startButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
+ settingsButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
+ upButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
+ downButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
+ hideButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
+ startButton->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
- settings->reloadTheme();
+ searchSettingsForm->reloadTheme();
}
void SearchForm::showEvent(QShowEvent* event)
@@ -144,7 +146,7 @@ QPushButton *SearchForm::createButton(const QString& name, const QString& state)
btn->setAttribute(Qt::WA_LayoutUsesWidgetRect);
btn->setObjectName(name);
btn->setProperty("state", state);
- btn->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
+ btn->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
return btn;
}
@@ -152,7 +154,7 @@ QPushButton *SearchForm::createButton(const QString& name, const QString& state)
ParameterSearch SearchForm::getAndCheckParametrSearch()
{
if (isActiveSettings) {
- auto sendParam = settings->getParameterSearch();
+ auto sendParam = searchSettingsForm->getParameterSearch();
if (!isChangedPhrase && !sendParam.isUpdate) {
sendParam.period = PeriodSearch::None;
}
@@ -170,7 +172,7 @@ void SearchForm::setStateName(QPushButton *btn, ToolButtonState state)
{
const auto index = static_cast(state);
btn->setProperty("state", STATE_NAME[index]);
- btn->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css")));
+ btn->setStyleSheet(Style::getStylesheet(QStringLiteral("chatForm/buttons.css"), settings));
btn->setEnabled(index != 0);
}
@@ -260,7 +262,7 @@ void SearchForm::clickedStart()
void SearchForm::clickedSearch()
{
isActiveSettings = !isActiveSettings;
- settings->setVisible(isActiveSettings);
+ searchSettingsForm->setVisible(isActiveSettings);
useBeginState();
if (isActiveSettings) {
@@ -328,5 +330,3 @@ void LineEdit::keyPressEvent(QKeyEvent* event)
QLineEdit::keyPressEvent(event);
}
-
-
diff --git a/src/widget/searchform.h b/src/widget/searchform.h
index 04d72dae2..064e206a6 100644
--- a/src/widget/searchform.h
+++ b/src/widget/searchform.h
@@ -27,6 +27,7 @@ class QPushButton;
class QLabel;
class LineEdit;
class SearchSettingsForm;
+class Settings;
class SearchForm final : public QWidget
{
@@ -38,7 +39,7 @@ public:
Active = 2, // Red
};
- explicit SearchForm(QWidget* parent = nullptr);
+ explicit SearchForm(Settings&, QWidget* parent = nullptr);
void removeSearchPhrase();
QString getSearchPhrase() const;
ParameterSearch getParameterSearch();
@@ -61,7 +62,7 @@ private:
QPushButton* hideButton;
QPushButton* startButton;
LineEdit* searchLine;
- SearchSettingsForm* settings;
+ SearchSettingsForm* searchSettingsForm;
QLabel* messageLabel;
QString searchPhrase;
@@ -71,6 +72,7 @@ private:
bool isChangedPhrase{false};
bool isSearchInBegin{true};
bool isPrevSearch{false};
+ Settings& settings;
private slots:
void changedSearchPhrase(const QString& text);
diff --git a/src/widget/style.cpp b/src/widget/style.cpp
index f16454f53..4951a54e1 100644
--- a/src/widget/style.cpp
+++ b/src/widget/style.cpp
@@ -148,7 +148,7 @@ QString Style::getThemeName()
return QStringLiteral("default");
}
-QString Style::getThemeFolder()
+QString Style::getThemeFolder(Settings& settings)
{
const QString themeName = getThemeName();
const QString themeFolder = ThemeSubFolder % themeName;
@@ -157,15 +157,15 @@ QString Style::getThemeFolder()
// No themes available, fallback to builtin
if(fullPath.isEmpty()) {
- return getThemePath();
+ return getThemePath(settings);
}
return fullPath % QDir::separator();
}
-const QString Style::getStylesheet(const QString& filename, const QFont& baseFont)
+const QString Style::getStylesheet(const QString& filename, Settings& settings, const QFont& baseFont)
{
- const QString fullPath = getThemeFolder() + filename;
+ const QString fullPath = getThemeFolder(settings) + filename;
const std::pair cacheKey(fullPath, baseFont);
auto it = stylesheetsCache.find(cacheKey);
if (it != stylesheetsCache.end())
@@ -174,14 +174,14 @@ const QString Style::getStylesheet(const QString& filename, const QFont& baseFon
return it->second;
}
// cache miss, new styleSheet, read it from file and add to cache
- const QString newStylesheet = resolve(filename, baseFont);
+ const QString newStylesheet = resolve(filename, settings, baseFont);
stylesheetsCache.insert(std::make_pair(cacheKey, newStylesheet));
return newStylesheet;
}
-const QString Style::getImagePath(const QString& filename)
+const QString Style::getImagePath(const QString& filename, Settings& settings)
{
- QString fullPath = getThemeFolder() + filename;
+ QString fullPath = getThemeFolder(settings) + filename;
// search for image in cache
if (existingImagesCache.contains(fullPath)) {
@@ -195,7 +195,7 @@ const QString Style::getImagePath(const QString& filename)
} else {
qWarning() << "Failed to open file (using defaults):" << fullPath;
- fullPath = getThemePath() % filename;
+ fullPath = getThemePath(settings) % filename;
if (QFileInfo::exists(fullPath)) {
return fullPath;
@@ -231,9 +231,9 @@ QFont Style::getFont(Style::Font font)
return fonts[font];
}
-const QString Style::resolve(const QString& filename, const QFont& baseFont)
+const QString Style::resolve(const QString& filename, Settings& settings, const QFont& baseFont)
{
- QString themePath = getThemeFolder();
+ QString themePath = getThemeFolder(settings);
QString fullPath = themePath + filename;
QString qss;
@@ -243,7 +243,7 @@ const QString Style::resolve(const QString& filename, const QFont& baseFont)
} else {
qWarning() << "Failed to open file:" << fullPath;
- fullPath = getThemePath();
+ fullPath = getThemePath(settings);
QFile defaultFile{fullPath};
if (defaultFile.open(QFile::ReadOnly | QFile::Text)) {
@@ -255,7 +255,7 @@ const QString Style::resolve(const QString& filename, const QFont& baseFont)
}
if (palette.isEmpty()) {
- initPalette();
+ initPalette(settings);
}
if (dictColor.isEmpty()) {
@@ -299,14 +299,14 @@ const QString Style::resolve(const QString& filename, const QFont& baseFont)
path.remove(QStringLiteral("@getImagePath("));
path.chop(1);
- QString fullImagePath = getThemeFolder() + path;
+ QString fullImagePath = getThemeFolder(settings) + path;
// image not in cache
if (!existingImagesCache.contains(fullPath)) {
if (QFileInfo::exists(fullImagePath)) {
existingImagesCache << fullImagePath;
} else {
qWarning() << "Failed to open file (using defaults):" << fullImagePath;
- fullImagePath = getThemePath() % path;
+ fullImagePath = getThemePath(settings) % path;
}
}
@@ -330,12 +330,12 @@ void Style::repolish(QWidget* w)
}
}
-void Style::setThemeColor(int color)
+void Style::setThemeColor(Settings& settings, int color)
{
stylesheetsCache.clear(); // clear stylesheet cache which includes color info
palette.clear();
dictColor.clear();
- initPalette();
+ initPalette(settings);
initDictColor();
if (color < 0 || color >= themeNameColors.size())
setThemeColor(QColor());
@@ -388,20 +388,20 @@ QPixmap Style::scaleSvgImage(const QString& path, uint32_t width, uint32_t heigh
return pixmap;
}
-void Style::initPalette()
+void Style::initPalette(Settings& settings)
{
- QSettings settings(getThemePath() % "palette.ini", QSettings::IniFormat);
+ QSettings colourSettings(getThemePath(settings) % "palette.ini", QSettings::IniFormat);
auto keys = aliasColors.keys();
- settings.beginGroup("colors");
+ colourSettings.beginGroup("colors");
QMap c;
for (auto k : keys) {
- c[k] = settings.value(aliasColors[k], "#000").toString();
- palette[k] = QColor(settings.value(aliasColors[k], "#000").toString());
+ c[k] = colourSettings.value(aliasColors[k], "#000").toString();
+ palette[k] = QColor(colourSettings.value(aliasColors[k], "#000").toString());
}
auto p = palette;
- settings.endGroup();
+ colourSettings.endGroup();
}
@@ -425,9 +425,9 @@ void Style::initDictColor()
{"@selectText", Style::getColor(Style::SelectText).name()}};
}
-QString Style::getThemePath()
+QString Style::getThemePath(Settings& settings)
{
- const int num = Settings::getInstance().getThemeColor();
+ const int num = settings.getThemeColor();
if (themeNameColors[num].type == Dark) {
return BuiltinThemeDarkPath;
}
diff --git a/src/widget/style.h b/src/widget/style.h
index 7653980af..5eec374f1 100644
--- a/src/widget/style.h
+++ b/src/widget/style.h
@@ -24,6 +24,7 @@
class QString;
class QWidget;
+class Settings;
class Style
{
@@ -75,21 +76,21 @@ public:
};
static QStringList getThemeColorNames();
- static const QString getStylesheet(const QString& filename, const QFont& baseFont = QFont());
- static const QString getImagePath(const QString& filename);
- static QString getThemeFolder();
+ static const QString getStylesheet(const QString& filename, Settings&, const QFont& baseFont = QFont());
+ static const QString getImagePath(const QString& filename, Settings&);
+ static QString getThemeFolder(Settings&);
static QString getThemeName();
static QColor getColor(ColorPalette entry);
static QFont getFont(Font font);
- static const QString resolve(const QString& filename, const QFont& baseFont = QFont());
+ static const QString resolve(const QString& filename, Settings&, const QFont& baseFont = QFont());
static void repolish(QWidget* w);
- static void setThemeColor(int color);
+ static void setThemeColor(Settings&, int color);
static void setThemeColor(const QColor& color);
static void applyTheme();
static QPixmap scaleSvgImage(const QString& path, uint32_t width, uint32_t height);
- static void initPalette();
+ static void initPalette(Settings&);
static void initDictColor();
- static QString getThemePath();
+ static QString getThemePath(Settings&);
signals:
void themeChanged();
diff --git a/src/widget/tool/callconfirmwidget.cpp b/src/widget/tool/callconfirmwidget.cpp
index 68ef3ed8d..0f2a4ccbc 100644
--- a/src/widget/tool/callconfirmwidget.cpp
+++ b/src/widget/tool/callconfirmwidget.cpp
@@ -50,7 +50,7 @@
* @brief Used to correct the rounding factors on non-square rects
*/
-CallConfirmWidget::CallConfirmWidget(const QWidget* anchor_)
+CallConfirmWidget::CallConfirmWidget(Settings& settings, const QWidget* anchor_)
: QWidget()
, anchor(anchor_)
, rectW{120}
@@ -90,8 +90,8 @@ CallConfirmWidget::CallConfirmWidget(const QWidget* anchor_)
reject->setFlat(true);
accept->setStyleSheet("QPushButton{border:none;}");
reject->setStyleSheet("QPushButton{border:none;}");
- accept->setIcon(QIcon(Style::getImagePath("acceptCall/acceptCall.svg")));
- reject->setIcon(QIcon(Style::getImagePath("rejectCall/rejectCall.svg")));
+ accept->setIcon(QIcon(Style::getImagePath("acceptCall/acceptCall.svg", settings)));
+ reject->setIcon(QIcon(Style::getImagePath("rejectCall/rejectCall.svg", settings)));
accept->setIconSize(accept->size());
reject->setIconSize(reject->size());
diff --git a/src/widget/tool/callconfirmwidget.h b/src/widget/tool/callconfirmwidget.h
index 7b10d7e7b..9a458e0c6 100644
--- a/src/widget/tool/callconfirmwidget.h
+++ b/src/widget/tool/callconfirmwidget.h
@@ -27,12 +27,13 @@
class QPaintEvent;
class QShowEvent;
+class Settings;
class CallConfirmWidget final : public QWidget
{
Q_OBJECT
public:
- explicit CallConfirmWidget(const QWidget* anchor_);
+ explicit CallConfirmWidget(Settings&, const QWidget* anchor_);
signals:
void accepted();
diff --git a/src/widget/tool/profileimporter.cpp b/src/widget/tool/profileimporter.cpp
index 6c3276201..b69895be6 100644
--- a/src/widget/tool/profileimporter.cpp
+++ b/src/widget/tool/profileimporter.cpp
@@ -35,8 +35,9 @@
* to create dialog forms.
*/
-ProfileImporter::ProfileImporter(QWidget* parent)
+ProfileImporter::ProfileImporter(Settings& settings_, QWidget* parent)
: QWidget(parent)
+ , settings{settings_}
{
}
@@ -105,7 +106,7 @@ bool ProfileImporter::importProfile(const QString& path)
return false; // ingore importing non-tox file
}
- QString settingsPath = Settings::getInstance().getPaths().getSettingsDirPath();
+ QString settingsPath = settings.getPaths().getSettingsDirPath();
QString profilePath = QDir(settingsPath).filePath(profile + Core::TOX_EXT);
if (QFileInfo(profilePath).exists()) {
diff --git a/src/widget/tool/profileimporter.h b/src/widget/tool/profileimporter.h
index 34cfbf31a..70f45336f 100644
--- a/src/widget/tool/profileimporter.h
+++ b/src/widget/tool/profileimporter.h
@@ -20,16 +20,18 @@
#pragma once
#include
+class Settings;
class ProfileImporter : public QWidget
{
Q_OBJECT
public:
- explicit ProfileImporter(QWidget* parent = nullptr);
+ explicit ProfileImporter(Settings&, QWidget* parent = nullptr);
bool importProfile(const QString& path);
bool importProfile();
private:
bool askQuestion(QString title, QString message);
+ Settings& settings;
};
diff --git a/src/widget/widget.cpp b/src/widget/widget.cpp
index 1d909a19d..419c17a33 100644
--- a/src/widget/widget.cpp
+++ b/src/widget/widget.cpp
@@ -82,8 +82,9 @@
#include "tool/removefrienddialog.h"
#include "src/persistence/smileypack.h"
-bool toxActivateEventHandler(const QByteArray&)
+bool toxActivateEventHandler(const QByteArray&, void* userData)
{
+ std::ignore = userData;
Widget* widget = Nexus::getDesktopGUI();
if (!widget) {
return true;
@@ -140,7 +141,7 @@ void Widget::acceptFileTransfer(const ToxFile& file, const QString& path)
Widget* Widget::instance{nullptr};
Widget::Widget(Profile &profile_, IAudioControl& audio_, CameraSource& cameraSource_,
- QWidget* parent)
+ Settings& settings_, QWidget* parent)
: QMainWindow(parent)
, profile{profile_}
, trayMenu{nullptr}
@@ -149,9 +150,12 @@ Widget::Widget(Profile &profile_, IAudioControl& audio_, CameraSource& cameraSou
, eventFlag(false)
, eventIcon(false)
, audio(audio_)
- , settings(Settings::getInstance())
- , smileyPack(new SmileyPack())
- , documentCache(new DocumentCache(*smileyPack))
+ , settings(settings_)
+#if DESKTOP_NOTIFICATIONS
+ , notifier{settings}
+#endif
+ , smileyPack(new SmileyPack(settings))
+ , documentCache(new DocumentCache(*smileyPack, settings))
, cameraSource{cameraSource_}
{
installEventFilter(this);
@@ -199,7 +203,7 @@ void Widget::init()
#endif
actionQuit->setIcon(
- prepareIcon(Style::getImagePath("rejectCall/rejectCall.svg"), icon_size, icon_size));
+ prepareIcon(Style::getImagePath("rejectCall/rejectCall.svg", settings), icon_size, icon_size));
connect(actionQuit, &QAction::triggered, qApp, &QApplication::quit);
layout()->setContentsMargins(0, 0, 0, 0);
@@ -258,7 +262,7 @@ void Widget::init()
sharedMessageProcessorParams.reset(new MessageProcessor::SharedParams(core->getMaxMessageSize(), coreExt->getMaxExtendedMessageSize()));
- contactListWidget = new FriendListWidget(*core, this, settings.getGroupchatPosition());
+ contactListWidget = new FriendListWidget(*core, this, settings, settings.getGroupchatPosition());
connect(contactListWidget, &FriendListWidget::searchCircle, this, &Widget::searchCircle);
connect(contactListWidget, &FriendListWidget::connectCircleWidget, this,
&Widget::connectCircleWidget);
@@ -283,25 +287,25 @@ void Widget::init()
// Disable some widgets until we're connected to the DHT
ui->statusButton->setEnabled(false);
- Style::setThemeColor(settings.getThemeColor());
+ Style::setThemeColor(settings, settings.getThemeColor());
CoreFile* coreFile = core->getCoreFile();
- filesForm = new FilesForm(*coreFile);
- addFriendForm = new AddFriendForm(core->getSelfId());
- groupInviteForm = new GroupInviteForm;
+ filesForm = new FilesForm(*coreFile, settings);
+ addFriendForm = new AddFriendForm(core->getSelfId(), settings);
+ groupInviteForm = new GroupInviteForm(settings);
#if UPDATE_CHECK_ENABLED
updateCheck = std::unique_ptr(new UpdateCheck(settings));
connect(updateCheck.get(), &UpdateCheck::updateAvailable, this, &Widget::onUpdateAvailable);
#endif
settingsWidget = new SettingsWidget(updateCheck.get(), audio, core, *smileyPack,
- cameraSource, this);
+ cameraSource, settings, this);
#if UPDATE_CHECK_ENABLED
updateCheck->checkForUpdate();
#endif
- profileInfo = new ProfileInfo(core, &profile);
- profileForm = new ProfileForm(profileInfo);
+ profileInfo = new ProfileInfo(core, &profile, settings);
+ profileForm = new ProfileForm(profileInfo, settings);
#if DESKTOP_NOTIFICATIONS
notificationGenerator.reset(new NotificationGenerator(settings, &profile));
@@ -800,7 +804,7 @@ void Widget::onSeparateWindowChanged(bool separate, bool clicked)
QWidget* contentWidget = new QWidget(this);
contentWidget->setObjectName("contentWidget");
- contentLayout = new ContentLayout(contentWidget);
+ contentLayout = new ContentLayout(settings, contentWidget);
ui->mainSplitter->addWidget(contentWidget);
setMinimumWidth(775);
@@ -1174,12 +1178,12 @@ void Widget::addFriend(uint32_t friendId, const ToxPk& friendPk)
assert(core != nullptr);
settings.updateFriendAddress(friendPk.toString());
- Friend* newfriend = FriendList::addFriend(friendId, friendPk);
+ Friend* newfriend = FriendList::addFriend(friendId, friendPk, settings);
auto dialogManager = ContentDialogManager::getInstance();
- auto rawChatroom = new FriendChatroom(newfriend, dialogManager, *core);
+ auto rawChatroom = new FriendChatroom(newfriend, dialogManager, *core, settings);
std::shared_ptr chatroom(rawChatroom);
const auto compact = settings.getCompactLayout();
- auto widget = new FriendWidget(chatroom, compact);
+ auto widget = new FriendWidget(chatroom, compact, settings);
connectFriendWidget(*widget);
auto history = profile.getHistory();
@@ -1193,7 +1197,8 @@ void Widget::addFriend(uint32_t friendId, const ToxPk& friendPk)
std::make_shared(*newfriend, history, *core, settings,
*friendMessageDispatcher);
auto friendForm = new ChatForm(profile, newfriend, *chatHistory,
- *friendMessageDispatcher, *documentCache, *smileyPack, cameraSource);
+ *friendMessageDispatcher, *documentCache, *smileyPack, cameraSource,
+ settings);
connect(friendForm, &ChatForm::updateFriendActivity, this, &Widget::updateFriendActivity);
friendMessageDispatchers[friendPk] = friendMessageDispatcher;
@@ -1606,7 +1611,7 @@ bool Widget::newFriendMessageAlert(const ToxPk& friendId, const QString& text, b
FriendWidget* widget = friendWidgets[friendId];
f->setEventFlag(true);
widget->updateStatusLight();
- ui->friendList->trackWidget(widget);
+ ui->friendList->trackWidget(settings, widget);
#if DESKTOP_NOTIFICATIONS
auto notificationData = filename.isEmpty() ? notificationGenerator->friendMessageNotification(f, text)
: notificationGenerator->fileTransferNotification(f, filename, filesize);
@@ -1790,7 +1795,7 @@ void Widget::removeFriend(Friend* f, bool fake)
lastDialog->removeFriend(friendPk);
}
- FriendList::removeFriend(friendPk, fake);
+ FriendList::removeFriend(friendPk, settings, fake);
if (!fake) {
core->removeFriend(f->getId());
// aliases aren't supported for non-friend peers in groups, revert to basic username
@@ -1856,7 +1861,7 @@ void Widget::onUpdateAvailable()
ContentDialog* Widget::createContentDialog() const
{
- ContentDialog* contentDialog = new ContentDialog(*core);
+ ContentDialog* contentDialog = new ContentDialog(*core, settings);
registerContentDialog(*contentDialog);
return contentDialog;
@@ -1917,7 +1922,7 @@ ContentLayout* Widget::createContentDialog(DialogType type) const
void reloadTheme() final
{
- setStyleSheet(Style::getStylesheet("window/general.css"));
+ setStyleSheet(Style::getStylesheet("window/general.css", settings));
}
protected:
@@ -1941,7 +1946,7 @@ ContentLayout* Widget::createContentDialog(DialogType type) const
Dialog* dialog = new Dialog(type, settings, core);
dialog->setAttribute(Qt::WA_DeleteOnClose);
- ContentLayout* contentLayoutDialog = new ContentLayout(dialog);
+ ContentLayout* contentLayoutDialog = new ContentLayout(settings, dialog);
dialog->setObjectName("detached");
dialog->setLayout(contentLayoutDialog);
@@ -2147,7 +2152,7 @@ Group* Widget::createGroup(uint32_t groupnumber, const GroupId& groupId)
std::shared_ptr chatroom(rawChatroom);
const auto compact = settings.getCompactLayout();
- auto widget = new GroupWidget(chatroom, compact);
+ auto widget = new GroupWidget(chatroom, compact, settings);
auto messageProcessor = MessageProcessor(*sharedMessageProcessorParams);
auto messageDispatcher =
std::make_shared(*newgroup, std::move(messageProcessor), *core,
@@ -2475,15 +2480,15 @@ void Widget::reloadTheme()
x->setStyleSheet("");
}
- setStyleSheet(Style::getStylesheet("window/general.css"));
- QString statusPanelStyle = Style::getStylesheet("window/statusPanel.css");
- ui->tooliconsZone->setStyleSheet(Style::getStylesheet("tooliconsZone/tooliconsZone.css"));
+ setStyleSheet(Style::getStylesheet("window/general.css", settings));
+ QString statusPanelStyle = Style::getStylesheet("window/statusPanel.css", settings);
+ ui->tooliconsZone->setStyleSheet(Style::getStylesheet("tooliconsZone/tooliconsZone.css", settings));
ui->statusPanel->setStyleSheet(statusPanelStyle);
ui->statusHead->setStyleSheet(statusPanelStyle);
- ui->friendList->setStyleSheet(Style::getStylesheet("friendList/friendList.css"));
- ui->statusButton->setStyleSheet(Style::getStylesheet("statusButton/statusButton.css"));
+ ui->friendList->setStyleSheet(Style::getStylesheet("friendList/friendList.css", settings));
+ ui->statusButton->setStyleSheet(Style::getStylesheet("statusButton/statusButton.css", settings));
- profilePicture->setStyleSheet(Style::getStylesheet("window/profile.css"));
+ profilePicture->setStyleSheet(Style::getStylesheet("window/profile.css", settings));
}
void Widget::nextContact()
diff --git a/src/widget/widget.h b/src/widget/widget.h
index 7ced61b71..d1fc58f27 100644
--- a/src/widget/widget.h
+++ b/src/widget/widget.h
@@ -118,7 +118,7 @@ private:
};
public:
- Widget(Profile& profile_, IAudioControl& audio_, CameraSource&,
+ Widget(Profile& profile_, IAudioControl& audio_, CameraSource&, Settings&,
QWidget* parent = nullptr);
~Widget() override;
void init();
@@ -388,4 +388,4 @@ private:
CameraSource& cameraSource;
};
-bool toxActivateEventHandler(const QByteArray& data);
+bool toxActivateEventHandler(const QByteArray& data, void* userData);
diff --git a/test/persistence/smileypack_test.cpp b/test/persistence/smileypack_test.cpp
index 05add03ed..038c4a5aa 100644
--- a/test/persistence/smileypack_test.cpp
+++ b/test/persistence/smileypack_test.cpp
@@ -18,6 +18,7 @@
*/
#include "src/persistence/smileypack.h"
+#include "src/persistence/settings.h"
#include
#include
@@ -40,6 +41,7 @@ private slots:
void testSmilifyAsciiEmoticon();
private:
std::unique_ptr app;
+ std::unique_ptr settings;
};
TestSmileyPack::TestSmileyPack()
@@ -51,6 +53,7 @@ TestSmileyPack::TestSmileyPack()
static int qtTestAppArgc = 3;
app = std::unique_ptr(new QGuiApplication(qtTestAppArgc, qtTestAppArgv));
+ settings = std::unique_ptr(new Settings());
}
/**
@@ -58,7 +61,7 @@ TestSmileyPack::TestSmileyPack()
*/
void TestSmileyPack::testSmilifySingleCharEmoji()
{
- SmileyPack smileyPack{};
+ SmileyPack smileyPack{*settings};
auto result = smileyPack.smileyfied("😊");
QVERIFY(result == SmileyPack::getAsRichText("😊"));
@@ -73,7 +76,7 @@ void TestSmileyPack::testSmilifySingleCharEmoji()
*/
void TestSmileyPack::testSmilifyMultiCharEmoji()
{
- SmileyPack smileyPack{};
+ SmileyPack smileyPack{*settings};
auto result = smileyPack.smileyfied("🇬🇧");
QVERIFY(result == SmileyPack::getAsRichText("🇬🇧"));
@@ -94,7 +97,7 @@ void TestSmileyPack::testSmilifyMultiCharEmoji()
*/
void TestSmileyPack::testSmilifyAsciiEmoticon()
{
- SmileyPack smileyPack{};
+ SmileyPack smileyPack{*settings};
auto result = smileyPack.smileyfied(":-)");
QVERIFY(result == SmileyPack::getAsRichText(":-)"));